本指南介绍了如何针对 Google Chat API 的 SpaceReadState
资源使用 update()
方法将聊天室标记为已读或未读。
SpaceReadState
资源是一个单例资源,用于表示指定用户在 Google Chat 聊天室中上次读取的消息的详细信息。
前提条件
Node.js
- 拥有对 Google Chat 访问权限的商务版或企业版 Google Workspace 账号。
- 设置环境:
- 创建 Google Cloud 项目。
- 配置 OAuth 同意屏幕。
- 启用和配置 Google Chat API,为 Chat 应用提供名称、图标和说明。
- 安装 Node.js Cloud 客户端库。
- 为桌面应用
创建 OAuth 客户端 ID 凭据。如需运行本指南中的示例,请将凭据保存为名为
client_secrets.json
的 JSON 文件,并保存到本地目录。
- 选择支持用户身份验证的授权范围。
更新发起调用的用户的聊天室读取状态
如需更新聊天室中用户的阅读状态,请在请求中添加以下内容:
- 指定
chat.users.readstate
授权范围。 - 调用
UpdateSpaceReadState()
方法。 - 传递值为
lastReadTime
的updateMask
。 - 使用以下代码将
spaceReadState
作为SpaceReadState
的实例传递:- 将
name
字段设置为要更新的聊天室读取状态,其中包含用户 ID 或别名和聊天室 ID。更新聊天室读取状态仅支持更新调用用户的读取状态,您可以通过设置以下任一项来指定该状态:me
别名。例如users/me/spaces/SPACE/spaceReadState
。- 发起通话的用户的 Workspace 电子邮件地址。例如,
users/[email protected]/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
的实例。