elastic-logger 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 330784ef74bac199f5f7e8f9312eb147561da20f
4
- data.tar.gz: 92371c2783a123baa12582c0884975adfe62ca18
3
+ metadata.gz: a43d74a210abd4c249c20bc89bc74c51d61267a3
4
+ data.tar.gz: e40dedc5c7eb1ed65f834c7c59fe2ca9333716f2
5
5
  SHA512:
6
- metadata.gz: ac919df31c20c1541f51d6b572905828e2b22ea1f36e82d5a3f3ec64a5ce4a2692d51745a7d975b532c8b79241a85211a8b4ecf607ab2c45af1f9156632a2761
7
- data.tar.gz: 4960f05cff16ed38c99b5c210e2c41827f1dbdbc061ef1f9402ba8d867dd24589d0c13129e7d8cef2fd332eea701f115cb18822b24eff55256146c884fc680c0
6
+ metadata.gz: 6c6a86a4c6416b3f1f7298985673c6d141cff164d438b31c5fc74cc2f3b914e84ab57c7eebf0c295f35ee5c4d37e21cf459fd538b880889b79e3b416e41dfb08
7
+ data.tar.gz: fb61352a4c0d62c0312a09a2eb4f25184a286122285f7d6b50e88302930599813f983b7c663115fd73ef419a9134a8edef8398fe9a67a3d368939a656f042ad6
@@ -1,5 +1,11 @@
1
- require 'elastic_logger/disk_writer'
2
- require 'elastic_logger/elk_writer'
1
+ require 'elastic-logger/configuration'
2
+ require 'elastic-logger/logger'
3
+
4
+ require 'elastic-logger/disk_writer'
5
+ require 'elastic-logger/elk_writer'
6
+ require 'elastic-logger/elk_rotator'
7
+
8
+ require 'elastic-logger/railtie' if defined?(Rails)
3
9
 
4
10
  module ElasticLogger
5
11
  class << self
@@ -0,0 +1,18 @@
1
+ after "deploy", "elastic_logger:rotate"
2
+
3
+ namespace :load do
4
+ task :defaults do
5
+ set :elastic_logger_server_role, -> { :app }
6
+ end
7
+ end
8
+
9
+ namespace :elastic_logger do
10
+ desc 'Sends info about rotations to elastic'
11
+ task :rotate do
12
+ on roles fetch(:elastic_logger_server_role) do
13
+ within(current_path) do
14
+ execute :rake, 'elastic_logger:rotate', fetch(:rails_env)
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,35 @@
1
+ require 'elasticsearch'
2
+ require 'elastic-logger/types'
3
+
4
+ module ElasticLogger
5
+ class ElkRotator
6
+ def rotate
7
+ logs.each do |name, value|
8
+ hash = value.select { |k,v| keys.include?(k) }
9
+ client.index(index: index, type: index, id: name, body: hash)
10
+ end
11
+ end
12
+
13
+ private
14
+
15
+ def logs
16
+ @logs ||= ElasticLogger::Types.new.by_writter('InfaktLogger::ElkWriter')
17
+ end
18
+
19
+ def client
20
+ @client ||= Elasticsearch::Client.new(host: config.host)
21
+ end
22
+
23
+ def config
24
+ ElasticLogger.configuration
25
+ end
26
+
27
+ def index
28
+ 'elastic_logger_rotate'
29
+ end
30
+
31
+ def keys
32
+ ["rotate_type", "rotate", "backup"]
33
+ end
34
+ end
35
+ end
@@ -1,3 +1,5 @@
1
+ require 'elasticsearch'
2
+
1
3
  module ElasticLogger
2
4
  class ElkWriter
3
5
  def initialize(name:, config:)
@@ -0,0 +1,10 @@
1
+ require 'rails/generators'
2
+
3
+ class ElasticLoggerGenerator < Rails::Generators::Base
4
+
5
+ self.source_paths << File.join(File.dirname(__FILE__), 'templates')
6
+
7
+ def create_config_files
8
+ template 'elastic_log_types.yml', 'config/elastic_log_types.yml.example'
9
+ end
10
+ end
@@ -1,3 +1,5 @@
1
+ require 'elastic-logger/types'
2
+
1
3
  module ElasticLogger
2
4
  class Logger
3
5
  def initialize(name)
@@ -24,7 +26,7 @@ module ElasticLogger
24
26
  end
25
27
 
26
28
  def logs
27
- @@logs ||= YAML.load_file(config.types_file)
29
+ @@logs ||= Elasticsearch::Types.new.all
28
30
  end
29
31
 
30
32
  def default
@@ -0,0 +1,11 @@
1
+ module ElasticLogger
2
+ class Railtie < Rails::Railtie
3
+ rake_tasks do
4
+ load 'elastic-logger/rotate.rake'
5
+ end
6
+
7
+ generators do
8
+ require 'elastic-logger/generator'
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,6 @@
1
+ namespace :elastic_logger do
2
+ desc "Sends rotate info to kibana"
3
+ task :rotate do
4
+ ElasticLogger::ElkRotator.new.rotate
5
+ end
6
+ end
@@ -0,0 +1,10 @@
1
+ first_sample_log:
2
+ writer: 'InfaktLogger::ElkWriter'
3
+ rotate_type: 'rotate'
4
+ rotate: 1
5
+ backup: false
6
+ second_sample_log:
7
+ writer: 'InfaktLogger::DiskWriter'
8
+ rotate_type: 'rotate'
9
+ rotate: 3
10
+ backup: false
@@ -0,0 +1,21 @@
1
+ module ElasticLogger
2
+ class Types
3
+ def all
4
+ logs
5
+ end
6
+
7
+ def by_writter(writer)
8
+ logs.select { |_, values| values.fetch("writer") == writer }
9
+ end
10
+
11
+ private
12
+
13
+ def logs
14
+ @@logs ||= YAML.load_file(config.types_file)
15
+ end
16
+
17
+ def config
18
+ ElasticLogger.configuration
19
+ end
20
+ end
21
+ end
@@ -1,3 +1,3 @@
1
1
  module ElasticLogger
2
- VERSION = '0.1.0'
2
+ VERSION = '0.2.0'
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: elastic-logger
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.2.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Radosław Woźnik
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2017-09-10 00:00:00.000000000 Z
12
+ date: 2017-09-11 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: bundler
@@ -50,11 +50,18 @@ files:
50
50
  - README.md
51
51
  - elastic-logger.gemspec
52
52
  - lib/elastic-logger.rb
53
+ - lib/elastic-logger/capistrano.rb
53
54
  - lib/elastic-logger/configuration.rb
54
55
  - lib/elastic-logger/disk_writer.rb
56
+ - lib/elastic-logger/elk_rotator.rb
55
57
  - lib/elastic-logger/elk_writer.rb
58
+ - lib/elastic-logger/generator.rb
56
59
  - lib/elastic-logger/logger.rb
57
60
  - lib/elastic-logger/null_writer.rb
61
+ - lib/elastic-logger/railtie.rb
62
+ - lib/elastic-logger/rotate.rake
63
+ - lib/elastic-logger/templates/elastic_log_types.yml
64
+ - lib/elastic-logger/types.rb
58
65
  - lib/elastic-logger/version.rb
59
66
  homepage: https://github.com/infakt/elastic-logger
60
67
  licenses: