onelinejson 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
data/.gitignore ADDED
@@ -0,0 +1,17 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in onelinejson.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2013 Hans Hasselberg
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,29 @@
1
+ # Onelinejson
2
+
3
+ TODO: Write a gem description
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ gem 'onelinejson'
10
+
11
+ And then execute:
12
+
13
+ $ bundle
14
+
15
+ Or install it yourself as:
16
+
17
+ $ gem install onelinejson
18
+
19
+ ## Usage
20
+
21
+ TODO: Write usage instructions here
22
+
23
+ ## Contributing
24
+
25
+ 1. Fork it
26
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
27
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
28
+ 4. Push to the branch (`git push origin my-new-feature`)
29
+ 5. Create new Pull Request
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
@@ -0,0 +1,3 @@
1
+ module Onelinejson
2
+ VERSION = "0.0.1"
3
+ end
@@ -0,0 +1,131 @@
1
+ require "onelinejson/version"
2
+ require 'json'
3
+ require 'lograge'
4
+
5
+ require 'active_support/core_ext/class/attribute'
6
+ require 'active_support/log_subscriber'
7
+
8
+ module Onelinejson
9
+ class TestSubscriber < ActiveSupport::LogSubscriber
10
+ def process_action(event)
11
+ return if ::Lograge.ignore?(event)
12
+
13
+ data = {
14
+ request: {},
15
+ response: {},
16
+ debug_info: {}
17
+ }
18
+ payload = event.payload
19
+
20
+ data[:request].merge! extract_request(payload)
21
+ data[:response].merge! extract_status(payload)
22
+ data[:response].merge! runtimes(event)
23
+ data[:response].merge! location(event)
24
+ data.merge! custom_options(event)
25
+
26
+ formatted_message = ::Lograge.formatter.call(data)
27
+ logger.send(::Lograge.log_level, formatted_message)
28
+ end
29
+
30
+ def redirect_to(event)
31
+ Thread.current[:lograge_location] = event.payload[:location]
32
+ end
33
+
34
+ def logger
35
+ ::Lograge.logger.presence or super
36
+ end
37
+
38
+ private
39
+
40
+ def extract_request(payload)
41
+ Hash[{
42
+ :method => payload[:method],
43
+ :path => extract_path(payload),
44
+ :format => extract_format(payload),
45
+ :controller => payload[:params]['controller'],
46
+ :action => payload[:params]['action'],
47
+ }.merge(payload[:request]).sort]
48
+ end
49
+
50
+ def extract_path(payload)
51
+ payload[:path].split("?").first
52
+ end
53
+
54
+ def extract_format(payload)
55
+ if ::ActionPack::VERSION::MAJOR == 3 && ::ActionPack::VERSION::MINOR == 0
56
+ payload[:formats].first
57
+ else
58
+ payload[:format]
59
+ end
60
+ end
61
+
62
+ def extract_status(payload)
63
+ if payload[:status]
64
+ { :status => payload[:status].to_i }
65
+ elsif payload[:exception]
66
+ exception, message = payload[:exception]
67
+ { :status => 500, :error => "#{exception}:#{message}" }
68
+ else
69
+ { :status => 0 }
70
+ end
71
+ end
72
+
73
+ def custom_options(event)
74
+ ::Lograge.custom_options(event) || {}
75
+ end
76
+
77
+ def runtimes(event)
78
+ {
79
+ :duration => event.duration,
80
+ :view => event.payload[:view_runtime],
81
+ :db => event.payload[:db_runtime]
82
+ }.inject({}) do |runtimes, (name, runtime)|
83
+ runtimes[name] = runtime.to_f.round(2) if runtime
84
+ runtimes
85
+ end
86
+ end
87
+
88
+ def location(event)
89
+ if location = Thread.current[:lograge_location]
90
+ Thread.current[:lograge_location] = nil
91
+ { :location => location }
92
+ else
93
+ {}
94
+ end
95
+ end
96
+ end
97
+
98
+ module AppControllerMethods
99
+ def append_info_to_payload(payload)
100
+ super
101
+ payload[:request] = {
102
+ params: params.reject { |k,v|
103
+ k == 'controller' || k == 'action' || v.is_a?(ActionDispatch::Http::UploadedFile)
104
+ },
105
+ headers: request.headers.env.reject {|k, v| !k.starts_with?("HTTP_") || k == "HTTP_AUTHORIZATION"},
106
+ ip: request.ip,
107
+ uuid: request.env['action_dispatch.request_id'],
108
+ controller: self.class.name,
109
+ date: Time.now.utc.iso8601,
110
+ }
111
+ payload[:request][:user_id] = current_user.id if defined?(current_user) && current_user
112
+ end
113
+ end
114
+
115
+ class JsonFormatter
116
+ def call(data)
117
+ ::JSON.dump(data)
118
+ end
119
+ end
120
+
121
+ class Railtie < Rails::Railtie
122
+ config.lograge = ActiveSupport::OrderedOptions.new
123
+ config.lograge.subscriber = TestSubscriber
124
+ config.lograge.formatter = JsonFormatter.new
125
+ config.lograge.enabled = true
126
+
127
+ ActiveSupport.on_load(:action_controller) do
128
+ include AppControllerMethods
129
+ end
130
+ end
131
+ end
@@ -0,0 +1,24 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'onelinejson/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "onelinejson"
8
+ spec.version = Onelinejson::VERSION
9
+ spec.authors = ["Hans Hasselberg"]
10
+ spec.email = ["me@hans.io"]
11
+ spec.summary = %q{Everything you need to log json oneliners}
12
+ spec.description = %q{Everything you need to log json oneliners}
13
+ spec.homepage = ""
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files`.split($/)
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_dependency "lograge"
22
+ spec.add_development_dependency "bundler", "~> 1.4"
23
+ spec.add_development_dependency "rake"
24
+ end
metadata ADDED
@@ -0,0 +1,102 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: onelinejson
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Hans Hasselberg
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2013-11-19 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: lograge
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ! '>='
20
+ - !ruby/object:Gem::Version
21
+ version: '0'
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ! '>='
28
+ - !ruby/object:Gem::Version
29
+ version: '0'
30
+ - !ruby/object:Gem::Dependency
31
+ name: bundler
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ~>
36
+ - !ruby/object:Gem::Version
37
+ version: '1.4'
38
+ type: :development
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ~>
44
+ - !ruby/object:Gem::Version
45
+ version: '1.4'
46
+ - !ruby/object:Gem::Dependency
47
+ name: rake
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ description: Everything you need to log json oneliners
63
+ email:
64
+ - me@hans.io
65
+ executables: []
66
+ extensions: []
67
+ extra_rdoc_files: []
68
+ files:
69
+ - .gitignore
70
+ - Gemfile
71
+ - LICENSE.txt
72
+ - README.md
73
+ - Rakefile
74
+ - lib/onelinejson.rb
75
+ - lib/onelinejson/version.rb
76
+ - onelinejson.gemspec
77
+ homepage: ''
78
+ licenses:
79
+ - MIT
80
+ post_install_message:
81
+ rdoc_options: []
82
+ require_paths:
83
+ - lib
84
+ required_ruby_version: !ruby/object:Gem::Requirement
85
+ none: false
86
+ requirements:
87
+ - - ! '>='
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ required_rubygems_version: !ruby/object:Gem::Requirement
91
+ none: false
92
+ requirements:
93
+ - - ! '>='
94
+ - !ruby/object:Gem::Version
95
+ version: '0'
96
+ requirements: []
97
+ rubyforge_project:
98
+ rubygems_version: 1.8.23
99
+ signing_key:
100
+ specification_version: 3
101
+ summary: Everything you need to log json oneliners
102
+ test_files: []