logger-metadata 0.1.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: bafba39702b54356d10b49d0effc9aaa057da8a9
4
+ data.tar.gz: 1ed2b47c177016b22518716ba570bd88146dfeb8
5
+ SHA512:
6
+ metadata.gz: ad681ece92428f041c63ae6aae79edb003c462c649f2b00fbbb5506b7546d79aab5947b9c5e5b51716568083308b58b593a2c0ead49e9b27ce8874b99e68b372
7
+ data.tar.gz: ed5bbda922bf0300565e8c1535aa8a15554e70b8dd5f13e6ff03a6584148bf231580f162dad486abe7174799d586b48eff5f4311e62306f53a46ea327a8f2032
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --format documentation
2
+ --color
@@ -0,0 +1,7 @@
1
+ sudo: false
2
+ language: ruby
3
+ rvm:
4
+ - 2.2.6
5
+ - 2.3.3
6
+ - jruby-9.1.6.0
7
+ before_install: gem install bundler -v 1.13.6
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in logger-metadata.gemspec
4
+ gemspec
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2016 Smartly.io Solutions Oy
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,39 @@
1
+ # Logger::Metadata
2
+
3
+ Enhance Ruby logger with support for key-value metadata.
4
+
5
+ [![Build Status](https://travis-ci.org/smartlyio/logger-metadata.svg?branch=master)](https://travis-ci.org/smartlyio/logger-metadata)
6
+
7
+ ## Installation
8
+
9
+ Logger::Metadata is available as a ruby gem.
10
+
11
+ $ gem install logger-metadata
12
+
13
+ ## Usage
14
+
15
+ ```ruby
16
+ require 'logger-metadata'
17
+
18
+ logger = Logger.new
19
+ Logger::Metadata.inject(logger)
20
+
21
+ logger.metadata(key: 'value') do
22
+ logger.info('message')
23
+ end
24
+ ```
25
+
26
+ All log messages within the metadata block will contain the metadata. Nested
27
+ metadata blocks can be used.
28
+
29
+ Logger::Metadata will augment the default the default formatter to include
30
+ metadata and timestamp. For example
31
+
32
+ ```
33
+ [2016-11-30 14:27:19 +0200] Message (key=value)
34
+ ```
35
+
36
+ ## Rails integration
37
+
38
+ If you include `logger-metadata` in a Rails application Gemfile, metadata
39
+ logging will be automatically set up.
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "logger/metadata"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,44 @@
1
+ require 'logger'
2
+ require 'logger/metadata/version'
3
+ require 'logger/metadata/formatter'
4
+ require 'logger/metadata/railtie' if defined?(Rails)
5
+
6
+ class Logger
7
+ # Metadata mixin for Ruby Logger
8
+ module Metadata
9
+ def flush
10
+ clear_metadata!
11
+ super if defined?(super)
12
+ end
13
+
14
+ def metadata(attributes)
15
+ formatter.metadata(attributes) { yield self }
16
+ end
17
+
18
+ def push_metadata(*args, &block)
19
+ formatter.push_metadata(*args, &block)
20
+ end
21
+
22
+ def pop_metadata(*args, &block)
23
+ formatter.pop_metadata(*args, &block)
24
+ end
25
+
26
+ def clear_metadata!(*args, &block)
27
+ formatter.clear_metadata!(*args, &block)
28
+ end
29
+
30
+ def self.inject(logger)
31
+ logger.formatter ||= default_formatter
32
+ logger.formatter.extend Formatter
33
+ logger.extend(self)
34
+ end
35
+
36
+ def self.default_formatter
37
+ if defined?(ActiveSupport::Logger::SimpleFormatter)
38
+ ActiveSupport::Logger::SimpleFormatter
39
+ else
40
+ Logger::Formatter
41
+ end.new
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,55 @@
1
+ require 'thread'
2
+
3
+ class Logger
4
+ module Metadata
5
+ module Formatter
6
+ def call(severity, timestamp, program_name, message)
7
+ timestamp_string = '[' + timestamp.to_s + ']'
8
+ formatted_message = "#{faint(timestamp_string)} #{message}#{faint(metadata_text)}"
9
+ super(severity, timestamp, program_name, formatted_message)
10
+ end
11
+
12
+ def metadata_stack
13
+ thread_key = @metadata_thread_key ||= "metadata_logging:#{object_id}".freeze
14
+ Thread.current[thread_key] ||= []
15
+ end
16
+
17
+ def current_metadata
18
+ metadata_stack.inject({}, &:merge)
19
+ end
20
+
21
+ def metadata(attributes)
22
+ push_metadata(attributes)
23
+ yield self
24
+ ensure
25
+ pop_metadata
26
+ end
27
+
28
+ def push_metadata(attributes)
29
+ metadata_stack.push attributes
30
+ end
31
+
32
+ def pop_metadata(size = 1)
33
+ metadata_stack.pop size
34
+ end
35
+
36
+ def clear_metadata!
37
+ metadata_stack.clear
38
+ end
39
+
40
+ def metadata_text
41
+ current_metadata.map do |(key, value)|
42
+ " (#{key}=#{value})"
43
+ end.join('')
44
+ end
45
+
46
+ def faint(string)
47
+ if string.empty?
48
+ string
49
+ else
50
+ "\e[2m#{string}\e[0m"
51
+ end
52
+ end
53
+ end
54
+ end
55
+ end
@@ -0,0 +1,19 @@
1
+ require 'action_dispatch'
2
+
3
+ class Logger
4
+ module Metadata
5
+ # Add request_id as metadata to all Rails requests
6
+ class Middleware
7
+ def initialize(app)
8
+ @app = app
9
+ end
10
+
11
+ def call(env)
12
+ request = ActionDispatch::Request.new env
13
+ ::Rails.logger.metadata(request_id: request.request_id) do
14
+ @app.call(env)
15
+ end
16
+ end
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,14 @@
1
+ require 'rails/railtie'
2
+ require 'logger/metadata/middleware'
3
+
4
+ class Logger
5
+ module Metadata
6
+ # Rails integration. Inject metadata-awareness to current Rails logger.
7
+ class Railtie < Rails::Railtie
8
+ initializer after: :initialize_logger do |app|
9
+ Metadata.inject ::Rails.logger
10
+ app.middleware.insert_before(::Rails::Rack::Logger, Middleware)
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,5 @@
1
+ class Logger
2
+ module Metadata
3
+ VERSION = '0.1.1'.freeze
4
+ end
5
+ end
@@ -0,0 +1,28 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'logger/metadata/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "logger-metadata"
8
+ spec.version = Logger::Metadata::VERSION
9
+ spec.authors = ["Ville Lautanala"]
10
+ spec.email = ["lautis@gmail.com"]
11
+
12
+ spec.summary = %q{Metadata-aware Ruby Logger}
13
+ spec.description = %q{Enhance Ruby logger with support for key-value metadata.}
14
+ spec.homepage = "https://github.com/smartlyio/logger-metadata"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
17
+ f.match(%r{^(test|spec|features)/})
18
+ end
19
+ spec.bindir = "exe"
20
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
21
+ spec.require_paths = ["lib"]
22
+
23
+ spec.add_dependency "activesupport"
24
+ spec.add_dependency "actionpack"
25
+ spec.add_development_dependency "bundler", "~> 1.13"
26
+ spec.add_development_dependency "rake", "~> 10.0"
27
+ spec.add_development_dependency "rspec", "~> 3.0"
28
+ end
metadata ADDED
@@ -0,0 +1,128 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: logger-metadata
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.1
5
+ platform: ruby
6
+ authors:
7
+ - Ville Lautanala
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2016-11-30 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: activesupport
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: actionpack
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '1.13'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '1.13'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '10.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '10.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rspec
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '3.0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '3.0'
83
+ description: Enhance Ruby logger with support for key-value metadata.
84
+ email:
85
+ - lautis@gmail.com
86
+ executables: []
87
+ extensions: []
88
+ extra_rdoc_files: []
89
+ files:
90
+ - ".gitignore"
91
+ - ".rspec"
92
+ - ".travis.yml"
93
+ - Gemfile
94
+ - LICENSE.txt
95
+ - README.md
96
+ - Rakefile
97
+ - bin/console
98
+ - bin/setup
99
+ - lib/logger/metadata.rb
100
+ - lib/logger/metadata/formatter.rb
101
+ - lib/logger/metadata/middleware.rb
102
+ - lib/logger/metadata/railtie.rb
103
+ - lib/logger/metadata/version.rb
104
+ - logger-metadata.gemspec
105
+ homepage: https://github.com/smartlyio/logger-metadata
106
+ licenses: []
107
+ metadata: {}
108
+ post_install_message:
109
+ rdoc_options: []
110
+ require_paths:
111
+ - lib
112
+ required_ruby_version: !ruby/object:Gem::Requirement
113
+ requirements:
114
+ - - ">="
115
+ - !ruby/object:Gem::Version
116
+ version: '0'
117
+ required_rubygems_version: !ruby/object:Gem::Requirement
118
+ requirements:
119
+ - - ">="
120
+ - !ruby/object:Gem::Version
121
+ version: '0'
122
+ requirements: []
123
+ rubyforge_project:
124
+ rubygems_version: 2.5.1
125
+ signing_key:
126
+ specification_version: 4
127
+ summary: Metadata-aware Ruby Logger
128
+ test_files: []