Questa guida spiega come utilizzare il metodo
get()
nella risorsa SpaceEvent
dell'API Google Chat per ottenere dettagli su
un evento da uno spazio Google Chat.
La
risorsa SpaceEvent
rappresenta una modifica a uno spazio o alle relative risorse secondarie, come messaggi,
reazioni e iscrizioni. Per scoprire di più sui tipi di eventi supportati, consulta il
campo eventType
della risorsa SpaceEvent
nella documentazione di riferimento.
Puoi richiedere eventi fino a 28 giorni prima della data della richiesta. L'evento
contiene la versione più recente della risorsa modificata. Ad esempio, se
richiedi un evento relativo a un nuovo messaggio, ma il messaggio è stato aggiornato in un secondo momento, il
server restituisce la risorsa Message
aggiornata nel payload dell'evento.
Per chiamare questo metodo, devi utilizzare l'autenticazione utente. Per ottenere un evento, l'utente autenticato deve essere membro dello spazio in cui si è verificato l'evento.
Prerequisiti
Node.js
- Un account Google Workspace Business o Enterprise con accesso a Google Chat.
- Configura l'ambiente:
- Crea un progetto Google Cloud.
- Configura la schermata per il consenso OAuth.
- Attiva e configura l'API Google Chat con un nome, un'icona e una descrizione per la tua app di chat.
- Installa la libreria client Cloud Node.js.
- Crea le credenziali di accesso in base a come vuoi autenticarti nella richiesta dell'API Google Chat:
- Per l'autenticazione come utente di Chat,
crea le credenziali dell'ID client OAuth e salvale come file JSON denominato
credentials.json
nella directory locale. - Per l'autenticazione come app Chat,
crea le credenziali
dell'account di servizio e salvale come file JSON denominato
credentials.json
.
- Per l'autenticazione come utente di Chat,
crea le credenziali dell'ID client OAuth e salvale come file JSON denominato
- Scegli un ambito di autorizzazione in base al fatto che tu voglia eseguire l'autenticazione come utente o come app Chat.
Python
- Un account Google Workspace Business o Enterprise con accesso a Google Chat.
- Configura l'ambiente:
- Crea un progetto Google Cloud.
- Configura la schermata per il consenso OAuth.
- Attiva e configura l'API Google Chat con un nome, un'icona e una descrizione per la tua app di chat.
- Installa la libreria client Python Cloud.
- Crea le credenziali di accesso in base a come vuoi autenticarti nella richiesta dell'API Google Chat:
- Per l'autenticazione come utente di Chat,
crea le credenziali dell'ID client OAuth e salvale come file JSON denominato
credentials.json
nella directory locale. - Per l'autenticazione come app Chat,
crea le credenziali
dell'account di servizio e salvale come file JSON denominato
credentials.json
.
- Per l'autenticazione come utente di Chat,
crea le credenziali dell'ID client OAuth e salvale come file JSON denominato
- Scegli un ambito di autorizzazione in base al fatto che tu voglia eseguire l'autenticazione come utente o come app Chat.
Visualizzare i dettagli di un evento dello spazio (autenticazione utente)
Per ottenere dettagli su un evento dello spazio in Google Chat, passa quanto segue nella tua richiesta:
- Specifica un ambito di autorizzazione che supporti il tipo di evento nella richiesta. Come best practice, scegli l'ambito più restrittivo che consenta comunque alla tua app di funzionare.
- Chiama il metodo
GetSpaceEvent()
, passandoname
dell'evento dello spazio da recuperare.
L'esempio seguente recupera un evento dello spazio:
Node.js
Questo esempio di codice Node.js utilizza l'API RPC Chat.
Per eseguire questo esempio, sostituisci quanto segue:
SCOPE_NAME
: un ambito di autorizzazione basato sul tipo di evento. Ad esempio, se ricevi un evento dello spazio relativo a un nuovo abbonamento, utilizza l'ambitochat.memberships.readonly
, formattato comehttps://www.googleapis.com/auth/chat.memberships.readonly
. Puoi ottenere il tipo di evento dal metodoListSpaceEvents()
. Per scoprire come utilizzare questo metodo, consulta Elencare gli eventi di uno spazio.SPACE_NAME
: l'ID diname
dello spazio. Puoi ottenere l'ID chiamando il metodoListSpaces()
o dall'URL dello spazio.SPACE_EVENT_NAME
: l'ID dell'name
dell'evento dello spazio. Puoi ottenere l'ID dal metodoListSpaceEvents()
. Per scoprire come utilizzare questo metodo, consulta Elencare gli eventi di uno spazio.
L'API Chat restituisce un'istanza di
SpaceEvent
con i dettagli dell'evento.
Visualizzare i dettagli di un evento dello spazio (autenticazione dell'app Chat)
L'autenticazione dell'app richiede l'approvazione dell'amministratore una sola volta.
Per ottenere i dettagli di un evento di uno spazio con autenticazione dell'app utilizzando l'API REST di Chat, trasmetti quanto segue nella richiesta:
- Specifica uno o più ambiti di autorizzazione per supportare ogni tipo di evento nella tua
richiesta. Come best practice, scegli l'ambito più restrittivo che consenta comunque
il funzionamento della tua app. Per scoprire di più sulla scelta di un ambito, consulta la
Panoramica di autenticazione e autorizzazione.
https://www.googleapis.com/auth/chat.app.memberships
https://www.googleapis.com/auth/chat.app.messages.readonly
https://www.googleapis.com/auth/chat.app.spaces
- Chiama il metodo
get
sulla risorsaspaceEvents
. - Passa l'
name
dello spazio da cui recuperare i dettagli dell'evento.
Crea una chiave API
Per chiamare un metodo API di anteprima per gli sviluppatori, devi utilizzare una versione di anteprima per gli sviluppatori non pubblica del documento di rilevamento API. Per autenticare la richiesta, devi trasmettere una chiave API.
Per creare la chiave API, apri il progetto Google Cloud della tua app e svolgi i seguenti passaggi:
- Nella console Google Cloud, vai a Menu > API e servizi > Credenziali.
- Fai clic su Crea credenziali > Chiave API.
- Viene visualizzata la nuova chiave API.
- Fai clic su Copia per copiare la chiave API da utilizzare nel codice della tua app. La chiave API è disponibile anche nella sezione "Chiavi API" delle credenziali del progetto.
- Per impedire l'uso non autorizzato, ti consigliamo di limitare dove e per quali API può essere utilizzata la chiave API. Per maggiori dettagli, vedi Aggiungere limitazioni API.
Scrivere uno script che chiama l'API Chat
Ecco come ottenere i dettagli di un evento dello spazio con l'autenticazione dell'app e l'API REST di Chat:
Python
Questo esempio di codice Python utilizza l'API REST di Chat.
- Nella directory di lavoro, crea un file denominato
chat_spaceevents_get_app.py
. Includi il seguente codice in
chat_spaceevents_get_app.py
:from google.oauth2 import service_account from apiclient.discovery import build # Define your app's authorization scopes. # Set authorization scopes based on the # event type. For example, if you are getting a space event # about a new membership, use the `chat.app.memberships.readonly` scope. # # When modifying these scopes, delete the file token.json, if it exists. SCOPES = ["https://www.googleapis.com/auth/chat.app.memberships", "https://www.googleapis.com/auth/chat.app.messages.readonly", "https://www.googleapis.com/auth/chat.app.spaces"] def main(): ''' Authenticates with Chat API using app authentication, then lists space events from a specified space. ''' # Specify service account details. creds = ( service_account.Credentials.from_service_account_file('credentials.json') .with_scopes(SCOPES) ) # Build a service endpoint for Chat API. chat = build('chat', 'v1', credentials=creds, discoveryServiceUrl='https://chat.googleapis.com/$discovery/rest?version=v1&labels=DEVELOPER_PREVIEW&key=API_KEY') # Use the service endpoint to call Chat API. result = chat.spaces().spaceEvents().get( # The space to get event details from. # # Replace SPACE_NAME with a space name. # Obtain the space name from the spaces resource of Chat API, # or from a space's URL. name='spaces/SPACE_NAME/spaceEvents/SPACE_EVENT_NAME', ).execute() # Print Chat API's response in your command line interface. print(result) if __name__ == '__main__': main()
Nel codice, sostituisci quanto segue:
API_KEY
: la chiave API che hai creato per creare l'endpoint del servizio per l'API Chat.SPACE_NAME
: il nome di uno spazio, che puoi ottenere dal metodospaces.list
nell'API Chat o dall'URL di uno spazio.SPACE_EVENT_NAME
: l'ID dell'name
dell'evento dello spazio. Puoi ottenere l'ID dal metodoListSpaceEvents()
. Per scoprire come utilizzare questo metodo, consulta Elencare gli eventi di uno spazio.
Nella directory di lavoro, compila ed esegui l'esempio:
python3 chat_spaceevents_get_app.py
L'API Chat restituisce un elenco impaginato di eventi dello spazio relativi a nuove iscrizioni e nuovi messaggi.