From 862282ce99760832d3e9e5b4b1171b861105e004 Mon Sep 17 00:00:00 2001 From: Ebus-at-dockstar Date: Mon, 25 Mar 2013 10:24:28 +0100 Subject: move old stuff away --- heap/ebus/webapp/soup_plugin.py | 42 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 heap/ebus/webapp/soup_plugin.py (limited to 'heap/ebus/webapp/soup_plugin.py') diff --git a/heap/ebus/webapp/soup_plugin.py b/heap/ebus/webapp/soup_plugin.py new file mode 100644 index 0000000..e85d0b0 --- /dev/null +++ b/heap/ebus/webapp/soup_plugin.py @@ -0,0 +1,42 @@ +# -*- coding: utf-8 -*- +# vim: autoindent tabstop=4 shiftwidth=4 expandtab softtabstop=4 filetype=python + +import inspect + +from sqlalchemy import create_engine, text +#from sqlalchemy.ext.sqlsoup import SqlSoup +from sqlsoup import SQLSoup as SqlSoup + + +class SoupPlugin(object): + name = 'soup' + def __init__(self, url, echo=False, keyword='soup'): + self.url = url + self.keyword = keyword + self.echo = echo + + def setup(self, app): + for other in app.plugins: + if not isinstance(other, SoupPlugin): continue + if other.keyword == self.keyword: + raise PluginError("Found another soup plugin with "\ + "conflicting settings (non-unique keyword).") + + self.engine = create_engine(self.url, echo=self.echo) + self.soup = SqlSoup(self.engine) + + + def apply(self, callback, context): + print "apply" + conf = context['config'].get('soup') or {} + keyword = conf.get('keyword', self.keyword) + + args = inspect.getargspec(context['callback'])[0] + if keyword not in args: + return callback + + def wrapper(*args, **kwargs): + kwargs[keyword] = self.soup + return callback(*args, **kwargs) + + return wrapper -- cgit v1.2.1