bell-tel.com\r\nMax-Forwards:32\r\nMIME-Version:2.0\r\nMin-Expires:\
30\r\nOrganization:Foobar\r\nPriority:normal\r\nProxy-Authenticate:\
Digest realm=\"atlanta.com\"\r\nProxy-Authorization:Digest \
- username=\"Bob\"\r\nProxy-Require:foo\r\nVia: localhost\r\n\r\n")
+ username=\"Bob\"\r\nProxy-Require:foo\r\nRecord-Route:<sip:server10.\
+ biloxi.com;lr>\r\nVia: localhost\r\n\r\n")
});
let finished = request.and_then(|(socket, _request)| {
Credentials, CallId, Purpose, InfoParam, Info, NameAddr, ContactParam, Target,
Contact, DispositionType, Handling, DispositionParam, ContentCoding, Day, Month, Date,
Time, DateTime, ErrorUri, FromParam, From, Priority, Domain, DigestChallenge,
- Challenge, OptionTag};
+ Challenge, OptionTag, Route};
fn is_mark(c: u8) -> bool {
c == b'-' || c == b'_' || c == b'.' || c == b'!' || c == b'~' || c == b'*' || c == b'\'' ||
tag!(b","),
token)));
+named!(route<Route>, pair!(
+ name_addr,
+ many0!(preceded!(
+ tag!(b";"),
+ generic_param))));
+
+named!(record_route_header<Vec<Route>>, preceded!(
+ tag!(b"Record-Route:"),
+ separated_nonempty_list!(
+ tag!(b","),
+ route)));
+
named!(pub header<Header>, alt!(
// RFC 3261 Headers
accept_header => { |a| Header::Accept(a) } |
priority_header => { |p| Header::Priority(p) } |
proxy_authenticate_header => { |p| Header::ProxyAuthenticate(p) } |
proxy_authorization_header => { |p| Header::ProxyAuthorization(p) } |
- proxy_require_header => { |p| Header::ProxyRequire(p) }
+ proxy_require_header => { |p| Header::ProxyRequire(p) } |
+ record_route_header => { |r| Header::RecordRoute(r) }
));
pub type OptionTag = Vec<u8>;
+pub type Route = (NameAddr, Vec<GenericParam>);
+
#[derive(Debug)]
pub enum Header {
Accept(Vec<AcceptRange>),
ProxyAuthenticate(Challenge),
ProxyAuthorization(Credentials),
ProxyRequire(Vec<OptionTag>),
+ RecordRoute(Vec<Route>),
To(Uri),
Extension { name: String, value: String },
}