GitXplorerGitXplorer
t

grape-middleware-lograge

public
8 stars
19 forks
6 issues

Commits

List of commits on branch master.
Unverified
3daaa11d71140a41f044d6a5cea58454239faded

bump version

ttchak committed 9 years ago
Unverified
5ca3dc9d5b9c17cc6f9a25096792ce6801c38e23

stringify remote_ip

ttchak committed 9 years ago
Unverified
568e08f4dcf584b5c02f8bfa3114984650488267

do not override rescue responses

ttchak committed 9 years ago
Unverified
44058d594985b74090e5ef06b63cab8c81086add

test ruby 2.3.0 on travis

ttchak committed 9 years ago
Unverified
52bbad78b888f588610e1980de7013b9c0ba4a2d

bump version

ttchak committed 9 years ago
Unverified
5dbb5a9370d1fc7f348ea802526636eb2c68fb48

leave custom_options alone

ttchak committed 9 years ago

README

The README file for this repository.

A logger for Grape apps that uses Lograge

Code Climate Gem Version Build Status

Logs:

  • Request path
  • Parameters
  • Endpoint class name and handler
  • Response status
  • Duration of the request
  • Exceptions
  • Error responses from error!

Installation

Add this line to your application's Gemfile:

gem 'grape', '>= 0.14.0'
gem 'grape-middleware-lograge'

Usage

class API < Grape::API
  # @note Make sure this above you're first +mount+
  use Grape::Middleware::Lograge
end

Server requests will be logged to STDOUT by default.

Custom setup

Customize the logging by passing the filter option. Example using parameter sanitization:

use Grape::Middleware::Lograge, {
  filter: CustomFilter.new
}

The filter option can be any object that responds to .filter(params_hash)

Example output

Get

Started GET "/v1/reports/101" at 2015-12-11 15:40:51 -0800
Processing by ReportsAPI#reports/:id
  Parameters: {"id"=>"101"}
Completed 200 in 6.29ms

Error

Started POST "/v1/reports" at 2015-12-11 15:42:33 -0800
Processing by ReportsAPI#reports
  Parameters: {"name"=>"foo", "password"=>"[FILTERED]"}
  Error: {:error=>"undefined something something bad", :detail=>"Whoops"}
Completed 422 in 6.29ms

Using Rails?

Rails.application.config.filter_parameters will be used automatically as the default param filterer.

Rack

If you're using the rackup command to run your server in development, pass the -q flag to silence the default rack logger.

Credits

This code is forked from grape-middleware-logger.

Big thanks to jadent's question/answer on stackoverflow for easily logging error responses. Borrowed some motivation from the grape_logging gem and would love to see these two consolidated at some point.

Contributing

  1. Fork it ( https://github.com/tchak/grape-middleware-lograge/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request