Sha256: 967ad279b7acac988e1692c5542bb1c41215067ddcaec21864fba6aeddbde3d1

Contents?: true

Size: 1.73 KB

Versions: 40

Compression:

Stored size: 1.73 KB

Contents

# frozen_string_literal: true

module Aws
  module Plugins
    # @see Log::Formatter
    # @api private
    class Logging < Seahorse::Client::Plugin

      option(:logger,
        doc_type: 'Logger',
        rbs_type: 'untyped',
        docstring: <<-DOCS
The Logger instance to send log messages to.  If this option
is not set, logging will be disabled.
        DOCS
      )

      option(:log_level,
        default: :info,
        doc_type: Symbol,
        docstring: 'The log level to send messages to the `:logger` at.'
      )

      option(:log_formatter,
        doc_type: 'Aws::Log::Formatter',
        rbs_type: 'untyped',
        doc_default: literal('Aws::Log::Formatter.default'),
        docstring: 'The log formatter.'
      ) do |config|
        Log::Formatter.default if config.logger
      end

      def add_handlers(handlers, config)
        handlers.add(Handler, step: :validate) if config.logger
      end

      class Handler < Seahorse::Client::Handler

        # @param [RequestContext] context
        # @return [Response]
        def call(context)
          context[:logging_started_at] = Time.now
          @handler.call(context).tap do |response|
            context[:logging_completed_at] = Time.now
            log(context.config, response)
          end
        end

        private

        # @param [Configuration] config
        # @param [Response] response
        # @return [void]
        def log(config, response)
          config.logger.send(config.log_level, format(config, response))
        end

        # @param [Configuration] config
        # @param [Response] response
        # @return [String]
        def format(config, response)
          config.log_formatter.format(response)
        end

      end
    end
  end
end

Version data entries

40 entries across 40 versions & 1 rubygems

Version Path
aws-sdk-core-3.214.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.213.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.212.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.211.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.210.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.209.1 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.209.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.208.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.207.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.206.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.205.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.204.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.203.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.202.2 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.202.1 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.202.0 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.201.5 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.201.4 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.201.3 lib/aws-sdk-core/plugins/logging.rb
aws-sdk-core-3.201.2 lib/aws-sdk-core/plugins/logging.rb