docs/ai-agents/connectors/gitlab/AUTH.md
This page documents the authentication and configuration options for the Gitlab agent connector.
In open source mode, you provide API credentials directly to the connector.
credentials fields you need:
| Field Name | Type | Required | Description |
|---|---|---|---|
client_id | str | Yes | The API ID of the GitLab developer application. |
client_secret | str | Yes | The API Secret of the GitLab developer application. |
access_token | str | Yes | Access Token for making authenticated requests. |
refresh_token | str | Yes | The key to refresh the expired access token. |
Example request:
from airbyte_agent_gitlab import GitlabConnector
from airbyte_agent_gitlab.models import GitlabOauth20AuthConfig
connector = GitlabConnector(
auth_config=GitlabOauth20AuthConfig(
client_id="<The API ID of the GitLab developer application.>",
client_secret="<The API Secret of the GitLab developer application.>",
access_token="<Access Token for making authenticated requests.>",
refresh_token="<The key to refresh the expired access token.>"
)
)
credentials fields you need:
| Field Name | Type | Required | Description |
|---|---|---|---|
access_token | str | Yes | Log into your GitLab account and generate a personal access token. |
Example request:
from airbyte_agent_gitlab import GitlabConnector
from airbyte_agent_gitlab.models import GitlabPersonalAccessTokenAuthConfig
connector = GitlabConnector(
auth_config=GitlabPersonalAccessTokenAuthConfig(
access_token="<Log into your GitLab account and generate a personal access token.>"
)
)
In hosted mode, you first create a connector via the Airbyte API (providing your OAuth or Token credentials), then execute operations using either the Python SDK or API. If you need a step-by-step guide, see the hosted execution tutorial.
Create a connector with OAuth credentials.
credentials fields you need:
| Field Name | Type | Required | Description |
|---|---|---|---|
client_id | str | Yes | The API ID of the GitLab developer application. |
client_secret | str | Yes | The API Secret of the GitLab developer application. |
access_token | str | Yes | Access Token for making authenticated requests. |
refresh_token | str | Yes | The key to refresh the expired access token. |
replication_config fields you need:
| Field Name | Type | Required | Description |
|---|---|---|---|
start_date | str (date-time) | No | UTC date and time in the format YYYY-MM-DDTHH:mm:ssZ from which to start replicating data. If not set, all data will be replicated. |
Example request:
curl -X POST "https://api.airbyte.ai/api/v1/integrations/connectors" \
-H "Authorization: Bearer <YOUR_BEARER_TOKEN>" \
-H "Content-Type: application/json" \
-d '{
"customer_name": "<CUSTOMER_NAME>",
"connector_type": "Gitlab",
"name": "My Gitlab Connector",
"credentials": {
"client_id": "<The API ID of the GitLab developer application.>",
"client_secret": "<The API Secret of the GitLab developer application.>",
"access_token": "<Access Token for making authenticated requests.>",
"refresh_token": "<The key to refresh the expired access token.>"
},
"replication_config": {
"start_date": "<UTC date and time in the format YYYY-MM-DDTHH:mm:ssZ from which to start replicating data. If not set, all data will be replicated.>"
}
}'
To implement your own OAuth flow, use Airbyte's server-side OAuth API endpoints. For a complete guide, see Build your own OAuth flow.
Request a consent URL for your user.
| Field Name | Type | Required | Description |
|---|---|---|---|
customer_name | string | Yes | Your unique identifier for the customer |
connector_type | string | Yes | The connector type (e.g., "Gitlab") |
redirect_url | string | Yes | URL to redirect to after OAuth authorization |
Example request:
curl -X POST "https://api.airbyte.ai/api/v1/integrations/connectors/oauth/initiate" \
-H "Authorization: Bearer <YOUR_BEARER_TOKEN>" \
-H "Content-Type: application/json" \
-d '{
"customer_name": "<CUSTOMER_NAME>",
"connector_type": "Gitlab",
"redirect_url": "https://yourapp.com/oauth/callback"
}'
Redirect your user to the consent_url from the response.
After the user authorizes access, Airbyte automatically creates the connector and redirects them to your redirect_url with a connector_id query parameter. You don't need to make a separate API call to create the connector.
https://yourapp.com/oauth/callback?connector_id=<connector_id>
Extract the connector_id from the callback URL and store it for future operations. For error handling and a complete implementation example, see Build your own OAuth flow.
Create a connector with Token credentials.
credentials fields you need:
| Field Name | Type | Required | Description |
|---|---|---|---|
access_token | str | Yes | Log into your GitLab account and generate a personal access token. |
replication_config fields you need:
| Field Name | Type | Required | Description |
|---|---|---|---|
start_date | str (date-time) | No | UTC date and time in the format YYYY-MM-DDTHH:mm:ssZ from which to start replicating data. If not set, all data will be replicated. |
Example request:
curl -X POST "https://api.airbyte.ai/api/v1/integrations/connectors" \
-H "Authorization: Bearer <YOUR_BEARER_TOKEN>" \
-H "Content-Type: application/json" \
-d '{
"customer_name": "<CUSTOMER_NAME>",
"connector_type": "Gitlab",
"name": "My Gitlab Connector",
"credentials": {
"access_token": "<Log into your GitLab account and generate a personal access token.>"
},
"replication_config": {
"start_date": "<UTC date and time in the format YYYY-MM-DDTHH:mm:ssZ from which to start replicating data. If not set, all data will be replicated.>"
}
}'
After creating the connector, execute operations using either the Python SDK or API.
If your Airbyte client can access multiple organizations, include organization_id in AirbyteAuthConfig and X-Organization-Id in raw API calls.
Python SDK
from airbyte_agent_gitlab import GitlabConnector, AirbyteAuthConfig
connector = GitlabConnector(
auth_config=AirbyteAuthConfig(
customer_name="<your_customer_name>",
organization_id="<your_organization_id>", # Optional for multi-org clients
airbyte_client_id="<your-client-id>",
airbyte_client_secret="<your-client-secret>"
)
)
@agent.tool_plain # assumes you're using Pydantic AI
@GitlabConnector.tool_utils
async def gitlab_execute(entity: str, action: str, params: dict | None = None):
return await connector.execute(entity, action, params or {})
API
curl -X POST 'https://api.airbyte.ai/api/v1/integrations/connectors/<connector_id>/execute' \
-H 'Authorization: Bearer <YOUR_BEARER_TOKEN>' \
-H 'X-Organization-Id: <YOUR_ORGANIZATION_ID>' \
-H 'Content-Type: application/json' \
-d '{"entity": "<entity>", "action": "<action>", "params": {}}'
The Gitlab connector requires the following configuration variables. These variables are used to construct the base API URL. Pass them via the config parameter when initializing the connector.
| Variable | Type | Required | Default | Description |
|---|---|---|---|---|
api_url | string | Yes | gitlab.com | GitLab instance hostname |