canaille-globuzma/canaille/oidc/tokens.py

64 lines
1.7 KiB
Python
Raw Normal View History

2023-02-04 17:41:49 +00:00
import datetime
2021-12-20 22:57:27 +00:00
from canaille.flaskutils import permissions_needed
2022-02-03 08:51:04 +00:00
from canaille.models import User
from canaille.oidc.models import Client
2022-01-11 18:49:06 +00:00
from canaille.oidc.models import Token
from flask import abort
from flask import Blueprint
2023-02-04 17:41:49 +00:00
from flask import flash
from flask import redirect
from flask import url_for
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("/")
2021-12-02 17:23:14 +00:00
@permissions_needed("manage_oidc")
2020-10-29 10:09:31 +00:00
def index(user):
tokens = Token.all()
items = (
(token, Client.get(token.client), User.get(dn=token.subject))
for token in tokens
2022-01-11 18:49:06 +00:00
)
return render_template("oidc/admin/token_list.html", items=items, menuitem="admin")
2020-08-26 15:23:53 +00:00
@bp.route("/<token_id>", methods=["GET", "POST"])
2021-12-02 17:23:14 +00:00
@permissions_needed("manage_oidc")
2020-10-29 10:09:31 +00:00
def view(user, token_id):
token = Token.get(token_id=token_id)
if not token:
abort(404)
2022-02-03 08:51:04 +00:00
token_client = Client.get(token.client)
token_user = User.get(dn=token.subject)
token_audience = [Client.get(aud) for aud in token.audience]
return render_template(
"oidc/admin/token_view.html",
token=token,
token_client=token_client,
token_user=token_user,
token_audience=token_audience,
menuitem="admin",
)
2023-02-04 17:41:49 +00:00
@bp.route("/<token_id>/revoke", methods=["GET", "POST"])
@permissions_needed("manage_oidc")
def revoke(user, token_id):
token = Token.get(token_id=token_id)
if not token:
abort(404)
token.revokation_date = datetime.datetime.now()
token.save()
flash(_("The token has successfully been revoked."), "success")
return redirect(url_for("oidc.tokens.view", token_id=token_id))