6.8k★glab-api – OpenClaw Skill
glab-api is an OpenClaw Skills integration for coding workflows. Use when working with glab api commands.
6.8k stars8.3k forksSecurity L1
Updated Feb 7, 2026Created Feb 7, 2026coding
Skill Snapshot
| name | glab-api |
| description | Use when working with glab api commands. OpenClaw Skills integration. |
| owner | vince-winkintel |
| repository | vince-winkintel/gitlab-cli-skillspath: glab-api |
| language | Markdown |
| license | MIT |
| topics | |
| security | L1 |
| install | openclaw add @vince-winkintel/gitlab-cli-skills:glab-api |
| last updated | Feb 7, 2026 |
Maintainer

File Explorer
1 files
glab-api
SKILL.md
11.7 KBSKILL.md
name: glab-api description: Use when working with glab api commands.
glab api
Overview
Makes an authenticated HTTP request to the GitLab API, and prints the response.
The endpoint argument should either be a path of a GitLab API v4 endpoint, or
`graphql` to access the GitLab GraphQL API.
- [GitLab REST API documentation](https://docs.gitlab.com/api/)
- [GitLab GraphQL documentation](https://docs.gitlab.com/api/graphql/)
If the current directory is a Git directory, uses the GitLab authenticated host in the current
directory. Otherwise, `gitlab.com` will be used.
To override the GitLab hostname, use `--hostname`.
These placeholder values, when used in the endpoint argument, are
replaced with values from the repository of the current directory:
- `:branch`
- `:fullpath`
- `:group`
- `:id`
- `:namespace`
- `:repo`
- `:user`
- `:username`
Methods: the default HTTP request method is `GET`, if no parameters are added,
and `POST` otherwise. Override the method with `--method`.
Pass one or more `--raw-field` values in `key=value` format to add
JSON-encoded string parameters to the `POST` body.
The `--field` flag behaves like `--raw-field` with magic type conversion based
on the format of the value:
- Literal values `true`, `false`, `null`, and integer numbers are converted to
appropriate JSON types.
- Placeholder values `:namespace`, `:repo`, and `:branch` are populated with values
from the repository of the current directory.
- If the value starts with `@`, the rest of the value is interpreted as a
filename to read the value from. Pass `-` to read from standard input.
For GraphQL requests, all fields other than `query` and `operationName` are
interpreted as GraphQL variables.
Raw request body can be passed from the outside via a file specified by `--input`.
Pass `-` to read from standard input. In this mode, parameters specified with
`--field` flags are serialized into URL query parameters.
In `--paginate` mode, all pages of results are requested sequentially until
no more pages of results remain. For GraphQL requests:
- The original query must accept an `$endCursor: String` variable.
- The query must fetch the `pageInfo{ hasNextPage, endCursor }` set of fields from a collection.
The `--output` flag controls the output format:
- `json` (default): Pretty-printed JSON. Arrays are output as a single JSON array.
- `ndjson`: Newline-delimited JSON (also known as JSONL or JSON Lines). Each array element
or object is output on a separate line. This format is more memory-efficient for large datasets
and works well with tools like `jq`. See https://github.com/ndjson/ndjson-spec and
https://jsonlines.org/ for format specifications.
USAGE
glab api <endpoint> [--flags]
EXAMPLES
$ glab api projects/:fullpath/releases
$ glab api projects/gitlab-com%2Fwww-gitlab-com/issues
$ glab api issues --paginate
$ glab api issues --paginate --output ndjson
$ glab api issues --paginate --output ndjson | jq 'select(.state == "opened")'
$ glab api graphql -f query="query { currentUser { username } }"
$ glab api graphql -f query='
query {
project(fullPath: "gitlab-org/gitlab-docs") {
name
forksCount
statistics {
wikiSize
}
issuesEnabled
boards {
nodes {
id
name
}
}
}
}
'
$ glab api graphql --paginate -f query='
query($endCursor: String) {
project(fullPath: "gitlab-org/graphql-sandbox") {
name
issues(first: 2, after: $endCursor) {
edges {
node {
title
}
}
pageInfo {
endCursor
hasNextPage
}
}
}
}'
FLAGS
-F --field Add a parameter of inferred type. Changes the default HTTP method to "POST".
-H --header Add an additional HTTP request header.
-h --help Show help for this command.
--hostname The GitLab hostname for the request. Defaults to 'gitlab.com', or the authenticated host in the current Git directory.
-i --include Include HTTP response headers in the output.
--input The file to use as the body for the HTTP request.
-X --method The HTTP method for the request. (GET)
--output Format output as: json, ndjson. (json)
--paginate Make additional HTTP requests to fetch all pages of results.
-f --raw-field Add a string parameter.
--silent Do not print the response body.
Quick start
glab api --help
Subcommands
This command has no subcommands.
README.md
No README available.
Permissions & Security
Security level L1: Low-risk skills with minimal permissions. Review inputs and outputs before running in production.
Requirements
- OpenClaw CLI installed and configured.
- Language: Markdown
- License: MIT
- Topics:
FAQ
How do I install glab-api?
Run openclaw add @vince-winkintel/gitlab-cli-skills:glab-api in your terminal. This installs glab-api into your OpenClaw Skills catalog.
Does this skill run locally or in the cloud?
OpenClaw Skills execute locally by default. Review the SKILL.md and permissions before running any skill.
Where can I verify the source code?
The source repository is available at https://github.com/openclaw/skills/tree/main/skills/vince-winkintel/gitlab-cli-skills. Review commits and README documentation before installing.
