Sha256: 526fe6053a0e0c27c9997669989de5164266dfd2f538f962aa9324ca07282b19
Contents?: true
Size: 1.85 KB
Versions: 2
Compression:
Stored size: 1.85 KB
Contents
require_relative 'log_repository' module RTALogger # propagate log records to multiple log repositories class LogPropagator def initialize @semaphore = Mutex.new @records = [] @repositories = [] end attr_reader :repositories def add_log(record) @semaphore.synchronize { @records.push(record.dup) } end def add_log_repository(repository) return unless repository.is_a? RTALogger::LogRepository @repositories.push(repository) unless @repositories.include?(repository) end def load_log_repository(config_json) type = config_json['type'] return if type.to_s.strip.empty? enable = config_json['enable'].nil? ? true : config_json['enable'] return unless enable repository = ::RTALogger::LogFactory.create_repository(type, config_json) add_log_repository(repository) end def drop_all_repositories @semaphore.synchronize { @repositories.clear } end def repository_by_title(title) result = nil @semaphore.synchronize do @repositories.keys.each do |repository_key| result = @repositories[repository_key.to_sym] if repository_key.to_s.casecmp(title).zero? break if result end end return result end def apply_run_time_config(config_json) return unless config_json if config_json['repositories'] config_json['repositories'].each do |repository_config| next if repository_config['title'].nil? repository = repository_by_title(repository_config['title']) repository.apply_run_time_config(repository_config) if repository end end end def propagate @semaphore.synchronize do @repositories.each do |repository| repository.add_log_records(@records) end @records.clear end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
RTALogger-2.0.2 | lib/log_propagator.rb |
RTALogger-2.0.1 | lib/log_propagator.rb |