تخطَّ إلى المحتوى

GitLab

استخدم Vikasit Code في مشكلات GitLab وطلبات الدمج.

يتكامل Vikasit Code مع سير عمل GitLab لديك عبر خط أنابيب GitLab CI/CD أو عبر GitLab Duo.

في كلتا الحالتين، سيعمل Vikasit Code على مشغّلات GitLab لديك.


GitLab CI

يعمل Vikasit Code ضمن خط أنابيب GitLab عادي. يمكنك دمجه في الخط كمكوّن CI.

هنا نستخدم مكوّن CI/CD أنشأه المجتمع لـ Vikasit Code — nagyv/gitlab-opencode.


الميزات

  • استخدام إعدادات مخصّصة لكل مهمة: يمكنك إعداد Vikasit Code باستخدام دليل إعدادات مخصّص، مثل ./config/#custom-directory، لتفعيل الوظائف أو تعطيلها في كل تشغيل لـ Vikasit Code.
  • إعداد بسيط: يقوم مكوّن CI بإعداد Vikasit Code في الخلفية؛ كل ما عليك هو إنشاء إعدادات Vikasit Code والمطالبة (prompt) الأولية.
  • مرن: يدعم مكوّن CI عدة مُدخلات لتخصيص سلوكه.

الإعداد

  1. احفظ JSON مصادقة Vikasit Code كمتغيرات بيئة CI من نوع File ضمن Settings > CI/CD > Variables. تأكد من تعيينها على “Masked and hidden”.

  2. أضف ما يلي إلى ملف .gitlab-ci.yml.

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

لمزيد من المُدخلات وحالات الاستخدام، اطّلع على الوثائق الخاصة بهذا المكوّن.


GitLab Duo

يتكامل Vikasit Code مع سير عمل GitLab لديك. اذكر @vikasit في تعليق، وسينفّذ Vikasit Code المهام ضمن خط أنابيب GitLab CI لديك.


الميزات

  • فرز المشكلات: اطلب من Vikasit Code النظر في مشكلة وشرحها لك.
  • الإصلاح والتنفيذ: اطلب من Vikasit Code إصلاح مشكلة أو تنفيذ ميزة. سيُنشئ فرعًا جديدًا ويرفع طلب دمج بالتغييرات.
  • آمن: يعمل Vikasit Code على مشغّلات GitLab لديك.

الإعداد

يعمل Vikasit Code ضمن خط أنابيب GitLab CI/CD لديك، وإليك ما ستحتاجه لإعداده:

  1. قم بتهيئة بيئة GitLab لديك

  2. أعد إعداد CI/CD

  3. احصل على مفتاح API من مزوّد نموذج ذكاء اصطناعي

  4. أنشئ حساب خدمة

  5. اضبط متغيرات CI/CD

  6. أنشئ ملف إعداد للتدفق، وإليك مثالًا:

    إعدادات التدفق
    image: node:22-slim
    commands:
    - echo "Installing vikasit"
    - npm install --global /vikasit-code
    - 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 Vikasit Code 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 "vikasit@gitlab.com"
    - git config --global user.name "Vikasit Code"
    - echo "Testing glab"
    - glab issue list
    - echo "Running Vikasit Code"
    - |
    vikasit 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 للحصول على تعليمات مفصلة.


أمثلة

فيما يلي بعض الأمثلة على كيفية استخدام Vikasit Code في GitLab.

  • شرح مشكلة

    أضف هذا التعليق في مشكلة على GitLab.

    @vikasit explain this issue

    سيقرأ Vikasit Code المشكلة ويرد بشرح واضح.

  • إصلاح مشكلة

    في مشكلة على GitLab، قل:

    @vikasit fix this

    سيُنشئ Vikasit Code فرعًا جديدًا، وينفّذ التغييرات، ويفتح طلب دمج بالتغييرات.

  • مراجعة طلبات الدمج

    اترك التعليق التالي على طلب دمج في GitLab.

    @vikasit review this merge request

    سيُراجع Vikasit Code طلب الدمج ويقدّم ملاحظات.