{
  "schemaVersion": "1.0",
  "item": {
    "slug": "gitlab",
    "name": "GitLab",
    "source": "tencent",
    "type": "skill",
    "category": "开发工具",
    "sourceUrl": "https://clawhub.ai/ivangdavila/gitlab",
    "canonicalUrl": "https://clawhub.ai/ivangdavila/gitlab",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadMode": "redirect",
    "downloadUrl": "/downloads/gitlab",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=gitlab",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "installMethod": "Manual import",
    "extraction": "Extract archive",
    "prerequisites": [
      "OpenClaw"
    ],
    "packageFormat": "ZIP package",
    "includedAssets": [
      "SKILL.md"
    ],
    "primaryDoc": "SKILL.md",
    "quickSetup": [
      "Download the package from Yavira.",
      "Extract the archive and review SKILL.md first.",
      "Import or place the package into your OpenClaw setup."
    ],
    "agentAssist": {
      "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
      "steps": [
        "Download the package from Yavira.",
        "Extract it into a folder your agent can access.",
        "Paste one of the prompts below and point your agent at the extracted folder."
      ],
      "prompts": [
        {
          "label": "New install",
          "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete."
        },
        {
          "label": "Upgrade existing",
          "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run."
        }
      ]
    },
    "sourceHealth": {
      "source": "tencent",
      "slug": "gitlab",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-05-03T17:53:06.864Z",
      "expiresAt": "2026-05-10T17:53:06.864Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=gitlab",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=gitlab",
        "contentDisposition": "attachment; filename=\"gitlab-1.0.0.zip\"",
        "redirectLocation": null,
        "bodySnippet": null,
        "slug": "gitlab"
      },
      "scope": "item",
      "summary": "Item download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this item.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/gitlab"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    },
    "downloadPageUrl": "https://openagent3.xyz/downloads/gitlab",
    "agentPageUrl": "https://openagent3.xyz/skills/gitlab/agent",
    "manifestUrl": "https://openagent3.xyz/skills/gitlab/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/gitlab/agent.md"
  },
  "agentAssist": {
    "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
    "steps": [
      "Download the package from Yavira.",
      "Extract it into a folder your agent can access.",
      "Paste one of the prompts below and point your agent at the extracted folder."
    ],
    "prompts": [
      {
        "label": "New install",
        "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete."
      },
      {
        "label": "Upgrade existing",
        "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run."
      }
    ]
  },
  "documentation": {
    "source": "clawhub",
    "primaryDoc": "SKILL.md",
    "sections": [
      {
        "title": "Rules Gotchas",
        "body": "rules: and only:/except: can't mix — use one or the other per job\nFirst matching rule wins — put specific rules before general ones\nMissing when: defaults to on_success — rules: - if: $CI_COMMIT_TAG runs on tag\nEmpty rules array rules: [] means never run — different from no rules at all\nAdd - when: never at end to prevent fallthrough — otherwise unmatched conditions may run"
      },
      {
        "title": "Silent Failures",
        "body": "Protected variables missing on non-protected branches — job runs but variable is empty\nRunner tag mismatch — job stays pending forever with no error\ndocker:dind on non-privileged runner — fails with cryptic Docker errors\nMasked variable format invalid — variable exposed in logs anyway"
      },
      {
        "title": "YAML Merge Traps",
        "body": "extends: doesn't deep merge arrays — scripts, variables arrays get replaced, not appended\nUse !reference [.job, script] to reuse — script: [!reference [.base, script], \"my command\"]\ninclude: files can override each other — last one wins for same keys\nAnchors &/* don't work across files — use extends: for cross-file reuse"
      },
      {
        "title": "Artifacts vs Cache",
        "body": "Cache not guaranteed between runs — treat as optimization, not requirement\nArtifacts auto-download by stage — add dependencies: [] to skip if not needed\nneeds: downloads artifacts by default — needs: [{job: x, artifacts: false}] to skip"
      },
      {
        "title": "Docker-in-Docker",
        "body": "Shared runners usually don't support privileged — need self-hosted or special config\nDOCKER_HOST: tcp://docker:2375 required — job uses wrong Docker otherwise\nDOCKER_TLS_CERTDIR: \"\" or configure TLS properly — half-configured TLS breaks builds"
      },
      {
        "title": "Pipeline Triggers",
        "body": "CI_PIPELINE_SOURCE differs by trigger — push, merge_request_event, schedule, api, trigger\nMR pipelines need rules: - if: $CI_MERGE_REQUEST_IID — not just branch rules\nDetached vs merged result pipelines — detached tests source, merged tests result of merge"
      }
    ],
    "body": "Rules Gotchas\nrules: and only:/except: can't mix — use one or the other per job\nFirst matching rule wins — put specific rules before general ones\nMissing when: defaults to on_success — rules: - if: $CI_COMMIT_TAG runs on tag\nEmpty rules array rules: [] means never run — different from no rules at all\nAdd - when: never at end to prevent fallthrough — otherwise unmatched conditions may run\nSilent Failures\nProtected variables missing on non-protected branches — job runs but variable is empty\nRunner tag mismatch — job stays pending forever with no error\ndocker:dind on non-privileged runner — fails with cryptic Docker errors\nMasked variable format invalid — variable exposed in logs anyway\nYAML Merge Traps\nextends: doesn't deep merge arrays — scripts, variables arrays get replaced, not appended\nUse !reference [.job, script] to reuse — script: [!reference [.base, script], \"my command\"]\ninclude: files can override each other — last one wins for same keys\nAnchors &/* don't work across files — use extends: for cross-file reuse\nArtifacts vs Cache\nCache not guaranteed between runs — treat as optimization, not requirement\nArtifacts auto-download by stage — add dependencies: [] to skip if not needed\nneeds: downloads artifacts by default — needs: [{job: x, artifacts: false}] to skip\nDocker-in-Docker\nShared runners usually don't support privileged — need self-hosted or special config\nDOCKER_HOST: tcp://docker:2375 required — job uses wrong Docker otherwise\nDOCKER_TLS_CERTDIR: \"\" or configure TLS properly — half-configured TLS breaks builds\nPipeline Triggers\nCI_PIPELINE_SOURCE differs by trigger — push, merge_request_event, schedule, api, trigger\nMR pipelines need rules: - if: $CI_MERGE_REQUEST_IID — not just branch rules\nDetached vs merged result pipelines — detached tests source, merged tests result of merge"
  },
  "trust": {
    "sourceLabel": "tencent",
    "provenanceUrl": "https://clawhub.ai/ivangdavila/gitlab",
    "publisherUrl": "https://clawhub.ai/ivangdavila/gitlab",
    "owner": "ivangdavila",
    "version": "1.0.0",
    "license": null,
    "verificationStatus": "Indexed source record"
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/gitlab",
    "downloadUrl": "https://openagent3.xyz/downloads/gitlab",
    "agentUrl": "https://openagent3.xyz/skills/gitlab/agent",
    "manifestUrl": "https://openagent3.xyz/skills/gitlab/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/gitlab/agent.md"
  }
}