--- /dev/null
+/*
+ * Copyright (C) 2014 Andrew Reitz
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Jenkins Notifier
+ *
+ * Checks a Jenkins server at a specific time, if the build fails it will turn on a light. If the build goes from
+ * failing back to succeeding the light will turn off. Hues can also be used in place of the light in order to create
+ * colors for build statuses
+ */
+
+// Automatically generated. Make future change here.
+definition(
+ name: "Jenkins Notifier",
+ namespace: "com.andrewreitz",
+ author: "aj.reitz@gmail.com",
+ description: "Turn off and on devices based on the state that your Jenkins Build is in.",
+ category: "Fun & Social",
+ iconUrl: "http://i.imgur.com/tyIp8wQ.jpg",
+ iconX2Url: "http://i.imgur.com/tyIp8wQ.jpg"
+)
+
+preferences {
+ section("The URL to your Jenkins, including the job you want to monitor. Ex. https://jenkins.example.com/job/myproject/") {
+ input "jenkinsUrl", "text", title: "Jenkins URL"
+ }
+ section("Jenkins Username") {
+ input "jenkinsUsername", "text", title: "Jenkins Username"
+ }
+ section("Jenkins Password") {
+ input "jenkinsPassword", "password", title: "Jenkins Password"
+ }
+ section("On Failed Build Turn On...") {
+ input "switches", "capability.switch", multiple: true, required: false
+ }
+ section("Or Change These Bulbs...") {
+ input "hues", "capability.colorControl", title: "Which Hue Bulbs?", required: false, multiple: true
+ input "colorSuccess", "enum", title: "Hue Color On Success?", required: false, multiple: false, options: getHueColors().keySet() as String[]
+ input "colorFail", "enum", title: "Hue Color On Fail?", required: false, multiple: false, options: getHueColors().keySet() as String[]
+ input "lightLevelSuccess", "number", title: "Light Level On Success?", required: false
+ input "lightLevelFail", "number", title: "Light Level On Fail?", required: false
+ }
+ section("Additional settings", hideable: true, hidden: true) {
+ paragraph("Default check time is 15 Minutes")
+ input "refreshInterval", "decimal", title: "Check Server... (minutes)",
+ description: "Enter time in minutes", defaultValue: 15, required: false
+ }
+}
+
+def installed() {
+ log.debug "Installed with settings: ${settings}"
+ initialize()
+}
+
+def updated() {
+ log.debug "Updated with settings: ${settings}"
+ unsubscribe()
+ initialize()
+}
+
+/** Constants for Hue Colors */
+Map getHueColors() {
+ return [Red: 0, Green: 39, Blue: 70, Yellow: 25, Orange: 10, Purple: 75, Pink: 83]
+}
+
+/** Constant for Saturation */
+int getSaturation() {
+ return 100;
+}
+
+/** Constant for Level */
+int getMaxLevel() {
+ return 100;
+}
+
+def initialize() {
+ def successColor = [switch: "on", hue: getHueColors()[colorSuccess], saturation: getSaturation(), level: lightLevelSuccess ?: getMaxLevel()]
+ def failColor = [switch: "on", hue: getHueColors()[colorFail], saturation: getSaturation(), level: lightLevelFail ?: getMaxLevel()]
+ state.successColor = successColor
+ state.failColor = failColor
+ log.debug "successColor: ${successColor}, failColor: ${failColor}"
+
+ checkServer()
+
+ def cron = "* */${refreshInterval ?: 15} * * * ?"
+ schedule(cron, checkServer)
+}
+
+def checkServer() {
+ log.debug "Checking Server Now"
+
+ def successColor = state.successColor
+ def failColor = state.failColor
+
+ def basicCredentials = "${jenkinsUsername}:${jenkinsPassword}"
+ def encodedCredentials = basicCredentials.encodeAsBase64().toString()
+ def basicAuth = "Basic ${encodedCredentials}"
+
+ def head = ["Authorization": basicAuth]
+
+ log.debug "Auth ${head}"
+
+ def host = jenkinsUrl.contains("lastBuild/api/json") ? jenkinsUrl : "${jenkinsUrl}/lastBuild/api/json"
+
+ httpGet(uri: host, headers: ["Authorization": "${basicAuth}"]) { resp ->
+ def buildError = (resp.data.result == "FAILURE")
+ def buildSuccess = (resp.data.result == "SUCCESS")
+ log.debug "Build Success? ${buildSuccess}"
+ if (buildError) {
+ switches?.on()
+ hues?.setColor(failColor)
+ } else if (buildSuccess) {
+ switches?.off()
+ hues?.setColor(successColor)
+ } // else in some other state, probably building, do nothing.
+
+ }
+}