1 #----------------------------------------------------------
2 # ir_http modular http routing
3 #----------------------------------------------------------
6 import werkzeug.exceptions
7 import werkzeug.routing
10 from openerp import http
11 from openerp.http import request
12 from openerp.osv import osv
14 _logger = logging.getLogger(__name__)
16 class ir_http(osv.osv):
18 _description = "HTTP routing"
20 def __init__(self, registry, cr):
21 osv.osv.__init__(self, registry, cr)
23 def _find_handler(self):
24 # TODO move to __init__(self, registry, cr)
25 if not hasattr(self, 'routing_map'):
26 _logger.info("Generating routing map")
28 m = request.registry.get('ir.module.module')
29 ids = m.search(cr, openerp.SUPERUSER_ID, [('state', '=', 'installed'), ('name', '!=', 'web')])
30 installed = set(x['name'] for x in m.read(cr, 1, ids, ['name']))
31 mods = ['', "web"] + sorted(installed)
32 self.routing_map = http.routing_map(mods, False)
34 # fallback to non-db handlers
35 path = request.httprequest.path
36 urls = self.routing_map.bind_to_environ(request.httprequest.environ)
38 return urls.match(path)
40 def _auth_method_user(self):
41 request.uid = request.session.uid
43 raise SessionExpiredException("Session expired")
45 def _auth_method_admin(self):
47 raise SessionExpiredException("No valid database for request %s" % request.httprequest)
48 request.uid = openerp.SUPERUSER_ID
50 def _auth_method_none(self):
51 request.disable_db = True
54 def _authenticate(self, func, arguments):
55 auth_method = getattr(func, "auth", "user")
56 if request.session.uid:
58 request.session.check_security()
59 except SessionExpiredException, e:
60 request.session.logout()
61 raise SessionExpiredException("Session expired for request %s" % request.httprequest)
62 getattr(self, "_auth_method_%s" % auth_method)()
65 def _handle_404(self, exception):
68 def _handle_403(self, exception):
71 def _handle_500(self, exception):
75 # locate the controller method
77 func, arguments = self._find_handler()
78 except werkzeug.exceptions.NotFound, e:
79 return self._handle_404(e)
81 # check authentication level
83 auth_method = self._authenticate(func, arguments)
84 except werkzeug.exceptions.NotFound, e:
85 return self._handle_403(e)
87 # set and execute handler
89 request.set_handler(func, arguments, auth_method)
90 result = request.dispatch()
92 return self._handle_500(e)