factorisation gestion des filtres
[restcoda.git] / rest.py
... / ...
CommitLineData
1#!/usr/bin/python
2# -*- coding: utf-8 -*-
3
4import sys, traceback
5
6# configuration (codes d'accès à la base MS-SQL)
7sys.path.append('/home/thomas/public_html/')
8import rest_config
9
10# pour savoir quel objet interroger : Routes
11from routes import Mapper
12from routes.middleware import RoutesMiddleware
13
14# Gestion des erreurs
15from jinja.exceptions import TemplateNotFound
16from objetsql import ObjetSQLInconnuError
17
18# TODO : ajouter un middleware de cache (beaker, basé sur REQUEST_URI quand la methode est GET)
19# from beaker.middleware import CacheMiddleware
20
21# formats de sortie autorisés, et content-type correspondant
22# formats = { 'xml': 'application/xml', 'html': 'text/html', 'txt': 'text/plain', 'json': 'application/json', 'rss': 'application/rss+xml' }
23formats = { 'xml': 'application/xml', 'html': 'text/html', 'txt': 'text/plain', 'json': 'text/plain', 'rss': 'application/rss+xml' } # pour debug : json en text/plain
24
25
26# les routes RESTful (cf http://routes.groovie.org/manual.html#restful-services)
27mapper = Mapper()
28mapper.resource('demlog','demlog')
29mapper.resource('comlog','comlog')
30mapper.resource('demdep','demdep')
31mapper.resource('comdep','comdep')
32mapper.resource('dempub','dempub')
33mapper.resource('compub','compub')
34mapper.resource('comare','comare')
35mapper.resource('comarei','comare:(impl)',controller='comare') # pour les comarexxx où xxx est un code d'implantation
36mapper.resource('comsre','comsre')
37mapper.resource('comsrei','comsre:(impl)',controller='comsre')
38mapper.resource('comxre','comxre') # comxre = comare + comsre
39mapper.resource('comxrei','comxre:(impl)',controller='comxre')
40mapper.resource('dem','dem')
41mapper.resource('com','com')
42mapper.resource('utilisateur','utilisateur')
43
44# objets disponibles
45from document import demlog, comlog, demdep, comdep, dempub, compub, comare, comsre, comxre, dem, com
46from utilisateur import utilisateur
47
48def dispatcher(environ, start_response):
49 """dispatch vers la bonne methode du bon objet, et retour WSGI"""
50 results = environ['wsgiorg.routing_args'][1] # résultat du middleware Routes
51 try:
52 # On cherche l'objet puis la méthode
53 target_class = globals()[results['controller']]
54 method = getattr(target_class,results['action'])
55 except:
56 # Si erreur pendant la recherche, on renvoie un 501
57 start_response("501 Not Implemented", [('Content-type', 'text/html')])
58 return '<html><body><h2>501 objet ou action invalide</h2></body></html>' # <pre>%s: %s\n%s</pre></body></html>' % ( sys.exc_info()[0] , sys.exc_info()[1] , traceback.format_exc())
59 try:
60 # On lance la méthode et on renvoie le résultat
61 type, output = method(target_class(environ))
62 start_response("200 OK", [('Content-type', formats[type])])
63 return output.encode('utf-8')
64 # gestion des problèmes possibles pendant l'exécution
65 except ObjetSQLInconnuError, type:
66 start_response("404 Not Found", [('Content-type', 'text/html')])
67 return '<html><body><h2>404 %s inexistant</h2></body></html>' % type
68 except TemplateNotFound, template:
69 start_response("415 Unsupported Media Type", [('Content-type', 'text/html')])
70 return '<html><body><h2>415 format non supporté (%s inexistant)</h2></body></html>' % template
71 except:
72 start_response("500 INTERNAL ERROR", [('Content-type', 'text/html')])
73 return '<html><body><h2>500 erreur lors du traitement</h2><pre>%s: %s\n%s</pre></body></html>' % ( sys.exc_info()[0] , sys.exc_info()[1] , traceback.format_exc())
74
75
76# application() sera lancée par mod_wsgi : on route et on dispatche
77application = RoutesMiddleware( dispatcher, mapper )
78
79