TurboGears - Crochets
Il existe trois façons dans TurboGears de brancher des comportements dans les applications existantes.
Hook - C'est un mécanisme par lequel il est possible de définir un événement, et de notifier les écouteurs enregistrés au fur et à mesure que les événements sont émis.
Controller Wrapper- Il se situe entre TurboGears et Controller, de sorte qu'il est possible d'étendre le contrôleur comme un décorateur. Ainsi, il peut être attaché à n'importe quelle application de contrôleur tiers.
Application Wrapper - Il est similaire à n'importe quel middleware WSGI, mais ne fonctionne que dans le contexte TurboGears.
Ici, dans ce chapitre, nous verrons comment utiliser des hooks dans une application existante.
Crochets
Les hooks sont des événements enregistrés dans le fichier de configuration de l'application app_cfg.py. Tout contrôleur est alors accroché à ces événements par les décorateurs d'événements.
Les crochets suivants sont définis dans TurboGears -
N ° Sr. | Crochets et description |
---|---|
1 | Startup() à l'échelle de l'application uniquement, appelée au démarrage de l'application. |
2 | shutdown() à l'échelle de l'application uniquement, appelée à la fermeture de l'application. |
3 | configure_new_app une nouvelle application a été créée par le configurateur d'application. |
4 | before_config(app) à l'échelle de l'application uniquement, appelée juste après la création de l'application, mais avant la configuration des options et du middleware |
5 | after_config(app) à l'échelle de l'application uniquement, appelée après avoir terminé de tout configurer. |
6 | before_validate Appelé avant d'effectuer la validation |
sept | before_call Appelé après validation, avant d'appeler la méthode de contrôleur réelle. |
8 | before_render Appelé avant le rendu d'un modèle de contrôleur, la sortie est la valeur de retour du contrôleur. |
9 | after_render Appelé après avoir terminé le rendu d'un modèle de contrôleur. |
Enregistrer un crochet
Afin de register a Hook, créer des fonctions dans app_cfg.py puis enregistrez-les en utilisant le code suivant -
tg.hooks.register(hookane, function, controller)
Dans le code suivant, les hooks on_startup, on_shutdown et before_render sont enregistrés dans app_cfg.py.
def on_startup():
print 'hello, startup world'
def on_shutdown():
print 'hello, shutdown world'
def before_render(remainder, params, output):
print 'system wide before render'
# ... (base_config init code)
tg.hooks.register('startup', on_startup)
tg.hooks.register('shutdown', on_shutdown)
tg.hooks.register('before_render', before_render)
Le hook before_render est enregistré avec une fonction de contrôleur dans le Rootcontroller. Ajoutez le code suivant dans controllers \ root.py.
from tg.decorators import before_render
class RootController(BaseController):
@expose('hello.templates.index')
@before_render(before_render_cb)
def index(self, *args, **kw):
return dict(page = 'index')
Lorsque l'application est servie, un message de démarrage s'affiche dans la console.
hello, startup world
Starting Standard HTTP server on http://127.0.0.1:8080
Lorsque l'URL '/' est saisie dans le navigateur, un message correspondant au hook before_render s'affiche sur la console.
system wide before render
Going to render {'page': 'index'}