aboutsummaryrefslogtreecommitdiffstats
path: root/python/fatcat_web/routes.py
diff options
context:
space:
mode:
authorBryan Newbold <bnewbold@robocracy.org>2019-01-03 20:45:29 -0800
committerBryan Newbold <bnewbold@robocracy.org>2019-01-03 20:45:29 -0800
commit422a8cc47489aa44b852ff0add1ef6ea63cfc1ff (patch)
tree6640c13f10271cffe8e442e1fc75202d032121ca /python/fatcat_web/routes.py
parent1cb3b1afa8df555d890cc556751222cf22c22696 (diff)
downloadfatcat-422a8cc47489aa44b852ff0add1ef6ea63cfc1ff.tar.gz
fatcat-422a8cc47489aa44b852ff0add1ef6ea63cfc1ff.zip
several auth improvements
Diffstat (limited to 'python/fatcat_web/routes.py')
-rw-r--r--python/fatcat_web/routes.py45
1 files changed, 34 insertions, 11 deletions
diff --git a/python/fatcat_web/routes.py b/python/fatcat_web/routes.py
index 51533a2f..5d46fe0b 100644
--- a/python/fatcat_web/routes.py
+++ b/python/fatcat_web/routes.py
@@ -4,6 +4,7 @@ import json
from flask import Flask, render_template, send_from_directory, request, \
url_for, abort, g, redirect, jsonify, session
from fatcat_web import app, api
+from fatcat_web.auth import handle_token_login, handle_logout
from fatcat_client.rest import ApiException
from fatcat_web.search import do_search
@@ -295,12 +296,6 @@ def work_view(ident):
return render_template('deleted_entity.html', entity=entity)
return render_template('work_view.html', work=entity, releases=releases)
-@app.route('/editgroup/current', methods=['GET'])
-def editgroup_current():
- raise NotImplementedError
- #eg = api.get_or_create_editgroup()
- #return redirect('/editgroup/{}'.format(eg.id))
-
@app.route('/editgroup/<ident>', methods=['GET'])
def editgroup_view(ident):
try:
@@ -327,6 +322,17 @@ def editor_changelog(ident):
return render_template('editor_changelog.html', editor=editor,
changelog_entries=changelog_entries)
+@app.route('/editor/<ident>/wip', methods=['GET'])
+def editor_wip(ident):
+ raise NotImplementedError
+ try:
+ editor = api.get_editor(ident)
+ entries = api.get_editor_wip(ident)
+ except ApiException as ae:
+ abort(ae.status)
+ return render_template('editor_changelog.html', editor=editor,
+ entries=entries)
+
@app.route('/changelog', methods=['GET'])
def changelog_view():
try:
@@ -369,16 +375,33 @@ def search():
### Auth ####################################################################
-@app.route('/login')
+@app.route('/auth/login')
def login():
# show the user a list of login options
- return render_template('release_search.html', query=query, fulltext_only=fulltext_only)
+ return render_template('auth_login.html')
+
+@app.route('/auth/token_login', methods=['GET', 'POST'])
+def token_login():
+ # show the user a list of login options
+ if 'token' in request.args:
+ return handle_token_login(request.args.get('token'))
+ if 'token' in request.form:
+ return handle_token_login(request.form.get('token'))
+ return render_template('auth_token_login.html')
-@app.route('/login')
+@app.route('/auth/logout')
def logout():
# TODO: clear extra session info
- logout_user()
- return render_template('logout.html')
+ handle_logout()
+ return render_template('auth_logout.html')
+
+@app.route('/auth/account')
+@login_required
+def logout():
+ # TODO: clear extra session info
+ handle_logout()
+ return render_template('auth_logout.html')
+
### Static Routes ###########################################################