diff --git a/invenio_oauthclient/ext.py b/invenio_oauthclient/ext.py index ec9f7620..248207e9 100644 --- a/invenio_oauthclient/ext.py +++ b/invenio_oauthclient/ext.py @@ -10,7 +10,12 @@ import warnings +from flask import request from flask_login import user_logged_out +from flask_menu import current_menu +from invenio_i18n import lazy_gettext as _ +from invenio_theme.proxies import current_theme_icons +from speaklater import make_lazy_string from . import config, handlers from .utils import load_or_import_from_config, obj_or_import_string @@ -185,3 +190,74 @@ def init_app(self, app): app.extensions["invenio-oauthclient"] = state return state + + +def finalize_app(app): + """Finalize app.""" + override_template_configuration(app) + init_index_menu(app) + post_ext_init(app) + + +def override_template_configuration(app): + """Override template configuration.""" + template_key = app.config.get( + "OAUTHCLIENT_TEMPLATE_KEY", + "SECURITY_LOGIN_USER_TEMPLATE", # default template key + ) + if template_key is not None: + template = app.config[template_key] # keep the old value + app.config["OAUTHCLIENT_LOGIN_USER_TEMPLATE_PARENT"] = template + app.config[template_key] = app.config.get( + "OAUTHCLIENT_LOGIN_USER_TEMPLATE", + "invenio_oauthclient/login_user.html", + ) + + +def init_index_menu(app): + """Init index menu.""" + menu = app.extensions["menu"] + + def active_when(): + return request.endpoint.startswith("invenio_oauthclient_settings.") + + def visible_when(): + return bool(app.config.get("OAUTHCLIENT_REMOTE_APPS")) is not False + + menu.submenu("settings.oauthclient").register( + "invenio_oauthclient_settings.index", + _( + "%(icon)s Linked accounts", + icon=make_lazy_string( + lambda: f'' + ), + ), + order=3, + active_when=active_when, + visible_when=visible_when, + ) + + menu.submenu("breadcrumbs.settings.oauthclient").register( + "invenio_oauthclient_settings.index", + _("Linked accounts"), + ) + + +def post_ext_init(app): + """Setup blueprint.""" + app.config.setdefault( + "OAUTHCLIENT_SITENAME", + app.config.get("THEME_SITENAME", "Invenio"), + ) + app.config.setdefault( + "OAUTHCLIENT_BASE_TEMPLATE", + app.config.get("BASE_TEMPLATE", "invenio_oauthclient/base.html"), + ) + app.config.setdefault( + "OAUTHCLIENT_COVER_TEMPLATE", + app.config.get("COVER_TEMPLATE", "invenio_oauthclient/base_cover.html"), + ) + app.config.setdefault( + "OAUTHCLIENT_SETTINGS_TEMPLATE", + app.config.get("SETTINGS_TEMPLATE", "invenio_oauthclient/settings/base.html"), + ) diff --git a/invenio_oauthclient/finalize_app.py b/invenio_oauthclient/finalize_app.py deleted file mode 100644 index e3d3c34e..00000000 --- a/invenio_oauthclient/finalize_app.py +++ /dev/null @@ -1,30 +0,0 @@ -# -*- coding: utf-8 -*- -# -# This file is part of Invenio. -# Copyright (C) 2023 Graz University of Technology. -# -# Invenio is free software; you can redistribute it and/or modify it -# under the terms of the MIT License; see LICENSE file for more details. - -"""Finalize app.""" - - -def finalize_app(app): - """Finalize app.""" - - override_template_configuration(app) - - -def override_template_configuration(app): - """Override template configuration.""" - template_key = app.config.get( - "OAUTHCLIENT_TEMPLATE_KEY", - "SECURITY_LOGIN_USER_TEMPLATE", # default template key - ) - if template_key is not None: - template = app.config[template_key] # keep the old value - app.config["OAUTHCLIENT_LOGIN_USER_TEMPLATE_PARENT"] = template - app.config[template_key] = app.config.get( - "OAUTHCLIENT_LOGIN_USER_TEMPLATE", - "invenio_oauthclient/login_user.html", - ) diff --git a/invenio_oauthclient/views/client.py b/invenio_oauthclient/views/client.py index e285aa61..7636d9af 100644 --- a/invenio_oauthclient/views/client.py +++ b/invenio_oauthclient/views/client.py @@ -39,28 +39,6 @@ ) -@blueprint.record_once -def post_ext_init(state): - """Setup blueprint.""" - app = state.app - - app.config.setdefault( - "OAUTHCLIENT_SITENAME", app.config.get("THEME_SITENAME", "Invenio") - ) - app.config.setdefault( - "OAUTHCLIENT_BASE_TEMPLATE", - app.config.get("BASE_TEMPLATE", "invenio_oauthclient/base.html"), - ) - app.config.setdefault( - "OAUTHCLIENT_COVER_TEMPLATE", - app.config.get("COVER_TEMPLATE", "invenio_oauthclient/base_cover.html"), - ) - app.config.setdefault( - "OAUTHCLIENT_SETTINGS_TEMPLATE", - app.config.get("SETTINGS_TEMPLATE", "invenio_oauthclient/settings/base.html"), - ) - - @blueprint.route("/login") def auto_redirect_login(*args, **kwargs): """Handles automatic redirect to external auth service. diff --git a/invenio_oauthclient/views/settings.py b/invenio_oauthclient/views/settings.py index 6c1a9c1e..a29cabb8 100644 --- a/invenio_oauthclient/views/settings.py +++ b/invenio_oauthclient/views/settings.py @@ -11,13 +11,8 @@ from operator import itemgetter import six -from flask import Blueprint, current_app, render_template, request -from flask_breadcrumbs import register_breadcrumb +from flask import Blueprint, current_app, render_template from flask_login import current_user, login_required -from flask_menu import register_menu -from invenio_i18n import lazy_gettext as _ -from invenio_theme.proxies import current_theme_icons -from speaklater import make_lazy_string from ..models import RemoteAccount from ..proxies import current_oauthclient @@ -33,21 +28,6 @@ @blueprint.route("/", methods=["GET", "POST"]) @login_required -@register_menu( - blueprint, - "settings.oauthclient", - _( - "%(icon)s Linked accounts", - icon=make_lazy_string(lambda: f''), - ), - order=3, - active_when=lambda: request.endpoint.startswith("invenio_oauthclient_settings."), - visible_when=lambda: bool(current_app.config.get("OAUTHCLIENT_REMOTE_APPS")) - is not False, -) -@register_breadcrumb( - blueprint, "breadcrumbs.settings.oauthclient", _("Linked accounts") -) def index(): """List linked accounts.""" oauth = current_oauthclient.oauth diff --git a/setup.cfg b/setup.cfg index 6e4189d7..2b91428a 100644 --- a/setup.cfg +++ b/setup.cfg @@ -84,7 +84,7 @@ invenio_base.secret_key = invenio_i18n.translations = invenio_oauthclient = invenio_oauthclient invenio_base.finalize_app = - invenio_oauthclient = invenio_oauthclient.finalize_app:finalize_app + invenio_oauthclient = invenio_oauthclient.ext:finalize_app [build_sphinx] source-dir = docs/