Pacchetto di policy per un sito Plone AGID.
Installando questo pacchetto, si inizializza un sito Plone Agid.
All'installazione di questo prodotto, oltre che l'installazione di tutte le dipendenze, viene anche eseguita la creazione in automatico di una serie di cartelle utili per la gestione dei contenuti richiesta da Agid.
- Plone 6.0, design.plone.policy 5.*, design.plone.contenttypes 6.*
- Plone 5.2, design.plone.policy 4.*, design.plone.contenttypes 5.*
Installando questo prodotto, si disabilitano alcuni tipi ricercabili (così non vengon mostrati in @search-filters).
Viene installato un plugin aggiuntivo (rer.customersatisfaction) per poter esprimere voti sulle pagine del portale Agid.
Per poter usare questo prodotto, va salvata la chiave privata per recaptcha v3 in una variabile d'ambiente (RECAPTCHA_PRIVATE_KEY). La chiave pubblica viene usata dal client Volto.
Questo endpoint serve al frontend di Volto, per popolare il menu e i filtri per la ricerca:
> curl -i http://localhost:8080/Plone/@search-filters -H 'Accept: application/json'
Ritorna un json con le sezioni principali, la lista degli argomenti e i tipi di contenuto ricercabili (tradotti):
{ "sections":{ "amministrazione":{ "@id": "", "path": "", "title": "", "items": [ { "@id": "", "path": "", "title": "", }, ... ] } "documenti-e-dati": {...} "novita": {...} "servizi": {...} }, "topics": [ { "@id": "", "path": "", "title": "", }, ... ], "portal_types": [ ... { "label": "Document", "id": "Page" } ... ] }
Questo endpoint serve al frontend di Volto, per popolare il menu e i filtri per la ricerca dei bandi:
> curl -i http://localhost:8080/Plone/@search-bandi-filters -H 'Accept: application/json'
Ritorna un json con la lista degli uffici (UO) referenziati da almeno un Bando e la lista delle parole chiave utilizzate dai Bandi:
{ "offices": [ { "key": "87bb96d90b6e42ee9db01ab2ab7543d5", "label": "uo 1" } ], "subjects": [ "bar", "foo" ] }
Questo endpoint va chiamato su un contesto con i blocchi abilitati e serve al frontend di Volto, per inviare via mail il form compilato:
> curl -i -X POST http://localhost:8080/Plone/document/@send-action-form -H 'Accept: application/json' -H 'Content-Type: application/json' --data-raw '{"from": "john@doe.com", "message": "Just want to say hi.", "block_id": "123456"}'
All'endpoint vanno passati i seguenti parametri:
- block_id [obbligatorio]: l'id del blocco di tipo "form" che è stato compilato
- message [obbligatorio]: il messaggio da inviare
- from: l'indirizzo email del mittente. Se non presente, viene utilizzato il campo default_from del blocco
- subject: l'oggetto della mail. Se non presente, viene utilizzato il campo default_subject del blocco
- attachments: eventuali allegati riferiti a campi "file upload" inseriti nel form.
La struttura degli attachments è la seguente:
{ "block_id": "foo", ... "attachments": { "field_id": { "data": "the content of the file", "content-type": "application/pdf", "filename": "example.pdf" } } }
Se l'invio va a buon fine, viene tornata una risposta con 204.
La vista "crea_area_trasparenza" crea la struttura per l'area "Amministrazione Trasparente". Si può lanciare dalla root del sito.
redturtle.volto permette di esporre dei vocabolari anche agli utenti anonimi.
In questo prodotto aggiungiamo quelli che servono per io-comune.
redturtle.volto personalizza questo ruolo per permettere ad utenti redazioniali di accedere a contenuti con data di pubblicazione nel futuro o scaduti (di base quel permesso ce l'hanno solo gli admin).
Per installare design.plone.policy bisogna per prima cosa aggiungerlo al buildout:
[buildout] ... eggs = design.plone.policy
e poi lanciare il buildout con bin/buildout
.
Successivamente va installato dal pannello di controllo di Plone.
Se le richieste arrivano con un header X-ForceAuth Plone forza l'autenticazione per quelle richieste, il meccanismo è utile ad esempiop se si vuole fare accedere alla ZMI o alle interfacce Plone legacy senza però esporle pubblicamente.
Si può usare questo prodotto anche da solo, per fare delle demo veloci di Volto, senza dover per forza creare un nuovo progetto/buildout.
E' presente un file buildout.cfg anche in questo prodotto, quindi basta lanciare il buildout ed avviare l'istanza.
Il sito Plone sarà esposto sulla porta standard (8080) ed è già configurato per accettare chiamate dalla porta 3000 (quindi Volto dovrà girare su quella porta, che poi è il suo default).
- Issue Tracker: https://github.com/redturtle/design.plone.policy/issues
- Codice sorgente: https://github.com/redturtle/design.plone.policy
Questo progetto è rilasciato con licenza GPLv2.
Questo progetto è stato sviluppato da RedTurtle Technology.