Coder Social home page Coder Social logo

jenkins-slack-command's Introduction

jenkins-slack-command

Twitter: @KauseFx License

Start a build in Jenkins using a Slack Command

Slack Command

Incoming Webhook

Features

  • Start a build
    • /jenkins MyAwesomeApp
  • Start a parameterized build
    • /jenkins MyAwesomeApp param1=value1 param2=value2

In Progress

  • Error handling when staring the build fails

Installation

1. Setup Slack integrations

  • Create a new "Slash Command"
    • Name command /jenkins
    • Set the URL to the url of your Heroku instance (created in step 3)
    • Method should be POST
    • Label should be 'Jenkins' or whatevs
  • Create a new "Inbound Webhook" (Optional)
    • Set the channel you would like to post to
    • Set the bot name Jenkins or whatevs

2. Setup environment variables on your Heroku instance

  • Required environment variables
  • SLACK_TOKEN - token from your "Slash Command"
  • JENKINS_URL - URL to your jenkins host
    • NOTE: if your jenkins requires authentication url will look like http://user:auth-token@your-jenkins-host:port. To obtain user authentication token click your name on the top right corner on every page, then click "Configure" to see your API token. (The URL $host/me/configure is a good shortcut.),
  • JENKINS_TOKEN - API token for jenkins job.
    • NOTE: you will need to enable remote builds for every job you would like to invoke remotely. Turn on "Trigger builds remotely (e.g., from scripts)" checkbox under Bild Triggers section in job configuration. Then input any random token and save. You will need to use the same token for all jobs you are planning to build from slack remotely, otherwise jenkins will fail with authentication error.
  • Optional environment variables
    • SLACK_WEBHOOK_URL - your incoming webhook URL

3. Spin up Heroku instance

Deploy

4. Execute command in Slack

/jenkins MyAwesomeApp

FAQ

How do I access my Jenkins server from behind a router?

I used ngrok.com with basic authentication to expose my Jenkins server

Can I integrate with fastlane and call different lanes?

You can! Make a parameterized build with a name called lane (or whatever you want to call it). Make this a string or choice parameter with all your build lanes available as choices (beta, inhouse, app_store). Then use this $lane in your build shell command in your job's configuration - bundle exec fasltane $lane.

To call this from Slack, all you need to do is send /jenkins MyAwesomeApp lane=beta.

Author

Josh Holtz, [email protected], @joshdholtz

License

jenkins-slack-command is available under the MIT license. See the LICENSE file for more info.

jenkins-slack-command's People

Contributors

tigran10 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

jenkins-slack-command's Issues

Heroku deployment fails with ruby "2.0.0"

heroku was complaining about, ruby "2.0.0" and the deployment was not going through from the template. Only after removing the line from Gemfile completely it went through with default ruby version coming from heroku.

ย 

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.