GitHub
Bruk opencode i GitHub-problemer og pull-forespørsler.
OpenCode integreres med GitHub-arbeidsflyten din. Nevn /opencode eller /oc i kommentaren din, og OpenCode vil utføre oppgaver i din GitHub Actions-løper.
Funksjoner
- Triage-problemer: Be OpenCode se på et problem og forklare det for deg.
- Fiks og implementer: Be OpenCode om å fikse et problem eller implementere en funksjon. Og den vil fungere i en ny gren og sender inn en PR med alle endringene.
- Sikkert: OpenCode kjører inne i GitHubs løpere.
Installasjon
Kjør følgende kommando i et prosjekt som er i en GitHub-repo:
opencode github installDette vil lede deg gjennom å installere GitHub-appen, lage arbeidsflyten og sette opp hemmeligheter.
Manuell oppsett
Eller du kan sette den opp manuelt.
-
Installer GitHub-appen
Gå over til github.com/apps/opencode-agent. Sørg for at den er installert på mållageret.
-
Legg til arbeidsflyten
Legg til følgende arbeidsflytfil til
.github/workflows/opencode.ymli repoen. Sørg for å sette riktigemodelog nødvendige API nøkler ienv..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 -
Lagre API-nøklene i hemmeligheter
Utvid Hemmeligheter og variabler til venstre i innstillingene for organisasjonen eller prosjektet og velg Handlinger. Og legg til de nødvendige API-nøklene.
Konfigurasjon
-
model: Modellen som skal brukes med OpenCode. Tar formatetprovider/model. Dette er obligatorisk. -
agent: Agenten som skal brukes. Må være en primær agent. Faller tilbake tildefault_agentfra config eller"build"hvis ikke funnet. -
share: Om OpenCode-økten skal deles. Standard er true for offentlige depoter. -
prompt: Valgfri egendefinert melding for å overstyre standard oppførsel. Bruk dette til å tilpasse hvordan OpenCode behandler forespørsler. -
token: Valgfritt GitHub-tilgangstoken for å utføre operasjoner som å lage kommentarer, foreta endringer og åpne pull-forespørsler. Som standard bruker OpenCode installasjonstilgangstokenet fra OpenCode GitHub-appen, så forpliktelser, kommentarer og pull-forespørsler ser ut til å komme fra appen.Alternativt kan du bruke GitHub Action-løperens innebygde
GITHUB_TOKENuten å installere OpenCode GitHub-appen. Bare sørg for å gi de nødvendige tillatelsene i arbeidsflyten din:permissions:id-token: writecontents: writepull-requests: writeissues: writeDu kan også bruke en personlig tilgangstoken(PAT) hvis foretrukket.
Støttede hendelser
OpenCode kan utløses av følgende GitHub-hendelser:
| Hendelsestype | Utløst av | Detaljer |
|---|---|---|
issue_comment | Kommenter et problem eller PR | Nevn /opencode eller /oc i kommentaren din. OpenCode leser kontekst og kan opprette grener, åpne PR-er eller svare. |
pull_request_review_comment | Kommenter spesifikke kodelinjer i en PR | Nevn /opencode eller /oc mens du ser gjennom koden. OpenCode mottar filbane, linjenummer og diff-kontekst. |
issues | Utgave åpnet eller redigert | Utløs OpenCode automatisk når problemer opprettes eller endres. Krever prompt inngang. |
pull_request | PR åpnet eller oppdatert | Utløs OpenCode automatisk når PR-er åpnes, synkroniseres eller gjenåpnes. Nyttig for automatiserte anmeldelser. |
schedule | Cron-basert tidsplan | Kjør OpenCode etter en tidsplan. Krever prompt inngang. Utdata går til logger og PR (ingen problem å kommentere). |
workflow_dispatch | Manuell utløser fra GitHub UI | Utløs OpenCode på forespørsel via fanen Handlinger. Krever prompt inngang. Utdata går til logger og PR-er. |
Tidsplan Eksempel
Kjør OpenCode på en tidsplan for å utføre automatiserte oppgaver:
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 planlagte arrangementer er prompt-inngangen påkrevd siden det ikke er noen kommentarer å trekke ut instruksjoner fra. Planlagte arbeidsflyter kjører uten brukerkontekst for tillatelsessjekking, så arbeidsflyten må gi contents: write og pull-requests: write hvis du forventer at OpenCode oppretter grener eller PR-er.
Pull Request Eksempel
Gjennomgå PR-er automatisk når de åpnes eller oppdateres:
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 improvementsFor pull_request-hendelser, hvis ingen prompt er oppgitt, går OpenCode som standard gjennom pull-forespørselen.
Issues Triage Eksempel
Triage automatisk nye problemer. Dette eksemplet filtrerer til kontoer eldre enn 30 dager for å redusere spam:
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.For issues-hendelser er prompt-inngangen påkrevd siden det ikke er noen kommentarer å trekke ut instruksjoner fra.
Egendefinerte ledetekster
Overstyr standardledeteksten for å tilpasse oppførselen til OpenCode for arbeidsflyten din.
- 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 improvementsDette er nyttig for å håndheve spesifikke vurderingskriterier, kodestandarder eller fokusområder som er relevante for prosjektet ditt.
Eksempler
Her er noen eksempler på hvordan du kan bruke OpenCode i GitHub.
-
Forklar et problem
Legg til denne kommentaren i en GitHub-utgave.
/opencode explain this issueOpenCode vil lese hele tråden, inkludert alle kommentarer, og svare med en tydelig forklaring.
-
Fiks et problem
I en GitHub-utgave, si:
/opencode fix thisOg OpenCode vil opprette en ny gren, implementere endringene og åpne en PR med endringene.
-
Gjennomgå PR-er og gjør endringer
Legg igjen følgende kommentar på en GitHub PR.
Delete the attachment from S3 when the note is removed /ocOpenCode vil implementere den forespurte endringen og forplikte den til samme PR.
-
Se gjennom spesifikke kodelinjer
Legg igjen en kommentar direkte på kodelinjer i PRs “Filer”-fane. OpenCode oppdager automatisk filen, linjenumrene og diff-konteksten for å gi presise svar.
[Comment on specific lines in Files tab]/oc add error handling hereNår du kommenterer spesifikke linjer, mottar OpenCode:
- Den nøyaktige filen blir gjennomgått
- De spesifikke kodelinjene
- Den omkringliggende diff-konteksten
- Linjenummerinformasjon
Dette gir mulighet for mer målrettede forespørsler uten å måtte spesifisere filstier eller linjenumre manuelt.