-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample.py
executable file
·74 lines (56 loc) · 1.88 KB
/
example.py
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#!/usr/bin/env python3
from http.server import BaseHTTPRequestHandler, HTTPServer
from json import dumps
from socketserver import ThreadingMixIn
from urllib import parse
import anticsrf
t = anticsrf.token_clerk(
keysize=8,
keyfunc=anticsrf.random_key,
expire_after=1e8
)
class Server(BaseHTTPRequestHandler):
def do_GET(self):
po = parse.urlparse(self.path)
qs = dict(parse.parse_qsl(po.query))
if "action" not in qs:
self.send_error(400)
return
self.send_response(200)
self.end_headers()
res = {}
if qs["action"] == "new":
res = t.register_new()
elif qs["action"] == "valid":
if "key" not in qs:
self.send_error(400)
return
res = t.is_valid(qs["key"])
self.wfile.write(bytes(dumps(res), "utf-8"))
# action=new
# {"tok": "760d40", "exp": 1497098237605895.0, "iat": 1497098227605895}
# within t.expire_after microseconds
# action=valid&key=760d40
# {"exp": 1497098270397330.0, "reg": false, "old": false}
# more than t.expire_after microseconds later
# {"exp": 1497098270397330.0, "reg": false, "old": false}
# restart the server
# action=valid&key=760d40
# {"reg": false, "old": false, "exp": 0}
class QuietServer(Server):
"ssshhhh!"
def log_message(*args):
pass
class ThreadedHTTPServer(ThreadingMixIn, HTTPServer):
"""Handle requests in a separate thread."""
def example_main(port, count_reqs=1, quiet=False):
server_address = ("", port)
if quiet:
httpd = ThreadedHTTPServer(server_address, QuietServer)
else:
httpd = ThreadedHTTPServer(server_address, Server)
print("Starting httpd on port {}...".format(port))
for i in range(count_reqs):
httpd.handle_request()
if __name__ == '__main__':
example_main(8090, count_reqs=100, quiet=False)