Digest realm=\"atlanta.com\"\r\nProxy-Authorization:Digest \
username=\"Bob\"\r\nProxy-Require:foo\r\nRecord-Route:<sip:server10.\
biloxi.com;lr>\r\nReply-To:<sip:bob@biloxi.com>\r\nRequire:\
- baz\r\nRetry-After:18000;duration=3600\r\nVia: localhost\r\n\r\n")
+ baz\r\nRetry-After:18000;duration=3600\r\nRoute:<sip:bigbox3.site3.\
+ atlanta.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, Route, ReplyTo, RetryAfterParam, RetryAfter };
+ Challenge, OptionTag, Route, ReplyTo, RetryAfterParam, RetryAfter};
fn is_mark(c: u8) -> bool {
c == b'-' || c == b'_' || c == b'.' || c == b'!' || c == b'~' || c == b'*' || c == b'\'' ||
retry_after_param
)))));
+named!(route_header<Vec<Route>>, preceded!(
+ tag!(b"Route:"),
+ separated_nonempty_list!(
+ tag!(b","),
+ route)));
+
named!(pub header<Header>, alt!(
// RFC 3261 Headers
accept_header => { |a| Header::Accept(a) } |
record_route_header => { |r| Header::RecordRoute(r) } |
reply_to_header => { |r| Header::ReplyTo(r) } |
require_header => { |r| Header::Require(r) } |
- retry_after_header => { |r| Header::RetryAfter(r) }
+ retry_after_header => { |r| Header::RetryAfter(r) } |
+ route_header => { |r| Header::Route(r) }
));