Introduzione all'API Admin Auth

Firebase Admin SDK ti consente di integrare i tuoi server con l'autenticazione Firebase. Puoi utilizzare Firebase Admin SDK per gestire i tuoi utenti o per gestire i token di autenticazione. Ci sono una serie di motivi per cui vorresti farlo:

Gestione utenti

Non è sempre conveniente dover visitare la console Firebase per gestire i tuoi utenti Firebase. L'API di gestione degli utenti amministratore fornisce l'accesso a livello di codice a quegli stessi utenti. Ti consente anche di fare cose che la console Firebase non può, come recuperare i dati completi di un utente e modificare la password, l'indirizzo e-mail o il numero di telefono di un utente.

Autenticazione personalizzata

Puoi integrare un sistema utente esterno con Firebase. Ad esempio, potresti già avere un database utente preesistente o potresti voler integrarti con un provider di identità di terze parti che l'autenticazione Firebase non supporta in modo nativo.

A tale scopo, puoi creare token personalizzati con attestazioni arbitrarie che identificano l'utente. Questi token personalizzati possono quindi essere utilizzati per accedere al servizio di autenticazione Firebase su un'applicazione client e assumere l'identità descritta dalle attestazioni del token. Questa identità verrà quindi utilizzata per l'accesso ad altri servizi Firebase, come Cloud Storage.

Verifica dell'identità

L'autenticazione Firebase viene utilizzata principalmente per identificare gli utenti della tua app al fine di limitare l'accesso ad altri servizi, come Cloud Storage. Puoi anche utilizzare il servizio per identificare questi utenti sul tuo server. Ciò ti consente di eseguire in modo sicuro la logica lato server per conto degli utenti che hanno eseguito l'accesso con l'autenticazione Firebase.

Per fare ciò, puoi recuperare un token ID da un'applicazione client che ha eseguito l'accesso con l'autenticazione Firebase e includere il token in una richiesta al tuo server. Il tuo server verifica quindi il token ID ed estrae le attestazioni che identificano l'utente (incluso il suo uid , il provider di identità con cui ha effettuato l'accesso e così via). Queste informazioni sull'identità possono quindi essere utilizzate dal server per eseguire azioni per conto dell'utente.

Firebase Admin SDK fornisce metodi per eseguire le attività di autenticazione di cui sopra, consentendoti di gestire i tuoi utenti, generare token personalizzati e verificare i token ID.

Reclami utente personalizzati

In alcuni casi, potresti voler implementare il controllo dell'accesso a grana fine per gli utenti già registrati con uno dei provider di autenticazione Firebase supportati come Email/Password, Google, Facebook, telefono, ecc. Una combinazione di attestazioni utente personalizzate e sicurezza dell'applicazione regole fornisce questa capacità. Ad esempio, un utente che ha eseguito l'accesso con il provider di posta elettronica e password di autenticazione Firebase può avere il controllo dell'accesso definito utilizzando attestazioni personalizzate.

Gestione utenti

Firebase Admin SDK fornisce un'API per la gestione degli utenti Firebase con privilegi elevati. L'API di gestione dell'utente amministratore offre la possibilità di recuperare, creare, aggiornare ed eliminare gli utenti in modo programmatico senza richiedere le credenziali esistenti dell'utente e senza preoccuparsi della limitazione della velocità lato client.

Gestisci gli utenti

Creazione di token personalizzati

L'uso principale per la creazione di token personalizzati consiste nel consentire agli utenti di autenticarsi in base a un meccanismo di autenticazione esterno o legacy. Potrebbe essere uno che controlli tu, come il tuo server LDAP, o un provider OAuth di terze parti che Firebase non supporta in modo nativo, come Instagram o LinkedIn.

Firebase Admin SDK ha un metodo integrato per la creazione di token personalizzati. Puoi anche creare a livello di codice token personalizzati in qualsiasi lingua utilizzando librerie JWT di terze parti.

Il tuo server dovrebbe creare un token personalizzato con un identificatore univoco ( uid ) e passare quel token a un'app client, che lo utilizzerà per accedere a Firebase. Vedere Creare token personalizzati per esempi di codice e altri dettagli sul processo di creazione di token personalizzati.

Crea token personalizzati

Verifica del token ID

Se l'app client Firebase comunica con il server back-end, potrebbe essere necessario identificare l'utente attualmente connesso al server in modo da poter eseguire la logica lato server per suo conto. Puoi farlo in modo sicuro utilizzando i token ID, che vengono creati da Firebase quando un utente accede a un'app Firebase. I token ID sono conformi alle specifiche OpenID Connect e contengono dati per identificare un utente, nonché alcune altre informazioni relative al profilo e all'autenticazione. Puoi inviare, verificare e ispezionare questi token dai tuoi backend. Ciò ti consente di identificare in modo sicuro l'utente attualmente connesso e di autorizzarlo nelle tue risorse di back-end.

Firebase Admin SDK ha un metodo integrato per la verifica dei token ID. Puoi anche verificare a livello di codice i token ID in qualsiasi lingua utilizzando librerie JWT di terze parti. Consulta Verifica dei token ID per ulteriori dettagli ed esempi di codice sul processo di verifica del token ID.

Verifica i token ID

Affermazioni utente personalizzate

Firebase Admin SDK ti consente di impostare attributi personalizzati sugli account utente. Con le attestazioni utente personalizzate, puoi fornire agli utenti diversi livelli di accesso (ruoli), che vengono poi applicati nelle regole di sicurezza di un'applicazione.

Dopo che le attestazioni personalizzate sono state modificate su un utente tramite Firebase Admin SDK, vengono propagate agli utenti autenticati sul lato client tramite i loro token ID. Il token ID è un meccanismo affidabile per la consegna di queste attestazioni personalizzate e tutti gli accessi autenticati devono convalidare il token ID prima di elaborare la richiesta associata.

Controllo dell'accesso con attestazioni personalizzate