Method: CiscoSparkDiff#run_hook

Defined in:
lib/oxidized/hook/ciscosparkdiff.rb

#run_hook(ctx) ⇒ Object



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/oxidized/hook/ciscosparkdiff.rb', line 13

def run_hook(ctx)
  return unless ctx.node
  return unless ctx.event.to_s == "post_store"

  logger.info "Connecting to Cisco Spark"
  CiscoSpark.configure do |config|
    config.api_key = cfg.accesskey
    config.proxy = cfg.proxy if cfg.has_key?('proxy')
  end
  room = CiscoSpark::Room.new(id: cfg.space)
  logger.info "Connected"

  if cfg.has_key?("diff") ? cfg.diff : true
    gitoutput = ctx.node.output.new
    diff = gitoutput.get_diff ctx.node, ctx.node.group, ctx.commitref, nil
    title = ctx.node.name.to_s
    logger.info "Posting diff as snippet to #{cfg.space}"
    room.send_message CiscoSpark::Message.new(text: "Device #{title} modified:\n" +
                                                    diff[:patch].lines.to_a[4..-1].join)
  end

  if cfg.message?
    logger.info cfg.message
    msg = cfg.message % { node: ctx.node.name.to_s, group: ctx.node.group.to_s, commitref: ctx.commitref,
                          model: ctx.node.model.class.name.to_s.downcase }
    logger.info msg
    logger.info "Posting message to #{cfg.space}"
    room.send_message CiscoSpark::Message.new(text: msg)
  end

  logger.info "Finished"
end