GitLab
استخدم OpenSploit في مشكلات GitLab وطلبات الدمج.
يتكامل OpenSploit مع سير عمل GitLab لديك عبر خط أنابيب GitLab CI/CD أو عبر GitLab Duo.
في كلتا الحالتين، سيعمل OpenSploit على مشغّلات GitLab لديك.
GitLab CI
يعمل OpenSploit ضمن خط أنابيب GitLab عادي. يمكنك دمجه في الخط كمكوّن CI.
هنا نستخدم مكوّن CI/CD أنشأه المجتمع لـ OpenSploit — nagyv/gitlab-opensploit.
الميزات
- استخدام إعدادات مخصّصة لكل مهمة: يمكنك إعداد OpenSploit باستخدام دليل إعدادات مخصّص، مثل
./config/#custom-directory، لتفعيل الوظائف أو تعطيلها في كل تشغيل لـ OpenSploit. - إعداد بسيط: يقوم مكوّن CI بإعداد OpenSploit في الخلفية؛ كل ما عليك هو إنشاء إعدادات OpenSploit والمطالبة (prompt) الأولية.
- مرن: يدعم مكوّن CI عدة مُدخلات لتخصيص سلوكه.
الإعداد
-
احفظ JSON مصادقة OpenSploit كمتغيرات بيئة CI من نوع File ضمن Settings > CI/CD > Variables. تأكد من تعيينها على “Masked and hidden”.
-
أضف ما يلي إلى ملف
.gitlab-ci.yml..gitlab-ci.yml include:- component: $CI_SERVER_FQDN/nagyv/gitlab-opensploit/opensploit@2inputs:config_dir: ${CI_PROJECT_DIR}/opensploit-configauth_json: $OPENCODE_AUTH_JSON # The variable name for your OpenSploit authentication JSONcommand: optional-custom-commandmessage: "Your prompt here"
لمزيد من المُدخلات وحالات الاستخدام، اطّلع على الوثائق الخاصة بهذا المكوّن.
GitLab Duo
يتكامل OpenSploit مع سير عمل GitLab لديك.
اذكر @opensploit في تعليق، وسينفّذ OpenSploit المهام ضمن خط أنابيب GitLab CI لديك.
الميزات
- فرز المشكلات: اطلب من OpenSploit النظر في مشكلة وشرحها لك.
- الإصلاح والتنفيذ: اطلب من OpenSploit إصلاح مشكلة أو تنفيذ ميزة. سيُنشئ فرعًا جديدًا ويرفع طلب دمج بالتغييرات.
- آمن: يعمل OpenSploit على مشغّلات GitLab لديك.
الإعداد
يعمل OpenSploit ضمن خط أنابيب GitLab CI/CD لديك، وإليك ما ستحتاجه لإعداده:
-
قم بتهيئة بيئة GitLab لديك
-
أعد إعداد CI/CD
-
احصل على مفتاح API من مزوّد نموذج ذكاء اصطناعي
-
أنشئ حساب خدمة
-
اضبط متغيرات CI/CD
-
أنشئ ملف إعداد للتدفق، وإليك مثالًا:
إعدادات التدفق
image: node:22-slimcommands:- echo "Installing opensploit"- npm install --global opensploit- 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 OpenSploit auth configuration"- mkdir --parents ~/.local/share/opensploit- |cat > ~/.local/share/opensploit/auth.json << EOF{"anthropic": {"type": "api","key": "$ANTHROPIC_API_KEY"}}EOF- echo "Configuring git"- git config --global user.email "opensploit@gitlab.com"- git config --global user.name "OpenSploit"- echo "Testing glab"- glab issue list- echo "Running OpenSploit"- |opensploit run "You are an AI assistant helping with GitLab operations.Context: $AI_FLOW_CONTEXTTask: $AI_FLOW_INPUTEvent: $AI_FLOW_EVENTPlease 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)" ]; thenecho "Git changes detected, adding and pushing..."git add .if git diff --cached --quiet; thenecho "No staged changes to commit"elseecho "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_REFecho "Changes successfully pushed"fielseecho "No git changes detected, skipping push"fivariables:- ANTHROPIC_API_KEY- GITLAB_TOKEN_OPENCODE- GITLAB_HOST
يمكنك الرجوع إلى وثائق GitLab CLI agents للحصول على تعليمات مفصلة.
أمثلة
فيما يلي بعض الأمثلة على كيفية استخدام OpenSploit في GitLab.
-
شرح مشكلة
أضف هذا التعليق في مشكلة على GitLab.
@opensploit explain this issueسيقرأ OpenSploit المشكلة ويرد بشرح واضح.
-
إصلاح مشكلة
في مشكلة على GitLab، قل:
@opensploit fix thisسيُنشئ OpenSploit فرعًا جديدًا، وينفّذ التغييرات، ويفتح طلب دمج بالتغييرات.
-
مراجعة طلبات الدمج
اترك التعليق التالي على طلب دمج في GitLab.
@opensploit review this merge requestسيُراجع OpenSploit طلب الدمج ويقدّم ملاحظات.