Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
spid-smart-button
Advanced tools
⚠️ WORK IN PROGRESS ⚠️
Lo Smart Button è un'evoluzione del bottone "Entra con SPID" che tutti i fornitori di servizi devono incorporare nei propri siti web per consentire all'utente la scelta del proprio Identity Provider e quindi l'autenticazione.
Ad oggi, ciascun fornitore di servizi adatta al proprio sito il bottone fornito nel repository italia/spid-sp-access-button e lo incorpora staticamente. Essendo in corso lo sviluppo dello Smart Button, i fornitori di servizi devono ancora seguire tale modalità.
Con l'utilizzo di spid-smart-button si intende:
Questo repository è mantenuto da AgID - Agenzia per l'Italia Digitale con l'ausilio del Team per la Trasformazione Digitale.
Nel momento in cui lo spid-smart-button sara' disponibile tramite CDN, sarà sufficiente importare lo script presente su CDN nella pagina web in cui si intende posizionare il bottone:
<script type="text/javascript" src="https://XXXXXXXXXXXX/spid-button.min.js"></script>
Nel punto in cui si intende posizionare il bottone si dovrà inserire un placeholder <div>
come da esempio:
<div id="spid-button">
<noscript>
Il login tramite SPID richiede che JavaScript sia abilitato nel browser.
</noscript>
</div>
Si dovrà poi inizializzare il bottone con una chiamata JavaScript:
SPID.init({
url: '/Login?idp={{idp}}',
supported: [
'https://idp1.it',
'https://idp2.it'
]
});
SPID.init({ ... })
La funzione SPID.init()
inizializza il bottone secondo i parametri forniti, che possono essere i seguenti:
Parametro | Descrizione | Esempio |
---|---|---|
lang | it /en /de (default: it ) | "it" |
method | GET /POST (default: GET ) | "GET" |
url | (obbligatorio) URL da chiamare (anche relativo). Il placeholder {{idp}} sarà sostituito con l’entityID dell’IdP selezionato (o con il valore custom specificato nel parametro mapping ). Se questo parametro è assente, sarà scritto un errore in console.error() | "/spid/login/idp={{idp}}" |
fieldName | Se method=POST, contiene il nome del campo hidden in cui passiamo l’IdP selezionato (default: idp ) | "idp" |
extraFields | Se method=POST, contiene eventuali valori aggiuntivi da passare in campi hidden | { foo: "bar" } |
selector | Selettore CSS da usare per individuare l’elemento in cui iniettare lo Smart Button (default: #spid-button) | "#spid-button" |
mapping | Dizionario di mappatura tra entityID e valori custom, da usare quando un SP identifica gli IdP con chiavi diverse dall’entityID | { "https://www.poste.it/spid": "poste" } |
supported | (obbligatorio) Array di entityID relativi agli IdP di cui il SP ha i metadati. Gli IdP non presenti saranno mostrati in grigio all’utente. | [ "https://www.poste.it/spid" ] |
extraProviders | Array di oggetti contenenti le configurazioni di ulteriori Identity Provider (di test) non ufficiali che si vogliano abilitare. I provider qui elencati sono automaticamente aggiunti all’elenco supported sopra descritto. Per motivi di sicurezza, qualora si configurino dei provider extra, i provider ufficiali verranno disabilitati. | [{ "entityID": "https://testidp.mycorp.com/", "entityName": "Test IdP" }] |
protocol | SAML /OIDC . Protocollo usato dal SP per interagire con gli IdP. Dal momento che alcuni IdP potrebbero non supportare OIDC (ad oggi nessun IdP lo supporta), questo parametro serve per mostrare in grigio gli IdP non supportati (default: "SAML" ) | "SAML" |
size | small /medium /large . Dimensione di visualizzazione (default: medium ) | "medium" |
colorScheme | positive /negative . Schema di colori da adottare in base allo sfondo (default: positive ) | "positive" |
fluid | true /false . Adatta la larghezza del bottone all’elemento che lo contiene (ma max 400px). (default: false ) | true |
cornerStyle | rounded /sharp . Stile degli angoli del bottone. Se impostato a sharp , il bottone non avrà margine. (default: rounded ) | "rounded" |
La funzione SPID.init()
restituisce un oggetto che può essere ignorato oppure assegnato ad una variabile qualora si intendano chiamare gli altri metodi documentati di seguito.
Esempio completo:
var spid = SPID.init({
lang: 'en', // opzionale
selector: '#my-spid-button', // opzionale
method: 'POST', // opzionale
url: '/Login', // obbligatorio
fieldName: 'idp', // opzionale
extraFields: { // opzionale
foo: 'bar',
baz: 'baz'
},
mapping: { // opzionale
'https://loginspid.aruba.it': 4,
'https://posteid.poste.it': 5,
'https://idp.namirialtsp.com/idp': 7,
},
supported: [ // obbligatorio
'https://identity.sieltecloud.it'
],
extraProviders: [ // opzionale
{
"protocols": ["SAML"],
"entityName": "Ciccio ID",
"logo": "spid-idp-aruba.svg",
"entityID": "https://loginciccio.it",
"active": true
},
{
"protocols": ["SAML"],
"entityName": "Pippocert ",
"logo": "spid-idp-infocertid.svg",
"entityID": "https://identity.pippocert.it",
"active": true
}
],
protocol: "SAML", // opzionale
size: "small" // opzionale
});
changeLanguage(lang)
Questo metodo consente di cambiare la lingua dello Smart Button a run-time.
La stringa lang
deve essere costituita da due caratteri eg it
.
Le lingue supportate sono italiano it
, inglese en
e tedesco de
spid.changeLanguage('en');
I dati degli IdP sono riportati staticamente nel codice sorgente dello Smart Button, e pertanto non è necessario aggiornarli manualmente. Eventuali variazioni al nome o al logo, così come eventuali rimozioni di Identity Provider, verranno automaticamente recepite dallo Smart Button senza bisogno di alcun intervento.
In caso di aggiunta di nuovi Identity Provider, o in caso di variazione di EntityID, il Service Provider dovrà aggiornare il proprio backend con i nuovi metadati e poi aggiungere l'entityID all'array supported
dello Smart Button che quindi renderà cliccabile il nuovo Identity Provider. Si consiglia, se possibile in base al proprio stack applicativo, di generare la lista supported
automaticamente a partire dai metadati caricati nell'applicazione.
Il parametro extraProviders
permette di configuare ulteriori Identity Provider rispetto a quelli ufficiali. Questa cosa può essere utile per usare un Identity Provider di test. I parametri per la configurazione di ciascun Identity Provider aggiuntivo sono i seguenti:
Parametro | Descrizione |
---|---|
entityID | (obbligatorio) Identificativo dell'Identity Provider |
entityName | (obbligatorio) Nome pubblico dell'Identity Provider da mostrare nella lista |
logo | URL completo del file PNG raffigurante il logo |
protocols | Array che può contenere i valori SAML e/o OIDC a seconda dei protocolli supportati dall'IdP (default: ["SAML"] ) |
active | true /false . Può essere usato per mostrare l'IdP come non attivo (default: true ) |
Per motivi di sicurezza, qualora si configurino dei provider extra i provider ufficiali verranno automaticamente disabilitati.
FAQs
Pulsante SSO per SPID
The npm package spid-smart-button receives a total of 33 weekly downloads. As such, spid-smart-button popularity was classified as not popular.
We found that spid-smart-button demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.