summaryrefslogtreecommitdiffstats
path: root/test/wpt/tests/xhr/resources/access-control-preflight-denied.py
blob: 1ec3037f36b88402e5f59b37b3842d19df10fa29 (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
46
47
48
49
def main(request, response):
    def fail(message):
        response.content = b"FAIL: " + message
        response.status = 400

    def getState(token):
        server_state = request.server.stash.take(token)
        if not server_state:
            return b"Uninitialized"
        return server_state

    def setState(token, state):
        request.server.stash.put(token, state)

    def resetState(token):
        setState(token, b"")

    response.headers.set(b"Cache-Control", b"no-store")
    response.headers.set(b"Access-Control-Allow-Origin", request.headers.get(b"origin"))
    response.headers.set(b"Access-Control-Max-Age", 1)
    token = request.GET.first(b"token", None)
    state = getState(token)
    command = request.GET.first(b"command", None)

    if command == b"reset":
        if request.method == u"GET":
            resetState(token)
            response.content = b"Server state reset"
        else:
            fail(b"Invalid Method.")
    elif state == b"Uninitialized":
        if request.method == u"OPTIONS":
            response.content = b"This request should not be displayed."
            setState(token, b"Denied")
        else:
            fail(state)
    elif state == b"Denied":
        if request.method == u"GET" and command == b"complete":
            resetState(token)
            response.content = b"Request successfully blocked."
        else:
            setState(token, b"Deny Ignored")
            fail(b"The request was not denied.")
    elif state == b"Deny Ignored":
        resetState(token)
        fail(state)
    else:
        resetState(token)
        fail(b"Unknown Error.")