| 1
2
3
4
5
6
7
8
9
10
11
12
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
 | #
#  The redis-alerter.
#
#  This doesn't raise/clear alerts in the traditional sense, instead it just
# stores results in a redis database where you can poll them from a status-panel,
# or similar.
#
#  There is a global set called "hosts" which has the hostname-test-type lists
# and the individual results can be pulled by simple key-fetches on those.
#
module Custodian
  module Alerter
    class RedisAlert < AlertFactory
      #
      # The test this alerter cares about
      #
      attr_reader :test
      #
      # The redis-object
      #
      attr_reader :redis
      #
      # Constructor - save the test-object away & instantiate
      # the redis connection.
      #
      def initialize( obj )
        begin
          require 'rubygems'
          require 'redis'
          @redis = Redis.new(:host => @target )
        rescue
          puts "ERROR Loading redis rubygem!"
        end
        @test  = obj
      end
      #
      # Store an alert in redis
      #
      def raise
        return unless( @redis )
        # hostname + test-type
        host = @test.target
        test = @test.get_type
        # store the error - set an expiry time of 5 minutes
        @redis.set( "#{host}-#{test}", "ERR")
        @redis.expireat( "#{host}-#{test}", Time.now.to_i + 5 * 60 )
        # Set the reason
        @redis.set( "#{host}-#{test}-reason", @test.error() )
        @redis.expireat( "#{host}-#{test}-reason", Time.now.to_i + 5 * 60 )
        # make sure this alert is discoverable
        @redis.sadd( "hosts", "#{host}-#{test}" )
      end
      #
      # Clear an alert in redis
      #
      def clear
        return unless( @redis )
        # hostname + test-type
        host = @test.target
        test = @test.get_type
        # store the OK - set the expiry time of five minutes
        @redis.set( "#{host}-#{test}", "OK")
        @redis.expireat( "#{host}-#{test}", Time.now.to_i + 5 * 60 )
        # clear the reason
        @redis.set( "#{host}-#{test}-reason", "")
        @redis.expireat( "#{host}-#{test}-reason", Time.now.to_i + 5 * 60 )
        # make sure this alert is discoverable
        @redis.sadd( "hosts", "#{host}-#{test}" )
      end
      #
      # Store a test-duration in redis
      #
      def duration( ms )
        return unless( @redis )
        #
        # hostname + test-type
        #
        host = @test.target
        test = @test.get_type
        #
        # Store the host.
        #
        # make sure this alert is discoverable
        @redis.sadd( "duration-hosts", host )
        #
        # Store the test.
        #
        @redis.sadd( "duration-host-#{host}", test )
        #
        # Now store the duration, and trim it to the most recent
        # 1000 entries.
        #
        @redis.lpush( "duration-#{host}-#{test}", ms )
        @redis.ltrim( "duration-#{host}-#{test}", "0", "1200" )
      end
      register_alert_type "redis"
    end
  end
end
 |