Sha256: eecd16db48a1823ca984034b59cd54b2140ce6a109c7896870df8e62fb6062cc

Contents?: true

Size: 1.09 KB

Versions: 8

Compression:

Stored size: 1.09 KB

Contents

# frozen_string_literal: true

module SidekiqUniqueJobs
  #
  # Provides the sidekiq middleware that makes the gem work
  #
  # @author Mikael Henriksson <mikael@zoolutions.se>
  #
  module Logging
    #
    # Context aware logging for Sidekiq Middlewares
    #
    # @author Mikael Henriksson <mikael@zoolutions.se>
    #
    module Middleware
      include Logging

      def self.included(base)
        base.class_eval do
          extend Logging::Middleware
        end
      end

      #
      # Provides a logging context for Sidekiq Middlewares
      #
      #
      # @return [Hash] when logger responds to `:with_context`
      # @return [String] when logger does not responds to `:with_context`
      #
      def logging_context
        middleware = is_a?(SidekiqUniqueJobs::Middleware::Client) ? :client : :server
        digest     = item[UNIQUE_DIGEST]
        lock_type  = item[LOCK]

        if logger_context_hash?
          { "uniquejobs" => middleware, lock_type => digest }
        else
          "uniquejobs-#{middleware} #{"DIG-#{digest}" if digest}"
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
sidekiq-unique-jobs-7.0.0.beta9 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta8 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta7 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta6 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta5 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta4 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta3 lib/sidekiq_unique_jobs/logging/middleware_context.rb
sidekiq-unique-jobs-7.0.0.beta2 lib/sidekiq_unique_jobs/logging/middleware_context.rb