File: worker.py

package info (click to toggle)
firefox-esr 140.5.0esr-1~deb13u1
  • links: PTS, VCS
  • area: main
  • in suites: trixie-proposed-updates
  • size: 4,539,036 kB
  • sloc: cpp: 7,381,527; javascript: 6,388,905; ansic: 3,710,087; python: 1,393,776; xml: 628,165; asm: 426,918; java: 184,004; sh: 65,744; makefile: 19,302; objc: 13,059; perl: 12,912; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,226; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (38 lines) | stat: -rw-r--r-- 1,735 bytes parent folder | download | duplicates (14)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
from cookies.resources.helpers import makeCookieHeader, readCookies, setNoCacheAndCORSHeaders

# Step 4/6 (workers/same-site-cookies/{})
def main(request, response):
    headers = setNoCacheAndCORSHeaders(request, response)
    headers[0] = (b"Content-Type", b"text/javascript")
    headers.append(makeCookieHeader(b"samesite_strict_set_on_load", b"test", {b"SameSite":b"Strict", b"path":b"/", b"Secure":b""}))
    headers.append(makeCookieHeader(b"samesite_lax_set_on_load", b"test", {b"SameSite":b"Lax", b"path":b"/", b"Secure":b""}))
    headers.append(makeCookieHeader(b"samesite_none_set_on_load", b"test", {b"SameSite":b"None", b"path":b"/", b"Secure":b""}))
    cookies = readCookies(request)
    message = b"ReadOnLoad:"
    if b"samesite_strict_set_before_load" in cookies:
        message += b"Strict"
    if b"samesite_lax_set_before_load" in cookies:
        message += b"Lax"
    if b"samesite_none_set_before_load" in cookies:
        message += b"None"
    document = b"""
self.onconnect = (e) => {
    fetch("/workers/same-site-cookies/resources/get_cookies_redirect.py", {credentials: 'include'}).then((resp) => {
        resp.json().then((cookies) => {
            let message = \"""" + message + b""",ReadOnFetch:";
            if (cookies.hasOwnProperty("samesite_strict_set_before_load")) {
                message += "Strict";
            }
            if (cookies.hasOwnProperty("samesite_lax_set_before_load")) {
                message += "Lax";
            }
            if (cookies.hasOwnProperty("samesite_none_set_before_load")) {
                message += "None";
            }
            e.ports[0].postMessage(message);
            self.close();
        });
    });
}
"""
    return headers, document