GitHub
GitHub の問題とプルリクエストで OpenCode を使用します。
OpenCode は GitHub ワークフローと統合します。コメントで /opencode または /oc に言及すると、OpenCode が GitHub Actions ランナー内でタスクを実行します。
特徴
- 問題のトリアージ: OpenCode に問題を調べて説明してもらいます。
- 修正と実装: OpenCode に問題の修正または機能の実装を依頼します。そして、新しいブランチで動作し、すべての変更を含む PR を送信します。
- 安全: OpenCode は GitHub のランナー内で実行されます。
インストール
GitHub リポジトリにあるプロジェクトで次のコマンドを実行します。
opencode github installここでは、GitHub アプリのインストール、ワークフローの作成、シークレットの設定について説明します。
手動セットアップ
または、手動で設定することもできます。
- GitHub アプリをインストールします
github.com/apps/opencode-agent にアクセスしてください。ターゲット リポジトリにインストールされていることを確認してください。
- ワークフローを追加
次のワークフロー ファイルをリポジトリの .github/workflows/opencode.yml に追加します。適切な model と必要な API キーを env に設定してください。
name: opencode
on: 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-latest permissions: id-token: write steps: - name: Checkout repository uses: actions/checkout@v6 with: fetch-depth: 1 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 # share: true # github_token: xxxx- API キーをシークレットに保存します
組織またはプロジェクトの設定で、左側のシークレットと変数を展開し、アクションを選択します。そして、必要な API キーを追加します。
構成
model: OpenCode で使用するモデル。provider/modelの形式をとります。これは必須です。agent: 使用するエージェント。プライマリ エージェントである必要があります。見つからない場合は、設定からdefault_agentにフォールバックするか、"build"にフォールバックします。share: OpenCode セッションを共有するかどうか。パブリック リポジトリのデフォルトは true です。prompt: デフォルトの動作をオーバーライドするためのオプションのカスタム プロンプト。これを使用して、OpenCode がリクエストを処理する方法をカスタマイズします。token: コメントの作成、変更のコミット、プル リクエストのオープンなどの操作を実行するためのオプションの GitHub アクセス トークン。デフォルトでは、OpenCode は OpenCode GitHub アプリからのインストール アクセス トークンを使用するため、コミット、コメント、プル リクエストはアプリからのものとして表示されます。
あるいは、OpenCode GitHub アプリをインストールせずに、GitHub Action ランナーの 組み込み GITHUB_TOKEN を使用することもできます。ワークフローで必要な権限を必ず付与してください。
permissions: id-token: write contents: write pull-requests: write issues: write必要に応じて、パーソナル アクセス トークン(PAT) を使用することもできます。
サポートされているイベント
OpenCode は、次の GitHub イベントによってトリガーできます。
| イベントの種類 | きっかけ | 詳細 |
|---|---|---|
issue_comment | 問題または PR についてコメントする | コメントで /opencode または /oc について言及してください。 OpenCode はコンテキストを読み取り、ブランチを作成したり、PR を開いたり、返信したりできます。 |
pull_request_review_comment | PR 内の特定のコード行にコメントする | コードをレビューするときに、/opencode または /oc について言及します。 OpenCode は、ファイル パス、行番号、および diff コンテキストを受け取ります。 |
issues | 問題がオープンまたは編集されました | 問題が作成または変更されると、OpenCode が自動的にトリガーされます。 prompt 入力が必要です。 |
pull_request | PR がオープンまたは更新されました | PR が開かれる、同期される、または再度開かれるときに、OpenCode を自動的にトリガーします。自動レビューに役立ちます。 |
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.スケジュールされたイベントの場合、指示を抽出するためのコメントがないため、prompt 入力は 必須 です。スケジュールされたワークフローは、権限チェックのためのユーザー コンテキストなしで実行されるため、OpenCode がブランチまたは PR を作成することが予想される場合、ワークフローは contents: write および pull-requests: write を付与する必要があります。
プルリクエストの例
PR が開かれるか更新されるときに、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 improvementspull_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 thisそして、OpenCode は新しいブランチを作成し、変更を実装し、変更を含む PR を開きます。
- PR を確認して変更を加える
GitHub PR に次のコメントを残してください。
Delete the attachment from S3 when the note is removed /ocOpenCode は要求された変更を実装し、同じ PR にコミットします。
- 特定のコード行を確認してください
PR の「ファイル」タブのコード行に直接コメントを残します。 OpenCode は、ファイル、行番号、および diff コンテキストを自動的に検出して、正確な応答を提供します。
[Comment on specific lines in Files tab] /oc add error handling here特定の行にコメントすると、OpenCode は以下を受け取ります。
- レビューされている正確なファイル
- コードの特定の行
- 周囲の差分コンテキスト
- 行番号情報
これにより、ファイル パスや行番号を手動で指定する必要がなく、よりターゲットを絞ったリクエストが可能になります。