GitLab
Используйте OpenCode в issues и merge request'ах GitLab.
OpenCode интегрируется с вашим рабочим процессом GitLab через CI/CD-пайплайн GitLab или с помощью GitLab Duo.
В обоих случаях OpenCode будет работать на ваших раннерах GitLab.
GitLab CI
OpenCode работает в обычном пайплайне GitLab. Вы можете встроить его в пайплайн как CI-компонент (opens in a new tab)
Здесь мы используем созданный сообществом CI/CD-компонент для OpenCode — nagyv/gitlab-opencode (opens in a new tab).
Возможности
- Используйте пользовательскую конфигурацию для каждого задания: настройте OpenCode с пользовательской директорией конфигурации, например
./config/#custom-directory, чтобы включать или отключать функциональность для каждого вызова OpenCode. - Минимальная настройка: CI-компонент настраивает OpenCode в фоновом режиме, вам нужно только создать конфигурацию OpenCode и начальный промпт.
- Гибкость: CI-компонент поддерживает несколько входных параметров для настройки его поведения
Настройка
-
Сохраните ваш JSON-файл аутентификации OpenCode как переменные окружения CI типа File в разделе Settings > CI/CD > Variables. Убедитесь, что вы отметили их как "Masked and hidden".
-
Добавьте следующее в ваш файл
.gitlab-ci.yml..gitlab-ci.ymlinclude: - 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"
Для получения дополнительных входных параметров и сценариев использования ознакомьтесь с документацией (opens in a new tab) для этого компонента.
GitLab Duo
OpenCode интегрируется с вашим рабочим процессом GitLab.
Упомяните @opencode в комментарии, и OpenCode выполнит задачи внутри вашего CI-пайплайна GitLab.
Возможности
- Сортировка issues: попросите OpenCode изучить issue и объяснить его вам.
- Исправление и реализация: попросите OpenCode исправить issue или реализовать функцию. Он создаст новую ветку и откроет merge request с изменениями.
- Безопасность: OpenCode работает на ваших раннерах GitLab.
Настройка
OpenCode работает в вашем CI/CD-пайплайне GitLab, вот что вам понадобится для его настройки:
Совет: ознакомьтесь с документацией GitLab (opens in a new tab) для получения актуальных инструкций.
-
Настройте ваше окружение GitLab
-
Настройте CI/CD
-
Получите API-ключ провайдера AI-модели
-
Создайте сервисный аккаунт
-
Настройте переменные CI/CD
-
Создайте файл конфигурации flow, вот пример:
Flow configuration
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 "[email protected]" - 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
Подробные инструкции вы можете найти в документации GitLab CLI agents (opens in a new tab).
Примеры
Вот несколько примеров того, как вы можете использовать OpenCode в GitLab.
Совет: вы можете настроить использование другой триггерной фразы вместо
@opencode.
-
Объяснить issue Добавьте этот комментарий в issue GitLab.
@opencode explain this issueOpenCode прочитает issue и ответит с понятным объяснением.
-
Исправить issue В issue GitLab напишите:
@opencode fix thisOpenCode создаст новую ветку, реализует изменения и откроет merge request с изменениями.
-
Ревью merge request'ов Оставьте следующий комментарий к merge request'у GitLab.
@opencode review this merge requestOpenCode проведёт ревью merge request'а и предоставит обратную связь.