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
|
2022-03-03 09:05:14 +00:00
|
|
|
from flask import abort
|
2021-10-28 13:24:34 +00:00
|
|
|
from flask import Blueprint
|
|
|
|
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):
|
2020-08-26 15:23:53 +00:00
|
|
|
tokens = Token.filter()
|
2022-02-03 09:04:14 +00:00
|
|
|
items = (
|
|
|
|
(token, Client.get(token.client), User.get(dn=token.subject))
|
|
|
|
for token in tokens
|
2022-01-11 18:49:06 +00:00
|
|
|
)
|
2022-02-03 09:04:14 +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):
|
2022-03-03 09:05:14 +00:00
|
|
|
token = Token.get(token_id=token_id) or 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",
|
|
|
|
)
|