Buongiorno,
devo integrare Keycloak con CIE utilizzando OIDC.
L’utilizzo di OIDC invece di SAML2 mi eviterebbe di usare plugin/proxy e far quindi dialogare i due sistemi in modo nativo.
Purtroppo oltre alla documentazione tecnica SPID/CIE OpenID Connect Regole tecniche | SPID/CIE OpenID Connect non si riescono a trovare altre indicazioni. Sembra che a nessuno freghi nulla dell’integrazione con CIE.
In più mi servirebbe un ambiente “demo” OIDC dove testare l’integrazione simile a quello predisposto per SPID/SAML2. Anche qui non ho trovato nulla.
Sapete darmi indicazioni su dove recuperare le informazioni mancanti?
Grazie
Grazie mille,
ma c’è da qualche parte una roadmap con le tempistiche e lo stato del progetto?
Perché per chi non è coinvolto in prima persona nel progetto risulta alquanto difficoltoso reperire informazioni in modo preciso. Sto raccimolando pezzi di informazione tra sito ufficiale, github, forum… e si fa fatica a capire come sia la situazione reale.
Nel corso del tempo sono state fornite varie date di attivazione della Federazione OIDC, ma per un motivo o per l’altro (riscrittura delle regole tecniche, contrasti e avvicendamenti fra gli IdP SPID, etc.) non sono state rispettate.
Che io sappia, al momento non vi è una (ulteriore) data ufficiale di attivazione.
@AGS da quanto ho capito la federazione OIDC per CIE dovrebbe essere già stata attivata dal Poligrafico. Quello che non riesco a trovare invece sono le informazioni su come poter validare l’Entity Configuration ed utilizzare l’ambiente di test e poi quello di produzione (quali endpoint chiamare, dove si trovano i tool ufficiali di validazione…). E’ necessario avviare la procedura di onboarding per poter disporre di queste informazioni?
Confermo che l’ambiente di test viene attivato al termine del processo di onboarding.
Al momento della creazione della componente tecnica viene richiesto di selezionare un protocollo (OIDC), l’ambiente (pre-produzione), il client id e la chiave pubblica.
Il problema è che quando si preme il pulsante per continuare, fallisce la validazione con un errore piuttosto generico:
“LA VALIDAZIONE NON E’ ANDATA A BUON FINE PER I SEGUENTI MOTIVI:[SUB] ELEMENTO MANCANTE”
Eppure nel metadata l’elemento “sub” è presente (sempre che il messaggio intenda quello).
Inoltre sono riuscito a validare con successo questo stesso metadata tramite il validatore di test dello SPID (quello raggiungibile qui: SPID OIDC CHECK RP).
A qualcuno è capitato lo stesso problema?
Mi è venuto un altro dubbio però: qualunque valore inserisca nel campo “Chiave pubblica di federazione”, il portale di federazione CIE mi restituisce sempre lo stesso errore (quello di elemento “sub” mancante). Temo quindi che il problema sia a monte e cioè che per qualche motivo non riesca a decodificare il jwt ritornato a causa di una chiave errata. Nel campo “Chiave pubblica di federazione” ho inserito il valore riportato nel JWT in jwks–>keys–>[0]–>x5c
E’ corretto?
secondo me devi guardare il client_id che hai messo perché dovrebbe essere uguale al sub e per x5c nel esempio della documentazione non l’hanno nemmeno scritto
Buongiorno a tutti, siamo anche noi bloccati nello stesso punto.
Inizialmente ci veniva restituito l’errore generico “L’ENTITA’ NON RISPETTA I REQUISITI DI FEDERAZIONE” successivamente a seguito di ticket con il ministero ci viene indicato di verificare il sigillo di firma portandoci all’errore del sub.
Anche per noi il validatore e il tool in docker risulta validare con successo il metadata.
Dai nostri log risulta che il portale di cie faccia solo la chiamata alla .well-known/openid-federation e al momento non testi nessun’altra endpoint.
Qualcuno è riuscito a risolvere?
Non riesco a trovare nessun provider già federato in OIDC in CIE per scaricarmi la sua EC e fare le verifiche con la nostra configurazione.
Si tratta del componente “spid-cie-oidc-php” disponibile su Developers Italia.
Per avere due kid differenti dovrei quindi utilizzare due chiavi differenti?
si certo che potresti creare due kid diversi con la stessa chiave per esempio $kid2 = hash(‘sha256’, strtoupper($organizationIdentifier) . ‘.’ . $serialNumber); io ho aggiunto upperCase. tu potresti giocare li
Ho modificato il kid (in effetti ci sono due kid differenti anche nell’esempio che c’è qui: SPID/CIE OpenID Connect Regole tecniche | Esempi), ma tentando di nuovo la creazione della componente tecnica sul portale CIE ho sempre lo stesso errore…
Buongiorno,
ho anche il lo stesso problema, continuo a ricevere l’errore “[sub] Elemento mancante”, siete riusciti a risolvere o capire da cosa potesse essere causato?