aserafin/grape_logging

View on GitHub
lib/grape_logging/loggers/response.rb

Summary

Maintainability
A
0 mins
Test Coverage
module GrapeLogging
  module Loggers
    class Response < GrapeLogging::Loggers::Base
      def parameters(_, response)
        response ? { response: serialized_response_body(response) } : {}
      end

      private

      # In some cases, response.body is not parseable by JSON.
      # For example, if you POST on a PUT endpoint, response.body is egal to """".
      # It's strange but it's the Grape behavior...
      def serialized_response_body(response)

        if response.respond_to?(:body)
          # Rack responses
          begin
            response.body.map{ |body| JSON.parse(body.to_s) }
          rescue # No reason to have "=> e" here when we don't use it..
            response.body
          end
        else
          # Error & Exception responses
          response
        end
      end
    end
  end
end