Sha256: 67fb4ea0a83a4281b9dce5214ae9d79c463b11c7c340e0947d3836f983bf9e3f

Contents?: true

Size: 2 KB

Versions: 1

Compression:

Stored size: 2 KB

Contents

require 'rubygems'

unless ENV['RSPEC']
  require 'chef'
  require 'chef/handler'
end
require 'hipchat'
require 'slack-notifier'

class StatusNotifierHandler < Chef::Handler

  DEFAULT_FAILED_MESSAGE  = '"Failure on #{node.name}: #{run_status.formatted_exception}"'.freeze
  DEFAULT_SUCCESS_MESSAGE = '"Chef run succesfully on #{node.name}"'.freeze

  def initialize(slack_params, hipchat_params, custom_message_params = {})
    @slack_params   = slack_params
    @hipchat_params = hipchat_params
    @custom_message_params = custom_message_params
  end

  def report
    if run_status.failed?
      msg = failed_message
      status = :failed
      send_to_hipchat(msg)
    else
      msg = success_message
      status = :success
    end

    send_to_slack(node.name, status, msg)
    send_to_hipchat(msg)
  end

  private

  def eval_message_for(message)
    return nil if message.nil?
    eval(message)
  end

  def failed_message
    eval_message_for(@custom_message_params[:failed_message] || DEFAULT_FAILED_MESSAGE)
  end

  def success_message
    eval_message_for(@custom_message_params[:success_message] || DEFAULT_SUCCESS_MESSAGE)
  end

  def send_to_hipchat(msg)
    return unless @hipchat_params[:enabled]
    hipchat[@hipchat_params[:room_name]].send(@hipchat_params[:username], msg, :notify => @hipchat_params[:notify])
  end

  def send_to_slack(node_name, status, msg)
    return unless @slack_params[:enabled]
    slack.ping '', attachments: [slack_attachment(node_name, status, msg)], channel: @slack_params[:channel], username: @slack_params[:username]
  end

  def hipchat
    @hipchat ||= HipChat::Client.new(@hipchat_params[:api_token])
  end

  def slack
    @slack ||= Slack::Notifier.new(@slack_params[:webhook_url])
  end

  def slack_attachment(node_name, status, msg)
    color = (status == :failed)? "#ff0000" : "#36a64f"
    {
      fallback: "Chef status, #{msg}",
      color: "#{color}",
      author_name: "Fai's Slave (#{node_name})",
      title: "status: #{status}",
      text: "#{msg}"
    }
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
chef-handler-status_notifier-0.5.0 lib/chef/handler/status_notifier.rb