本指南介绍了如何使用 Google Chat API 的 ThreadReadState
资源中的 get()
方法来获取消息线程中用户的已读状态的详细信息。如需获取聊天室中消息的已读状态,请参阅获取有关用户聊天室已读状态的详细信息。
ThreadReadState
资源是一种单例资源,用于表示指定用户在 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
或chat.users.readstate.readonly
授权范围。 - 调用
GetThreadReadState()
方法,并传递线程读取状态的name
以获取包含用户 ID 或别名以及聊天室 ID 的线程读取状态。获取线程读取状态仅支持获取调用用户的读取状态,该状态可通过设置以下其中一项来指定:me
别名。例如users/me/spaces/SPACE/threads/THREAD/threadReadState
。- 调用用户的 Workspace 电子邮件地址。例如,
users/user@example.com/spaces/SPACE/threads/THREAD/threadReadState
。 - 调用用户的用户 ID。例如,
users/USER/spaces/SPACE/threads/THREAD/threadReadState
。
以下示例用于获取调用用户的线程读取状态:
Node.js
如需运行此示例,请替换以下内容:
SPACE_NAME
:来自空间name
的 ID。您可以通过调用ListSpaces()
方法或从空间的网址中获取 ID。THREAD_NAME
:来自线程的name
的 ID。 您可以通过以下方式获取 ID:使用 Chat API 异步创建消息后返回的响应正文,或者创建消息时分配给消息的自定义名称。
Google Chat API 会获取指定线程的已读状态,并返回 ThreadReadState
的实例。