Sha256: a8aea727c1190cbb811dcae56fd9619bfb0b2c81e32d489a7684884f9df25e41

Contents?: true

Size: 1.42 KB

Versions: 5

Compression:

Stored size: 1.42 KB

Contents

module Timber
  module Util
    module HTTPEvent
      AUTHORIZATION_HEADER = 'authorization'.freeze
      QUERY_STRING_LIMIT = 5_000.freeze

      extend self

      def full_path(path, query_string)
        if query_string
          "#{path}?#{query_string}"
        else
          path
        end
      end

      def normalize_body(body)
        if body.respond_to?(:body)
          body = body.body.to_s
        end

        body[0..(Config.instance.http_body_limit - 1)]
      end

      def normalize_headers(headers)
        if headers.is_a?(::Hash)
          h = headers.each_with_object({}) do |(k, v), h|
            # Force the header into a valid UTF-8 string, otherwise we will encounter
            # encoding issues when we convert this data to json. Moreoever, if the
            # data is already valid UTF-8 we don't pay a penalty.
            h[k] = Timber::Util::String.normalize_to_utf8(v)
          end

          keys_to_sanitize = [AUTHORIZATION_HEADER] + (Config.instance.header_filters || [])
          Util::Hash.sanitize(h, keys_to_sanitize)
        else
          headers
        end
      end

      def normalize_method(method)
        method.is_a?(::String) ? method.upcase : method
      end

      def normalize_query_string(query_string)
        if !query_string.nil?
          query_string = query_string.to_s
        end

        query_string && query_string[0..(QUERY_STRING_LIMIT - 1)]
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
timber-2.0.14 lib/timber/util/http_event.rb
timber-2.0.12 lib/timber/util/http_event.rb
timber-2.0.11 lib/timber/util/http_event.rb
timber-2.0.10 lib/timber/util/http_event.rb
timber-2.0.9 lib/timber/util/http_event.rb