From 05c3e05e75f6f070e2799b7611495dd99eddd7ec Mon Sep 17 00:00:00 2001 From: Mauro Amico Date: Mon, 18 Dec 2023 15:34:46 +0100 Subject: [PATCH 1/3] booking type voc --- .isort.cfg | 2 + src/design/plone/ioprenoto/configure.zcml | 1 + .../restapi/services/bookable_list/get.py | 11 +++-- src/design/plone/ioprenoto/utilities.py | 11 +++++ .../plone/ioprenoto/vocabularies/__init__py | 0 .../ioprenoto/vocabularies/configure.zcml | 11 +++++ .../ioprenoto/vocabularies/tipologies.py | 45 +++++++++++++++++++ 7 files changed, 77 insertions(+), 4 deletions(-) create mode 100644 .isort.cfg create mode 100644 src/design/plone/ioprenoto/utilities.py create mode 100644 src/design/plone/ioprenoto/vocabularies/__init__py create mode 100644 src/design/plone/ioprenoto/vocabularies/configure.zcml create mode 100644 src/design/plone/ioprenoto/vocabularies/tipologies.py diff --git a/.isort.cfg b/.isort.cfg new file mode 100644 index 0000000..40c8f14 --- /dev/null +++ b/.isort.cfg @@ -0,0 +1,2 @@ +[settings] +profile=plone diff --git a/src/design/plone/ioprenoto/configure.zcml b/src/design/plone/ioprenoto/configure.zcml index 0c87f3d..98267e9 100644 --- a/src/design/plone/ioprenoto/configure.zcml +++ b/src/design/plone/ioprenoto/configure.zcml @@ -20,6 +20,7 @@ + diff --git a/src/design/plone/ioprenoto/restapi/services/bookable_list/get.py b/src/design/plone/ioprenoto/restapi/services/bookable_list/get.py index d2384c4..5558be6 100644 --- a/src/design/plone/ioprenoto/restapi/services/bookable_list/get.py +++ b/src/design/plone/ioprenoto/restapi/services/bookable_list/get.py @@ -1,15 +1,16 @@ # -*- coding: utf-8 -*- from logging import getLogger -from urllib.parse import urlencode - from plone import api from plone.restapi.interfaces import ISerializeToJsonSummary from plone.restapi.serializer.converters import json_compatible from plone.restapi.services import Service +from urllib.parse import urlencode from zc.relation.interfaces import ICatalog -from zope.component import getMultiAdapter, getUtility +from zope.component import getMultiAdapter +from zope.component import getUtility from zope.intid.interfaces import IIntIds + logger = getLogger(__name__) @@ -28,7 +29,9 @@ def reply(self): portal_url = api.portal.get().absolute_url() query = {"portal_type": "Servizio", "sort_on": "sortable_title"} for brain_service in api.content.find(**query): - # service = brain.getObject() + # XXX: get_uo_from_service_uid ha l'object, ma anzichè usarlo, si tira fuori lo UID + # e poi si cerca quell'UID nel catalog. Sicuarmente questo aiuta a escludere + # oggetti privati, ma sembra un passaggio inutilmente complicato (?) for brain_uo in api.content.find( UID=self.get_uo_from_service_uid(uid=brain_service.UID) ): diff --git a/src/design/plone/ioprenoto/utilities.py b/src/design/plone/ioprenoto/utilities.py new file mode 100644 index 0000000..16d3c0e --- /dev/null +++ b/src/design/plone/ioprenoto/utilities.py @@ -0,0 +1,11 @@ +# -*- coding: utf-8 -*- + + +def get_uo_from_service(service): + """Dato lo UID di un servizio, restituisce le UO a cui è collegato + come canale fisico o unità organizzativa responsabile""" + canale_fisico = getattr(service, "canale_fisico", []) + if canale_fisico: + return [x.to_object for x in canale_fisico if x.to_object] + ufficio_responsabile = getattr(service, "ufficio_responsabile", []) + return [x.to_object for x in ufficio_responsabile if x.to_object] diff --git a/src/design/plone/ioprenoto/vocabularies/__init__py b/src/design/plone/ioprenoto/vocabularies/__init__py new file mode 100644 index 0000000..e69de29 diff --git a/src/design/plone/ioprenoto/vocabularies/configure.zcml b/src/design/plone/ioprenoto/vocabularies/configure.zcml new file mode 100644 index 0000000..c348d50 --- /dev/null +++ b/src/design/plone/ioprenoto/vocabularies/configure.zcml @@ -0,0 +1,11 @@ + + + + + diff --git a/src/design/plone/ioprenoto/vocabularies/tipologies.py b/src/design/plone/ioprenoto/vocabularies/tipologies.py new file mode 100644 index 0000000..75fe7fb --- /dev/null +++ b/src/design/plone/ioprenoto/vocabularies/tipologies.py @@ -0,0 +1,45 @@ +# -*- coding: utf-8 -*- +from design.plone.ioprenoto.utilities import get_uo_from_service +from plone import api +from redturtle.prenotazioni.vocabularies.tipologies import ( + PrenotazioneTypesVocabulary as Base, +) +from zc.relation.interfaces import ICatalog +from zope.component import getUtility +from zope.interface import implementer +from zope.intid.interfaces import IIntIds +from zope.schema.interfaces import IVocabularyFactory +from zope.schema.vocabulary import SimpleVocabulary + + +@implementer(IVocabularyFactory) +class PrenotazioneTypesVocabulary(Base): + def __call__(self, context): + """ + Return all the tipologies defined in the PrenotazioniFolder related to a Service + """ + terms = [] + intids = getUtility(IIntIds) + catalog = getUtility(ICatalog) + for uo in get_uo_from_service(context) or []: + relations = catalog.findRelations( + { + "to_id": intids.getId(uo), + "from_attribute": "uffici_correlati", + } + ) + for rel in relations: + prenotazioni_folder = rel.from_object + if prenotazioni_folder and api.user.has_permission( + "View", obj=prenotazioni_folder + ): + terms.extend( + [ + self.booking_type2term(booking_type) + for booking_type in prenotazioni_folder.get_booking_types() + ] + ) + return SimpleVocabulary(terms) + + +PrenotazioneTypesVocabularyFactory = PrenotazioneTypesVocabulary() From 08fcfd6856e756210cd03095a8406e5e02b6a4f1 Mon Sep 17 00:00:00 2001 From: Mauro Amico Date: Mon, 18 Dec 2023 15:35:28 +0100 Subject: [PATCH 2/3] booking type voc changes --- CHANGES.rst | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGES.rst b/CHANGES.rst index 985a792..742b1cc 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -4,7 +4,8 @@ Changelog 1.2.1 (unreleased) ------------------ -- Nothing changed yet. +- booking_type vocabulary for Service + [mamico] 1.2.0 (2023-11-20) From 5d223ac6107187abe6dd726c0c49cb336e2f571e Mon Sep 17 00:00:00 2001 From: Mauro Amico Date: Mon, 18 Dec 2023 16:25:28 +0100 Subject: [PATCH 3/3] test --- src/design/plone/ioprenoto/tests/test_stringinterp.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/design/plone/ioprenoto/tests/test_stringinterp.py b/src/design/plone/ioprenoto/tests/test_stringinterp.py index 480927d..3bf6e8b 100644 --- a/src/design/plone/ioprenoto/tests/test_stringinterp.py +++ b/src/design/plone/ioprenoto/tests/test_stringinterp.py @@ -79,7 +79,7 @@ def setUp(self): ) booker = IBooker(self.folder_prenotazioni) - self.prenotazione = booker.create( + self.prenotazione = booker.book( { "booking_date": datetime.now(), "booking_type": "Type A",