Loading

Elastic GitLab connector reference

Serverless Preview Stack Planned

The Elastic GitLab connector is a connector for GitLab. This connector is written in Python using the Elastic connector framework.

View the source code for this connector (branch main, compatible with Elastic 9.3).

Important

As of Elastic 9.0, managed connectors on Elastic Cloud Hosted are no longer available. All connectors must be self-managed.

This connector is available as a self-managed connector.

This self-managed connector is compatible with Elastic versions 9.3.0+.

To use this connector, satisfy all self-managed connector requirements.

To create a new GitLab connector:

  1. In the Kibana UI, search for "connectors" using the global search field and choose the "Elasticsearch" connectors.
  2. Follow the instructions to create a new GitLab self-managed connector.

You can use the Elasticsearch Create connector API to create a new self-managed GitLab self-managed connector.

For example:

				PUT _connector/my-gitlab-connector
					{
  "index_name": "my-elasticsearch-index",
  "name": "Content synced from GitLab",
  "service_type": "gitlab"
}
		

Refer to the Elasticsearch API documentation for details of all available Connector APIs.

To use this connector as a self-managed connector, see Self-managed connectors For additional usage operations, see Connectors UI in Kibana.

Configure a GitLab personal access token to fetch data from GitLab.

Follow these steps to generate a GitLab personal access token:

  • Go to User Settings → Access Tokens (or for project tokens: Settings → Access Tokens → Project Access Tokens).

  • Click Add new token.

  • Enter a token name and optional expiration date.

  • Select the following scopes:

    • api - Required for GraphQL API access (note: the connector only performs read-only operations)
    • read_api - Grants read access to REST API endpoints
    • read_repository - Grants read access to repository files
  • Click Create personal access token and copy the token.

This connector supports GitLab Cloud (gitlab.com) only. GitLab Self-Managed instances are not currently supported.

The following configuration fields are required:

token
GitLab personal access token to authenticate with the GitLab instance. The token must have api, read_api, and read_repository scopes.
projects

List of project paths to sync (e.g., group/project, username/project). Use * or leave empty ([]) to sync all projects where the token's user is a member.

Default value is [] (empty list, which syncs all projects).

Examples:

  • elastic/elasticsearch, elastic/kibana
  • *
  • [] (syncs all projects)
Tip

Project path format

Projects should be specified using their full path including the namespace (group or username).

In the examples provided here:

  • elastic/elasticsearch syncs the Elasticsearch project from the elastic group
  • elastic/kibana syncs the Kibana project from the elastic group

You can deploy the GitLab connector as a self-managed connector using Docker. Follow these instructions.

Refer to DOCKER.md in the elastic/connectors repo for more details.

Find all available Docker images in the official registry.

Tip

We also have a quickstart self-managed option using Docker Compose, so you can spin up all required services at once: Elasticsearch, Kibana, and the connectors service. Refer to this README in the elastic/connectors repo for more information.

The connector syncs the following objects and entities:

  • Projects
  • Issues (using Work Items API)
  • Merge Requests
  • Epics (using Work Items API, group-level, requires Premium/Ultimate tier)
  • Releases (project-level version releases with changelogs)
  • README Files (.md, .rst, .txt)

Only the following file extensions are ingested for README files:

  • .md
  • .rst
  • .txt
Note
  • Content of files bigger than 10 MB won't be extracted.
  • Epics are only available for Premium/Ultimate GitLab tiers and are synced at the group level.
  • Epic syncing behavior: Epics are fetched only for groups that contain synced projects.
  • Permissions are not synced. All documents indexed to an Elastic deployment will be visible to all users with access to that Elasticsearch Index.

Full syncs are supported by default for all connectors.

This connector does not currently support incremental syncs.

Basic sync rules are identical for all connectors and are available by default. For more information read Types of sync rule.

Advanced sync rules are not currently supported for this connector. This feature may be added in future releases.

See Content extraction.

The connector framework enables operators to run functional tests against a real data source. Refer to Connector testing for more details.

To perform E2E testing for the GitLab connector, run the following command:

$ make ftest NAME=gitlab
		

For faster tests, add the DATA_SIZE=small flag:

make ftest NAME=gitlab DATA_SIZE=small
		

There are currently no known issues for this connector. Refer to Known issues for a list of known issues for all connectors.

See Troubleshooting.

See Security.