Skip to content

A service that receives hook notifications from GitLab and posts information to an incoming webhook on Slack.

License

Notifications You must be signed in to change notification settings

trongdong/gitlab-slack

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gitlab-slack is a service that receives outgoing webhook notifications from GitLab and posts information to an incoming webhook on Slack.

Information

Features

  • Processes GitLab webhook messages for commits, branches, tags and issues. (more info)
  • Provides Translation from Markdown to Slack formatting syntax for the formatting features that Slack supports. (more info)
  • Issues mentioned anywhere in the commit message are aggregated and provided as links to the right of the commit summary line. (more info)
  • Status and error messages are logged to gitlab-slack.log in the application directory.
  • Changes to tracked labels on issues are notified as issue updates with a summary of label changes as attachments. (more info)

Configuration Syntax

gitlab-slack is configured by values in the config.json file. This file is expected to be in the application directory. The configuration file has the following structure:

{
	"port": 0,
	"slackWebhookUrl": "",
	"gitlab": {
		"baseUrl": "",
		"api": {
			"basePath": "/api/v3",
			"token": ""
		},
		"projects": {
			"0": {
				"name": "",
				"channel": "",
				"labels": [
					""
				]
			}
		}
	}
}
  • port - The port on which to listen. (Default = 21012)
  • slackWebhookUrl - The URL of the Slack incoming webhook. (Example = "https://hooks.slack.com/services/...")
  • gitlab - The GitLab configuration.
    • baseUrl - The protocol/host/port of the GitLab installation. (Example = "https://gitlab.company.com/")
    • api - The GitLab API configuration.
      • basePath - The API base path. (Default = "/api/v3")
      • token - The API token with which to query GitLab. (Example = "hxg1qaDqX8xVELvMefPr")
    • projects - The project configuration. This section defines which projects should be tracked.
      • id - The ID of the project as a string. (Example = "23")
        • name - The name of the project. This value is unused by the service; it is suggested for documentation purposes. (Example = "group/project-name")
        • channel - The Slack channel to which notifications for this project should post. The channel name must be preceded by an octothorpe (#). (Example = "#project-name")
        • labels - Optional. An array of regular expressions used to select issue labels that should be tracked for changes. (Example = [ "^Status:" ])

NOTE: If the service receives a message for a project that is not configured, its notifications will go to the default channel for the incoming webhook.

Feature Details

Attractive and Functional Notifications

gitlab-slack improves upon GitLab's built-in Slack integration with attractive notification formatting that provides more detail and functionality while cutting the fat and remaining as concise as possible.

Commits

Commit Notification
Commit notifications include the repository name and branch, the username of the user who pushed the commit as a link and a list of commits included in the push. Each commit includes the username of the user who made it, the short-form commit hash as a link, the first line of the commit message, and a summary of all issues mentioned in the commit message. (more info)

Tags and Branches

Tag and Branch Notifications
Tag and branch notifications include the repository name, the username of the user who pushed them as a link and the branch or tag name as a link. All commit information for branch creation is discarded as those commits would have already been notified when they were made.

Issues

Issue Notifications
Issue notifications include the repository name, the username of the user performed the issue action, the username of the user to whom the issues is assigned, the milestone to which the issue is assigned and the username of the user who created the issue. Milestones and usernames are formatted as a link. Issue notifications include a main attachment that includes the title of the issue, as a link, and, depending on the kind of action, also the issue description. Additional attachments will be included for changes to tracked labels. (more info)

Issue Mention Summary

As commit messages are truncated to their first line for notification, any issues mentioned elsewhere in the message are summarized as a link at the end of the notified commit message. The following two commit messages...

Added a fun file.

* This is more description.
* Fixed an issue with not having a fun file. (#3)
* Fixed another issue. (#1)
Removed the fun file
* Fixed an issue where there was a fun file. (#8)

...produce the following notification...

Issue Summary

Markdown to Slack Formatting Translation

The following Markdown structures will be translated to a Slack-formatting analogue:

  • Bold
  • Italic
  • Links
  • Headings
  • Bulleted Lists (up to two levels deep)

An issue titled Markdown to Slack formatting is awesome with the following following markdown in the description...

# Heading H1
* Something is _italic_ or *italic*.
* Something else is __bold__ or **bold**.
* Here's a link to [Google](https://google.com).

## Heading H2
* A list with...
  * ...more than one level!
* Back to the base level.

...produces an issue notification similiar to the following...
Markdown to Slack Formatting

Issue Label Change Tracking

For configured projects, label change tracking can be enabled by providing a list of regular expressions defining which labels gitlab-slack should be interested in. When enabled, label changes will be notified in additional attachments following the main summary attachment. Each label attachment will follow the label's configured color and indicate whether the label was Added or Removed.

Issue Label Change Tracking

Installation

nodejs and npm are prerequisites to the installation of this application.

Installing the Service

The /scripts directory contains some example service definitions scripts for various init flavors. Check the README files in those directories for more information about each script.

Adding the GitLab Webhook

The Master or Owner permission level is required to modify webhooks in GitLab.

  1. From the project home, click Settings.
  2. Click Web Hooks.
  3. Enter http://127.0.0.1:PORT into the URL field if, for example, gitlab-slack is running on the same server as GitLab.
    Use the value of the port key from the config.json file in place of PORT.
  4. If gitlab-slack is running on another server, enter the appropriate DNS or URI.
  5. Check the Push events, Tag push events and Issues events options. Merge Request events are not supported.
  6. Click Add Web Hook.

Once added, the webhook can be tested using the Test Hook button.

About

A service that receives hook notifications from GitLab and posts information to an incoming webhook on Slack.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 94.0%
  • Shell 6.0%