Closed
      
        Bug 643051
      
      
        Opened 14 years ago
          Closed 14 years ago
      
        
    
  
document.cookie should only allow setting one cookie at a time 
    Categories
(Core :: Networking: Cookies, defect)
        Core
          
        
        
      
        
    
        Networking: Cookies
          
        
        
      
        
    Tracking
()
        RESOLVED
        FIXED
        
    
  
        
            mozilla5
        
    
  
People
(Reporter: Biesinger, Assigned: Biesinger)
Details
(Keywords: verified1.9.2, Whiteboard: [sg:nse])
Attachments
(2 files, 4 obsolete files)
| 5.12 KB,
          patch         | Biesinger
:
              
              review+ dveditz
:
              
              approval2.0+ dveditz
:
              
              approval1.9.2.18+ | Details | Diff | Splinter Review | 
| 5.12 KB,
          patch         | Details | Diff | Splinter Review | 
Currently, document.cookie allows setting multiple cookies in a single call.
This is inconsistent with other browsers as well as our documentation:
https://developer.mozilla.org/en/document.cookie
"Note that you can only set/update a single cookie at a time using this method."
This can lead to security problems in web applications: When an external script takes untrusted input (e.g. from a URL parameter), that input can contain line breaks, and thus set multiple cookies to the including web site.
Therefore, we should disallow setting multiple cookies using document.cookie.
| Assignee | ||
| Comment 1•14 years ago
           | ||
| Assignee | ||
| Updated•14 years ago
           | 
        Attachment #520373 -
        Flags: review? → review?(jduell.mcbugs)
| Updated•14 years ago
           | 
Whiteboard: [sg:low]
| Comment 2•14 years ago
           | ||
As a security problem this really arises because of insufficient filtering on the web app side more than a problem in Firefox. But it's clearly a bug and we should fix it.
Whiteboard: [sg:low] → [sg:nse]
|   | ||
| Comment 3•14 years ago
           | ||
Comment on attachment 520373 [details] [diff] [review]
patch
r=me
Might be worth creating a mochitest with document.cookie too.
        Attachment #520373 -
        Flags: review?(jduell.mcbugs) → review+
| Assignee | ||
| Comment 4•14 years ago
           | ||
| Assignee | ||
| Comment 5•14 years ago
           | ||
        Attachment #520373 -
        Attachment is obsolete: true
        Attachment #524724 -
        Attachment is obsolete: true
| Assignee | ||
| Updated•14 years ago
           | 
Status: ASSIGNED → RESOLVED
Closed: 14 years ago
Resolution: --- → FIXED
Whiteboard: [sg:nse] → [sg:nse] fixed-in-cedar
| Assignee | ||
| Comment 6•14 years ago
           | ||
Comment on attachment 524733 [details] [diff] [review]
final patch for checkin
transfering r=bz
I would like to land this on the ff4 and 3.6 branches too, if possible.
        Attachment #524733 -
        Flags: approval2.0?
        Attachment #524733 -
        Flags: approval1.9.2.18?
| Assignee | ||
| Comment 7•14 years ago
           | ||
| Assignee | ||
| Comment 8•14 years ago
           | ||
| Comment 9•14 years ago
           | ||
This failed mochitest-1 persistently, and the followups didn't fix it, so I backed out the original patch and both followups from cedar:
http://hg.mozilla.org/projects/cedar/rev/4e6e2a9c48c6
http://hg.mozilla.org/projects/cedar/rev/865870bbe148
http://hg.mozilla.org/projects/cedar/rev/a998aa8043f1
http://hg.mozilla.org/projects/cedar/rev/9409b0c8864f
http://hg.mozilla.org/projects/cedar/rev/c04359d5920f
Reopening the bug (which shouldn't have been marked Resolved:Fixed yet anyway as it hadn't landed on m-c).
Status: RESOLVED → REOPENED
Resolution: FIXED → ---
Whiteboard: [sg:nse] fixed-in-cedar → [sg:nse]
| Assignee | ||
| Updated•14 years ago
           | 
        Attachment #524733 -
        Flags: approval2.0?
        Attachment #524733 -
        Flags: approval1.9.2.18?
| Assignee | ||
| Comment 10•14 years ago
           | ||
Let's try this again. Currently running this version through a local "make mochitest-1", will push to cedar if that worked.
This version clears the "a" cookie in the test that sets it.
        Attachment #524733 -
        Attachment is obsolete: true
        Attachment #524774 -
        Attachment is obsolete: true
| Assignee | ||
| Comment 11•14 years ago
           | ||
Landed again, this time on m-c. Let's hope this will stick. Once I have test results, will request approval again.
http://hg.mozilla.org/mozilla-central/rev/61b822ac2d41
Status: REOPENED → RESOLVED
Closed: 14 years ago → 14 years ago
Resolution: --- → FIXED
| Assignee | ||
| Comment 12•14 years ago
           | ||
Comment on attachment 525202 [details] [diff] [review]
Patch v2
This is now passing the tests on Tinderbox.
Transferring r=bz.
Since this affects webapp security I'd like to check this in to the branches too.
        Attachment #525202 -
        Flags: review+
        Attachment #525202 -
        Flags: approval2.0?
        Attachment #525202 -
        Flags: approval1.9.1.20?
| Assignee | ||
| Updated•14 years ago
           | 
        Attachment #525202 -
        Flags: approval1.9.1.20? → approval1.9.2.18?
| Assignee | ||
| Updated•14 years ago
           | 
blocking1.9.2: --- → ?
blocking2.0: --- → ?
| Updated•14 years ago
           | 
| Comment 13•14 years ago
           | ||
Comment on attachment 525202 [details] [diff] [review]
Patch v2
Approved for 1.9.2.18, a=dveditz
clearing request for dead mozilla2.0 branch
        Attachment #525202 -
        Flags: approval2.0?
        Attachment #525202 -
        Flags: approval1.9.2.18?
        Attachment #525202 -
        Flags: approval1.9.2.18+
| Updated•14 years ago
           | 
Target Milestone: --- → mozilla5
| Assignee | ||
| Comment 14•14 years ago
           | ||
| Assignee | ||
| Comment 15•14 years ago
           | ||
| Comment 16•14 years ago
           | ||
Per security group discussion, requesting landing on mozilla-2.0.
| Comment 17•14 years ago
           | ||
Comment on attachment 525202 [details] [diff] [review]
Patch v2
Approved for the mozilla2.0 repository, a=dveditz
Cameron: if you request approval on these using flags it'd be easier to find than watching random IRC conversations ;-)
        Attachment #525202 -
        Flags: approval2.0+
| Comment 18•14 years ago
           | ||
Ah, flag was semi-disabled so you couldn't. Fixed now, request away.
| Comment 19•14 years ago
           | ||
Yes -- thanks for reenabling it. I will properly remark the other bugs (it looks like some were done already).
| Assignee | ||
| Comment 20•14 years ago
           | ||
          status-firefox5:
          --- → fixed
| Comment 21•14 years ago
           | ||
Verified fixed based on the updated tests passing for 1.9.2.18.
Keywords: verified1.9.2
          You need to log in
          before you can comment on or make changes to this bug.
        
Description
•