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
|