-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathhttpserver.py
More file actions
93 lines (72 loc) · 2.92 KB
/
Copy pathhttpserver.py
File metadata and controls
93 lines (72 loc) · 2.92 KB
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
from http.server import BaseHTTPRequestHandler,HTTPServer
from threading import Thread
import os
PORT = 8000
class ThreadedHTTPServer(HTTPServer):
def process_request(self, request, client_address):
thread = Thread(target=self.__new_request, args=(self.RequestHandlerClass, request, client_address, self))
thread.start()
def __new_request(self, handlerClass, request, address, server):
handlerClass(request, address, server)
self.shutdown_request(request)
class TileHandler(BaseHTTPRequestHandler):
protocol_version = 'HTTP/1.1'
def TH_SendHeaders(self, statusCode, endHeader=False, logRequest=False):
if (statusCode == 200):
self.send_response(statusCode)
else:
self.send_error(statusCode)
self.send_header('Access-Control-Allow-Origin', "*")
self.send_header('Access-Control-Allow-Headers', "Content-Length, Range")
self.send_header('Access-Control-Allow-Methods', "HEAD, GET, OPTIONS")
self.send_header('Cross-Origin-Opener-Policy', 'same-origin')
# credentialless (instead of require-corp) keeps the context cross-origin
# isolated — SharedArrayBuffer and wasm threads stay available for the
# udSDK — while letting cross-origin scripts/assets (the ArcGIS CDN,
# basemap tiles, etc.) load without needing explicit CORP/CORS headers
# or a `crossorigin` attribute on every dynamically-injected script tag.
self.send_header('Cross-Origin-Embedder-Policy', 'credentialless')
self.send_header('Cross-Origin-Resource-Policy', 'cross-origin')
if (endHeader):
self.end_headers()
if (logRequest):
lf = open('badreqs.log', 'a')
lf.write(self.client_address[0] + " | " + self.path + "\n")
lf.close()
def do_GET(self, sendBody = True):
filename = "./src/" + self.path.split("?", 1)[0]
print(filename)
#see if it exists
if not os.path.exists(filename):
return self.TH_SendHeaders(404, endHeader=True, logRequest=True)
else:
fp = open(filename, 'rb');
data = fp.read()
fp.close()
self.TH_SendHeaders(200)
extensions_map = {
'manifest': 'text/cache-manifest',
'html': 'text/html',
'png': 'image/png',
'jpg': 'image/jpg',
'svg': 'image/svg+xml',
'css': 'text/css',
'js': 'application/x-javascript',
'json': 'application/json',
'wasm': 'application/wasm'
}
if (filename.split(".")[-1] in extensions_map):
self.send_header('Content-Type', extensions_map[filename.split(".")[-1]])
self.send_header('Content-Length', str(len(data)))
self.end_headers()
if (sendBody):
self.wfile.write(data)
def do_POST(self):
self.do_GET()
def do_OPTIONS(self):
self.do_GET(sendBody=False)
def do_HEAD(self):
self.do_GET(sendBody=False)
server = ThreadedHTTPServer(('', PORT), TileHandler)
print("Server running on port", PORT)
server.serve_forever()