# frozen_string_literal: true module SidekiqUniqueJobs # ThreadSafe config exists to be able to document the config class without errors ThreadSafeConfig = Concurrent::MutableStruct.new("ThreadSafeConfig", :lock_timeout, :lock_ttl, :enabled, :lock_prefix, :logger, :logger_enabled, :locks, :strategies, :debug_lua, :max_history, :reaper, :reaper_count, :reaper_interval, :reaper_timeout, :reaper_resurrector_interval, :reaper_resurrector_enabled, :lock_info, :raise_on_config_error, :current_redis_version) # # Shared class for dealing with gem configuration # # @author Mauro Berlanda # rubocop:disable Metrics/ClassLength class Config < ThreadSafeConfig # # @return [Hash , # locks: { # around_perform: SidekiqUniqueJobs::Lock::WhileExecuting, # while_busy: SidekiqUniqueJobs::Lock::WhileExecuting, # while_executing: SidekiqUniqueJobs::Lock::WhileExecuting, # while_working: SidekiqUniqueJobs::Lock::WhileExecuting, # while_executing_reject: SidekiqUniqueJobs::Lock::WhileExecutingReject, # until_executing: SidekiqUniqueJobs::Lock::UntilExecuting, # while_enqueued: SidekiqUniqueJobs::Lock::UntilExecuting, # until_expired: SidekiqUniqueJobs::Lock::UntilExpired, # until_completed: SidekiqUniqueJobs::Lock::UntilExecuted, # until_executed: SidekiqUniqueJobs::Lock::UntilExecuted, # until_performed: SidekiqUniqueJobs::Lock::UntilExecuted, # until_processed: SidekiqUniqueJobs::Lock::UntilExecuted, # until_and_while_executing: SidekiqUniqueJobs::Lock::UntilAndWhileExecuting, # until_successfully_completed: SidekiqUniqueJobs::Lock::UntilExecuted # }, # strategies: { # log: SidekiqUniqueJobs::OnConflict::Log, # raise: SidekiqUniqueJobs::OnConflict::Raise, # reject: SidekiqUniqueJobs::OnConflict::Reject, # replace: SidekiqUniqueJobs::OnConflict::Replace, # reschedule: SidekiqUniqueJobs::OnConflict::Reschedule # }, # debug_lua: false, # max_history: 1000, # reaper:: ruby, # reaper_count: 1000, # lock_info: false, # raise_on_config_error: false, # }> # # # @return [SidekiqUniqueJobs::Config] a default configuration # def self.default # rubocop:disable Metrics/MethodLength new( LOCK_TIMEOUT, LOCK_TTL, ENABLED, PREFIX, Sidekiq.logger, LOGGER_ENABLED, LOCKS, STRATEGIES, DEBUG_LUA, MAX_HISTORY, REAPER, REAPER_COUNT, REAPER_INTERVAL, REAPER_TIMEOUT, REAPER_RESURRECTOR_INTERVAL, REAPER_RESURRECTOR_ENABLED, USE_LOCK_INFO, RAISE_ON_CONFIG_ERROR, REDIS_VERSION, ) end # # Set the default_lock_ttl # @deprecated # # @param [Integer] obj value to set (seconds) # # @return [] # def default_lock_ttl=(obj) warn "[DEPRECATION] `#{class_name}##{__method__}` is deprecated." \ " Please use `#{class_name}#lock_ttl=` instead." self.lock_ttl = obj end # # Set new value for default_lock_timeout # @deprecated # # @param [Integer] obj value to set (seconds) # # @return [Integer] # def default_lock_timeout=(obj) warn "[DEPRECATION] `#{class_name}##{__method__}` is deprecated." \ " Please use `#{class_name}#lock_timeout=` instead." self.lock_timeout = obj end # # Default lock TTL (Time To Live) # @deprecated # # @return [nil, Integer] configured value or nil # def default_lock_ttl warn "[DEPRECATION] `#{class_name}##{__method__}` is deprecated." \ " Please use `#{class_name}#lock_ttl` instead." lock_ttl end # # Default Lock Timeout # @deprecated # # # @return [nil, Integer] configured value or nil # def default_lock_timeout warn "[DEPRECATION] `#{class_name}##{__method__}` is deprecated." \ " Please use `#{class_name}#lock_timeout` instead." lock_timeout end # # Memoized variable to get the class name # # # @return [String] name of the class # def class_name @class_name ||= self.class.name end # # Adds a lock type to the configuration. It will raise if the lock exists already # # @example Add a custom lock # add_lock(:my_lock, CustomLocks::MyLock) # # @raise DuplicateLock when the name already exists # # @param [String, Symbol] name the name of the lock # @param [Class] klass the class describing the lock # # @return [void] # def add_lock(name, klass) lock_sym = name.to_sym raise DuplicateLock, ":#{name} already defined, please use another name" if locks.key?(lock_sym) new_locks = locks.dup.merge(lock_sym => klass).freeze self.locks = new_locks end # # Adds an on_conflict strategy to the configuration. # # @example Add a custom strategy # add_lock(:my_strategy, CustomStrategies::MyStrategy) # # @raise [DuplicateStrategy] when the name already exists # # @param [String] name the name of the custom strategy # @param [Class] klass the class describing the strategy # def add_strategy(name, klass) strategy_sym = name.to_sym raise DuplicateStrategy, ":#{name} already defined, please use another name" if strategies.key?(strategy_sym) new_strategies = strategies.dup.merge(strategy_sym => klass).freeze self.strategies = new_strategies end # # The current version of redis # # # @return [String] a version string eg. `5.0.1` # def redis_version self.current_redis_version = SidekiqUniqueJobs.fetch_redis_version if current_redis_version == REDIS_VERSION current_redis_version end end # rubocop:enable Metrics/ClassLength end