From af5df31324ae701234b9db19f1bc378cdeb61662 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=20S=C3=A1nchez-Aedo?= <145811200+franfastly@users.noreply.github.com> Date: Wed, 7 Aug 2024 18:07:42 +0100 Subject: [PATCH] fix: Allow characters `#`, `$`, `%`, `&`, `'` in ` Method` (#713) * Allow characters `#`, `$`, `%,` `&,` `'` in HTTP method * Update method character docomentation to RFC 9110 --- src/method.rs | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/src/method.rs b/src/method.rs index 94e4d4ec..3d45ef9f 100644 --- a/src/method.rs +++ b/src/method.rs @@ -356,7 +356,7 @@ mod extension { } } - // From the HTTP spec section 5.1.1, the HTTP method is case-sensitive and can + // From the RFC 9110 HTTP Semantics, section 9.1, the HTTP method is case-sensitive and can // contain the following characters: // // ``` @@ -366,7 +366,7 @@ mod extension { // "^" / "_" / "`" / "|" / "~" / DIGIT / ALPHA // ``` // - // https://www.w3.org/Protocols/HTTP/1.1/draft-ietf-http-v11-spec-01#Method + // https://datatracker.ietf.org/doc/html/rfc9110#section-9.1 // // Note that this definition means that any &[u8] that consists solely of valid // characters is also valid UTF-8 because the valid method characters are a @@ -377,7 +377,7 @@ mod extension { b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', // x b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', // 1x b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', // 2x - b'\0', b'\0', b'\0', b'!', b'\0', b'\0', b'\0', b'\0', b'\0', b'\0', // 3x + b'\0', b'\0', b'\0', b'!', b'\0', b'#', b'$', b'%', b'&', b'\'', // 3x b'\0', b'\0', b'*', b'+', b'\0', b'-', b'.', b'\0', b'0', b'1', // 4x b'2', b'3', b'4', b'5', b'6', b'7', b'8', b'9', b'\0', b'\0', // 5x b'\0', b'\0', b'\0', b'\0', b'\0', b'A', b'B', b'C', b'D', b'E', // 6x @@ -466,4 +466,20 @@ mod test { let long_method = "This_is_a_very_long_method.It_is_valid_but_unlikely."; assert_eq!(Method::from_str(long_method).unwrap(), long_method); } + + #[test] + fn test_extension_method_chars() { + const VALID_METHOD_CHARS: &str = + "!#$%&'*+-.^_`|~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; + + for c in VALID_METHOD_CHARS.chars() { + let c = c.to_string(); + + assert_eq!( + Method::from_str(&c).unwrap(), + c.as_str(), + "testing {c} is a valid method character" + ); + } + } }