31 lines
1.2 KiB
Ruby
31 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Observability
|
|
module ContentSecurityPolicy
|
|
extend ActiveSupport::Concern
|
|
|
|
included do
|
|
content_security_policy_with_context do |p|
|
|
current_group = if defined?(group)
|
|
group
|
|
else
|
|
defined?(project) ? project&.group : nil
|
|
end
|
|
|
|
next if p.directives.blank? || !Gitlab::Observability.observability_enabled?(current_user, current_group)
|
|
|
|
default_frame_src = p.directives['frame-src'] || p.directives['default-src']
|
|
|
|
# When ObservabilityUI is not authenticated, it needs to be able
|
|
# to redirect to the GL sign-in page, hence '/users/sign_in' and '/oauth/authorize'
|
|
frame_src_values = Array.wrap(default_frame_src) | [Gitlab::Observability.observability_url,
|
|
Gitlab::Utils.append_path(Gitlab.config.gitlab.url,
|
|
'/users/sign_in'),
|
|
Gitlab::Utils.append_path(Gitlab.config.gitlab.url,
|
|
'/oauth/authorize')]
|
|
|
|
p.frame_src(*frame_src_values)
|
|
end
|
|
end
|
|
end
|
|
end
|