Per le app di Google Chat create su endpoint HTTP, questa sezione spiega come verificare che le richieste al tuo endpoint provengano da Chat.
Per inviare gli eventi di interazione all'endpoint della tua app di Chat, Google effettua richieste al tuo servizio. Per verificare che la richiesta provenga da Google, Chat include un token di autenticazione nell'intestazione Authorization di ogni richiesta HTTPS al tuo endpoint. Ad esempio:
POST
Host: yourappurl.com
Authorization: Bearer AbCdEf123456
Content-Type: application/json
User-Agent: Google-Dynamite
La stringa AbCdEf123456 nell'esempio precedente è il token di autorizzazione di autenticazione. Si tratta di un token crittografico prodotto da Google. Il tipo di token
di autenticazione e il valore del campo audience dipendono dal tipo di pubblico
di autenticazione selezionato quando
configuri l'app di Chat.
Se hai implementato l'app di Chat utilizzando Cloud Run Functions, Cloud IAM gestisce automaticamente la verifica dei token. Devi aggiungere il service account di Google Chat come invoker autorizzato. Se la tua app implementa il proprio server HTTP, puoi verificare il token di connessione utilizzando una libreria client delle API di Google open source:
- Java: https://github.com/google/google-api-java-client
- Python: https://github.com/google/google-api-python-client
- Node.js: https://github.com/google/google-api-nodejs-client
- .NET: https://github.com/google/google-api-dotnet-client
Se il token non viene verificato per l'app di Chat, il servizio deve rispondere alla richiesta con un codice di risposta HTTPS 401 (Unauthorized).
Autenticare le richieste utilizzando Cloud Run Functions
Dopodiché, devi autorizzare il service account di Google Chat chat@system.gserviceaccount.com come invoker seguendo questi passaggi:
Console
Dopo aver eseguito il deployment della funzione o del servizio su Google Cloud:
Nella console Google Cloud, vai alla pagina Cloud Run:
Nell'elenco dei servizi Cloud Run, fai clic sulla casella di controllo accanto alla funzione ricevente. (Non fare clic sulla funzione stessa.)
Fai clic su Autorizzazioni nella parte superiore della schermata. Si apre il riquadro Autorizzazioni.
Fai clic su Aggiungi entità.
Nel campo Nuove entità, inserisci
chat@system.gserviceaccount.com.Dal menu Seleziona un ruolo, seleziona il ruolo Cloud Run
Invoker di Cloud Run.
Fai clic su Salva.
gcloud
Utilizza il comando gcloud functions add-invoker-policy-binding:
gcloud functions add-invoker-policy-binding RECEIVING_FUNCTION \
--member='serviceAccount:chat@system.gserviceaccount.com'Sostituisci RECEIVING_FUNCTION con il nome della funzione dell'app di Chat.
Autenticare le richieste HTTP con un token ID
Se il campo Pubblico di autenticazione dell'app di Chat
impostazione di connessione è impostato su
URL dell'endpoint HTTP,
il token di autorizzazione di autenticazione nella richiesta è un token ID OpenID Connect
(OIDC)
firmato da Google.
Il campo email è impostato su chat@system.gserviceaccount.com. Il campo Pubblico di autenticazione è impostato sull'URL che hai configurato in Google Chat per inviare le richieste alla tua app di Chat. Ad esempio, se l'endpoint configurato della tua app di Chat è https://example.com/app/, il campo Pubblico di autenticazione nel token ID èhttps://example.com/app/.
Questo è il metodo di autenticazione consigliato se l'endpoint HTTP non è ospitato su un servizio che supporta l'autenticazione basata su IAM (ad esempio Cloud Run). Utilizzando questo metodo, il servizio HTTP ha bisogno di informazioni sull'URL dell'endpoint in cui è in esecuzione, ma non ha bisogno di informazioni sul numero di progetto Cloud.
I seguenti esempi mostrano come verificare che il token di connessione sia stato emesso da Google Chat e sia destinato alla tua app utilizzando la libreria client Google OAuth.
Java
Python
Node.js
Autenticare le richieste con un JWT del numero di progetto
Se il campo Pubblico di autenticazione dell'app di Chat
impostazione di connessione è impostato su Project
Number, il token di autorizzazione di autenticazione nella richiesta è un token
JSON Web Token (JWT) autofirmato,
emesso e firmato da chat@system.gserviceaccount.com.
Il campo audience è impostato sul numero di progetto Google Cloud che hai utilizzato per creare l'app di Chat. Ad esempio, se il numero di progetto Cloud della tua app di Chat è 1234567890, il campo audience nel JWT è 1234567890.
Questo metodo di autenticazione è consigliato solo se preferisci utilizzare il numero di progetto Cloud per verificare le richieste anziché l'URL dell'endpoint HTTP. Ad esempio, se vuoi modificare l'URL dell'endpoint nel tempo mantenendo lo stesso numero di progetto Cloud o se vuoi utilizzare lo stesso endpoint per più numeri di progetto Cloud e vuoi confrontare il campo audience con un elenco di numeri di progetto Cloud.
I seguenti esempi mostrano come verificare che il token di connessione sia stato emesso da Google Chat e sia destinato al tuo progetto utilizzando la libreria client Google OAuth.
Java
Python
Node.js
Argomenti correlati
- Per una panoramica dell'autenticazione e dell'autorizzazione in Google Workspace, consulta Informazioni sull'autenticazione e l'autorizzazione.
- Per una panoramica dell'autenticazione e dell'autorizzazione in Chat, vedi Panoramica dell'autenticazione.
- Configura l'autenticazione e l'autorizzazione con credenziali utente o un service account.