lib/grape/error_formatter/base.rb in grape-0.8.0 vs lib/grape/error_formatter/base.rb in grape-0.9.0
- old
+ new
@@ -24,8 +24,36 @@
else
spec
end
end
end
+
+ module_function
+
+ def present(message, env)
+ present_options = {}
+ present_options[:with] = message.delete(:with) if message.is_a?(Hash)
+
+ presenter = env['api.endpoint'].entity_class_for_obj(message, present_options)
+
+ unless presenter || env['rack.routing_args'].nil?
+ # env['api.endpoint'].route does not work when the error occurs within a middleware
+ # the Endpoint does not have a valid env at this moment
+ http_codes = env['rack.routing_args'][:route_info].route_http_codes || []
+ found_code = http_codes.find do |http_code|
+ (http_code[0].to_i == env['api.endpoint'].status) && http_code[2].respond_to?(:represent)
+ end
+
+ presenter = found_code[2] if found_code
+ end
+
+ if presenter
+ embeds = { env: env }
+ embeds[:version] = env['api.version'] if env['api.version']
+ message = presenter.represent(message, embeds).serializable_hash
+ end
+
+ message
+ end
end
end
end