kansu 0.0.1

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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 0a03211d26b8dc52b0e7516c1f016b721e3eef59
4
+ data.tar.gz: b7d837abe28a403ef551f027571b0bf08e7427d6
5
+ SHA512:
6
+ metadata.gz: a5ce549b51c8097781e5a32e2a744b34cfd867592eca42b288da95eeb716540392bb363b5e59f3fa4993526e4294709be7cac534efcf0636221615adb298bfd8
7
+ data.tar.gz: 92bd8f0c70629b6a99eb65fe409b4260afa06519ec5718d468dae880ecc4ab46971be195c89da8a02e553c9c1135a506c796ee9cc332915f08827fb925c43195
data/lib/kansu.rb ADDED
@@ -0,0 +1,64 @@
1
+ require 'kansu/persistor'
2
+ require 'kansu/kansu_logger'
3
+ require 'kansu/formatter'
4
+ class Kansu
5
+ attr_reader :persist,:formatter,:debug_mode
6
+
7
+
8
+ def initialize(redis,list_name,debug_mode=true)
9
+ begin
10
+ @persist = Persistor.new(redis,list_name)
11
+ @formatter = Formatter.new
12
+ @debug_mode = debug_mode
13
+ rescue Exception => e
14
+ puts e.message
15
+ end
16
+ end
17
+
18
+ def unknown(message,data)
19
+ kansu_logger = KansuLogger.new(__method__,message,data)
20
+ save(kansu_logger)
21
+ end
22
+
23
+ def fatal(message,data)
24
+ kansu_logger = KansuLogger.new(__method__,message,data)
25
+ save(kansu_logger)
26
+ end
27
+
28
+ def error(message,data)
29
+ kansu_logger = KansuLogger.new(__method__,message,data)
30
+ save(kansu_logger)
31
+ end
32
+
33
+ def warn(message,data)
34
+ kansu_logger = KansuLogger.new(__method__,message,data)
35
+ save(kansu_logger)
36
+ end
37
+
38
+ def info(message,data)
39
+ kansu_logger = KansuLogger.new(__method__,message,data)
40
+ save(kansu_logger)
41
+ end
42
+
43
+ def debug(message,data)
44
+ kansu_logger = KansuLogger.new(__method__,message,data)
45
+ if @debug_mode
46
+ save(kansu_logger)
47
+ end
48
+ end
49
+
50
+
51
+ private
52
+ def save(log)
53
+ if log.is_a?(KansuLogger)
54
+ @persist.save(format_log(log))
55
+ end
56
+
57
+ end
58
+
59
+ def format_log(log)
60
+ @formatter.format_log_to_json(log)
61
+ end
62
+
63
+
64
+ end
@@ -0,0 +1,16 @@
1
+ require 'json'
2
+ class Formatter
3
+
4
+ def format_log_to_json(log)
5
+ json_log = {
6
+ :message => log.message,
7
+ :extra => log.extra,
8
+ :level => log.level,
9
+ :levelName => log.level_name,
10
+ :method => log.method,
11
+ :file => log.file
12
+ }
13
+ json_log.to_json
14
+ end
15
+
16
+ end
@@ -0,0 +1,35 @@
1
+ require 'logger'
2
+ require 'json'
3
+
4
+ class KansuLogger
5
+
6
+ attr_reader :level,:file,:method,:level_name,:extra,:message
7
+
8
+ def initialize(type,message,data)
9
+ @level = get_level(type)
10
+ @level_name = type.upcase
11
+ @file = get_file
12
+ @method = get_method
13
+ @extra = data.to_json
14
+ @message = message
15
+ end
16
+
17
+
18
+ private
19
+ def get_level(type)
20
+ Logger::const_get(type.upcase)
21
+ end
22
+
23
+ def get_file
24
+ path = caller_locations(4,1)[0].path
25
+ end_pos = path.index('.rb') + 3
26
+ start_pos = path.rindex('/') + 1
27
+ path[start_pos..end_pos]
28
+ end
29
+
30
+ def get_method
31
+ caller_locations(4,1)[0].label
32
+ end
33
+
34
+ end
35
+
@@ -0,0 +1,17 @@
1
+ class Persistor
2
+
3
+ attr_reader :redis,:list
4
+
5
+ def initialize(database,list)
6
+ if database.is_a?(Redis) and list != nil
7
+ @redis = database
8
+ @list = list
9
+ else
10
+ raise Exception("Database not recognized")
11
+ end
12
+ end
13
+
14
+ def save(log)
15
+ @redis.lpush(@list,log)
16
+ end
17
+ end
metadata ADDED
@@ -0,0 +1,61 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: kansu
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Sergi Case
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-03-23 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: json
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - '='
18
+ - !ruby/object:Gem::Version
19
+ version: 1.8.3
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - '='
25
+ - !ruby/object:Gem::Version
26
+ version: 1.8.3
27
+ description: 'Gem for log into redis that logstash can read '
28
+ email: sergi-41@hotmail.com
29
+ executables: []
30
+ extensions: []
31
+ extra_rdoc_files: []
32
+ files:
33
+ - lib/kansu.rb
34
+ - lib/kansu/formatter.rb
35
+ - lib/kansu/kansu_logger.rb
36
+ - lib/kansu/persistor.rb
37
+ homepage: http://rubygems.org/gems/kansu
38
+ licenses:
39
+ - MIT
40
+ metadata: {}
41
+ post_install_message:
42
+ rdoc_options: []
43
+ require_paths:
44
+ - lib
45
+ required_ruby_version: !ruby/object:Gem::Requirement
46
+ requirements:
47
+ - - ">="
48
+ - !ruby/object:Gem::Version
49
+ version: '0'
50
+ required_rubygems_version: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ requirements: []
56
+ rubyforge_project:
57
+ rubygems_version: 2.4.6
58
+ signing_key:
59
+ specification_version: 4
60
+ summary: Logger ELK!
61
+ test_files: []