Class: Kennel::Models::Monitor
- Includes:
- OptionalValidations
- Defined in:
- lib/kennel/models/monitor.rb
Constant Summary collapse
- RENOTIFY_INTERVALS =
minutes
[0, 10, 20, 30, 40, 50, 60, 90, 120, 180, 240, 300, 360, 720, 1440].freeze
- OPTIONAL_SERVICE_CHECK_THRESHOLDS =
[:ok, :warning].freeze
- READONLY_ATTRIBUTES =
superclass::READONLY_ATTRIBUTES + [ :multi, :matching_downtimes, :overall_state_modified, :overall_state, :restricted_roles ]
- TRACKING_FIELD =
:message
- MONITOR_DEFAULTS =
{ priority: nil }.freeze
- MONITOR_OPTION_DEFAULTS =
defaults that datadog uses when options are not sent, so safe to leave out if our values match their defaults
{ evaluation_delay: nil, new_host_delay: 300, timeout_h: 0, renotify_interval: 0, notify_audit: false, no_data_timeframe: nil, # this works out ok since if notify_no_data is on, it would never be nil groupby_simple_monitor: false }.freeze
- DEFAULT_ESCALATION_MESSAGE =
["", nil].freeze
- ALLOWED_PRIORITY_CLASSES =
[NilClass, Integer].freeze
Constants inherited from Record
Record::LOCK, Record::TRACKING_FIELDS
Constants inherited from Base
Base::SETTING_OVERRIDABLE_METHODS
Constants included from SettingsAsMethods
SettingsAsMethods::SETTING_OVERRIDABLE_METHODS
Instance Attribute Summary
Attributes inherited from Record
Class Method Summary collapse
- .api_resource ⇒ Object
- .normalize(expected, actual) ⇒ Object
- .parse_url(url) ⇒ Object
- .url(id) ⇒ Object
Instance Method Summary collapse
Methods included from OptionalValidations
Methods inherited from Record
#add_tracking_id, api_resource_map, #diff, #initialize, parse_any_url, parse_tracking_id, remove_tracking_id, #remove_tracking_id, #tracking_id
Methods inherited from Base
Methods included from SubclassTracking
#recursive_subclasses, #subclasses
Methods included from SettingsAsMethods
included, #initialize, #raise_with_location
Constructor Details
This class inherits a constructor from Kennel::Models::Record
Class Method Details
.api_resource ⇒ Object
129 130 131 |
# File 'lib/kennel/models/monitor.rb', line 129 def self.api_resource "monitor" end |
.normalize(expected, actual) ⇒ Object
149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 |
# File 'lib/kennel/models/monitor.rb', line 149 def self.normalize(expected, actual) super ignore_default(expected, actual, MONITOR_DEFAULTS) = actual.fetch(:options) .delete(:silenced) # we do not manage silenced, so ignore it when diffing # fields are not returned when set to true if ["service check", "event alert"].include?(actual[:type]) [:include_tags] = true unless .key?(:include_tags) [:require_full_window] = true unless .key?(:require_full_window) end case actual[:type] when "event alert" # setting nothing results in thresholds not getting returned from the api [:thresholds] ||= { critical: 0 } when "service check" # fields are not returned when created with default values via UI OPTIONAL_SERVICE_CHECK_THRESHOLDS.each do |t| [:thresholds][t] ||= 1 end end # nil / "" / 0 are not returned from the api when set via the UI [:evaluation_delay] ||= nil = expected[:options] || {} ignore_default(, , MONITOR_OPTION_DEFAULTS) if DEFAULT_ESCALATION_MESSAGE.include?([:escalation_message]) .delete(:escalation_message) .delete(:escalation_message) end end |
.parse_url(url) ⇒ Object
137 138 139 140 141 142 143 144 145 146 147 |
# File 'lib/kennel/models/monitor.rb', line 137 def self.parse_url(url) # datadog uses / for show and # for edit as separator in it's links id = url[/\/monitors[\/#](\d+)/, 1] # slo alert url id ||= url[/\/slo\/edit\/[a-z\d]{10,}\/alerts\/(\d+)/, 1] return unless id Integer(id) end |
.url(id) ⇒ Object
133 134 135 |
# File 'lib/kennel/models/monitor.rb', line 133 def self.url(id) Utils.path_to_url "/monitors##{id}/edit" end |
Instance Method Details
#as_json ⇒ Object
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 |
# File 'lib/kennel/models/monitor.rb', line 58 def as_json return @as_json if @as_json data = { name: "#{name}#{LOCK}", type: type, query: query.strip, message: .strip, tags: .uniq, priority: priority, options: { timeout_h: timeout_h, notify_no_data: notify_no_data, no_data_timeframe: notify_no_data ? no_data_timeframe : nil, notify_audit: notify_audit, require_full_window: require_full_window, new_host_delay: new_host_delay, new_group_delay: new_group_delay, include_tags: true, escalation_message: Utils.presence(.strip), evaluation_delay: evaluation_delay, locked: false, # setting this to true prevents any edit and breaks updates when using replace workflow renotify_interval: renotify_interval || 0 } } data[:id] = id if id = data[:options] if data.fetch(:type) != "composite" thresholds = ([:thresholds] = { critical: critical }) # warning, ok, critical_recovery, and warning_recovery are optional [:warning, :ok, :critical_recovery, :warning_recovery].each do |key| if value = send(key) thresholds[key] = value end end thresholds[:critical] = critical unless case data.fetch(:type) when "service check" # avoid diff for default values of 1 OPTIONAL_SERVICE_CHECK_THRESHOLDS.each { |t| thresholds[t] ||= 1 } when "query alert" # metric and query values are stored as float by datadog thresholds.each { |k, v| thresholds[k] = Float(v) } end end if windows = threshold_windows [:threshold_windows] = windows end # Datadog requires only either new_group_delay or new_host_delay, never both .delete([:new_group_delay] ? :new_host_delay : :new_group_delay) validate_json(data) if validate @as_json = data end |
#resolve_linked_tracking_ids!(id_map, **args) ⇒ Object
119 120 121 122 123 124 125 126 127 |
# File 'lib/kennel/models/monitor.rb', line 119 def resolve_linked_tracking_ids!(id_map, **args) case as_json[:type] when "composite", "slo alert" type = (as_json[:type] == "composite" ? :monitor : :slo) as_json[:query] = as_json[:query].gsub(/%{(.*?)}/) do resolve($1, type, id_map, **args) || $& end end end |