GitHub
在 GitHub 問題和拉取請求中使用 opencode。
opencode 與您的 GitHub 工作流程集成。在評論中提及/opencode 或/oc,opencode 將在您的 GitHub Actions 運行器中執行任務。
特徵
- 分類問題:要求 opencode 調查問題並向您解釋。
- 修復和實施:要求 opencode 修復問題或實施功能。它將在一個新分支中工作並提交包含所有更改的 PR。
- 安全:opencode 在 GitHub 的運行器中運行。
安裝
在 GitHub 存儲庫中的項目中運行以下命令:
opencode github install這將引導您完成安裝 GitHub 應用程式、創建工作流程和設置機密。
手動設置
或者您可以手動設置。
-
Error 500 (Server Error)!!1500.That’s an error.There was an error. Please try again later.That’s all we know.
前往github.com/apps/opencode-agent。確保它已安裝在目標存儲庫上。
-
添加工作流程
將以下工作流程文件添加到存儲庫中的
.github/workflows/opencode.yml中。確保在model中設置適當的env和所需的API密鑰。.github/workflows/opencode.yml name: opencodeon:issue_comment:types: [created]pull_request_review_comment:types: [created]jobs:opencode:if: |contains(github.event.comment.body, '/oc') ||contains(github.event.comment.body, '/opencode')runs-on: ubuntu-latestpermissions:id-token: writesteps:- name: Checkout repositoryuses: actions/checkout@v6with:fetch-depth: 1persist-credentials: false- name: Run OpenCodeuses: anomalyco/opencode/github@latestenv:ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }}with:model: anthropic/claude-sonnet-4-20250514# share: true# github_token: xxxx -
Error 500 (Server Error)!!1500.That’s an error.There was an error. Please try again later.That’s all we know.
在您的組織或項目的設置中,展開左側的秘密和變量,然後選擇操作。並添加所需的 API 密鑰。
配置
-
model:與 opencode 一起使用的模型。採用provider/model格式。這是必需的。 -
agent: The agent to use.必須是一級代理。如果未找到,則從配置回退到default_agent或"build"。 -
share:是否共享opencode會話。對於公共存儲庫,默認為 true。 -
prompt:可選的自定義提示以覆蓋默認行為。使用它來自定義 opencode 處理請求的方式。 -
token:可選的 GitHub 訪問令牌,用於執行創建評論、提交更改和打開拉取請求等操作。默認情況下,opencode 使用來自 opencode GitHub 應用程式的安裝訪問令牌,因此提交、評論和拉取請求顯示為來自應用程式。或者,您可以使用 GitHub Action 運行程序的內置
GITHUB_TOKEN,而無需安裝 opencode GitHub 應用程式。只需確保在您的工作流程中授予所需的權限:permissions:id-token: writecontents: writepull-requests: writeissues: writeError 500 (Server Error)!!1500.That’s an error.There was an error. Please try again later.That’s all we know.
支持的活動
opencode 可以由以下 GitHub 事件觸發:
| 事件類型 | 觸發者 | 詳情 |
|---|---|---|
issue_comment | 對問題或 PR 發表評論 | Mention /opencode or /oc in your comment. opencode 讀取上下文並可以創建分支、打開 PR 或回复。 |
pull_request_review_comment | 對 PR 中的特定程式碼行進行評論 | 在檢查程式碼時提及/opencode 或/oc。 opencode receives file path, line numbers, and diff context. |
issues | 問題已打開或已編輯 | 創建或修改問題時自動觸發 opencode。需要 prompt 輸入。 |
pull_request | PR 已開啟或已更新 | Automatically trigger opencode when PRs are opened, synchronized, or reopened.對於自動評論很有用。 |
schedule | 基於 Cron 的計劃 | 按計劃運行 opencode。需要 prompt 輸入。輸出進入日誌和 PR(沒有可評論的問題)。 |
workflow_dispatch | 從 GitHub UI 手動觸發 | 通過“操作”選項卡按需觸發 opencode。需要 prompt 輸入。輸出進入日誌和 PR。 |
時間表示例
按計劃運行 opencode 以執行自動化任務:
name: Scheduled OpenCode Task
on: schedule: - cron: "0 9 * * 1" # Every Monday at 9am UTC
jobs: opencode: runs-on: ubuntu-latest permissions: id-token: write contents: write pull-requests: write issues: write steps: - name: Checkout repository uses: actions/checkout@v6 with: persist-credentials: false
- name: Run OpenCode uses: anomalyco/opencode/github@latest env: ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }} with: model: anthropic/claude-sonnet-4-20250514 prompt: | Review the codebase for any TODO comments and create a summary. If you find issues worth addressing, open an issue to track them.For scheduled events, the prompt input is required since there’s no comment to extract instructions from.計劃工作流在沒有用戶上下文的情況下運行以進行權限檢查,因此如果您希望 opencode 創建分支或 PR,工作流必須授予 contents: write 和 pull-requests: write。
拉取請求示例
打開或更新 PR 時自動審核:
name: opencode-review
on: pull_request: types: [opened, synchronize, reopened, ready_for_review]
jobs: review: runs-on: ubuntu-latest permissions: id-token: write contents: read pull-requests: read issues: read steps: - uses: actions/checkout@v6 with: persist-credentials: false - uses: anomalyco/opencode/github@latest env: ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: model: anthropic/claude-sonnet-4-20250514 use_github_token: true prompt: | Review this pull request: - Check for code quality issues - Look for potential bugs - Suggest improvements對於 pull_request 事件,如果未提供 prompt,opencode 將默認審核拉取請求。
問題分類示例
自動分類新問題。此示例過濾超過 30 天的帳戶以減少垃圾郵件:
name: Issue Triage
on: issues: types: [opened]
jobs: triage: runs-on: ubuntu-latest permissions: id-token: write contents: write pull-requests: write issues: write steps: - name: Check account age id: check uses: actions/github-script@v7 with: script: | const user = await github.rest.users.getByUsername({ username: context.payload.issue.user.login }); const created = new Date(user.data.created_at); const days = (Date.now() - created) / (1000 * 60 * 60 * 24); return days >= 30; result-encoding: string
- uses: actions/checkout@v6 if: steps.check.outputs.result == 'true' with: persist-credentials: false
- uses: anomalyco/opencode/github@latest if: steps.check.outputs.result == 'true' env: ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }} with: model: anthropic/claude-sonnet-4-20250514 prompt: | Review this issue. If there's a clear fix or relevant docs: - Provide documentation links - Add error handling guidance for code examples Otherwise, do not comment.對於 issues 事件,prompt 輸入是必需的,因為沒有註釋可從中提取指令。
自定義提示
覆蓋默認提示,為您的工作流程自定義 opencode 的行為。
- uses: anomalyco/opencode/github@latest with: model: anthropic/claude-sonnet-4-5 prompt: | Review this pull request: - Check for code quality issues - Look for potential bugs - Suggest improvements這對於執行與您的項目相關的特定審查標準、編碼標准或重點領域非常有用。
示例
以下是如何在 GitHub 中使用 opencode 的一些示例。
-
解釋一個問題
在 GitHub 問題中添加此評論。
/opencode explain this issueopencode 將閱讀整個線程,包括所有評論,並回复並提供清晰的解釋。
-
解決問題
在 GitHub 問題中,說:
/opencode fix thisopencode 將創建一個新分支,實施更改,並使用更改打開 PR。
-
審查 PR 並進行更改
在 GitHub PR 上留下以下評論。
Delete the attachment from S3 when the note is removed /ocError 500 (Server Error)!!1500.That’s an error.There was an error. Please try again later.That’s all we know.
-
查看特定程式碼行
直接在 PR 的“文件”選項卡中的程式碼行上留下評論。 opencode 自動檢測文件、行號和差異上下文以提供精確的響應。
[Comment on specific lines in Files tab]/oc add error handling hereError 500 (Server Error)!!1500.That’s an error.There was an error. Please try again later.That’s all we know.
- 正在審查的確切文件
- 具體程式碼行
- 周圍的 diff 上下文
- 行號信息
這允許更有針對性的請求,而無需手動指定文件路徑或行號。