Bug 100538

Summary: malformed X-XSS-Protection headers not reported
Product: WebKit Reporter: Thomas Sepez <tsepez>
Component: WebKit Misc.Assignee: Thomas Sepez <tsepez>
Status: RESOLVED FIXED    
Severity: Trivial CC: abarth, dbates, mkwst, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Attachments:
Description Flags
Patch for discussion
none
patch + changelogs for landing
none
Patch, fix style, add missing file. none

Thomas Sepez
Reported 2012-10-26 10:46:42 PDT
Follow-on from https://bugs.webkit.org/show_bug.cgi?id=100423, where we noticed that a badly-formed X-XSS-Protection header is silently ignored. Two steps required: 1. Make some noise (log a console message when parse fails) 2. Add a test for it with some bad examples.
Attachments
Patch for discussion (8.93 KB, patch)
2012-10-26 12:40 PDT, Thomas Sepez
no flags
patch + changelogs for landing (29.61 KB, patch)
2012-10-29 13:20 PDT, Thomas Sepez
no flags
Patch, fix style, add missing file. (27.08 KB, patch)
2012-10-29 13:37 PDT, Thomas Sepez
no flags
Thomas Sepez
Comment 1 2012-10-26 12:36:16 PDT
Actually, there was a test, but bad headers aren't flagged should they be accidentally introduced in other tests.
Thomas Sepez
Comment 2 2012-10-26 12:40:24 PDT
Created attachment 170984 [details] Patch for discussion We need to discuss the approach before I cobble together changelogs and the like for actual submission.
Thomas Sepez
Comment 3 2012-10-26 13:07:54 PDT
Also note that at line 326 or thereabouts there looks to be a legit bug unsigned length = header.length(); vs. unsigned length = strippedHeader.length(); which would theoretically fail to kick in full blocking mode. Looks like this would only be tickled by the test xss-protection-parsing-01.html if at all.
Mike West
Comment 4 2012-10-26 14:51:42 PDT
Comment on attachment 170984 [details] Patch for discussion View in context: https://bugs.webkit.org/attachment.cgi?id=170984&action=review Hi Tom! Two superquick comments before bedtime. > Source/WebCore/html/parser/XSSAuditor.cpp:222 > + DEFINE_STATIC_LOCAL(String, consoleMessage, (ASCIILiteral("Invalid header: X-XSS-Protection: "))); Nit: The header itself isn't invalid, just its value. It might also be worth noting the effect (that protection is enabled, regardless of the author's misstated intent). If you don't mind verbosity, I'd suggest something along the lines of "The X-XSS-Protection HTTP header's value, '[VALUE]', is malformed. The header will be ignored, and protection will be enabled." > Source/WebCore/platform/network/HTTPParsers.cpp:331 > + return XSSProtectionInvalid; If you enumerate the ways things can break, you'd be able to give more detailed error messages. Returning XSSProtectionMalformedToggle might result in "The first non-whitespace character must be 0 or 1.", and XSSProtectionMalformedMode could do likewise. If you actually moved logging into this function, you could have even more detail, but it doesn't look like that would be straightforward since there's no reference to the document anywhere in this file.
Thomas Sepez
Comment 5 2012-10-26 15:06:28 PDT
Comment on attachment 170984 [details] Patch for discussion View in context: https://bugs.webkit.org/attachment.cgi?id=170984&action=review > Source/WebCore/platform/network/HTTPParsers.cpp:338 > + if (!strippedHeader[pos++] == ';') You moron. Look at what you wrote here.
Adam Barth
Comment 6 2012-10-26 15:08:31 PDT
Hey now! Be nice to yourself. :)
Thomas Sepez
Comment 7 2012-10-26 15:24:10 PDT
Comment on attachment 170984 [details] Patch for discussion View in context: https://bugs.webkit.org/attachment.cgi?id=170984&action=review > Source/WebCore/platform/network/HTTPParsers.cpp:77 > + pos = current; This looks like its been wrong for a long time. eg given input like "mode=blo\n", we'd say that "blo" matches against "block".
Thomas Sepez
Comment 8 2012-10-29 13:20:43 PDT
Created attachment 171297 [details] patch + changelogs for landing - Rather than pass back an ever increasing set of enums, I added a String& failureReason argument along the lines of some of the other parsers. - Split out success cases into xss-protection-parsing-* to match existing, and put malformed cases into malformed-*.
WebKit Review Bot
Comment 9 2012-10-29 13:26:07 PDT
Attachment 171297 [details] did not pass style-queue: Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'LayoutTests/ChangeLog', u'LayoutTests/http..." exit_code: 1 Source/WebCore/platform/network/HTTPParsers.cpp:355: Weird number of spaces at line-start. Are you using a 4-space indent? [whitespace/indent] [3] Source/WebCore/platform/network/HTTPParsers.cpp:356: Weird number of spaces at line-start. Are you using a 4-space indent? [whitespace/indent] [3] Source/WebCore/platform/network/HTTPParsers.cpp:357: Weird number of spaces at line-start. Are you using a 4-space indent? [whitespace/indent] [3] Source/WebCore/platform/network/HTTPParsers.cpp:358: Weird number of spaces at line-start. Are you using a 4-space indent? [whitespace/indent] [3] Total errors found: 4 in 18 files If any of these errors are false positives, please file a bug against check-webkit-style.
Thomas Sepez
Comment 10 2012-10-29 13:37:20 PDT
Created attachment 171300 [details] Patch, fix style, add missing file.
Adam Barth
Comment 11 2012-10-31 12:46:55 PDT
Comment on attachment 171300 [details] Patch, fix style, add missing file. View in context: https://bugs.webkit.org/attachment.cgi?id=171300&action=review > Source/WebCore/html/parser/XSSAuditor.cpp:225 > + DEFINE_STATIC_LOCAL(String, consoleMessageStart, (ASCIILiteral("Error parsing header X-XSS-Protection: "))); > + DEFINE_STATIC_LOCAL(String, consoleMessageSeparator, (ASCIILiteral(": "))); > + DEFINE_STATIC_LOCAL(String, consoleMessageEnd, (ASCIILiteral(". The default protections will be applied."))); There isn't really a benefit to defining these statics since you're going to concatenate them anyway. The most efficient thing is to just write out the whole concatenation on one line with the literals and everything.
WebKit Review Bot
Comment 12 2012-10-31 13:07:50 PDT
Comment on attachment 171300 [details] Patch, fix style, add missing file. Clearing flags on attachment: 171300 Committed r133066: <http://trac.webkit.org/changeset/133066>
WebKit Review Bot
Comment 13 2012-10-31 13:07:54 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.