| 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 |