debian-mirror-gitlab/lib/gitlab/safe_request_store.rb

47 lines
1.3 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
module Gitlab
module SafeRequestStore
NULL_STORE = Gitlab::NullRequestStore.new
class << self
# These methods should always run directly against RequestStore
delegate :clear!, :begin!, :end!, :active?, to: :RequestStore
# These methods will run against NullRequestStore if RequestStore is disabled
delegate :read, :[], :write, :[]=, :exist?, :fetch, :delete, to: :store
end
def self.store
if RequestStore.active?
RequestStore
else
NULL_STORE
end
end
2019-02-15 15:39:39 +05:30
2021-09-04 01:27:46 +05:30
# Access to the backing storage of the request store. This returns an object
# with `[]` and `[]=` methods that does not discard values.
#
# This can be useful if storage is needed for a delimited purpose, and the
# forgetful nature of the null store is undesirable.
def self.storage
store.store
end
2019-02-15 15:39:39 +05:30
# This method accept an options hash to be compatible with
# ActiveSupport::Cache::Store#write method. The options are
# not passed to the underlying cache implementation because
# RequestStore#write accepts only a key, and value params.
def self.write(key, value, options = nil)
store.write(key, value)
end
2021-09-04 01:27:46 +05:30
def self.delete_if(&block)
return unless RequestStore.active?
2023-03-04 22:38:38 +05:30
storage.delete_if { |k, v| yield(k) }
2021-09-04 01:27:46 +05:30
end
2018-12-05 23:21:45 +05:30
end
end