summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/cookies/resources/set-cookie.py
blob: 59b5b8006a0b24b0dfc90365c203e2bf6689bffa (plain)
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
39
40
41
42
43
44
45
from datetime import date

def main(request, response):
    """
    Returns cookie name and path from query params in a Set-Cookie header.

    e.g.

    > GET /cookies/resources/set-cookie.py?name=match-slash&path=%2F HTTP/1.1
    > Host: localhost:8000
    > User-Agent: curl/7.43.0
    > Accept: */*
    >
    < HTTP/1.1 200 OK
    < Content-Type: application/json
    < Set-Cookie: match-slash=1; Path=/; Expires=09 Jun 2021 10:18:14 GMT
    < Server: BaseHTTP/0.3 Python/2.7.12
    < Date: Tue, 04 Oct 2016 18:16:06 GMT
    < Content-Length: 80
    """

    name = request.GET[b'name']
    path = request.GET[b'path']
    samesite = request.GET.get(b'samesite')
    secure = b'secure' in request.GET
    expiry_year = date.today().year + 1
    cookie = b"%s=1; Path=%s; Expires=09 Jun %d 10:18:14 GMT" % (name, path, expiry_year)
    if samesite:
        cookie += b";SameSite=%s" % samesite
    if secure:
        cookie += b";Secure"

    headers = [
        (b"Content-Type", b"application/json"),
        (b"Set-Cookie", cookie)
    ]

    # Set the cors enabled headers.
    origin = request.headers.get(b"Origin")
    if origin is not None and origin != b"null":
        headers.append((b"Access-Control-Allow-Origin", origin))
        headers.append((b"Access-Control-Allow-Credentials", 'true'))

    body = b"var dummy='value';"
    return headers, body