本指南介绍了如何使用 Google Chat API 的 资源中的 update()
方法将聊天室标记为已读或未读。SpaceReadState
SpaceReadState
资源是一个单例资源,用于表示指定用户在 Google Chat 聊天室中最后一条已读消息的详细信息。
前提条件
Node.js
- 拥有可访问 Google Chat 的 Google Workspace 商务版或企业版账号。
- 设置环境:
- 创建 Google Cloud 项目。
- 配置 OAuth 权限请求页面。
- 启用并配置 Google Chat API,为您的 Chat 应用指定名称、图标和说明。
- 安装 Node.js Cloud 客户端库。
- 为桌面应用
创建 OAuth 客户端 ID 凭据。如需运行本指南中的示例,请将凭据保存为名为
credentials.json
的 JSON 文件,并将其保存到本地目录。
- 选择支持用户身份验证的授权范围。
更新调用用户的空间读取状态
如需更新空间内用户的已读状态,请在请求中添加以下内容:
- 指定
chat.users.readstate
授权范围。 - 调用
UpdateSpaceReadState()
方法。 - 传递
updateMask
,值为lastReadTime
。 - 将
spaceReadState
作为SpaceReadState
的实例传递,并包含以下内容:name
字段设置为要更新的空间读取状态,其中包括用户 ID 或别名以及空间 ID。更新空间读取状态仅支持更新调用用户的读取状态,可以通过设置以下任一参数来指定:me
别名。例如users/me/spaces/SPACE/spaceReadState
。- 调用用户的 Workspace 电子邮件地址。例如,
users/user@example.com/spaces/SPACE/spaceReadState
。 - 调用用户的用户 ID。例如,
users/USER/spaces/SPACE/spaceReadState
。
lastReadTime
字段设置为用户空间读取状态更新时间的更新值。通常,这与上次读取的消息的时间戳或用户指定的时间戳(用于标记空间中的上次读取位置)相对应。如果lastReadTime
早于最新消息创建时间,则相应聊天室在界面中会显示为未读。如需将相应聊天室标记为已读,请将lastReadTime
设置为晚于(大于)最新消息创建时间的任何值。系统会强制将lastReadTime
调整为与最新消息创建时间一致。请注意,聊天室的已读状态只会影响聊天室顶级对话中显示的消息的已读状态。 消息串中的回复不受此时间戳的影响,而是依赖于消息串的已读状态。
以下示例会更新调用用户的空间读取状态:
Node.js
如需运行此示例,请将 SPACE_NAME
替换为相应空间的 name
中的 ID。
您可以通过调用 ListSpaces()
方法或从空间的网址中获取 ID。
Google Chat API 会更新指定聊天室的已读状态,并返回 SpaceReadState
的实例。