| author | Sandro Knauß <knauss@netzguerilla.net> |
| Tue, 10 Jan 2012 06:10:38 +0100 | |
| branch | devel |
| changeset 97 | 7556364b8104 |
| parent 93 | ee10253258ad |
| child 96 | 883b25b0b760 |
| permissions | -rw-r--r-- |
| 92 | 1 |
import logging |
2 |
import re |
|
3 |
||
4 |
from .database import WithSession |
|
|
93
ee10253258ad
now right relative imports
Sandro Knauß <knauss@netzguerilla.net>
parents:
92
diff
changeset
|
5 |
from ..model import User |
| 92 | 6 |
|
|
93
ee10253258ad
now right relative imports
Sandro Knauß <knauss@netzguerilla.net>
parents:
92
diff
changeset
|
7 |
from ..error import UserNotFound, InterfaceException, ValidateException |
| 92 | 8 |
|
9 |
||
10 |
def rehash(hash): |
|
11 |
if not re.match(r'^[a-f0-9]{15,}$', hash.lower()): |
|
12 |
raise ValidateException() |
|
13 |
return True |
|
14 |
||
15 |
def validate(**kargs): |
|
16 |
def v(f): |
|
17 |
def new_f(*a,**k): |
|
18 |
for i in kargs: |
|
19 |
kargs[i](k[i]) |
|
20 |
return f(*a,**k) |
|
21 |
new_f.__name__ = f.__name__ |
|
22 |
return new_f |
|
23 |
return v |
|
24 |
||
25 |
||
26 |
@validate(userhash=rehash) |
|
27 |
def getuser(userhash): |
|
28 |
with WithSession() as session: |
|
29 |
user = session.query(User).filter_by(apikey=userhash).first() |
|
30 |
if user is None: |
|
31 |
raise UserNotFound() |
|
32 |
else: |
|
33 |
return user |
|
34 |
||
35 |
def with_user(f): |
|
36 |
def new_f(*args,**kargs): |
|
37 |
args=list(args) |
|
38 |
logging.debug("Entering %s"%f.__name__) |
|
39 |
try: |
|
40 |
kargs["user"]=getuser(userhash = kargs["apikey"]) |
|
41 |
del kargs["apikey"] |
|
42 |
except KeyError: |
|
43 |
try: |
|
44 |
kargs["user"]=getuser(userhash = args[1]) |
|
45 |
except IndexError: |
|
46 |
raise InterfaceException() |
|
47 |
del args[1] |
|
48 |
ret=f(*args,**kargs) |
|
49 |
logging.debug("Exited %s"%f.__name__) |
|
50 |
return ret |
|
51 |
new_f.__name__ = f.__name__ |
|
52 |
return new_f |
|
53 |
||
54 |