A GitHub Action that integrates opencode directly into your GitHub workflow.
Start your comment with hey opencode, and opencode will take action via your GitHub Actions runner.
hey opencode, explain this issue
hi opencode, fix this
Review PRs and make changes
Delete the attachment from S3 when the note is removed @opencode-agent
Run the following command in the terminal from your GitHub repo:
opencode github install
This will walk you through installing the GitHub app, configuring the workflow, and setting up secrets.
Add the following workflow file to .github/workflows/opencode.yml in your repo. Set the appropriate model and required API keys in env.
name: opencode
on:
issue_comment:
types: [created]
jobs:
opencode:
if: |
startsWith(github.event.comment.body, 'opencode') ||
startsWith(github.event.comment.body, 'hi opencode') ||
startsWith(github.event.comment.body, 'hey opencode') ||
contains(github.event.comment.body, '@opencode-agent')
runs-on: ubuntu-latest
permissions:
id-token: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 1
- name: Run opencode
uses: sst/opencode/github@latest
env:
ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }}
with:
model: anthropic/claude-sonnet-4-20250514
Store the API keys in secrets. In your organization or project settings, expand Secrets and variables on the left and select Actions. Add the required API keys.
This is an early release. If you encounter issues or have feedback, please create an issue at https://github.com/sst/opencode/issues.
To test locally:
Navigate to a test repo (e.g. hello-world):
cd hello-world
Run:
MODEL=anthropic/claude-sonnet-4-20250514 \
ANTHROPIC_API_KEY=sk-ant-api03-1234567890 \
GITHUB_RUN_ID=dummy \
bun /path/to/opencode/packages/opencode/src/index.ts github run \
--token 'github_pat_1234567890' \
--event '{"eventName":"issue_comment",...}'
MODEL: The model used by opencode. Same as the MODEL defined in the GitHub workflow.ANTHROPIC_API_KEY: Your model provider API key. Same as the keys defined in the GitHub workflow.GITHUB_RUN_ID: Dummy value to emulate GitHub action environment./path/to/opencode: Path to your cloned opencode repo. bun /path/to/opencode/packages/opencode/src/index.ts runs your local version of opencode.--token: A GitHub persontal access token. This token is used to verify you have admin or write access to the test repo. Generate a token here.--event: Mock GitHub event payload (see templates below). --event '{"eventName":"issue_comment","repo":{"owner":"sst","repo":"hello-world"},"actor":"fwang","payload":{"issue":{"number":4},"comment":{"id":1,"body":"hey opencode, summarize thread"}}}'
Replace:
"owner":"sst" with repo owner"repo":"hello-world" with repo name"actor":"fwang" with the GitHub username of commentor"number":4 with the GitHub issue id"body":"hey opencode, summarize thread" with comment body --event '{"eventName":"issue_comment","repo":{"owner":"sst","repo":"hello-world"},"actor":"fwang","payload":{"issue":{"number":4},"comment":{"id":1,"body":"hey opencode, what is in my image "}}}'
Replace the image URL https://github.com/user-attachments/assets/xxxxxxxx with a valid GitHub attachment (you can generate one by commenting with an image in any issue).
--event '{"eventName":"issue_comment","repo":{"owner":"sst","repo":"hello-world"},"actor":"fwang","payload":{"issue":{"number":4,"pull_request":{}},"comment":{"id":1,"body":"hey opencode, summarize thread"}}}'