canaille-globuzma/canaille/oidc/tokens.py

53 lines
1.6 KiB
Python
Raw Normal View History

2023-02-04 17:41:49 +00:00
import datetime
from canaille.app import models
2023-04-09 13:52:55 +00:00
from canaille.app.flask import permissions_needed
from canaille.app.flask import render_htmx_template
from canaille.app.forms import TableForm
from canaille.oidc.forms import TokenRevokationForm
from flask import abort
from flask import Blueprint
2023-02-04 17:41:49 +00:00
from flask import flash
from flask import request
2023-02-04 17:41:49 +00:00
from flask_babel import gettext as _
from flask_themer import render_template
2020-08-26 15:23:53 +00:00
2022-01-11 18:49:06 +00:00
bp = Blueprint("tokens", __name__, url_prefix="/admin/token")
2020-08-26 15:23:53 +00:00
@bp.route("/", methods=["GET", "POST"])
2021-12-02 17:23:14 +00:00
@permissions_needed("manage_oidc")
2020-10-29 10:09:31 +00:00
def index(user):
table_form = TableForm(models.Token, formdata=request.form)
if request.form and request.form.get("page") and not table_form.validate():
abort(404)
return render_htmx_template(
"oidc/admin/token_list.html", menuitem="admin", table_form=table_form
2022-01-11 18:49:06 +00:00
)
2020-08-26 15:23:53 +00:00
2023-06-29 10:15:12 +00:00
@bp.route("/<token:token>", methods=["GET", "POST"])
2021-12-02 17:23:14 +00:00
@permissions_needed("manage_oidc")
2023-06-29 10:15:12 +00:00
def view(user, token):
form = TokenRevokationForm(request.form or None)
if request.form and form.validate():
if request.form.get("action") == "confirm-revoke":
return render_template("modals/revoke-token.html", token=token)
elif request.form.get("action") == "revoke":
token.revokation_date = datetime.datetime.now(datetime.timezone.utc)
token.save()
flash(_("The token has successfully been revoked."), "success")
else:
abort(400, f"bad form action: {request.form.get('action')}")
2022-02-03 08:51:04 +00:00
return render_template(
"oidc/admin/token_view.html",
token=token,
menuitem="admin",
form=form,
2022-02-03 08:51:04 +00:00
)