diff --git a/pyproject.toml b/pyproject.toml index 442976224e..bcac4635a7 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -319,9 +319,11 @@ vendors = "rero_ils.modules.vendors.jsonschemas" files = "rero_ils.modules.files.jsonschemas" [tool.poetry.plugins."invenio_oauth2server.scopes"] +fullname = "rero_ils.oauth.scopes:fullname" birthdate = "rero_ils.oauth.scopes:birthdate" +patrons = "rero_ils.oauth.scopes:patrons" +# deprecated scopes expiration_date = "rero_ils.oauth.scopes:expiration_date" -fullname = "rero_ils.oauth.scopes:fullname" institution = "rero_ils.oauth.scopes:institution" patron_type = "rero_ils.oauth.scopes:patron_type" patron_types = "rero_ils.oauth.scopes:patron_types" diff --git a/rero_ils/modules/patrons/views.py b/rero_ils/modules/patrons/views.py index 54967e5dad..b602315ad1 100644 --- a/rero_ils/modules/patrons/views.py +++ b/rero_ils/modules/patrons/views.py @@ -1,7 +1,7 @@ # -*- coding: utf-8 -*- # # RERO ILS -# Copyright (C) 2019-2023 RERO +# Copyright (C) 2024 RERO # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by @@ -19,7 +19,6 @@ from __future__ import absolute_import, print_function -import copy import datetime import re @@ -321,15 +320,6 @@ def info(): """Get patron info.""" token_scopes = flask_request.oauth.access_token.scopes - def get_main_patron(patrons): - """Return the main patron. - - :param patrons: List of patrons. - :returns: The main patron. - """ - # TODO: Find a way to determine which is the main patron. - return patrons[0] - def get_institution_code(institution): """Get the institution code for a given institution. @@ -341,21 +331,10 @@ def get_institution_code(institution): # TODO: make this non rero specific using a configuration return institution["code"] if institution["code"] != "nj" else "rbnj" - user = User.get_record(current_user.id).dumps_metadata() - - # Process for all patrons - patrons = copy.deepcopy(current_patrons) - for patron in patrons: - patron["institution"] = patron.organisation - patron["patron"]["type"] = PatronType.get_record_by_pid( - extracted_data_from_ref(patron["patron"]["type"]["$ref"]) - ) + # user = User.get_record(current_user.id).dumps_metadata() # Birthdate data = {} - birthdate = current_user.user_profile.get("birth_date") - if "birthdate" in token_scopes and birthdate: - data["birthdate"] = birthdate # Full name name_parts = [ current_user.user_profile.get("last_name", "").strip(), @@ -364,34 +343,50 @@ def get_institution_code(institution): fullname = ", ".join(filter(None, name_parts)) if "fullname" in token_scopes and fullname: data["fullname"] = fullname + birthdate = current_user.user_profile.get("birth_date") + if "birthdate" in token_scopes and birthdate: + data["birthdate"] = birthdate - # No patrons found for user - if not patrons: - return jsonify(data) - - # Get the main patron - patron = get_main_patron(patrons) - # Barcode - if patron.get("patron", {}).get("barcode"): - data["barcode"] = patron["patron"]["barcode"][0] + patrons = current_patrons + if len(patrons) > 0: + patron = patrons[0] + # Barcode + if patron.get("patron", {}).get("barcode"): + data["barcode"] = patron["patron"]["barcode"][0] # Patron types if "patron_types" in token_scopes: patron_types = [] + patrons_info = {} for patron in patrons: - info = {} - patron_type_code = patron.get("patron", {}).get("type", {}).get("code") - if patron_type_code: + # old list + info = {"patron_pid": patron.pid} + patron_type = PatronType.get_record_by_pid( + extracted_data_from_ref(patron["patron"]["type"]["$ref"]) + ) + if patron_type_code := patron_type.get("code"): info["patron_type"] = patron_type_code - if patron.get("institution"): - info["institution"] = get_institution_code(patron["institution"]) - if patron.get("patron", {}).get("expiration_date"): + if org := patron.organisation: + info["institution"] = get_institution_code(org) + if expiration_date := patron.get("patron", {}).get("expiration_date"): info["expiration_date"] = datetime.datetime.strptime( - patron["patron"]["expiration_date"], "%Y-%m-%d" + expiration_date, "%Y-%m-%d" ).isoformat() - if info: - patron_types.append(info) + patron_types.append(info) + # new dict + if org := patron.organisation: + org_code = get_institution_code(org) + patron_info = {"patron_pid": patron.pid, "institution": org_code} + if patron_type_code := patron_type.get("code"): + patron_info["patron_type"] = patron_type_code + if expiration_date := patron.get("patron", {}).get("expiration_date"): + patron_info["expiration_date"] = datetime.datetime.strptime( + expiration_date, "%Y-%m-%d" + ).isoformat() + patrons_info[org_code] = patron_info + if patron_types: data["patron_types"] = patron_types + data["patrons"] = patrons_info return jsonify(data) diff --git a/rero_ils/oauth/scopes.py b/rero_ils/oauth/scopes.py index 93922c449c..550f3fe4b9 100644 --- a/rero_ils/oauth/scopes.py +++ b/rero_ils/oauth/scopes.py @@ -1,7 +1,7 @@ # -*- coding: utf-8 -*- # # RERO ILS -# Copyright (C) 2021 RERO +# Copyright (C) 2024 RERO # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by @@ -21,7 +21,13 @@ fullname = Scope("fullname", help_text="Full name", group="User") birthdate = Scope("birthdate", help_text="Birthdate", group="User") -institution = Scope("institution", help_text="Institution", group="User") -expiration_date = Scope("expiration_date", help_text="Expiration date", group="User") -patron_type = Scope("patron_type", help_text="Patron type", group="User") -patron_types = Scope("patron_types", help_text="Patron types", group="User") +patrons = Scope("patrons", help_text="Patrons", group="User") +expiration_date = Scope( + "expiration_date", help_text="Expiration date (deprecated)", group="User" +) +barcode = Scope("barcode", help_text="Barcode (deprecated)", group="User") +institution = Scope("institution", help_text="Institution (deprecated)", group="User") +patron_type = Scope("patron_type", help_text="Patron type (deprecated)", group="User") +patron_types = Scope( + "patron_types", help_text="Patron types (deprecated)", group="User" +) diff --git a/setup.py b/setup.py index 0137a76b43..623cc3330b 100644 --- a/setup.py +++ b/setup.py @@ -370,10 +370,12 @@ def run(self): 'invenio_oauth2server.scopes': [ 'fullname = rero_ils.oauth.scopes:fullname', 'birthdate = rero_ils.oauth.scopes:birthdate', - 'institution = rero_ils.oauth.scopes:institution', + 'patrons = rero_ils.oauth.scopes:patrons', + # deprecated scopes 'expiration_date = rero_ils.oauth.scopes:expiration_date', + 'institution = rero_ils.oauth.scopes:institution', 'patron_type = rero_ils.oauth.scopes:patron_type', - 'patron_types = rero_ils.oauth.scopes:patron_types' + 'patron_types = rero_ils.oauth.scopes:patron_types', ] }, classifiers=[ diff --git a/tests/api/patrons/test_patrons_rest.py b/tests/api/patrons/test_patrons_rest.py index 855e9de4f5..00a6369ca6 100644 --- a/tests/api/patrons/test_patrons_rest.py +++ b/tests/api/patrons/test_patrons_rest.py @@ -1,7 +1,7 @@ # -*- coding: utf-8 -*- # # RERO ILS -# Copyright (C) 2019 RERO +# Copyright (C) 2024 RERO # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by @@ -559,9 +559,19 @@ def test_patron_info(app, client, patron_martigny, librarian_martigny): "expiration_date": patron_martigny["patron"]["expiration_date"] + "T00:00:00", "institution": "org1", + "patron_pid": patron_martigny.pid, "patron_type": "patron-code", } ], + "patrons": { + "org1": { + "expiration_date": patron_martigny["patron"]["expiration_date"] + + "T00:00:00", + "institution": "org1", + "patron_pid": patron_martigny.pid, + "patron_type": "patron-code", + } + }, } # librarian information with all scopes