CieID-android-sdk è un SDK Android sviluppato in Kotlin che include le funzionalità di autenticazione di "Entra con CIE". Utilizzando questo kit, gli sviluppatori di applicazioni terze Android possono integrare l'autenticazione mediante la cartà d'identità elettronica (CIE 3.0).
CieID-android-sdk è compatibile dalla versione Android 6.0 (API level 23) o successive. Necessità inoltre di connessione ad internet e di smartphone con tecnologia NFC.
CieID-android-sdk necessita che il fornitore del servizio digitale sia un Service Provider federato e che integri la tecnologia abilitante al flusso di autenticazione "Entra con CIE". Maggiori informazioni qui.
Nel kit è presente un'applicazione di esempio, con un activity per ogni flusso, che mostra come integrare i 2 flussi facilmente. La gestione degli errori è demandata all'applicazione integrante.
Permette di completare il flusso di autenticazione mediante l'applicazione "CieID" presente sul Play Store Android.
Permette di completare il flusso di autenticazione internamente all'applicazione stessa integrando il modulo "CieIDSdk":
implementation project(path: ':cieidsdk')
E' possibile utilizzare la soluzione su due ambienti: uno di preproduzione, per gli sviluppi applicativi, e l'altro di produzione, per l'esercizio.
Entrambi i flussi vengono avviati tramite l'utilizzo di una Webview, é per questo necessario caricare la URL della pagina web del Service Provider che integra il pulsante "Entra con CIE" come mostrato nell'esempio:
//inserire url service provider
webView.loadUrl("URL del Service Provider")
E' necessario selezionare l'applicazione "CieID" a cui indirizzare le richieste di autenticazione. Ció puó essere fatto modificando i commenti dalle righe di interesse, come mostrato di seguito.
val appPackageName = "it.ipzs.cieid"
//COLLAUDO
//val appPackageName = "it.ipzs.cieid.collaudo"
Per integrare le funzionalità dell'SDK é necessario intercettare la URL contenente il valore "/OpenApp" ed avviare l'App CieID integrando il codice seguente:
val intent = Intent()
try {
//inserire package di collaudo
intent.setClassName(appPackageName, className)
//settare la url caricata dalla webview su /OpenApp
intent.data = Uri.parse(url)
intent.action = Intent.ACTION_VIEW
startActivityForResult(intent, 0)
} catch (a : ActivityNotFoundException) {
startActivity(
Intent(
Intent.ACTION_VIEW,
Uri.parse("https://play.google.com/store/apps/details?id=$appPackageName")
)
)
}
return true
Una volta avviata correttamente l'App CieID, avviene l'autenticazione tramite la CIE, e al termine viene restituita una nuova URL da ricaricare nella WebView precedente, come mostrato nell'esempio seguente:
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
val url = data?.getStringExtra(URL)
webView.loadUrl(url)
}
Nel build.gradle seleziona l'ambiente di tuo interesse utilizzando i commenti
//AMBIENTI:
//Ambiente di produzione
//buildConfigField "String", "BASE_URL_IDP", "\"https://idserver.servizicie.interno.gov.it/idp/\""
//Ambiente di collaudo
buildConfigField "String", "BASE_URL_IDP", "\"https://preproduzione.idserver.servizicie.interno.gov.it/idp/\""
Per integrare le funzionalità dell'SDK utilizza i seguenti metodi nell'activity di tuo interesse:
//Configurazione iniziale
CieIDSdk.start(activity, callback)
//Avvio utilizzo NFC
CieIDSdk.startNFCListening(activity)
//Abilitare o disabilitare i log, da disattivare in produzione
CieIDSdk.enableLog = true
//Bisogna settare la url caricata dalla pagina web dell' SP dalla webview su /OpenApp
CieIDSdk.setUrl(url.toString())
//inserire il pin della CIE
CieIDSdk.pin = input.text.toString()
//Avviare NFC
startNFC()
Implementa inoltre le interfacce di Callback implementando i seguenti metodi:
override fun onEvent(event: Event) {
//evento
}
override fun onError(e: Throwable) {
//caso di errore
}
override fun onSuccess(url: String) {
//caso di successo con url della pagina da caricare
}
Il codice sorgente è rilasciato sotto licenza BSD (codice SPDX: BSD-3-Clause).