-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathall_exception_handler.py
63 lines (48 loc) · 1.83 KB
/
all_exception_handler.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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import json
# pip install cherrypy
# https://github.com/cherrypy/cherrypy
import cherrypy
class Root:
def __init__(self):
# Set a custom response for errors.
self._cp_config = {"error_page.default": Root.all_exception_handler}
# # OR:
# Root._cp_config = {'error_page.default': Root.all_exception_handler}
# Expose the index method through the web. CherryPy will never
# publish methods that don't have the exposed attribute set to True.
@cherrypy.expose
def index(self):
# CherryPy will call this method for the root URI ("/") and send
# its return value to the client. Because this is tutorial
# lesson number 01, we'll just send something really simple.
# How about...
return 'Hello world!<br><a href="/error">Get error</a>'
@cherrypy.expose
def error(self):
_ = 1 / 0
return "Bad!"
@staticmethod
def all_exception_handler(status, message, traceback, version):
response = cherrypy.response
response.headers["Content-Type"] = "application/json"
return json.dumps(
{
"about": "Catch error!",
"status": status,
"message": message,
"text": traceback.strip().split("\n")[-1],
"traceback": traceback,
"version": version,
}
)
if __name__ == "__main__":
# CherryPy always starts with app.root when trying to map request URIs
# to objects, so we need to mount a request handler root. A request
# to '/' will be mapped to HelloWorld().index().
# Set port
cherrypy.config.update({"server.socket_port": 9090})
# Autoreload off
cherrypy.config.update({"engine.autoreload.on": False})
cherrypy.quickstart(Root())