summaryrefslogtreecommitdiff
path: root/app/controllers/concerns/static_object_external_storage.rb
blob: dbfe0ed3adf0c056ef4150558984808a420d1359 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# frozen_string_literal: true

module StaticObjectExternalStorage
  extend ActiveSupport::Concern

  included do
    include ApplicationHelper
  end

  def redirect_to_external_storage
    return if external_storage_request?

    redirect_to external_storage_url_or_path(request.fullpath, project)
  end

  def external_storage_request?
    header_token = request.headers['X-Gitlab-External-Storage-Token']
    return false unless header_token.present?

    external_storage_token = Gitlab::CurrentSettings.static_objects_external_storage_auth_token
    ActiveSupport::SecurityUtils.secure_compare(header_token, external_storage_token) ||
      raise(Gitlab::Access::AccessDeniedError)
  end
end