* Verifies that the given val is a valid HTTP token * per the rules defined in RFC 7230 * See https://tools.ietf.org/html/rfc7230#section-3.2.6 * @param {string} val * @returns {boolean}
(val)
| 241 | * @returns {boolean} |
| 242 | */ |
| 243 | function checkIsHttpToken(val) { |
| 244 | if (val.length >= 10) { |
| 245 | return tokenRegExp.test(val); |
| 246 | } |
| 247 | |
| 248 | if (val.length === 0) return false; |
| 249 | |
| 250 | // Use lookup table for short strings, regex for longer ones |
| 251 | for (let i = 0; i < val.length; i++) { |
| 252 | if (!validTokenChars[val.charCodeAt(i)]) { |
| 253 | return false; |
| 254 | } |
| 255 | } |
| 256 | return true; |
| 257 | } |
| 258 | |
| 259 | // Strict header value regex per RFC 7230 (original/default behavior): |
| 260 | // field-value = *( field-content / obs-fold ) |
no test coverage detected
searching dependent graphs…