Gå til indhold

GitHub

Brug ArmIn i GitHub-problemer og Pull Requests.

ArmIn integreres med din GitHub arbejdsgang. Nævn /armin eller /oc i din kommentar, og ArmIn vil udføre opgaver i din GitHub Actions-løber.


Funktioner

  • Triageproblemer: Bed ArmIn om at undersøge et problem og forklare dig det.
  • Ret og implementer: Bed ArmIn om at løse et problem eller implementere en funktion. Og det vil fungere i en ny branch og indsende en PR med alle ændringerne.
  • Sikker: ArmIn løber inde i din GitHubs løbere.

Installation

Kør følgende kommando i et projekt, der er i en GitHub repo:

Terminal window
armin github install

Dette vil lede dig gennem installation af GitHub-appen, oprettelse af arbejdsgangen og opsætning af hemmeligheder.


Manuel opsætning

Eller du kan indstille det manuelt.

  1. Installationsprogrammet GitHub-appen

    Gå over til github.com/apps/armin-agent. Sørg for, at det er installeret på mållageret.

  2. Tilføj arbejdsgangen

    Tilføj følgende workflow-fil til .github/workflows/armin.yml i din repo. Sørg for at indstille de relevante model og nødvendige API-nøgler i env.

    .github/workflows/armin.yml
    name: armin
    on:
    issue_comment:
    types: [created]
    pull_request_review_comment:
    types: [created]
    jobs:
    armin:
    if: |
    contains(github.event.comment.body, '/oc') ||
    contains(github.event.comment.body, '/armin')
    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 ArmIn
    uses: simon-cheung/arm-in/github@latest
    env:
    ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }}
    with:
    model: anthropic/claude-sonnet-4-20250514
    # share: true
    # github_token: xxxx
  3. Opbevar API-nøglerne i hemmeligheder

    I din organisation eller dit projekt indstillinger skal du udvide Hemmeligheder og variabler til venstre og vælge Handlinger. Og tilføj de nødvendige API-nøgler.


Konfiguration

  • model: Den model, der skal bruges med ArmIn. Antager formatet provider/model. Dette er påkrævet.

  • agent: Agenten, der skal bruges. Skal være en primær agent. Falder tilbage til default_agent fra config eller "build", hvis den ikke findes.

  • share: Om ArmIn-sessionen skal dele. Standard er true for offentlige arkiver.

  • prompt: Valgfri brugerdefineret prompt for at tilsidesætte standardadfærden. Brug dette til at tilpasse, hvordan ArmIn behandler anmodninger.

  • token: Valgfrit GitHub adgangstoken til at udføre operationer såsom oprettelse af kommentarer, begå ændringer og åbning af Pull Requests. Som standard bruger ArmIn installationsadgangstokenet fra ArmIn GitHub-appen, så commits, kommentarer og Pull Requests ser ud til at komme fra appen.

    Alternativt kan du bruge GitHub Action runners built-in GITHUB_TOKEN uden at installere ArmIn GitHub appen. Bare sørg for at give de nødvendige tilladelser i dit workflow:

    permissions:
    id-token: write
    contents: write
    pull-requests: write
    issues: write

    Du kan også bruge en personal access tokens(PAT), hvis det foretrækkes.


Understøttede begivenheder

ArmIn kan udløses af følgende GitHub hændelser:

BegivenhedstypeUdløst afDetaljer
issue_commentKommentarer og problemer eller PRNævn /armin eller /oc i din kommentar. ArmIn læser kontekst og kan oprette brancher, åbne PR’er eller svare.
pull_request_review_commentKommenter specifikke kodelinjer i en PRNævn /armin eller /oc, mens du gennemgår koden. ArmIn modtager filsti, linjenumre og diff-kontekst.
issuesUdgave åbnet eller redigeretUdløs automatisk ArmIn, når problemer oprettes eller ændres. Kræver prompt input.
pull_requestPR åbnet eller opdateretUdløs automatisk ArmIn, når PR’er åbnes, synkroniseres eller genåbnes. Nyttigt til automatiserede kodegennemgange.
scheduleCron-baseret tidsplanKør ArmIn efter en tidsplan. Kræver prompt input. Output går til logfiler og PR’er (intet problem ved kommentere).
workflow_dispatchManuel trigger fra GitHub UIUdløs ArmIn efter behov via fanen Handlinger. Kræver prompt input. Output går til logfiler og PR’er.

Tidsplan eksempel

Kør ArmIn efter en tidsplan for at udføre automatiske opgaver:

.github/workflows/armin-scheduled.yml
name: Scheduled ArmIn Task
on:
schedule:
- cron: "0 9 * * 1" # Every Monday at 9am UTC
jobs:
armin:
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 ArmIn
uses: simon-cheung/arm-in/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 begivenheder er prompt input påkrævet, da der ikke er nogen kommentarer at udtrække instruktioner fra. Planlagte arbejdsgange kører uden en brugerkontekst til kontrol af tilladelser, så arbejdsgangen skal give contents: write og pull-requests: write, hvis du forventer, at ArmIn skal oprette brancher eller PR’er.


Pull Request eksempel

Gennemgå automatisk PR’er, når de åbnes eller opdateres:

.github/workflows/armin-review.yml
name: armin-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: simon-cheung/arm-in/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

For pull_request hændelser, hvis der ikke er angivet nogen prompt, vil ArmIn som standard gennemgå Pull Requesten.


Issues Triage eksempel

Triage automatisk nye problemer. Dette eksempel filtrerer til konti ældre end 30 dage for at reducere spam:

.github/workflows/armin-triage.yml
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: simon-cheung/arm-in/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 begivenheder er prompt input påkrævet, da der ikke er nogen kommentarer at udtrække instruktioner fra.


Brugerdefinerede prompter

Tilsidesæt standardprompten for at tilpasse OpenCodes adfærd til din arbejdsgang.

.github/workflows/armin.yml
- uses: simon-cheung/arm-in/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

Dette er nyttigt til at håndhæve specifikke gennemgangskriterier, kodningsstandarder eller fokusområder, der er relevante for dit projekt.


Eksempler

Her er nogle eksempler på, hvordan du kan bruge ArmIn i GitHub.

  • Forklar et problem

    Tilføj denne kommentar i et GitHub-nummer.

    /armin explain this issue

    ArmIn vil læse hele tråden, inklusive alle kommentarer, og svare med en klar forklaring.

  • Løs et problem

    I et GitHub-problem skal du sige:

    /armin fix this

    Og ArmIn vil oprette en ny branch, implementere ændringer og åbne en PR med ændringer.

  • Gennemgå PR’er og foretag ændringer

    Efterlad følgende kommentar på en GitHub PR.

    Delete the attachment from S3 when the note is removed /oc

    ArmIn vil implementere den ønskede ændring og forpligtelse til den samme PR.

  • Gennemgå specifikke kodelinjer

    Efterlad en kommentar direkte på kodelinjer i PR’s faneblad “Filer”. ArmIn detekterer automatisk filer, linjenumrene og diff-konteksten for at give præcise svar.

    [Comment on specific lines in Files tab]
    /oc add error handling here

    Når du kommenterer på specifikke linjer, modtager ArmIn:

    • Den nøjagtige fil bliver gennemgået
    • De specifikke kodelinjer
    • Den omgivende forskellig kontekst
    • Linjenummeroplysninger

    Dette giver mulighed for mere målrettede anmodninger uden at skulle angive filstier eller linjenumre manuelt.