12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- module MonitoringHelper
- class HealthChecker
- class Channels < Backend
- include ActionView::Helpers::DateHelper
- LAST_RUN_TOLERANCE = 1.hour
- OPTIONS_KEYS = %w[host user uid].freeze
- def run_health_check
- scope.each { |channel| single_channel_check(channel) }
- end
- private
- def scope
- Channel.where(active: true)
- end
- def single_channel_check(channel)
- status_in(channel)
- status_out(channel)
- last_fetch(channel)
- end
- def status_in(channel)
- return if channel.status_in != 'error'
- message = status_message(channel, :in)
- response.issues.push "#{message} #{channel.last_log_in}"
- end
- def status_out(channel)
- return if channel.status_out != 'error'
- message = status_message(channel, :out)
- response.issues.push "#{message} #{channel.last_log_out}"
- end
- def status_message(channel, direction)
- message = "Channel: #{channel.area} #{direction} "
- OPTIONS_KEYS.each do |key|
- next if channel.options[key].blank?
- message += "#{key}:#{channel.options[key]};"
- end
- message
- end
- def last_fetch(channel)
- last_fetch = channel.preferences&.dig('last_fetch')
- return if !last_fetch
- return if last_fetch >= LAST_RUN_TOLERANCE.ago
- message = status_message(channel, :in)
- response.issues.push "#{message} is active but not fetched for #{time_ago_in_words(last_fetch)}"
- end
- end
- end
- end
|