Merge pull request #225 from pyfisch/accesscontrol
Added AccessControl* family of headers.
This commit is contained in:
25
src/header/common/access_control/allow_headers.rs
Normal file
25
src/header/common/access_control/allow_headers.rs
Normal file
@@ -0,0 +1,25 @@
|
||||
use std::fmt::{self};
|
||||
|
||||
use header;
|
||||
use header::shared;
|
||||
|
||||
#[derive(Clone)]
|
||||
struct AccessControlAllowHeaders(pub Vec<String>);
|
||||
|
||||
impl header::Header for AccessControlAllowHeaders {
|
||||
#[inline]
|
||||
fn header_name(_: Option<AccessControlAllowHeaders>) -> &'static str {
|
||||
"Access-Control-Allow-Headers"
|
||||
}
|
||||
|
||||
fn parse_header(raw: &[Vec<u8>]) -> Option<AccessControlAllowHeaders> {
|
||||
shared::from_comma_delimited(raw).map(AccessControlAllowHeaders)
|
||||
}
|
||||
}
|
||||
|
||||
impl header::HeaderFormat for AccessControlAllowHeaders {
|
||||
fn fmt_header(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
let AccessControlAllowHeaders(ref parts) = *self;
|
||||
shared::fmt_comma_delimited(f, parts.as_slice())
|
||||
}
|
||||
}
|
||||
26
src/header/common/access_control/allow_methods.rs
Normal file
26
src/header/common/access_control/allow_methods.rs
Normal file
@@ -0,0 +1,26 @@
|
||||
use std::fmt::{self};
|
||||
|
||||
use header;
|
||||
use header::shared;
|
||||
use method;
|
||||
|
||||
#[derive(Clone)]
|
||||
struct AccessControlAllowMethods(pub Vec<method::Method>);
|
||||
|
||||
impl header::Header for AccessControlAllowMethods {
|
||||
#[inline]
|
||||
fn header_name(_: Option<AccessControlAllowMethods>) -> &'static str {
|
||||
"Access-Control-Allow-Methods"
|
||||
}
|
||||
|
||||
fn parse_header(raw: &[Vec<u8>]) -> Option<AccessControlAllowMethods> {
|
||||
shared::from_comma_delimited(raw).map(AccessControlAllowMethods)
|
||||
}
|
||||
}
|
||||
|
||||
impl header::HeaderFormat for AccessControlAllowMethods {
|
||||
fn fmt_header(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
let AccessControlAllowMethods(ref parts) = *self;
|
||||
shared::fmt_comma_delimited(f, parts.as_slice())
|
||||
}
|
||||
}
|
||||
47
src/header/common/access_control/allow_origin.rs
Normal file
47
src/header/common/access_control/allow_origin.rs
Normal file
@@ -0,0 +1,47 @@
|
||||
extern crate url;
|
||||
|
||||
use std::fmt::{self};
|
||||
use std::str;
|
||||
|
||||
use header;
|
||||
|
||||
#[derive(Clone)]
|
||||
enum AccessControlAllowOrigin {
|
||||
AllowStar,
|
||||
AllowOrigin(url::Url),
|
||||
}
|
||||
|
||||
impl header::Header for AccessControlAllowOrigin {
|
||||
#[inline]
|
||||
fn header_name(_: Option<AccessControlAllowOrigin>) -> &'static str {
|
||||
"Access-Control-Allow-Origin"
|
||||
}
|
||||
|
||||
fn parse_header(raw: &[Vec<u8>]) -> Option<AccessControlAllowOrigin> {
|
||||
if raw.len() == 1 {
|
||||
match str::from_utf8(unsafe { raw[].get_unchecked(0)[] }) {
|
||||
Ok(s) => {
|
||||
if s == "*" {
|
||||
Some(AccessControlAllowOrigin::AllowStar)
|
||||
} else {
|
||||
url::Url::parse(s).ok().map(
|
||||
|url| AccessControlAllowOrigin::AllowOrigin(url))
|
||||
}
|
||||
},
|
||||
_ => return None,
|
||||
}
|
||||
} else {
|
||||
return None;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl header::HeaderFormat for AccessControlAllowOrigin {
|
||||
fn fmt_header(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
match *self {
|
||||
AccessControlAllowOrigin::AllowStar => write!(f, "*"),
|
||||
AccessControlAllowOrigin::AllowOrigin(ref url) =>
|
||||
write!(f, "{}", url)
|
||||
}
|
||||
}
|
||||
}
|
||||
25
src/header/common/access_control/max_age.rs
Normal file
25
src/header/common/access_control/max_age.rs
Normal file
@@ -0,0 +1,25 @@
|
||||
use std::fmt;
|
||||
|
||||
use header;
|
||||
use header::shared;
|
||||
|
||||
#[derive(Clone)]
|
||||
struct AccessControlMaxAge(pub u32);
|
||||
|
||||
impl header::Header for AccessControlMaxAge {
|
||||
#[inline]
|
||||
fn header_name(_: Option<AccessControlMaxAge>) -> &'static str {
|
||||
"Access-Control-Max-Age"
|
||||
}
|
||||
|
||||
fn parse_header(raw: &[Vec<u8>]) -> Option<AccessControlMaxAge> {
|
||||
shared::from_one_raw_str(raw).map(AccessControlMaxAge)
|
||||
}
|
||||
}
|
||||
|
||||
impl header::HeaderFormat for AccessControlMaxAge {
|
||||
fn fmt_header(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
let AccessControlMaxAge(ref num) = *self;
|
||||
write!(f, "{}", num)
|
||||
}
|
||||
}
|
||||
17
src/header/common/access_control/mod.rs
Normal file
17
src/header/common/access_control/mod.rs
Normal file
@@ -0,0 +1,17 @@
|
||||
/// Exposes the AccessControlAllowHeaders header
|
||||
pub mod allow_headers;
|
||||
|
||||
/// Exposes the AccessControlAllowMethods header
|
||||
pub mod allow_methods;
|
||||
|
||||
/// Exposes the AccessControlAllowOrigin header
|
||||
pub mod allow_origin;
|
||||
|
||||
/// Exposes the AccessControlMaxAge header
|
||||
pub mod max_age;
|
||||
|
||||
/// Exposes the AccessControlRequestHeaders header
|
||||
pub mod request_headers;
|
||||
|
||||
/// Exposes the AccessControlRequestMethod header
|
||||
pub mod request_method;
|
||||
25
src/header/common/access_control/request_headers.rs
Normal file
25
src/header/common/access_control/request_headers.rs
Normal file
@@ -0,0 +1,25 @@
|
||||
use std::fmt::{self};
|
||||
|
||||
use header;
|
||||
use header::shared;
|
||||
|
||||
#[derive(Clone)]
|
||||
struct AccessControlRequestHeaders(pub Vec<String>);
|
||||
|
||||
impl header::Header for AccessControlRequestHeaders {
|
||||
#[inline]
|
||||
fn header_name(_: Option<AccessControlRequestHeaders>) -> &'static str {
|
||||
"Access-Control-Request-Headers"
|
||||
}
|
||||
|
||||
fn parse_header(raw: &[Vec<u8>]) -> Option<AccessControlRequestHeaders> {
|
||||
shared::from_comma_delimited(raw).map(AccessControlRequestHeaders)
|
||||
}
|
||||
}
|
||||
|
||||
impl header::HeaderFormat for AccessControlRequestHeaders {
|
||||
fn fmt_header(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
let AccessControlRequestHeaders(ref parts) = *self;
|
||||
shared::fmt_comma_delimited(f, parts.as_slice())
|
||||
}
|
||||
}
|
||||
26
src/header/common/access_control/request_method.rs
Normal file
26
src/header/common/access_control/request_method.rs
Normal file
@@ -0,0 +1,26 @@
|
||||
use std::fmt;
|
||||
|
||||
use header;
|
||||
use header::shared;
|
||||
use method::Method;
|
||||
|
||||
#[derive(Clone)]
|
||||
struct AccessControlRequestMethod(pub Method);
|
||||
|
||||
impl header::Header for AccessControlRequestMethod {
|
||||
#[inline]
|
||||
fn header_name(_: Option<AccessControlRequestMethod>) -> &'static str {
|
||||
"Access-Control-Request-Method"
|
||||
}
|
||||
|
||||
fn parse_header(raw: &[Vec<u8>]) -> Option<AccessControlRequestMethod> {
|
||||
shared::from_one_raw_str(raw).map(AccessControlRequestMethod)
|
||||
}
|
||||
}
|
||||
|
||||
impl header::HeaderFormat for AccessControlRequestMethod {
|
||||
fn fmt_header(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
let AccessControlRequestMethod(ref method) = *self;
|
||||
write!(f, "{}", method)
|
||||
}
|
||||
}
|
||||
@@ -76,6 +76,9 @@ macro_rules! deref(
|
||||
}
|
||||
);
|
||||
|
||||
/// Exposes the AccessControl* family of headers.
|
||||
pub mod access_control;
|
||||
|
||||
/// Exposes the Accept header.
|
||||
pub mod accept;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user