debian-mirror-gitlab/app/controllers/concerns/requires_whitelisted_monitoring_client.rb

41 lines
1 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2017-09-10 17:25:29 +05:30
module RequiresWhitelistedMonitoringClient
extend ActiveSupport::Concern
2018-03-17 18:26:18 +05:30
2017-09-10 17:25:29 +05:30
included do
before_action :validate_ip_whitelisted_or_valid_token!
end
private
def validate_ip_whitelisted_or_valid_token!
render_404 unless client_ip_whitelisted? || valid_token?
end
def client_ip_whitelisted?
2019-09-30 21:07:59 +05:30
# Always allow developers to access http://localhost:3000/-/metrics for
# debugging purposes
return true if Rails.env.development? && request.local?
2020-03-13 15:44:24 +05:30
ip_whitelist.any? { |e| e.include?(Gitlab::RequestContext.instance.client_ip) }
2017-09-10 17:25:29 +05:30
end
def ip_whitelist
@ip_whitelist ||= Settings.monitoring.ip_whitelist.map(&IPAddr.method(:new))
end
def valid_token?
token = params[:token].presence || request.headers['TOKEN']
token.present? &&
2019-09-30 21:07:59 +05:30
ActiveSupport::SecurityUtils.secure_compare(
2017-09-10 17:25:29 +05:30
token,
2018-03-17 18:26:18 +05:30
Gitlab::CurrentSettings.health_check_access_token
2017-09-10 17:25:29 +05:30
)
end
def render_404
render file: Rails.root.join('public', '404'), layout: false, status: '404'
end
end