Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rohitjmathew/hubot-jenkins-slack-optimised
Jenkins notifier adapted for Slack
https://github.com/rohitjmathew/hubot-jenkins-slack-optimised
coffeescript hubot jenkins slack
Last synced: 27 days ago
JSON representation
Jenkins notifier adapted for Slack
- Host: GitHub
- URL: https://github.com/rohitjmathew/hubot-jenkins-slack-optimised
- Owner: rohitjmathew
- License: mit
- Created: 2019-05-30T11:03:37.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-06-01T21:41:20.000Z (over 5 years ago)
- Last Synced: 2024-10-06T04:04:24.426Z (3 months ago)
- Topics: coffeescript, hubot, jenkins, slack
- Language: CoffeeScript
- Size: 91.8 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# [Hubot][hubot] Jenkins notifier for [Slack][slack]
Respond to [Jenkins][jenkins] notifications in a format appropiated for [Slack][slack] [attachments][slack-attach]. This is a personalised implementation of [hubot-jenkins-slack](https://github.com/inkel/hubot-jenkins-slack).## Installation
In hubot project repository, run:```
npm install hubot-jenkins-slack-optimised --save
```Then add `hubot-jenkins-slack-optimised` to your `external-scripts.json`:
```json
[
"hubot-jenkins-slack-optimised"
]
```You also need [slack-attachment-optimised](https://github.com/rohitjmathew/hubot-slack-attachment-optimised) module installed for version 3 of hubot-slack adapter.
## Screenshots
Below you could see a sample session of `hubot-jenkins-slack-optimised` with:1. a build that finalized with success;
2. a build that starts from our `master` branch;
3. a build that failed;
4. a build that starts from a pull request.![attachments][attachments]
The obscured information in the first line of each notification follows the following pattern: `Jenkins #{job name} #{action} #{job build URL}`.
## Configuration
### Jenkins
You need to enable Jenkins [Notification plugin][notification-plugin] and then, in each project you would like to be notified about, add an endpoint like the following:![Add Notification endpoint][notification-endpoint]
You only need to change `URL` to point to your host. Take into account that the URL path begins with your Hubot instance name, so if your Hubot is named `marvin`, the URL should be `http://example.com/marvin/jenkins` instead.
The `room` query string parameter is required, as an indicator of the channel name where you would like your notification to be displayed. You don't need to prefix your room name with `#`, so if you want your notifications displayed in the `#ci` channel, then you need to pass `?room=ci`.
In case you want to see the message received and the attachment sent, you can also pass `debug=1`.
### Environment variables
The following environment variables define the colors used for each build status:* `HUBOT_JENKINS_COLOR_ABORTED`
* `HUBOT_JENKINS_COLOR_FAILURE`
* `HUBOT_JENKINS_COLOR_FIXED`
* `HUBOT_JENKINS_COLOR_STILL_FAILING`
* `HUBOT_JENKINS_COLOR_SUCCESS`
* `HUBOT_JENKINS_COLOR_DEFAULT`## Commands
This plugin currently offers no commands.## License
This software is licensed under MIT License. See [License][license] for more details.[hubot]: https://hubot.github.com/
[jenkins]: http://jenkins-ci.org/
[slack]: https://slack.com/
[slack-attach]: https://api.slack.com/docs/attachments
[license]: https://github.com/inkel/hubot-jenkins-slack/blob/master/LICENSE
[notification-plugin]: https://wiki.jenkins-ci.org/display/JENKINS/Notification+Plugin
[notification-endpoint]: screenshots/notification-endpoint.png
[attachments]: screenshots/attachments.png