-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmysql_web_server.py
executable file
·67 lines (57 loc) · 2.03 KB
/
mysql_web_server.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
#!/usr/bin/env python3
from bottle import Bottle, request, response, abort
import bottle_mysql
import time # Used for tracking query time taken
import datetime
import json
import datetime
from gevent.pywsgi import WSGIServer
from geventwebsocket import WebSocketError
from geventwebsocket.handler import WebSocketHandler
application = Bottle()
plugin = bottle_mysql.Plugin(dbuser='qonqr_ro', dbpass='readonly', dbname='qonqr', dbhost='localhost')
application.install(plugin)
@application.hook('after_request')
def enable_cors(): # Cross Origin Resource Sharing - to allow the API to be reached from any website
response.headers['Access-Control-Allow-Origin'] = '*'
response.headers['Access-Control-Allow-Methods'] = 'PUT, GET, POST, DELETE, OPTIONS'
response.headers['Access-Control-Allow-Headers'] = 'Origin, Accept, Content-Type, X-Requested-With, X-CSRF-Token'
def query(db, query):
s = time.time()
try:
db.execute(query)
results = db.fetchall()
for r in results:
for k, v in r.items():
if v and type(v) in [datetime.datetime, datetime.date]:
r[k] = str(v)
except Exception as e:
results = {"error": str(e)}
print(f"""Query: {query}. Query completed in {time.time() - s}s, {len(results)} results""")
return {"results": results}
@application.get('/<sql>')
def get(db, sql):
print(sql)
return query(db, sql)
@application.route('/websocket')
def handle_websocket(db):
wsock = request.environ.get('wsgi.websocket')
if not wsock:
abort(400, 'Expected WebSocket request.')
while True:
try:
sql = wsock.receive()
result = query(db, sql)
wsock.send(json.dumps(result))
except WebSocketError:
break
if __name__ == "__main__":
application.run(
host='localhost',
port=8081,
server='gunicorn',
workers=16,
worker_class="geventwebsocket.gunicorn.workers.GeventWebSocketWorker",
timeout=600,
capture_output=True
)