跳到主要内容

xAI Grok OAuth (SuperGrok / X Premium+)

Hermes 智能体通过基于浏览器的 OAuth 登录流程,针对 accounts.x.ai 支持 xAI Grok,使用 SuperGrok 订阅 (grok.com) 或 X Premium+ 订阅 (关联的 X 账户)。无需 XAI_API_KEY — 登录一次,Hermes 会在后台自动刷新您的会话。

当您使用已订阅 Premium+ 的 X 账户登录时,xAI 会自动将订阅状态与您的 xAI 会话关联,因此 OAuth 流程对于直接 SuperGrok 订阅者是相同的。

传输层复用了 codex_responses 适配器 (xAI 提供了一个响应式的端点),因此推理、工具调用、流式传输和提示缓存无需对适配器做任何更改即可工作。

相同的 OAuth 持有者令牌也被 Hermes 中每个直接连接到 xAI 的服务所复用 — 文本转语音、图像生成、视频生成和转录 — 因此一次登录覆盖所有四种服务。

概览

项目
提供商 IDxai-oauth
显示名称xAI Grok OAuth (SuperGrok / X Premium+)
认证类型浏览器 OAuth 2.0 PKCE (本地回环回调)
传输层xAI Responses API (codex_responses)
默认模型grok-4.3
端点https://api.x.ai/v1
认证服务器https://accounts.x.ai
需要环境变量否 (XAI_API_KEY 用于此提供商)
订阅SuperGrokX Premium+ — 请参见下方说明

先决条件

  • Python 3.9+
  • 已安装 Hermes 智能体
  • 在您的 xAI 账户上拥有活跃的 SuperGrok 订阅, 在您登录的 X 账户上拥有 X Premium+ 订阅(xAI 会自动关联订阅)
  • 本地机器上可用的浏览器(或为远程会话使用 --no-browser
xAI 可能按层级限制 OAuth API 访问权限

xAI 的后端对其 OAuth API 表面实施了自己的允许列表,并且已被观察到拒绝标准 SuperGrok 订阅者,返回 HTTP 403 错误(参见问题 #26847),即使应用内订阅是活跃的。如果浏览器中的 OAuth 登录成功,但推理返回 403 错误,请设置 XAI_API_KEY 并切换到 API 密钥路径(provider: xai)——该访问路径目前不受相同的限制。

快速开始

# 启动提供者和模型选择器
hermes model
# → 从提供者列表中选择 "xAI Grok OAuth (SuperGrok / X Premium+)"
# → Hermes 会打开浏览器访问 accounts.x.ai
# → 在浏览器中批准访问权限
# → 选择一个模型(grok-4.3 位于顶部)
# → 开始聊天

hermes

首次登录后,凭据会存储在 ~/.hermes/auth.json 中,并在过期前自动刷新。

手动登录

您可以通过模型选择器之外的方式触发登录:

hermes auth add xai-oauth

远程 / 无头会话

在没有可用浏览器的服务器、容器或 SSH 会话中,Hermes 会检测远程环境并打印授权 URL,而不是打开浏览器。

重要提示: 回环监听器仍在远程机器的 127.0.0.1:56121 上运行。xAI 的重定向需要访问监听器,因此在您的笔记本电脑上打开该 URL 将失败(Could not establish connection. We couldn't reach your app.),除非您转发端口:

# 在本地机器上的另一个终端中:
ssh -N -L 56121:127.0.0.1:56121 user@remote-host

# 然后在远程机器上的 SSH 会话中:
hermes auth add xai-oauth --no-browser
# 在本地浏览器中打开打印出的授权 URL。

通过跳板机/堡垒主机:添加 -J jump-user@jump-host

有关完整的分步指南,包括 ProxyJump 链、mosh/tmux 和 ControlMaster 的注意事项,请参阅 SSH / 远程主机上的 OAuth

仅浏览器的远程环境(Cloud Shell、Codespaces、EC2 Instance Connect)

如果您没有常规的 SSH 客户端(例如,您正在 GCP Cloud Shell、GitHub Codespaces、AWS EC2 Instance Connect、Gitpod 或其他基于浏览器的控制台中运行 Hermes),则上面的 ssh -L 方法不可用。请改用 --manual-paste —— Hermes 会跳过回环监听器,允许您直接从浏览器粘贴失败的回调 URL:

hermes auth add xai-oauth --manual-paste
# 或通过模型选择器:
hermes model --manual-paste

有关完整的演练,请参阅 SSH / 远程主机上的 OAuth。针对问题 #26923 的回归修复。

登录工作原理

  1. Hermes 打开浏览器访问 accounts.x.ai
  2. 您登录(或确认现有会话)并批准访问权限。
  3. xAI 重定向回 Hermes,令牌被保存到 ~/.hermes/auth.json
  4. 此后,Hermes 会在后台刷新访问令牌——您将保持登录状态,直到您执行 hermes auth remove xai-oauth 或从您的 xAI 账户设置中撤销访问权限。

检查登录状态

hermes doctor

◆ Auth Providers 部分将显示每个提供者的当前状态,包括 xai-oauth

切换模型

hermes model
# → 选择 "xAI Grok OAuth (SuperGrok / X Premium+)"
# → 从模型列表中选择(grok-4.3 固定在顶部)

或直接设置模型:

hermes config set model.default grok-4.3
hermes config set model.provider xai-oauth

配置参考

登录后,~/.hermes/config.yaml 将包含:

model:
default: grok-4.3
provider: xai-oauth
base_url: https://api.x.ai/v1

提供者别名

以下所有名称均解析为 xai-oauth

hermes --provider xai-oauth # 标准名称
hermes --provider grok-oauth # 别名
hermes --provider x-ai-oauth # 别名
hermes --provider xai-grok-oauth # 别名

直接调用 xAI 的工具(TTS / 图像 / 视频 / 转录 / X 搜索)

一旦您通过 OAuth 登录,每个直接调用 xAI 的工具都会自动重用相同的承载令牌——无需单独设置,除非您更愿意使用 API 密钥。

要为每个工具选择后端:

hermes tools
# → Text-to-Speech → "xAI TTS"
# → Image Generation → "xAI Grok Imagine (image)"
# → Video Generation → "xAI Grok Imagine"
# → X (Twitter) Search → "xAI Grok OAuth (SuperGrok / X Premium+)"

如果 OAuth 令牌已存储,选择器会确认并跳过凭据提示。如果既未设置 OAuth 也未设置 XAI_API_KEY,选择器会提供一个三选一的菜单:OAuth 登录、粘贴 API 密钥或跳过。

视频生成默认关闭

video_gen 工具集默认是禁用的。在智能体可以调用 video_generate 之前,请在 hermes tools🎬 Video Generation(按空格键)中启用它。否则,智能体可能会回退到捆绑的 ComfyUI 技能,该技能也标记为可用于视频生成。

当存在 xAI 凭据时,X 搜索会自动启用

每当配置了 xAI 凭据(SuperGrok / X Premium+ OAuth 令牌或 XAI_API_KEY)时,x_search 工具集会自动启用。如果您不需要此功能,请通过 hermes tools🐦 X (Twitter) Search(按空格键)显式禁用。该工具通过 xAI 内置的 x_search 响应 API 进行路由——它既适用于您的 SuperGrok / X Premium+ OAuth 登录,也适用于付费 XAI_API_KEY,并且当两者都配置时会优先使用 OAuth(使用您的订阅配额,而不是 API 消耗)。当未配置 xAI 凭据时,无论工具集是否启用,工具模式对模型都是隐藏的。

模型

工具模型备注
聊天grok-4.3默认模型;通过 OAuth 登录时自动选择
聊天grok-4.20-0309-reasoning推理变体
聊天grok-4.20-0309-non-reasoning非推理变体
聊天grok-4.20-multi-agent-0309多智能体变体
图像grok-imagine-image默认模型;约 5-10 秒
图像grok-imagine-image-quality更高保真度;约 10-20 秒
视频grok-imagine-video文本转视频和图像转视频;最多 7 张参考图像
语音合成(默认语音)xAI /v1/tts 端点

聊天目录是从磁盘上的 models.dev 缓存实时生成的;新的 xAI 发布版本会在该缓存刷新后自动出现。grok-4.3 始终固定在列表顶部。

环境变量

变量作用
XAI_BASE_URL覆盖默认的 https://api.x.ai/v1 端点(很少需要)。

要选择 xAI 作为活动提供者,请在 config.yaml 中设置 model.provider: xai-oauth(使用 hermes setup 进行引导流程),或在单次调用中传递 --provider xai-oauth

故障排除

令牌过期 —— 未自动重新登录

Hermes 在每次会话前刷新令牌,并在收到 401 错误时响应式刷新。如果刷新失败并返回 invalid_grant(刷新令牌被撤销,或账户已轮换),Hermes 会显示一条类型化的重新认证消息,而不是崩溃。

当刷新失败是终端性的(HTTP 4xx、invalid_grant、授权被撤销等)时,Hermes 会将刷新令牌标记为无效并在本地隔离它——后续调用会跳过注定失败的刷新尝试,而不是一遍遍地重放相同的 401 错误。智能体会显示一条“需要重新认证”的消息,然后不再打扰,直到您重新登录。

修复方法: 重新运行 hermes auth add xai-oauth 以开始新的登录。隔离状态会在下一次成功的令牌交换后清除。

授权超时

回环监听器具有有限的过期窗口(默认 180 秒)。如果您没有及时批准登录,Hermes 会引发超时错误。

修复方法: 重新运行 hermes auth add xai-oauth(或 hermes model)。流程将重新开始。

状态不匹配(可能的 CSRF 攻击)

Hermes 检测到授权服务器返回的 state 值与其发送的值不匹配。

修复方法: 重新运行登录。如果问题持续存在,请检查是否有修改 OAuth 响应的代理或重定向。

从远程服务器登录

在 SSH 或容器会话中,Hermes 会打印授权 URL 而不是打开浏览器。回环回调监听器仍然绑定在远程主机的 127.0.0.1:56121 上——您笔记本电脑的浏览器如果没有 SSH 本地端口转发将无法访问它:

# 本地机器,另一个终端:
ssh -N -L 56121:127.0.0.1:56121 user@remote-host

# 远程机器:
hermes auth add xai-oauth --no-browser

完整的演练(跳板机、mosh/tmux、端口冲突):SSH / 远程主机上的 OAuth

成功登录后出现 HTTP 403 错误(层级/权限问题)

OAuth 在浏览器中完成,令牌已保存,但推理或令牌刷新返回 HTTP 403 错误,消息类似于 “调用者没有权限执行指定的操作”

不是令牌过期问题——重新运行 hermes model 不会改变它。尽管应用内订阅是活跃的,但已观察到 xAI 的后端将 OAuth API 访问权限限制给特定的 SuperGrok 层级(问题 #26847)。

修复方法: 设置 XAI_API_KEY 并切换到 API 密钥路径:

export XAI_API_KEY=xai-...
hermes config set model.provider xai

如果需要 OAuth 路径,请在 x.ai/grok 升级您的订阅。

运行时出现 “No xAI credentials found” 错误

认证存储中没有 xai-oauth 条目,且未设置 XAI_API_KEY。您尚未登录,或凭据文件已被删除。

修复方法: 运行 hermes model 并选择 xAI Grok OAuth 提供者,或运行 hermes auth add xai-oauth

退出登录

要移除所有存储的xAI Grok OAuth凭据:

hermes auth logout xai-oauth

此操作会清除auth.json中的单例OAuth条目以及所有xai-oauth的凭据池行。如果你只想移除单个池条目,请使用 hermes auth remove xai-oauth <索引|ID|标签> (运行 hermes auth list xai-oauth 以查看条目)。

另请参阅