In diesem Leitfaden wird erläutert, wie Sie die Methode update()
für die Ressource SpaceReadState
der Google Chat API verwenden, um Bereiche als gelesen oder ungelesen zu markieren.
Die SpaceReadState
-Ressource ist eine Singleton-Ressource, die Details zur zuletzt gelesenen Nachricht eines bestimmten Nutzers in einem Google Chat-Gruppenbereich enthält.
Vorbereitung
Node.js
- Ein Google Workspace-Konto für Unternehmen mit Zugriff auf Google Chat.
- Umgebung einrichten:
- Google Cloud-Projekt erstellen
- OAuth-Zustimmungsbildschirm konfigurieren
- Aktivieren und konfigurieren Sie die Google Chat API mit einem Namen, einem Symbol und einer Beschreibung für Ihre Chat-App.
- Installieren Sie die Cloud-Clientbibliothek für Node.js.
-
OAuth-Client-ID-Anmeldedaten für eine Desktopanwendung erstellen Wenn Sie das Beispiel in dieser Anleitung ausführen möchten, speichern Sie die Anmeldedaten als JSON-Datei mit dem Namen
credentials.json
in Ihrem lokalen Verzeichnis.
- Wählen Sie einen Autorisierungsbereich aus, der die Nutzerauthentifizierung unterstützt.
Lesestatus des Anrufers im Gruppenbereich aktualisieren
Wenn Sie den Lesestatus eines Nutzers in einem Bereich aktualisieren möchten, fügen Sie Folgendes in Ihre Anfrage ein:
- Geben Sie den
chat.users.readstate
-Autorisierungsbereich an. - Rufen Sie die Methode
UpdateSpaceReadState()
auf. - Übergeben Sie
updateMask
mit dem WertlastReadTime
. - Übergeben Sie
spaceReadState
als Instanz vonSpaceReadState
mit Folgendem:- Das Feld
name
ist auf den zu aktualisierenden Lesestatus des Bereichs festgelegt. Es enthält eine Nutzer-ID oder einen Alias und eine Bereichs-ID. Das Aktualisieren des Lesestatus von Bereichen unterstützt nur das Aktualisieren des Lesestatus des anrufenden Nutzers, der durch Festlegen einer der folgenden Optionen angegeben werden kann:- Der Alias
me
. Beispiel:users/me/spaces/SPACE/spaceReadState
- Die Google Workspace-E-Mail-Adresse des anrufenden Nutzers. Beispiel:
users/user@example.com/spaces/SPACE/spaceReadState
- Die Nutzer-ID des aufrufenden Nutzers. Beispiel:
users/USER/spaces/SPACE/spaceReadState
- Der Alias
- Das Feld
lastReadTime
ist auf den aktualisierten Wert der Zeit festgelegt, zu der der Lesestatus des Bereichs des Nutzers aktualisiert wurde. Normalerweise entspricht dies entweder dem Zeitstempel der letzten gelesenen Nachricht oder einem vom Nutzer angegebenen Zeitstempel, um die letzte gelesene Position in einem Bereich zu markieren. WennlastReadTime
vor dem Zeitpunkt der Erstellung der letzten Nachricht liegt, wird der Gruppenbereich in der Benutzeroberfläche als ungelesen angezeigt. Wenn Sie den Gruppenbereich als gelesen markieren möchten, legen SielastReadTime
auf einen beliebigen Wert fest, der später (größer) als die Erstellungszeit der letzten Nachricht ist. DielastReadTime
wird so angepasst, dass sie mit der Erstellungszeit der letzten Nachricht übereinstimmt. Der Lesestatus des Gruppenbereichs wirkt sich nur auf den Lesestatus von Nachrichten aus, die in der Unterhaltung der obersten Ebene des Gruppenbereichs sichtbar sind. Antworten in Threads sind von diesem Zeitstempel nicht betroffen. Stattdessen wird der Lesestatus des Threads berücksichtigt.
- Das Feld
Im folgenden Beispiel wird der Lesestatus des Anrufers für den Gruppenbereich aktualisiert:
Node.js
Ersetzen Sie SPACE_NAME
durch die ID aus der name
des Bereichs, um dieses Beispiel auszuführen.
Sie können die ID abrufen, indem Sie die Methode ListSpaces()
aufrufen oder die URL des Bereichs verwenden.
Die Google Chat API aktualisiert den angegebenen Lesestatus des Gruppenbereichs und gibt eine Instanz von SpaceReadState
zurück.
Weitere Informationen
- Lesestatus des Anrufers für den Bereich abrufen:
- Lesestatus des Threads des anrufenden Nutzers abrufen