İçeriğe geç

GitLab

GitLab sorunlarında ve parçalanma isteğinde opencode'u kullanın.

opencode, GitLab CI/CD ardışık düzeniniz veya GitLab Duo aracılığıyla GitLab iş akışınızla bütünleşir.

Her iki durumda da opencode, GitLab çalıştırıcılarınızda çalışacaktır.


GitLab CI

opencode normal bir GitLab hattında çalışır. Bunu bir CI component olarak bir boru hattına oluşturabilirsiniz.

Burada opencode için topluluk tarafından oluşturulan bir CI/CD bileşeni kullanıyoruz — nagyv/gitlab-opencode.


Özellikler

  • İş başına özel işlemleri kullanın: opencode parçalarının kullanıma veya devre dışı bırakmak için opencode’u özel bir yapılandırma dizini ile yapılandırın; örneğin ./config/#custom-directory.
  • Minimum kurulum: CI bileşeni opencode’u arka planda kurar; yalnızca opencode yapılandırmasını ve ilk istemi oluşturmanız gerekir.
  • Esnek: CI bileşeni, davranışını özelleştirmek için çeşitli girişleri destekler

Setup

  1. opencode kimlik doğrulamanızı JSON Ayarlar > CI/CD > Değişkenler altında Dosya türü CI ortam değişkenleri olarak saklayın. Bunları “Maskeli ve gizli” olarak işaretlediğinizden emin olun.

  2. Aşağıdakileri .gitlab-ci.yml dosyanıza ekleyin.

    .gitlab-ci.yml
    include:
    - component: $CI_SERVER_FQDN/nagyv/gitlab-opencode/opencode@2
    inputs:
    config_dir: ${CI_PROJECT_DIR}/opencode-config
    auth_json: $OPENCODE_AUTH_JSON # The variable name for your OpenCode authentication JSON
    command: optional-custom-command
    message: "Your prompt here"

Daha fazla girdi ve bu bileşene yönelik kullanım durumları için check out the docs.


GitLab Duo

opencode, GitLab iş akışınızla bütünleşir. Bir yorumda @opencode’dan bahsedin; opencode, GitLab CI işlem hattınızdaki görevleri yürütecektir.


Features

  • Sorunları önceliklendirin: opencode’dan bir sorunu araştırıp size açıklamasını isteyin.
  • Düzelt ve uygula: opencode’dan bir sorunu düzeltmesini veya bir özelliği uygulamasını isteyin. Yeni bir şube oluşturacak ve değişikliklerle birlikte bir birleştirme isteği oluşturacaktır.
  • Güvenli: opencode, GitLab çalıştırıcılarınızda çalışır.

Kurmak

opencode, GitLab CI/CD işlem hattınızda çalışır; bunu ayarlamak için ihtiyacınız olacaklar:

  1. GitLab ortamınızı yapılandırın

  2. CI/CD’yi kurma

  3. Bir AI model sağlayıcısı API anahtarını gösterir

  4. Hizmet hesabı oluşturun

  5. CI/CD değişkenlerini yapılandırma

  6. Bir akış yapılandırma dosyası oluşturun; işte bir örnek:

    Akış yapılandırması
    image: node:22-slim
    commands:
    - echo "Installing opencode"
    - npm install --global opencode-ai
    - echo "Installing glab"
    - export GITLAB_TOKEN=$GITLAB_TOKEN_OPENCODE
    - apt-get update --quiet && apt-get install --yes curl wget gpg git && rm --recursive --force /var/lib/apt/lists/*
    - curl --silent --show-error --location "https://raw.githubusercontent.com/upciti/wakemeops/main/assets/install_repository" | bash
    - apt-get install --yes glab
    - echo "Configuring glab"
    - echo $GITLAB_HOST
    - echo "Creating OpenCode auth configuration"
    - mkdir --parents ~/.local/share/opencode
    - |
    cat > ~/.local/share/opencode/auth.json << EOF
    {
    "anthropic": {
    "type": "api",
    "key": "$ANTHROPIC_API_KEY"
    }
    }
    EOF
    - echo "Configuring git"
    - git config --global user.email "opencode@gitlab.com"
    - git config --global user.name "OpenCode"
    - echo "Testing glab"
    - glab issue list
    - echo "Running OpenCode"
    - |
    opencode run "
    You are an AI assistant helping with GitLab operations.
    Context: $AI_FLOW_CONTEXT
    Task: $AI_FLOW_INPUT
    Event: $AI_FLOW_EVENT
    Please execute the requested task using the available GitLab tools.
    Be thorough in your analysis and provide clear explanations.
    <important>
    Please use the glab CLI to access data from GitLab. The glab CLI has already been authenticated. You can run the corresponding commands.
    If you are asked to summarize an MR or issue or asked to provide more information then please post back a note to the MR/Issue so that the user can see it.
    You don't need to commit or push up changes, those will be done automatically based on the file changes you make.
    </important>
    "
    - git checkout --branch $CI_WORKLOAD_REF origin/$CI_WORKLOAD_REF
    - echo "Checking for git changes and pushing if any exist"
    - |
    if ! git diff --quiet || ! git diff --cached --quiet || [ --not --zero "$(git ls-files --others --exclude-standard)" ]; then
    echo "Git changes detected, adding and pushing..."
    git add .
    if git diff --cached --quiet; then
    echo "No staged changes to commit"
    else
    echo "Committing changes to branch: $CI_WORKLOAD_REF"
    git commit --message "Codex changes"
    echo "Pushing changes up to $CI_WORKLOAD_REF"
    git push https://gitlab-ci-token:$GITLAB_TOKEN@$GITLAB_HOST/gl-demo-ultimate-dev-ai-epic-17570/test-java-project.git $CI_WORKLOAD_REF
    echo "Changes successfully pushed"
    fi
    else
    echo "No git changes detected, skipping push"
    fi
    variables:
    - ANTHROPIC_API_KEY
    - GITLAB_TOKEN_OPENCODE
    - GITLAB_HOST

Ayrıntılı talimatlar için GitLab CLI agents docs’a başvurabilirsiniz.


Examples

GitLab’da opencode’u nasıl kullanabileceğinize dair bazı örnekleri burada bulabilirsiniz.

  • Explain an issue

    Bu yorumu bir GitLab sayısına ekleyin.

    @opencode explain this issue

    opencode konuyu okuyacak ve net bir açıklama ile yanıt verecektir.

  • Fix an issue

    In a GitLab issue, say:

    @opencode fix this

    opencode yeni bir şube oluşturacak, değişiklikleri uygulayacak ve değişiklikleri içeren bir birleştirme isteği açacaktır.

  • Review merge requests

    GitLab birleştirme isteğine aşağıdaki yorumu bırakın.

    @opencode review this merge request

    opencode, birleştirme isteğini inceleyecek ve geri bildirim sağlayacaktır.