logdna 1.0.5 → 1.0.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +16 -7
- data/lib/logdna.rb +98 -30
- data/lib/logdna/client.rb +6 -2
- data/lib/logdna/resources.rb +1 -1
- data/lib/logdna/version.rb +1 -1
- data/test.rb +15 -3
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6da31685ff73906727582ec00d03ce4e2769032f
|
4
|
+
data.tar.gz: f9926e2524488199bd6d3a7e8893ce051250434a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 9655acac1f9eaafe8f0e37a17d90159bbcb8cfe2745bfaa1cef3327b0b3550ce3dbbd1b1178bdb83bc17422add250e3440bcf09ec1b8365f18a540c4df7454fe
|
7
|
+
data.tar.gz: 72ae741872be4ef83cbceb9271bfedf7987939a558afbfc6d315a34e372cc0708d851c79d75735bf389bf0fa80cfa12887d8a8a8b905cf8e4a6729ece9f73f51
|
data/README.md
CHANGED
@@ -55,16 +55,11 @@ Options are optional variables that may contain hostname, app name, mac address,
|
|
55
55
|
|
56
56
|
To send logs, use "log" method.
|
57
57
|
|
58
|
-
require 'logdna'
|
59
|
-
|
60
|
-
logger = LogDNA::Ruby.new(your_ingestion_key, options)
|
61
|
-
=> #<Logdna::Ruby:0x00000000000000>
|
62
|
-
|
63
58
|
logger.log('This is my first log')
|
64
59
|
=> "Saved" # Saved to buffer. Ready to be flushed automatically
|
65
60
|
|
66
61
|
|
67
|
-
By default, it will log at the level of "INFO" unless you specified otherwise during initialzation of the logger.
|
62
|
+
By default, it will log at the level of "INFO" unless you specified otherwise during the initialzation of the logger.
|
68
63
|
You can change a particular message's log level.
|
69
64
|
|
70
65
|
logger.log('This is warn message', {:level => "WARN"})
|
@@ -77,7 +72,21 @@ You can also send a metadata with your message by specifying 'meta' field
|
|
77
72
|
|
78
73
|
Hostname and app name cannot be more than 80 characters.
|
79
74
|
|
80
|
-
|
75
|
+
This logger extends the standard Ruby logger and inherits some of the conventions from it.
|
76
|
+
|
77
|
+
logger.info('This is info log') # same as logger.log('This is info message', {:level => "INFO"})
|
78
|
+
logger.info? => true
|
79
|
+
logger.trace('trace log')
|
80
|
+
logger.error('error log')
|
81
|
+
|
82
|
+
You can also set logger level, environment, app name this way:
|
83
|
+
|
84
|
+
logger.env = 'PRODUCTION'
|
85
|
+
logger.app = 'NEW APP NAME'
|
86
|
+
logger.level = 'FATAL'
|
87
|
+
logger.level = Logger::FATAL
|
88
|
+
|
89
|
+
|
81
90
|
|
82
91
|
|
83
92
|
# Important Notes
|
data/lib/logdna.rb
CHANGED
@@ -4,7 +4,8 @@ require 'socket'
|
|
4
4
|
require_relative 'logdna/client.rb'
|
5
5
|
require_relative 'logdna/resources.rb'
|
6
6
|
module Logdna
|
7
|
-
class Ruby
|
7
|
+
class Ruby < ::Logger
|
8
|
+
Logger::TRACE = 5
|
8
9
|
attr_accessor :level, :app, :env
|
9
10
|
@level = nil
|
10
11
|
@app = nil
|
@@ -13,6 +14,7 @@ module Logdna
|
|
13
14
|
def initialize(key, opts={})
|
14
15
|
@@client = Logdna::Client.new(key, opts)
|
15
16
|
sleep 0.01
|
17
|
+
|
16
18
|
if @@client[:value] === Resources::LOGGER_NOT_CREATED
|
17
19
|
@@client = nil
|
18
20
|
puts "LogDNA logger not created"
|
@@ -28,79 +30,145 @@ module Logdna
|
|
28
30
|
@env = nil
|
29
31
|
end
|
30
32
|
|
31
|
-
|
32
|
-
puts "Logger Not Initialized Yet"
|
33
|
-
return
|
34
|
-
end
|
33
|
+
loggerExist?
|
35
34
|
@response = @@client.tobuffer(msg, opts)
|
36
35
|
'Saved'
|
37
36
|
end
|
38
37
|
|
39
|
-
|
40
38
|
def trace(msg, opts={})
|
41
39
|
opts[:level] = "TRACE"
|
42
|
-
|
43
|
-
puts "Logger Not Initialized Yet"
|
44
|
-
return
|
45
|
-
end
|
40
|
+
loggerExist?
|
46
41
|
@response = @@client.tobuffer(msg, opts)
|
47
42
|
'Saved'
|
48
43
|
end
|
49
44
|
|
50
45
|
def debug(msg, opts={})
|
51
46
|
opts[:level] = "DEBUG"
|
52
|
-
|
53
|
-
puts "Logger Not Initialized Yet"
|
54
|
-
return
|
55
|
-
end
|
47
|
+
loggerExist?
|
56
48
|
@response = @@client.tobuffer(msg, opts)
|
57
49
|
'Saved'
|
58
50
|
end
|
59
51
|
|
60
52
|
def info(msg, opts={})
|
61
53
|
opts[:level] = "INFO"
|
62
|
-
|
63
|
-
puts "Logger Not Initialized Yet"
|
64
|
-
return
|
65
|
-
end
|
54
|
+
loggerExist?
|
66
55
|
@response = @@client.tobuffer(msg, opts)
|
67
56
|
'Saved'
|
68
57
|
end
|
69
58
|
|
70
59
|
def warn(msg, opts={})
|
71
60
|
opts[:level] = "WARN"
|
72
|
-
|
73
|
-
puts "Logger Not Initialized Yet"
|
74
|
-
return
|
75
|
-
end
|
61
|
+
loggerExist?
|
76
62
|
@response = @@client.tobuffer(msg, opts)
|
77
63
|
'Saved'
|
78
64
|
end
|
79
65
|
|
80
66
|
def error(msg, opts={})
|
81
67
|
opts[:level] = "ERROR"
|
82
|
-
|
83
|
-
puts "Logger Not Initialized Yet"
|
84
|
-
return
|
85
|
-
end
|
68
|
+
loggerExist?
|
86
69
|
@response = @@client.tobuffer(msg, opts)
|
87
70
|
'Saved'
|
88
71
|
end
|
89
72
|
|
90
73
|
def fatal(msg, opts={})
|
91
74
|
opts[:level] = "FATAL"
|
75
|
+
loggerExist?
|
76
|
+
@response = @@client.tobuffer(msg, opts)
|
77
|
+
'Saved'
|
78
|
+
end
|
79
|
+
|
80
|
+
def trace?
|
81
|
+
loggerExist?
|
82
|
+
unless @level
|
83
|
+
return 'TRACE' == @@client.getLevel
|
84
|
+
end
|
85
|
+
logLevel('TRACE')
|
86
|
+
end
|
87
|
+
|
88
|
+
def debug?
|
89
|
+
loggerExist?
|
90
|
+
unless @level
|
91
|
+
return 'DEBUG' == @@client.getLevel
|
92
|
+
end
|
93
|
+
logLevel('DEBUG')
|
94
|
+
end
|
95
|
+
|
96
|
+
def info?
|
97
|
+
loggerExist?
|
98
|
+
unless @level
|
99
|
+
return 'INFO' == @@client.getLevel
|
100
|
+
end
|
101
|
+
logLevel('INFO')
|
102
|
+
end
|
103
|
+
|
104
|
+
def warn?
|
105
|
+
loggerExist?
|
106
|
+
unless @level
|
107
|
+
return 'WARN' == @@client.getLevel
|
108
|
+
end
|
109
|
+
logLevel('WARN')
|
110
|
+
end
|
111
|
+
|
112
|
+
def error?
|
113
|
+
loggerExist?
|
114
|
+
unless @level
|
115
|
+
return 'ERROR' == @@client.getLevel
|
116
|
+
end
|
117
|
+
logLevel('ERROR')
|
118
|
+
end
|
119
|
+
|
120
|
+
def fatal?
|
121
|
+
loggerExist?
|
122
|
+
unless @level
|
123
|
+
return 'FATAL' == @@client.getLevel
|
124
|
+
end
|
125
|
+
logLevel('FATAL')
|
126
|
+
end
|
127
|
+
|
128
|
+
def loggerExist?
|
92
129
|
if @@client.nil?
|
93
130
|
puts "Logger Not Initialized Yet"
|
94
|
-
|
131
|
+
close
|
95
132
|
end
|
96
|
-
|
97
|
-
|
133
|
+
end
|
134
|
+
|
135
|
+
def logLevel(comparedTo)
|
136
|
+
if @level.is_a? Numeric
|
137
|
+
@level = Resources::LOG_LEVELS[@level]
|
138
|
+
end
|
139
|
+
return comparedTo == @level.upcase
|
140
|
+
end
|
141
|
+
|
142
|
+
def <<(*arg)
|
143
|
+
puts "<< not supported in LogDNA logger"
|
144
|
+
return false
|
145
|
+
end
|
146
|
+
|
147
|
+
def add(*arg)
|
148
|
+
puts "add not supported in LogDNA logger"
|
149
|
+
return false
|
150
|
+
end
|
151
|
+
|
152
|
+
def unknown(*arg)
|
153
|
+
puts "unknown not supported in LogDNA logger"
|
154
|
+
return false
|
155
|
+
end
|
156
|
+
|
157
|
+
def datetime_format(*arg)
|
158
|
+
puts "datetime_format not supported in LogDNA logger"
|
159
|
+
return false
|
98
160
|
end
|
99
161
|
|
100
162
|
|
163
|
+
def close
|
164
|
+
if @@client
|
165
|
+
@@client.exitout()
|
166
|
+
end
|
167
|
+
exit!
|
168
|
+
end
|
101
169
|
|
102
170
|
at_exit do
|
103
|
-
if
|
171
|
+
if @@client
|
104
172
|
@@client.exitout()
|
105
173
|
end
|
106
174
|
exit!
|
data/lib/logdna/client.rb
CHANGED
@@ -69,6 +69,10 @@ module Logdna
|
|
69
69
|
end
|
70
70
|
end
|
71
71
|
|
72
|
+
def getLevel
|
73
|
+
@qs[:level].upcase
|
74
|
+
end
|
75
|
+
|
72
76
|
def tobuffer(msg, opts)
|
73
77
|
if @task
|
74
78
|
unless @task.running?
|
@@ -93,7 +97,7 @@ module Logdna
|
|
93
97
|
@currentbytesize += msg.bytesize
|
94
98
|
@firstbuff.push({
|
95
99
|
:line => msg,
|
96
|
-
:app => @qs[:app],
|
100
|
+
:app => opts[:app] ||= @qs[:app],
|
97
101
|
:level => opts[:level] ||= @qs[:level],
|
98
102
|
:timestamp => Time.now.to_i,
|
99
103
|
:meta => opts[:meta] ||= nil,
|
@@ -103,7 +107,7 @@ module Logdna
|
|
103
107
|
@secondbytesize += msg.bytesize
|
104
108
|
@secondbuff.push({
|
105
109
|
:line => msg,
|
106
|
-
:app => @qs[:app],
|
110
|
+
:app => opts[:app] ||= @qs[:app],
|
107
111
|
:level => opts[:level] ||= @qs[:level],
|
108
112
|
:timestamp => Time.now.to_i,
|
109
113
|
:meta => opts[:meta] ||= nil,
|
data/lib/logdna/resources.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
module Resources
|
2
2
|
|
3
|
-
LOG_LEVELS = ['DEBUG', 'INFO', 'WARN', 'ERROR', 'FATAL'].freeze
|
3
|
+
LOG_LEVELS = ['DEBUG', 'INFO', 'WARN', 'ERROR', 'FATAL', 'TRACE'].freeze
|
4
4
|
DEFAULT_REQUEST_HEADER = { 'Content-Type': 'application/json; charset=UTF-8' }.freeze
|
5
5
|
DEFAULT_REQUEST_TIMEOUT = 180000
|
6
6
|
MS_IN_A_DAY = 86400000
|
data/lib/logdna/version.rb
CHANGED
data/test.rb
CHANGED
@@ -2,10 +2,15 @@ require 'require_all'
|
|
2
2
|
require_all 'lib'
|
3
3
|
|
4
4
|
|
5
|
-
options = {hostname: "
|
5
|
+
options = {hostname: "yondfsoikplghjniodhnfvreulwignfewfnrleuwinf"}
|
6
6
|
|
7
7
|
|
8
|
-
logger1 = Logdna::Ruby.new('
|
8
|
+
logger1 = Logdna::Ruby.new('Your ingestion key', options)
|
9
|
+
|
10
|
+
logger1.level = Logger::TRACE
|
11
|
+
logger1.log('is this trace')
|
12
|
+
|
13
|
+
=begin
|
9
14
|
logger1.level = Logger::WARN
|
10
15
|
logger1.log('This should be warn')
|
11
16
|
logger1.trace('This should be trace')
|
@@ -19,8 +24,15 @@ logger1.log('DEBUG log1')
|
|
19
24
|
logger1.app = 'NEW APP NAME'
|
20
25
|
logger1.env = 'Staging'
|
21
26
|
logger1.level = 'INFO'
|
22
|
-
logger1.log('are changes all updated')
|
23
27
|
|
28
|
+
|
29
|
+
|
30
|
+
logger1.level = 'INFO'
|
31
|
+
logger1.level == Logger::INFO
|
32
|
+
|
33
|
+
|
34
|
+
logger1.log('are changes all updated')
|
35
|
+
=end
|
24
36
|
sleep 3
|
25
37
|
|
26
38
|
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: logdna
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.6
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Gun Woo Choi
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2017-07-
|
11
|
+
date: 2017-07-31 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: concurrent-ruby
|