{/* 本页面由 website/scripts/generate-skill-docs.py 从技能 SKILL.md 自动生成。请编辑源 SKILL.md 而非本页面。 */}

Codex

将编码委托给 OpenAI Codex CLI(功能、PR)。

技能元数据

来源内置(默认安装)
路径skills/autonomous-ai-agents/codex
版本1.0.0
作者Hermes Agent
许可证MIT
平台linux, macos, windows
标签Coding-Agent, Codex, OpenAI, Code-Review, Refactoring
相关技能claude-code, hermes-agent

参考:完整 SKILL.md

:::info 以下是此技能被触发时 Hermes 加载的完整技能定义。这是技能激活时代理所看到的指令。 :::

Codex CLI

通过 Hermes 终端将编码任务委托给 Codex。Codex 是 OpenAI 的自主编码代理 CLI。

使用时机

  • 构建功能
  • 重构
  • PR 审查
  • 批量问题修复

需要 codex CLI 和 git 仓库。

前提条件

  • 安装 Codex:npm install -g @openai/codex
  • 配置 OpenAI 认证:OPENAI_API_KEY 或来自 Codex CLI 登录流程的 Codex OAuth 凭据
  • 必须在 git 仓库内运行——Codex 拒绝在仓库外运行
  • 在终端调用中使用 pty=true——Codex 是一个交互式终端应用

对于 Hermes 本身,model.provider: openai-codex 使用 Hermes 管理的 Codex OAuth,来自 ~/.hermes/auth.json(通过 hermes auth add openai-codex 后)。对于独立 Codex CLI,有效的 CLI OAuth 会话可能位于 ~/.codex/auth.json;不要将缺失 OPENAI_API_KEY 单独视为缺少 Codex 认证的证据。

一次性任务

terminal(command="codex exec 'Add dark mode toggle to settings'", workdir="~/project", pty=true)

用于临时工作(Codex 需要 git 仓库):

terminal(command="cd $(mktemp -d) && git init && codex exec 'Build a snake game in Python'", pty=true)

后台模式(长时间任务)

# 在后台启动,使用 PTY
terminal(command="codex exec --full-auto 'Refactor the auth module'", workdir="~/project", background=true, pty=true)
# 返回 session_id

# 监控进度
process(action="poll", session_id="<id>")
process(action="log", session_id="<id>")

# 如果 Codex 提问,发送输入
process(action="submit", session_id="<id>", data="yes")

# 如果需要,杀死进程
process(action="kill", session_id="<id>")

关键标志

标志效果
exec "prompt"一次性执行,完成后退出
--full-auto沙盒化但自动批准工作区中的文件更改
--yolo无沙盒,无审批(最快,最危险)

PR 审查

克隆到临时目录进行安全审查:

terminal(command="REVIEW=$(mktemp -d) && git clone https://github.com/user/repo.git $REVIEW && cd $REVIEW && gh pr checkout 42 && codex review --base origin/main", pty=true)

使用工作树进行并行问题修复

# 创建工作树
terminal(command="git worktree add -b fix/issue-78 /tmp/issue-78 main", workdir="~/project")
terminal(command="git worktree add -b fix/issue-99 /tmp/issue-99 main", workdir="~/project")

# 在每个中启动 Codex
terminal(command="codex --yolo exec 'Fix issue #78: <description>. Commit when done.'", workdir="/tmp/issue-78", background=true, pty=true)
terminal(command="codex --yolo exec 'Fix issue #99: <description>. Commit when done.'", workdir="/tmp/issue-99", background=true, pty=true)

# 监控
process(action="list")

# 完成后,推送并创建 PR
terminal(command="cd /tmp/issue-78 && git push -u origin fix/issue-78")
terminal(command="gh pr create --repo user/repo --head fix/issue-78 --title 'fix: ...' --body '...'")

# 清理
terminal(command="git worktree remove /tmp/issue-78", workdir="~/project")

规则

  1. 始终使用 pty=true — Codex 是一个交互式终端应用,没有 PTY 会挂起
  2. 需要 Git 仓库 — Codex 不会在 git 目录外运行。使用 mktemp -d && git init 进行临时工作
  3. 使用 exec 进行一次性任务codex exec "prompt" 运行并干净退出
  4. --full-auto 用于构建 — 自动批准沙盒内的更改
  5. 长时间任务使用后台 — 使用 background=true 并通过 process 工具监控
  6. 不要干扰 — 使用 poll/log 监控,对长时间运行的任务保持耐心
  7. 并行没问题 — 可同时运行多个 Codex 进程进行批量工作