Guidelines for automation and access tokens
Overview
Token management is crucial in providing authentication and authorization within various systems and subsystems used by GitLab. The token overview will assist in identifying the tokens used in GitLab. Refer to the Token Management Standard for approved token usage and distribution.
Guidelines for automation and access tokens
Automations for the gitlab-org
group and projects under it can be split into three categories:
- Automation for repository, packages, container registry within a project: a project deploy token is sufficient.
- Automation via API within a project: a project access token is sufficient.
- Automation via API within a group: a group access token is sufficient.
These guidelines ensure consistency for Engineering automation using approved secure patterns aligned with least privileged access principle.
Merge request automation guidelines
Automation that opens a merge request in projects under gitlab-org
shall apply the ~"automation:bot-authored"
label for clearer measurements for bot authored MRs that may cause an impact to Engineering PIs.
Access token best practices
Don’t reuse an existing token
Never reuse an existing token for your own automation, as this makes it harder to track what a token is used for. It also increases the number of changes required if the token is revoked.
Use project access tokens by default
By default, and when possible, create a new project access token for any API automation, and follow these guidelines:
- Create a suitable name for the access token. Keep in mind that this is also the name of the bot user created for the token.
- Always set an expiration date for the token, even if this is for temporary automation.
- Give the token the minimum scopes your automation requires (usually the
api
scope).
Project access tokens have a few known limitations, but dogfooding them can only help us improve the feature.
Use a project deploy token for repository, packages, or container registry automation
Create a new project deploy token for repository, packages, or container registry automation.
Follow the same guidelines as for the project access tokens above.
Use a specific service account token when project access tokens can’t be used
For cases where automation is applied at the group level or across multiple projects, and where the Maintainer permission is required to perform the automation (for example, to post restricted quick actions), you can request a new service account that will be owned by a specific team.
List of automations currently in place
GitLab uses automation to streamline engineering processes, such as:
- Danger bot for merge request hygiene. We use the Danger bot group access token.
- Triage ops for automated:
- Scheduled reminders and reports of issues and merge requests. Requires a service account.
- Real-time reaction to events on issues and merge requests. Requires a service account.
- Allure test reports. We use the End-to-end tests Allure report project access token to post Allure test report on merge requests that run end-to-end tests against their Review App.
- Asynchronous retrospective generation. Can use a project access tokens unless fetching confidential issues.
- GitLab Runner releases. Requires a service account.
- Repository mirroring. Requires a service account.
Current and potential GitLab.com service accounts
@gitlab-bot
owned by the Engineering Productivity team, running various things. We’re breaking this down into multiple dedicated service accounts.@gitlab-qa
owned by the Quality department, running QA-related automation.@gitlab-release-tools-bot
owned by the Delivery team, running delivery/release-related automation.@gl-build-trigger
owned by the Distribution group, triggering build-related pipelines.@gitlab-omnibus-mirror-bot
owned by the Distribution group, mirroring various dependency projects of thegitlab-org/omnibus-gitlab
project.- Triage operations for
gitlab-org/quality/triage-ops
,gitlab-org/gitlab-triage
owned by the Engineering Productivity team.
Background on the single @gitlab-bot
service account
Previously, we had a single @gitlab-bot
service account that we used for almost all of our automated processes.
This had two main drawbacks:
- If the bot hit the API rate limit, we had to disable the rate limit. This meant that an infinite-loop script could lead to a DoS (denial-of-service) against our own API.
- It caused security concerns:
- Reusing the same token everywhere creates a lot of disruption if the token is leaked and needs to be rotated.
- The service account credentials were accessible to the whole Engineering division. Anyone could log into the bot’s account and create their own access token.
We are in the process of:
- Moving the
@gitlab-bot
service account credentials to an Engineering Productivity 1Password vault, to stop the self-service of creating tokens. - Migrating the current
@gitlab-bot
’s tokens to project access tokens where possible, and to specific service accounts for the other cases.
e353870b
)