-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathappetiser.py
86 lines (73 loc) · 2.27 KB
/
appetiser.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
75
76
77
78
79
80
81
82
83
84
85
86
import subprocess
from app.json_utils import (
extract_process_kwargs,
extract_response_items,
add_iiif_info_json
)
from app.jp2.convert import (
process
)
import flask
import logging
import logging.config
logging.config.dictConfig({
'version': 1,
'disable_existing_loggers': False,
'formatters': {'default': {
'format': '[%(asctime)s] %(levelname)s in %(name)s: %(message)s',
}},
'handlers': {'wsgi': {
'class': 'logging.StreamHandler',
'stream': 'ext://flask.logging.wsgi_errors_stream',
'formatter': 'default'
}},
'root': {
'level': 'DEBUG',
'handlers': ['wsgi']
}
})
appetiser = flask.Flask(__name__)
# Import after setup of logging to allow inclusion of
# initialisation logging in wsgi stdout.
@appetiser.errorhandler(500)
def server_error(e):
return flask.jsonify(
status='server error',
message=str(e)
), 500
@appetiser.route('/ping', methods=['GET'])
def ping():
return flask.jsonify(status='working')
@appetiser.route('/convert', methods=['POST'])
def convert():
json_data = flask.request.get_json()
appetiser.logger.info('Processing request data: %s', json_data)
try:
result = process(**extract_process_kwargs(json_data))
proto_reponse = {
**result,
**extract_response_items(json_data)
}
response = add_iiif_info_json(proto_reponse)
appetiser.logger.info('Response: %s', json_data)
return flask.jsonify(response)
except FileNotFoundError as fileError:
appetiser.logger.exception('Error: %s', fileError)
return flask.jsonify(
status='file not found',
message=str(fileError)
), 400
except subprocess.CalledProcessError as subprocess_error:
appetiser.logger.exception('Error: %s', subprocess_error.stderr)
return flask.jsonify(
status='kakadu error',
message=str(subprocess_error.stderr)
), 500
except Exception as general_error:
appetiser.logger.exception('Error: %s', general_error)
return flask.jsonify(
status='server error',
message=str(general_error)
), 500
if __name__ == '__main__':
appetiser.run(threaded=True, debug=True)