Puoi passare lo stato tramite un URL di continuazione quando invii azioni email per il ripristino della password o la verifica dell'indirizzo email di un utente. In questo modo, l'utente può tornare all'app al termine dell'azione. Inoltre, puoi specificare se gestire il link all'azione email direttamente da un'applicazione mobile quando è installata anziché da una pagina web.
Questo può essere estremamente utile nei seguenti scenari comuni:
Un utente che al momento non ha eseguito l'accesso potrebbe provare ad accedere a contenuti che richiedono l'accesso. Tuttavia, l'utente potrebbe aver dimenticato la password e quindi attivare il flusso di reimpostazione della password. Al termine del flusso, l'utente si aspetta di tornare alla sezione dell'app a cui stava tentando di accedere.
Un'applicazione può offrire l'accesso solo agli account verificati. Ad esempio, per iscriversi a una newsletter l'utente potrebbe dover verificare il proprio indirizzo email. L'utente deve completare il flusso di verifica email e poi tornare all'app per completare l'abbonamento.
In altri casi, l'utente potrebbe aver avviato il flusso dal proprio dispositivo mobile e dopo la verifica si aspetta di tornare all'app mobile anziché al browser.
La possibilità di passare lo stato tramite un URL di continuazione è una funzionalità potente fornita da Firebase Auth che può migliorare notevolmente l'esperienza utente.
Trasmissione dell'URL di stato/continuazione nelle azioni email
Per trasmettere in sicurezza un URL di continuazione, il dominio dell'URL dovrà essere inserito nella whitelist nella console Firebase. Per farlo, vai alla sezione Autenticazione e aggiungi il dominio all'elenco di domini autorizzati nella scheda Metodo di accesso, se non è già presente.
È necessario fornire un'istanza ActionCodeSettings quando si invia un'email di reimpostazione della password o un'email di verifica. Può essere creato con la classe associata ActionCodeSettings.Builder che contiene i seguenti metodi:
Metodo | Descrizione |
---|---|
setUrl(String url) |
Imposta il link (URL stato/continua) che ha significati diversi in contesti diversi:
|
setIOSBundleId(String iOSBundleId) |
Imposta l'ID bundle iOS. Verrà tentato di aprire il link in un'app per iOS, se è installata. L'app per iOS deve essere registrata nella console. |
setAndroidPackageName(String androidPackageName, boolean installIfNotAvailable, String minimumVersion) |
Imposta il nome del pacchetto Android. Verrà tentato di aprire il link in un'app Android se è installata. Se installIfNotAvailable è impostato su true , specifica se installare l'app per Android se il dispositivo la supporta e se non è già installata. Se è specificata la versione minima e è installata una versione precedente dell'app, l'utente viene indirizzato al Play Store per eseguire l'upgrade dell'app. L'app per Android deve essere registrata in Console. |
setHandleCodeInApp(boolean status) |
Indica se il link all'azione email deve essere aperto prima in un'app mobile o in un link web. Il valore predefinito è false. Se impostato su true, il link al codice di azione verrà inviato come link universale o link app per Android e verrà aperto dall'app, se installata. Nel caso in cui il valore sia falso, il codice verrà inviato prima al widget web e poi, al termine, reindirizzerà all'app se installata. |
setDynamicLinkDomain(String dynamicLinkDomain) |
Imposta il dominio (o sottodominio) del link dinamico da utilizzare per il link corrente se deve essere aperto utilizzando Firebase Dynamic Links. Poiché è possibile configurare più domini di link dinamici per progetto, questo campo consente di sceglierne uno esplicitamente. Se non viene specificato alcun dominio, per impostazione predefinita viene utilizzato il primo. |
L'esempio seguente illustra come inviare un link di verifica email che si aprirà inizialmente in un'app mobile come link dinamico Firebase (app per iOS com.example.ios
o Android com.example.android
). Il link diretti conterrà il payload dell'URL di continuazionehttps://www.example.com/?email=user@example.com
.
Kotlin
val auth = Firebase.auth val user = auth.currentUser!! val url = "http://www.example.com/verify?uid=" + user.uid val actionCodeSettings = ActionCodeSettings.newBuilder() .setUrl(url) .setIOSBundleId("com.example.ios") // The default for this is populated with the current android package name. .setAndroidPackageName("com.example.android", false, null) .build() user.sendEmailVerification(actionCodeSettings) .addOnCompleteListener { task -> if (task.isSuccessful) { Log.d(TAG, "Email sent.") } }
Java
FirebaseAuth auth = FirebaseAuth.getInstance(); FirebaseUser user = auth.getCurrentUser(); String url = "http://www.example.com/verify?uid=" + user.getUid(); ActionCodeSettings actionCodeSettings = ActionCodeSettings.newBuilder() .setUrl(url) .setIOSBundleId("com.example.ios") // The default for this is populated with the current android package name. .setAndroidPackageName("com.example.android", false, null) .build(); user.sendEmailVerification(actionCodeSettings) .addOnCompleteListener(new OnCompleteListener<Void>() { @Override public void onComplete(@NonNull Task<Void> task) { if (task.isSuccessful()) { Log.d(TAG, "Email sent."); } } });
Configurazione di Firebase Dynamic Links
Firebase Auth utilizza Firebase Dynamic Links quando invia un link che deve essere aperto in un'applicazione mobile. Per utilizzare questa funzionalità, i link dinamici devono essere configurati nella console di Firebase.
Attiva Firebase Dynamic Links:
- Nella console Firebase, apri la sezione Dynamic Links.
-
Se non hai ancora accettato i termini di Dynamic Links e creato un dominio Dynamic Links, fallo ora.
Se hai già creato un dominio Dynamic Links, prendine nota. Un dominio Dynamic Links è simile al seguente esempio:
example.page.link
Questo valore ti servirà quando configuri la tua app per Apple o Android in modo da intercettare il link in arrivo.
Configurazione delle applicazioni Android:
- Se prevedi di gestire questi link dalla tua applicazione per Android, il nome del pacchetto Android deve essere specificato nelle impostazioni del progetto della Console Firebase. Inoltre, devono essere forniti gli hash SHA-1 e SHA-256 del certificato dell'applicazione.
- Dovrai anche configurare il filtro per intent per il link diretto nel file AndroidManifest.xml.
- Per saperne di più, consulta Istruzioni per la ricezione dei link dinamici Android.
Configurazione delle applicazioni per iOS:
- Se prevedi di gestire questi link dalla tua applicazione per iOS, l'ID pacchetto iOS deve essere specificato nelle impostazioni del progetto della Console Firebase. Inoltre, è necessario specificare anche l'ID App Store e l'ID team sviluppatore Apple.
- Dovrai anche configurare il dominio del link universale FDL come Domini associati nelle funzionalità dell'applicazione.
- Se prevedi di distribuire la tua applicazione per le versioni di iOS 8 e precedenti, dovrai impostare l'ID pacchetto iOS come schema personalizzato per gli URL incoming.
- Per saperne di più, consulta Istruzioni per la ricezione dei link dinamici per iOS.
Gestione delle azioni email in un'applicazione web
Puoi specificare se vuoi gestire prima il link al codice di azione da un'applicazione web e poi reindirizzare a un'altra pagina web o applicazione mobile al termine dell'operazione, a condizione che l'applicazione mobile sia disponibile.
A questo scopo, chiama setHandleCodeInApp(false)
nell'oggetto
ActionCodeSettings.Builder. Sebbene non siano obbligatori, l'ID pacchetto iOS o il nome del pacchetto Android consentiranno all'utente di reindirizzarsi all'app specificata al termine del codice di azione email.
L'URL web utilizzato qui è quello configurato nella sezione dei modelli di azioni email. Per tutti i progetti viene eseguito il provisioning di un valore predefinito. Per saperne di più su come personalizzare il gestore delle azioni email, consulta la sezione sulla personalizzazione dei gestori email.
In questo caso, il link all'interno del parametro di query continueUrl
sarà un link FDL il cui payload è il URL
specificato nell'oggetto ActionCodeSettings
. Sebbene tu possa intercettare e gestire il link in arrivo dalla tua app
senza alcuna dipendenza aggiuntiva, ti consigliamo di utilizzare la libreria client FDL per
analizzare il link diretto per te.
Quando gestisci azioni email come la verifica email, il codice di azione del parametro di query oobCode
deve essere analizzato dal link diretto e poi applicato tramite applyActionCode
affinché la modifica venga applicata, ovvero l'email venga verificata.
Gestione delle azioni email in un'applicazione mobile
Puoi specificare se vuoi gestire prima il collegamento del codice di azione all'interno della tua
app mobile, a condizione che sia installata. Con le applicazioni per Android,
puoi anche specificare tramite il valore booleano installIfNotAvailable
che l'app deve essere installata se il dispositivo la supporta e non è già installata.
Se il link viene fatto clic da un dispositivo che non supporta l'applicazione mobile, viene aperto da una pagina web.
A questo scopo, chiama setHandleCodeInApp(true)
nell'oggetto
ActionCodeSettings.Builder. Dovrà essere specificato anche il nome del pacchetto Android o l'ID bundle iOS dell'applicazione mobile.
L'URL web di riserva utilizzato qui, quando non è disponibile un'app mobile, è quello configurato nella sezione dei modelli di azioni email. Per impostazione predefinita, viene eseguito il provisioning per tutti i progetti. Per saperne di più su come personalizzare il gestore delle azioni email, consulta la sezione relativa alla personalizzazione dei gestori email.
In questo caso, il link all'app mobile inviato all'utente sarà un link FDL il cui payload è l'URL del codice di azione, configurato nella Console, con i parametri di query oobCode
, mode
, apiKey
e continueUrl
. Quest'ultimo sarà il URL
originale specificato nell'oggetto ActionCodeSettings
. Sebbene tu possa intercettare e gestire il link in arrivo dalla tua app senza alcuna dipendenza aggiuntiva, ti consigliamo di utilizzare la libreria client FDL per analizzare il link diretto al posto tuo. Il codice di azione può essere applicato direttamente da un'applicazione mobile in modo simile a come viene gestito dal flusso web descritto nella sezione sulla personalizzazione dei gestori email.
Quando gestisci azioni email come la verifica email, il codice di azione del parametro di query oobCode
deve essere analizzato dal link diretto e poi applicato tramite applyActionCode
affinché la modifica venga applicata, ovvero l'email venga verificata.