2021-02-08 07:09:20 -05:00
---
stage: Configure
group: Configure
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
type: index, concepts, howto
---
# GitLab ChatOps **(FREE)**
2021-09-07 17:10:59 -04:00
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/4466) in GitLab Ultimate 10.6.
> - [Moved](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/24780) to GitLab Free in 11.9.
2021-09-29 02:09:19 -04:00
> - `CHAT_USER_ID` was [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/341798) in GitLab 14.4.
2021-02-08 07:09:20 -05:00
GitLab ChatOps provides a method to interact with CI/CD jobs through chat services
like Slack. Many organizations' discussion, collaboration, and troubleshooting takes
place in chat services. Having a method to run CI/CD jobs with output
posted back to the channel can significantly augment your team's workflow.
## How GitLab ChatOps works
2021-09-29 11:11:47 -04:00
GitLab ChatOps is built upon [GitLab CI/CD ](../index.md ) and
2021-02-08 07:09:20 -05:00
[Slack Slash Commands ](../../user/project/integrations/slack_slash_commands.md ).
ChatOps provides a `run` action for [slash commands ](../../integration/slash_commands.md )
with the following arguments:
- A `<job name>` to execute.
- The `<job arguments>` .
2021-06-28 11:08:03 -04:00
ChatOps passes the following [CI/CD variables ](../variables/index.md#predefined-cicd-variables )
2021-02-08 07:09:20 -05:00
to the job:
- `CHAT_INPUT` contains any additional arguments.
- `CHAT_CHANNEL` is set to the name of channel the action was triggered in.
2021-09-29 02:09:19 -04:00
- `CHAT_USER_ID` is set to the chat service's user ID of the user who triggered the slash command.
2021-02-08 07:09:20 -05:00
When executed, ChatOps looks up the specified job name and attempts to match it
2021-06-28 17:10:13 -04:00
to a corresponding job in [`.gitlab-ci.yml` ](../yaml/index.md ). If a matching job
2021-06-16 23:09:59 -04:00
is found on the default branch, a pipeline containing only that job is scheduled. After the
2021-02-08 07:09:20 -05:00
job completes:
- If the job completes in *less than 30 minutes* , the ChatOps sends the job's output to Slack.
- If the job completes in *more than 30 minutes* , the job must use the
[Slack API ](https://api.slack.com/ ) to send data to the channel.
2021-07-10 17:08:26 -04:00
To use the `run` command, you must have at least the
2022-01-30 19:14:49 -05:00
Developer role.
2021-02-08 07:09:20 -05:00
If a job shouldn't be able to be triggered from chat, you can set the job to `except: [chat]` .
## Best practices for ChatOps CI jobs
Since ChatOps is built upon GitLab CI/CD, the job has all the same features and
functions available. Consider these best practices when creating ChatOps jobs:
2021-08-10 02:08:47 -04:00
- GitLab strongly recommends you set [`rules` ](../yaml/index.md#rules ) so the job does not run as part
2021-02-08 07:09:20 -05:00
of the standard CI pipeline.
- If the job is set to `when: manual` , ChatOps creates the pipeline, but the job waits to be started.
- ChatOps provides limited support for access control. If the user triggering the
2022-01-30 19:14:49 -05:00
slash command has at least the Developer role
2021-02-08 07:09:20 -05:00
in the project, the job runs. The job itself can use existing
2021-06-28 11:08:03 -04:00
[CI/CD variables ](../variables/index.md#predefined-cicd-variables ) like
2021-02-08 07:09:20 -05:00
`GITLAB_USER_ID` to perform additional rights validation, but
2021-06-28 11:08:03 -04:00
these variables can be [overridden ](../variables/index.md#cicd-variable-precedence ).
2021-02-08 07:09:20 -05:00
### Controlling the ChatOps reply
The output for jobs with a single command is sent to the channel as a reply. For
example, the chat reply of the following job is `Hello World` in the channel:
```yaml
2021-08-10 02:08:47 -04:00
stages:
- chatops
2021-02-08 07:09:20 -05:00
hello-world:
stage: chatops
2021-08-10 02:08:47 -04:00
rules:
2022-04-27 05:10:46 -04:00
- if: $CI_PIPELINE_SOURCE == "chat"
2021-02-08 07:09:20 -05:00
script:
- echo "Hello World"
```
Jobs that contain multiple commands (or `before_script` ) return additional
content in the chat reply. In these cases, both the commands and their output are
included, with the commands wrapped in ANSI color codes.
To selectively reply with the output of one command, its output must be bounded by
the `chat_reply` section. For example, the following job lists the files in the
current directory:
```yaml
2021-08-10 02:08:47 -04:00
stages:
- chatops
2021-02-08 07:09:20 -05:00
ls:
stage: chatops
2021-08-10 02:08:47 -04:00
rules:
2022-04-27 05:10:46 -04:00
- if: $CI_PIPELINE_SOURCE == "chat"
2021-02-08 07:09:20 -05:00
script:
- echo "This command will not be shown."
- echo -e "section_start:$( date +%s ):chat_reply\r\033[0K\n$( ls -la )\nsection_end:$( date +%s ):chat_reply\r\033[0K"
```
## GitLab ChatOps examples
The GitLab.com team created a repository of [common ChatOps scripts ](https://gitlab.com/gitlab-com/chatops )
they use to interact with our Production instance of GitLab. Administrators of
other GitLab instances may find them useful. They can serve as inspiration for ChatOps
scripts you can write to interact with your own applications.
## GitLab ChatOps icon
The [official GitLab ChatOps icon ](img/gitlab-chatops-icon.png ) is available for download.
You can find and download the official GitLab ChatOps icon here.
![GitLab ChatOps bot icon ](img/gitlab-chatops-icon-small.png )
<!-- ## Troubleshooting
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
one might have when setting this up, or when something is changed, or on upgrading, it's
important to describe those, too. Think of things that may go wrong and include them here.
This is important to minimize requests for support, and to avoid doc comments with
questions that you know someone might ask.
Each scenario can be a third-level heading, e.g. `### Getting error message X` .
If you have none to add when creating a doc, leave this section in place
but commented out to help encourage others to add to it in the future. -->