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
|
# frozen_string_literal: true
module API
module Internal
class ErrorTracking < ::API::Base
GITLAB_ERROR_TRACKING_TOKEN_HEADER = "Gitlab-Error-Tracking-Token"
feature_category :observability
helpers do
def verify_error_tracking_token!
input = params['error_tracking_token']
if headers.key?(GITLAB_ERROR_TRACKING_TOKEN_HEADER)
input ||= headers[GITLAB_ERROR_TRACKING_TOKEN_HEADER]
end
input&.chomp!
unauthorized! unless Devise.secure_compare(error_tracking_token, input)
end
def error_tracking_token
Gitlab::CurrentSettings.error_tracking_access_token
end
def error_tracking_enabled?
Gitlab::CurrentSettings.error_tracking_enabled
end
end
namespace 'internal' do
namespace 'error_tracking' do
before do
verify_error_tracking_token!
end
post '/allowed', urgency: :high do
public_key = params[:public_key]
project_id = params[:project_id]
unprocessable_entity! if public_key.blank? || project_id.blank?
project = Project.find(project_id)
enabled = error_tracking_enabled? &&
Feature.enabled?(:gitlab_error_tracking, project) &&
::ErrorTracking::ClientKey.enabled_key_for(project_id, public_key).exists?
status 200
{ enabled: enabled }
end
end
end
end
end
end
|