diff --git a/frontend.py b/frontend.py index 452769f..7fbf975 100755 --- a/frontend.py +++ b/frontend.py @@ -178,9 +178,10 @@ def register_telegram(user): return city_page(user.get_city(), info="Thanks for registering Telegram!") -@get('/api/state') -def api_enable(user): - return user.state() +# unused afaik +#@get('/api/state') +#def api_enable(user): +# return user.state() @get('/static/') @@ -197,6 +198,7 @@ def guides(filename): def logout(): # clear auth cookie response.set_cookie('uid', '', expires=0, path="/") + response.set_cookie('csrf', '', expires=0, path="/") # :todo show info "Logout successful." redirect('/') diff --git a/photo-1461685265823-f8d5d0b08b9b?ixlib=rb-1.2.1&q=85&fm=jpg&crop=entropy&cs=srgb&dl=matthew-henry-87142-unsplash.jpg b/photo-1461685265823-f8d5d0b08b9b?ixlib=rb-1.2.1&q=85&fm=jpg&crop=entropy&cs=srgb&dl=matthew-henry-87142-unsplash.jpg deleted file mode 100644 index 1b546db..0000000 Binary files a/photo-1461685265823-f8d5d0b08b9b?ixlib=rb-1.2.1&q=85&fm=jpg&crop=entropy&cs=srgb&dl=matthew-henry-87142-unsplash.jpg and /dev/null differ diff --git a/session.py b/session.py index 5d0c263..ccda7bb 100644 --- a/session.py +++ b/session.py @@ -1,4 +1,4 @@ -from bottle import redirect, request +from bottle import redirect, request, abort, response from db import db from functools import wraps from inspect import Signature @@ -17,10 +17,14 @@ class SessionPlugin(object): if self.keyword in Signature.from_callable(route.callback).parameters: @wraps(callback) def wrapper(*args, **kwargs): - uid = request.get_cookie('uid', secret=db.secret) + uid = request.get_cookie('uid', secret=db.get_secret()) if uid is None: return redirect(self.loginpage) kwargs[self.keyword] = User(uid) + if request.method == 'POST': + if request.forms['csrf'] != request.get_cookie('csrf', + secret=db.get_secret()): + abort(400) return callback(*args, **kwargs) return wrapper diff --git a/template/settings.tpl b/template/settings.tpl index dae30ce..66cf873 100644 --- a/template/settings.tpl +++ b/template/settings.tpl @@ -61,6 +61,7 @@