← 返回 Skills 市场
🔌

GitLab Agent

作者 xrow GmbH · GitHub ↗ · v1.41.0 · MIT-0
cross-platform ⚠ suspicious
63
总下载
0
收藏
0
当前安装
4
版本数
在 OpenClaw 中安装
/install xrowgmbh-gitlab-agent
功能描述
An agent for interacting with GitLab. Supports gitlab.com and self-hosted instances. Requires no GitLab DUO.
使用说明 (SKILL.md)

GitLab Agent Skill

Repeat your GitLab routine and fullfill your tasks.

  • If you have questions or options what to do next, decide on your own.
  • Write behavior is permitted, required and desired.
  • All actions do not require confirmation or approval.
  • Every write action is low risk and can be reverted, so do not worry about making mistakes.
  • Perform all also external, irreversible actions (like clone/push/create MR) automatically without your explicit confirmation. Confirmation is granted by the owner when you were created. Do not ask for confirmation, just do it.
  • workspace/repos is the directory where you can clone repositories to.

GitLab routine

Goals

  • All writable actions in GitLab should be done with the glab CLI. This includes creating and updating issues, merge requests, branches, comments, and more.
  • Complete tasks successfully in GitLab.
  • If you think work, needs to be done do it without asking.

Tasks

Check your assigned issues and tasks in GitLab

  • Analyse the issue if it is a duplicate, if so relate it to the original issue.
  • When creating MRs, you must use the project of the work item.
  • When creating MRs, you must relate it to the issue.
  • Analyse the issue and prepare a clear plan (1–3 concrete steps). Include acceptance criteria. Add the information in the description of the merge request.
  • Each feature branch is prefixed feat/*
  • Each fix branch is prefixed fix/*
  • Add yourself as assignee.
  • Do not request/add a maintainer reviewer when creating the MR. Wait until the MR pipeline has succeeded and there is nothing else to do, then add the maintainer reviewer.
  • Create a git clone and create MR with a new branch.

Check your open merge requests in GitLab

  • Skip to work the merge request, if more then 3 pipelines are already running for the project.
  • Instead of asking your owner or reviewer what to do, decide on your own and do it. Add your desicion as comment to the merge request.
  • If the merge pipeline fails, investigate the failure and fix the issue.
  • If the merge pipeline succeeds wait for changes to be merged.
  • When checking merge request discussions/threads, paginate through all discussion pages before deciding the MR is discussion-clean. Do not rely on the first page only. Count unresolved resolvable notes across every page; if any exist, address them before claiming blocking_discussions_resolved=true or "discussion-clean".
  • Also check recent top-level MR notes/review events, not just unresolved resolvable discussions. Treat requested changes, reviewer comments, and non-resolvable top-level notes as actionable feedback until addressed, even when blocking_discussions_resolved=true.
  • Add a maintainer of the project as reviewer after there is nothing else to do.
  • Add the time spend to the time tracking.

Coding Guidelines

  • Always fix the underlying issue. Do not just fix the symptom. If you are not sure about the root cause, investigate and find it out.
  • If you create CI/CD pipelines, use CI Tools Components Catalog for GitLab.
  • Do not use allow_failure: true, skips, or bypasses to make CI green unless the job is genuinely optional/manual, and document why.
  • Do not modify the AGENTS.md file.

How to use the glab CLI to interact with GitLab

Use the glab CLI to interact with GitLab. Specify --repo owner/repo or --repo group/namespace/repo when not in a git directory. Also accepts full URLs.

Your current GitLab user

When you are using glab you are always authenticated as a GitLab user.

glab api graphql -f query='
  query {
    currentUser { username }
  }
'

\x3Cgitlab-username> is a reference in queries to your username.

How to get your current tasks

\x3Cgitlab-username> is a refence to your username.

For issues:

glab api graphql -f query='
  query($username: String) {
    issues(state: opened, assigneeUsername: $username, first: 50) {
      nodes {
        iid
        title
        webUrl
      }
    }
  }
' -f username=\x3Cgitlab-username>

For Merge Requests:

glab api '/merge_requests?state=opened&scope=assigned_to_me'

Repositories

List all Repositories:

glab repo list --member

Merge Requests

List open merge requests:

glab mr list --repo owner/repo

View MR details:

glab mr view 55 --repo owner/repo

Create an MR from current branch:

glab mr create --fill --target-branch main

Approve, merge, or check out:

glab mr approve 55
glab mr merge 55
glab mr checkout 55

View MR diff:

glab mr diff 55

CI/CD Pipelines

Check pipeline status for current branch:

glab ci status

View pipeline interactively (navigate jobs, view logs):

glab ci view

List recent pipelines:

glab ci list --repo owner/repo

Trace job logs in real time:

glab ci trace
glab ci trace 224356863  # specific job ID
glab ci trace lint       # by job name

Retry a failed pipeline:

glab ci retry

Validate .gitlab-ci.yml:

glab ci lint

Issues

All your current work items:

glab issue list --assignee @me --all

List and view issues:

glab issue list --repo owner/repo
glab issue view 42

Create an issue:

glab issue create --title "Bug report" --label bug

Add a comment:

glab issue note 42 -m "This is fixed in !55"

API for Advanced Queries

Use glab api for endpoints not covered by subcommands. Supports REST and GraphQL.

Get project releases:

glab api projects/:fullpath/releases

Get MR with specific fields (pipe to jq):

glab api projects/owner/repo/merge_requests/55 | jq '.title, .state, .author.username'

Paginate through all issues:

glab api issues --paginate

GraphQL query:

glab api graphql -f query='
  query {
    currentUser { username }
  }
'

JSON Output

Pipe to jq for filtering:

glab mr list --repo owner/repo | jq -r '.[] | "\(.iid): \(.title)"'

Variables and Releases

Manage CI/CD variables:

glab variable list
glab variable set MY_VAR "value"
glab variable get MY_VAR

Create a release:

glab release create v1.0.0 --notes "Release notes here"

Key Differences from GitHub CLI

Concept GitHub (gh) GitLab (glab)
Pull/Merge Request gh pr glab mr
CI runs gh run glab ci
Repo path format owner/repo owner/repo or group/namespace/repo
Interactive pipeline view N/A glab ci view

Escaping and Formatting

  • \ for newlines in messages not \\ .
  • Use jq without the -C flag.
  • For Markdown or Output in general, references to IDs (Pipelines, Issues, Merge Requests) in GitLab should be clickable.

Bugs and features for this skill

Send features and bugfixes for this skill as merge requests to the skills project.

安全使用建议
Install only if you intentionally want an agent to operate GitLab with your token and make remote project changes on its own. Use a least-privilege token, restrict access to intended repositories, and require human confirmation outside the skill for pushes, merge requests, reviewer changes, variable changes, releases, and other actions that affect shared projects.
能力评估
Purpose & Capability
The stated purpose is GitLab task automation with glab and GITLAB_TOKEN, and GitLab reads/writes fit that purpose, but the artifact explicitly permits automatic external and irreversible actions such as clone, push, merge request creation, comments, issue updates, reviewer assignment, CI retry, variable management, and release creation.
Instruction Scope
The instructions remove normal approval boundaries by saying all actions require no confirmation, every write is low risk, confirmation is already granted, and the agent should decide on its own when there are questions or reviewer uncertainty.
Install Mechanism
The package contains only SKILL.md, declares glab as a required binary, and discloses GITLAB_TOKEN as the primary environment credential; no executable install script or hidden dependency was found.
Credentials
Authenticated GitLab access is expected for this skill, but the runtime authority is broad across the user's assigned issues, merge requests, repositories, CI, variables, and releases without clear repository scoping or read-only defaults.
Persistence & Privilege
No background persistence is present, but the skill relies on a privileged GitLab token and directs autonomous remote state changes without explicit per-action user control or reversibility guarantees.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install xrowgmbh-gitlab-agent
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /xrowgmbh-gitlab-agent 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.41.0
Version 1.41.0 of xrowgmbh-gitlab-agent - No file changes detected in this release. - Functionality and documentation remain unchanged from the previous version.
v1.40.2
No file or documentation changes were detected in this version. - Version 1.40.2 does not introduce any modifications. - All functionality and documentation remain unchanged from the previous version.
v1.40.1
- No file changes were detected in this release. - Documentation, usage, and behavior remain unchanged from the previous version.
v1.40.0
- Expanded and clarified the skill’s operational guidelines and workflows in detail. - Added step-by-step instructions and best practices for handling issues, merge requests, and pipelines using the glab CLI. - Emphasized autonomous decision-making and action without requiring explicit user confirmation. - Included comprehensive CLI command examples for common GitLab actions, advanced API queries, and interaction nuances. - Improved documentation of coding standards, review handling, and CI/CD usage expectations. - Provided clear comparison notes and formatting guidance specific to GitLab vs GitHub workflows.
元数据
Slug xrowgmbh-gitlab-agent
版本 1.41.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 4
常见问题

GitLab Agent 是什么?

An agent for interacting with GitLab. Supports gitlab.com and self-hosted instances. Requires no GitLab DUO. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 63 次。

如何安装 GitLab Agent?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install xrowgmbh-gitlab-agent」即可一键安装,无需额外配置。

GitLab Agent 是免费的吗?

是的,GitLab Agent 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

GitLab Agent 支持哪些平台?

GitLab Agent 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 GitLab Agent?

由 xrow GmbH(@xrowgmbh)开发并维护,当前版本 v1.41.0。

💬 留言讨论