papertrail-cli 0.8.2 → 0.8.3
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +2 -59
- data/papertrail-cli.gemspec +7 -40
- metadata +16 -47
- data/Gemfile +0 -5
- data/README.md +0 -131
- data/bin/papertrail +0 -88
- data/examples/papertrail.yml.example +0 -1
- data/lib/papertrail-cli.rb +0 -5
- data/lib/papertrail/search_client.rb +0 -60
data/Rakefile
CHANGED
@@ -17,8 +17,7 @@ def module_name
|
|
17
17
|
end
|
18
18
|
|
19
19
|
def version
|
20
|
-
|
21
|
-
line.match(/.*VERSION\s*=\s*['"](.*)['"]/)[1]
|
20
|
+
'0.8.3'
|
22
21
|
end
|
23
22
|
|
24
23
|
def date
|
@@ -41,49 +40,6 @@ def replace_header(head, header_name)
|
|
41
40
|
head.sub!(/(\.#{header_name}\s*= ').*'/) { "#{$1}#{send(header_name)}'"}
|
42
41
|
end
|
43
42
|
|
44
|
-
#############################################################################
|
45
|
-
#
|
46
|
-
# Standard tasks
|
47
|
-
#
|
48
|
-
#############################################################################
|
49
|
-
|
50
|
-
task :default => :test
|
51
|
-
|
52
|
-
require 'rake/testtask'
|
53
|
-
Rake::TestTask.new(:test) do |test|
|
54
|
-
test.libs << 'lib' << 'test'
|
55
|
-
test.pattern = 'test/**/test_*.rb'
|
56
|
-
test.verbose = true
|
57
|
-
end
|
58
|
-
|
59
|
-
desc "Generate RCov test coverage and open in your browser"
|
60
|
-
task :coverage do
|
61
|
-
require 'rcov'
|
62
|
-
sh "rm -fr coverage"
|
63
|
-
sh "rcov test/test_*.rb"
|
64
|
-
sh "open coverage/index.html"
|
65
|
-
end
|
66
|
-
|
67
|
-
require 'rake/rdoctask'
|
68
|
-
Rake::RDocTask.new do |rdoc|
|
69
|
-
rdoc.rdoc_dir = 'rdoc'
|
70
|
-
rdoc.title = "#{name} #{version}"
|
71
|
-
rdoc.rdoc_files.include('README*')
|
72
|
-
rdoc.rdoc_files.include('lib/**/*.rb')
|
73
|
-
end
|
74
|
-
|
75
|
-
desc "Open an irb session preloaded with this library"
|
76
|
-
task :console do
|
77
|
-
sh "irb -rubygems -r ./lib/#{name}.rb"
|
78
|
-
end
|
79
|
-
|
80
|
-
#############################################################################
|
81
|
-
#
|
82
|
-
# Custom tasks (add your own tasks here)
|
83
|
-
#
|
84
|
-
#############################################################################
|
85
|
-
|
86
|
-
|
87
43
|
|
88
44
|
#############################################################################
|
89
45
|
#
|
@@ -112,7 +68,7 @@ task :build => :gemspec do
|
|
112
68
|
end
|
113
69
|
|
114
70
|
desc "Generate #{gemspec_file}"
|
115
|
-
task :gemspec
|
71
|
+
task :gemspec do
|
116
72
|
# read spec file and split out manifest section
|
117
73
|
spec = File.read(gemspec_file)
|
118
74
|
head, manifest, tail = spec.split(" # = MANIFEST =\n")
|
@@ -139,16 +95,3 @@ task :gemspec => :validate do
|
|
139
95
|
File.open(gemspec_file, 'w') { |io| io.write(spec) }
|
140
96
|
puts "Updated #{gemspec_file}"
|
141
97
|
end
|
142
|
-
|
143
|
-
desc "Validate #{gemspec_file}"
|
144
|
-
task :validate do
|
145
|
-
libfiles = Dir['lib/*'] - ["lib/#{name}.rb", "lib/#{module_name}"]
|
146
|
-
unless libfiles.empty?
|
147
|
-
puts "Directory `lib` should only contain a `#{name}.rb` file and `#{module_name}` dir."
|
148
|
-
exit!
|
149
|
-
end
|
150
|
-
unless Dir['VERSION*'].empty?
|
151
|
-
puts "A `VERSION` file at root level violates Gem best practices."
|
152
|
-
exit!
|
153
|
-
end
|
154
|
-
end
|
data/papertrail-cli.gemspec
CHANGED
@@ -13,67 +13,34 @@ Gem::Specification.new do |s|
|
|
13
13
|
## If your rubyforge_project name is different, then edit it and comment out
|
14
14
|
## the sub! line in the Rakefile
|
15
15
|
s.name = 'papertrail-cli'
|
16
|
-
s.version = '0.8.
|
17
|
-
s.date = '
|
16
|
+
s.version = '0.8.3'
|
17
|
+
s.date = '2012-02-11'
|
18
18
|
s.rubyforge_project = 'papertrail-cli'
|
19
19
|
|
20
20
|
## Make sure your summary is short. The description may be as long
|
21
21
|
## as you like.
|
22
|
-
s.summary = "
|
23
|
-
s.description = "
|
22
|
+
s.summary = "Placeholder gem to point to new papertrail gem"
|
23
|
+
s.description = "Placeholder gem to point to new papertrail gem."
|
24
24
|
|
25
25
|
## List the primary authors. If there are a bunch of authors, it's probably
|
26
26
|
## better to set the email to an email list or something. If you don't have
|
27
27
|
## a custom homepage, consider using your GitHub URL or the like.
|
28
28
|
s.authors = ['Papertrail']
|
29
|
-
s.email = '
|
30
|
-
s.homepage = 'http://github.com/papertrail/papertrail-cli'
|
31
|
-
|
32
|
-
## This gets added to the $LOAD_PATH so that 'lib/NAME.rb' can be required as
|
33
|
-
## require 'NAME.rb' or'/lib/NAME/file.rb' can be as require 'NAME/file.rb'
|
34
|
-
s.require_paths = %w[lib]
|
35
|
-
|
36
|
-
## This sections is only necessary if you have C extensions.
|
37
|
-
# s.require_paths << 'ext'
|
38
|
-
# s.extensions = %w[ext/extconf.rb]
|
39
|
-
|
40
|
-
## If your gem includes any executables, list them here.
|
41
|
-
s.executables = ["papertrail"]
|
42
|
-
s.default_executable = 'papertrail'
|
43
|
-
|
44
|
-
## Specify any RDoc options here. You'll want to add your README and
|
45
|
-
## LICENSE files to the extra_rdoc_files list.
|
46
|
-
s.rdoc_options = ["--charset=UTF-8"]
|
47
|
-
# s.extra_rdoc_files = %w[README LICENSE]
|
48
|
-
s.extra_rdoc_files = []
|
29
|
+
s.email = 'eric@sevenscale.com'
|
30
|
+
s.homepage = 'http://github.com/papertrail/papertrail-cli-gem'
|
49
31
|
|
50
32
|
## List your runtime dependencies here. Runtime dependencies are those
|
51
33
|
## that are needed for an end user to actually USE your code.
|
52
|
-
s.add_dependency('
|
53
|
-
s.add_dependency('faraday', [ '~> 0.6' ])
|
54
|
-
s.add_dependency('faraday-stack', [ '~> 0.1' ])
|
55
|
-
|
56
|
-
## List your development dependencies here. Development dependencies are
|
57
|
-
## those that are only needed during development
|
58
|
-
# s.add_development_dependency('DEVDEPNAME', [">= 1.1.0", "< 2.0.0"])
|
34
|
+
s.add_dependency('papertrail', [ '~> 0.8' ])
|
59
35
|
|
60
36
|
## Leave this section as-is. It will be automatically generated from the
|
61
37
|
## contents of your Git repository via the gemspec task. DO NOT REMOVE
|
62
38
|
## THE MANIFEST COMMENTS, they are used as delimiters by the task.
|
63
39
|
# = MANIFEST =
|
64
40
|
s.files = %w[
|
65
|
-
Gemfile
|
66
|
-
README.md
|
67
41
|
Rakefile
|
68
|
-
bin/papertrail
|
69
|
-
examples/papertrail.yml.example
|
70
|
-
lib/papertrail-cli.rb
|
71
|
-
lib/papertrail/search_client.rb
|
72
42
|
papertrail-cli.gemspec
|
73
43
|
]
|
74
44
|
# = MANIFEST =
|
75
45
|
|
76
|
-
## Test files will be grabbed from the file list. Make sure the path glob
|
77
|
-
## matches what you actually use.
|
78
|
-
s.test_files = s.files.select { |path| path =~ /^test\/test_.*\.rb/ }
|
79
46
|
end
|
metadata
CHANGED
@@ -5,8 +5,8 @@ version: !ruby/object:Gem::Version
|
|
5
5
|
segments:
|
6
6
|
- 0
|
7
7
|
- 8
|
8
|
-
-
|
9
|
-
version: 0.8.
|
8
|
+
- 3
|
9
|
+
version: 0.8.3
|
10
10
|
platform: ruby
|
11
11
|
authors:
|
12
12
|
- Papertrail
|
@@ -14,71 +14,40 @@ autorequire:
|
|
14
14
|
bindir: bin
|
15
15
|
cert_chain: []
|
16
16
|
|
17
|
-
date:
|
18
|
-
default_executable:
|
17
|
+
date: 2012-02-11 00:00:00 -08:00
|
18
|
+
default_executable:
|
19
19
|
dependencies:
|
20
20
|
- !ruby/object:Gem::Dependency
|
21
|
-
name:
|
21
|
+
name: papertrail
|
22
22
|
prerelease: false
|
23
23
|
requirement: &id001 !ruby/object:Gem::Requirement
|
24
|
-
requirements:
|
25
|
-
- - ">="
|
26
|
-
- !ruby/object:Gem::Version
|
27
|
-
segments:
|
28
|
-
- 0
|
29
|
-
version: "0"
|
30
|
-
type: :runtime
|
31
|
-
version_requirements: *id001
|
32
|
-
- !ruby/object:Gem::Dependency
|
33
|
-
name: faraday
|
34
|
-
prerelease: false
|
35
|
-
requirement: &id002 !ruby/object:Gem::Requirement
|
36
24
|
requirements:
|
37
25
|
- - ~>
|
38
26
|
- !ruby/object:Gem::Version
|
39
27
|
segments:
|
40
28
|
- 0
|
41
|
-
-
|
42
|
-
version: "0.
|
29
|
+
- 8
|
30
|
+
version: "0.8"
|
43
31
|
type: :runtime
|
44
|
-
version_requirements: *
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
requirements:
|
50
|
-
- - ~>
|
51
|
-
- !ruby/object:Gem::Version
|
52
|
-
segments:
|
53
|
-
- 0
|
54
|
-
- 1
|
55
|
-
version: "0.1"
|
56
|
-
type: :runtime
|
57
|
-
version_requirements: *id003
|
58
|
-
description: Command-line client for Papertrail hosted log management service. Tails and searches app server logs and system syslog. Supports Boolean search and works with grep and pipe output (Unix).
|
59
|
-
email: troy@sevenscale.com
|
60
|
-
executables:
|
61
|
-
- papertrail
|
32
|
+
version_requirements: *id001
|
33
|
+
description: Placeholder gem to point to new papertrail gem.
|
34
|
+
email: eric@sevenscale.com
|
35
|
+
executables: []
|
36
|
+
|
62
37
|
extensions: []
|
63
38
|
|
64
39
|
extra_rdoc_files: []
|
65
40
|
|
66
41
|
files:
|
67
|
-
- Gemfile
|
68
|
-
- README.md
|
69
42
|
- Rakefile
|
70
|
-
- bin/papertrail
|
71
|
-
- examples/papertrail.yml.example
|
72
|
-
- lib/papertrail-cli.rb
|
73
|
-
- lib/papertrail/search_client.rb
|
74
43
|
- papertrail-cli.gemspec
|
75
44
|
has_rdoc: true
|
76
|
-
homepage: http://github.com/papertrail/papertrail-cli
|
45
|
+
homepage: http://github.com/papertrail/papertrail-cli-gem
|
77
46
|
licenses: []
|
78
47
|
|
79
48
|
post_install_message:
|
80
|
-
rdoc_options:
|
81
|
-
|
49
|
+
rdoc_options: []
|
50
|
+
|
82
51
|
require_paths:
|
83
52
|
- lib
|
84
53
|
required_ruby_version: !ruby/object:Gem::Requirement
|
@@ -101,6 +70,6 @@ rubyforge_project: papertrail-cli
|
|
101
70
|
rubygems_version: 1.3.6
|
102
71
|
signing_key:
|
103
72
|
specification_version: 2
|
104
|
-
summary:
|
73
|
+
summary: Placeholder gem to point to new papertrail gem
|
105
74
|
test_files: []
|
106
75
|
|
data/Gemfile
DELETED
data/README.md
DELETED
@@ -1,131 +0,0 @@
|
|
1
|
-
# papertrail Command-line tail & search client for Papertrail log management service
|
2
|
-
|
3
|
-
Small standalone [binary] to retrieve, search, and tail recent app
|
4
|
-
server log and system syslog messages from [Papertrail].
|
5
|
-
|
6
|
-
Supports optional Boolean search queries and polling for new events
|
7
|
-
(like "tail -f"). Example:
|
8
|
-
|
9
|
-
papertrail -f "(www OR db) (nginx OR pgsql) -accepted"
|
10
|
-
|
11
|
-
Output is line-buffered so it can be fed into a pipe, like for grep.
|
12
|
-
See below for colorization setup.
|
13
|
-
|
14
|
-
The [SearchClient] class can be used by other apps to perform one-off
|
15
|
-
API searches or follow (tail) events matching a given query. Interface
|
16
|
-
may change.
|
17
|
-
|
18
|
-
|
19
|
-
## Quick Start
|
20
|
-
|
21
|
-
$ [sudo] gem install papertrail-cli
|
22
|
-
$ echo "token: 123456789012345678901234567890ab" > ~/.papertrail.yml
|
23
|
-
$ papertrail
|
24
|
-
|
25
|
-
Retrieve token from Papertrail [User Profile].
|
26
|
-
|
27
|
-
|
28
|
-
## Installation
|
29
|
-
|
30
|
-
Install the gem (details on [RubyGems]), which includes a binary called
|
31
|
-
"papertrail":
|
32
|
-
|
33
|
-
$ [sudo] gem install papertrail-cli
|
34
|
-
|
35
|
-
|
36
|
-
## Configuration
|
37
|
-
|
38
|
-
Create ~/.papertrail.yml containing your API token, or specify the
|
39
|
-
path to that file with -c. Example (from
|
40
|
-
examples/papertrail.yml.example):
|
41
|
-
|
42
|
-
token: 123456789012345678901234567890ab
|
43
|
-
|
44
|
-
Retrieve token from Papertrail [User Profile]. For compatibility with
|
45
|
-
older config files, `username` and `password` keys are also supported.
|
46
|
-
|
47
|
-
You may want to alias "trail" to "papertrail", like:
|
48
|
-
|
49
|
-
echo "alias trail=papertrail" >> ~/.bashrc
|
50
|
-
|
51
|
-
|
52
|
-
## Usage & Examples
|
53
|
-
|
54
|
-
$ papertrail -h
|
55
|
-
papertrail - command-line tail and search for Papertrail log management service
|
56
|
-
-h, --help Show usage
|
57
|
-
-f, --follow Continue running and print new events (off)
|
58
|
-
-d, --delay SECONDS Delay between refresh (3)
|
59
|
-
-c, --configfile PATH Path to config (~/.papertrail.yml)
|
60
|
-
|
61
|
-
Usage: papertrail [-f] [-d seconds] [-c /path/to/papertrail.yml] [query]
|
62
|
-
|
63
|
-
Examples:
|
64
|
-
papertrail -f
|
65
|
-
papertrail something
|
66
|
-
papertrail 1.2.3 Failure
|
67
|
-
papertrail -f "(www OR db) (nginx OR pgsql) -accepted"
|
68
|
-
papertrail -f -d 10 "ns1 OR 'connection refused'"
|
69
|
-
|
70
|
-
More: http://papertrailapp.com/
|
71
|
-
|
72
|
-
|
73
|
-
## Colors
|
74
|
-
|
75
|
-
Pipe through [colortail] or [MultiTail]. We recommend colortail:
|
76
|
-
|
77
|
-
$ sudo gem install colortail
|
78
|
-
|
79
|
-
Save [colortailrc] as `~/.colortailrc` and edit it to enable:
|
80
|
-
|
81
|
-
$ papertrail -f -d 5 | colortail -g papertrail
|
82
|
-
|
83
|
-
### Shorthand
|
84
|
-
|
85
|
-
If you're using bash, create a function that accepts arguments, then
|
86
|
-
invoke `pt` with optional search operators:
|
87
|
-
|
88
|
-
$ function pt() { papertrail -f -d 5 $_ | colortail -g papertrail }
|
89
|
-
$ pt 1.2.3 Failure
|
90
|
-
|
91
|
-
Add the function line to your `~/.bashrc`.
|
92
|
-
|
93
|
-
### Advanced
|
94
|
-
|
95
|
-
For complete control, pipe through anything capable of inserting ANSI
|
96
|
-
control characters. Here's an example that colorizes 3 fields separately
|
97
|
-
- the first 15 characters for the date, a word for the hostname, and a
|
98
|
-
word for the program name:
|
99
|
-
|
100
|
-
$ papertrail | perl -pe 's/^(.{15})(.)([\S]+)(.)([\S]+)/\e[1;31;43m\1\e[0m\2\e[1;31;43m\3\e[0m\4\e[1;31;43m\5\e[0m/g'
|
101
|
-
|
102
|
-
the "1;31;43" are bold (1), foreground red (31), background yellow (43),
|
103
|
-
and can be any ANSI [escape characters].
|
104
|
-
|
105
|
-
|
106
|
-
## Contribute
|
107
|
-
|
108
|
-
Bug report:
|
109
|
-
|
110
|
-
1. See whether the issue has already been reported:
|
111
|
-
http://github.com/papertrail/papertrail-cli/issues/
|
112
|
-
2. If you don't find one, create an issue with a repro case.
|
113
|
-
|
114
|
-
Enhancement or fix:
|
115
|
-
|
116
|
-
1. Fork the project:
|
117
|
-
http://github.com/papertrail/papertrail-cli
|
118
|
-
2. Make your changes with tests.
|
119
|
-
3. Commit the changes without changing the Rakefile or other files unrelated
|
120
|
-
to your enhancement.
|
121
|
-
4. Send a pull request.
|
122
|
-
|
123
|
-
[binary]: https://github.com/papertrail/papertrail-cli/blob/master/bin/papertrail
|
124
|
-
[Papertrail]: http://papertrailapp.com/
|
125
|
-
[SearchClient]: https://github.com/papertrail/papertrail-cli/blob/master/lib/papertrail/search_client.rb
|
126
|
-
[User Profile]: https://papertrailapp.com/user/edit
|
127
|
-
[RubyGems]: https://rubygems.org/gems/papertrail-cli
|
128
|
-
[colortail]: http://rubydoc.info/gems/colortail
|
129
|
-
[colortailrc]: https://github.com/papertrail/papertrail-cli/wiki/colortailrc
|
130
|
-
[MultiTail]: http://www.vanheusden.com/multitail/index.html
|
131
|
-
[escape characters]: http://en.wikipedia.org/wiki/ANSI_escape_code#Colors
|
data/bin/papertrail
DELETED
@@ -1,88 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
|
3
|
-
require 'optparse'
|
4
|
-
require 'yaml'
|
5
|
-
|
6
|
-
require 'papertrail-cli'
|
7
|
-
|
8
|
-
class PapertrailSearch
|
9
|
-
def run
|
10
|
-
options = {
|
11
|
-
:configfile => File.expand_path('~/.papertrail.yml'),
|
12
|
-
:delay => 10,
|
13
|
-
:follow => false
|
14
|
-
}
|
15
|
-
|
16
|
-
OptionParser.new do |opts|
|
17
|
-
opts.banner = "papertrail - command-line tail and search for Papertrail log management service"
|
18
|
-
|
19
|
-
opts.on("-h", "--help", "Show usage") do |v|
|
20
|
-
puts opts
|
21
|
-
exit
|
22
|
-
end
|
23
|
-
opts.on("-f", "--follow", "Continue running and print new events (off)") do |v|
|
24
|
-
options[:follow] = true
|
25
|
-
end
|
26
|
-
opts.on("-d", "--delay SECONDS", "Delay between refresh (3)") do |v|
|
27
|
-
options[:delay] = v.to_i
|
28
|
-
end
|
29
|
-
opts.on("-c", "--configfile PATH", "Path to config (~/.papertrail.yml)") do |v|
|
30
|
-
options[:configfile] = File.expand_path(v)
|
31
|
-
end
|
32
|
-
|
33
|
-
opts.separator usage
|
34
|
-
end.parse!
|
35
|
-
|
36
|
-
credentials = open(options[:configfile]) do |f|
|
37
|
-
YAML.load(f)
|
38
|
-
end
|
39
|
-
|
40
|
-
if credentials['token']
|
41
|
-
client = Papertrail::SearchClient.new(:token => credentials['token'])
|
42
|
-
else
|
43
|
-
client = Papertrail::SearchClient.new(:username => credentials['username'], :password => credentials['password'])
|
44
|
-
end
|
45
|
-
|
46
|
-
search_and_print(client)
|
47
|
-
|
48
|
-
if options[:follow]
|
49
|
-
loop do
|
50
|
-
sleep options[:delay]
|
51
|
-
search_and_print(client)
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
def search_and_print(client)
|
57
|
-
events = client.search(ARGV[0])
|
58
|
-
return unless events
|
59
|
-
|
60
|
-
Papertrail::SearchClient.format_events(events) do |e|
|
61
|
-
puts e
|
62
|
-
$stdout.flush
|
63
|
-
end
|
64
|
-
end
|
65
|
-
|
66
|
-
def usage
|
67
|
-
<<EOF
|
68
|
-
|
69
|
-
Usage: papertrail [-f] [-d seconds] [-c /path/to/papertrail.yml] [query]
|
70
|
-
|
71
|
-
Examples:
|
72
|
-
papertrail -f
|
73
|
-
papertrail something
|
74
|
-
papertrail 1.2.3 Failure
|
75
|
-
papertrail -f "(www OR db) (nginx OR pgsql) -accepted"
|
76
|
-
papertrail -f -d 10 "ns1 OR 'connection refused'"
|
77
|
-
|
78
|
-
More: https://papertrailapp.com/
|
79
|
-
|
80
|
-
EOF
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
begin
|
85
|
-
PapertrailSearch.new.run
|
86
|
-
rescue Interrupt
|
87
|
-
exit(0)
|
88
|
-
end
|
@@ -1 +0,0 @@
|
|
1
|
-
token: 123456789012345678901234567890ab
|
data/lib/papertrail-cli.rb
DELETED
@@ -1,60 +0,0 @@
|
|
1
|
-
require 'faraday'
|
2
|
-
require 'time'
|
3
|
-
require 'openssl'
|
4
|
-
require 'faraday_stack'
|
5
|
-
|
6
|
-
module Papertrail
|
7
|
-
class SearchClient
|
8
|
-
def initialize(options)
|
9
|
-
ssl_options = { :verify => OpenSSL::SSL::VERIFY_PEER }
|
10
|
-
|
11
|
-
# Make Ubuntu OpenSSL work
|
12
|
-
#
|
13
|
-
# From: https://bugs.launchpad.net/ubuntu/+source/openssl/+bug/396818
|
14
|
-
# "[OpenSSL] does not presume to select a set of CAs by default."
|
15
|
-
if File.file?('/etc/ssl/certs/ca-certificates.crt')
|
16
|
-
ssl_options[:ca_file] = '/etc/ssl/certs/ca-certificates.crt'
|
17
|
-
end
|
18
|
-
|
19
|
-
@conn = Faraday::Connection.new(:url => 'https://papertrailapp.com', :ssl => ssl_options) do |builder|
|
20
|
-
builder.adapter Faraday.default_adapter
|
21
|
-
builder.use FaradayStack::ResponseJSON
|
22
|
-
end.tap do |conn|
|
23
|
-
if options[:username] && options[:password]
|
24
|
-
conn.basic_auth(options[:username], options[:password])
|
25
|
-
else
|
26
|
-
conn.headers['X-Papertrail-Token'] = options[:token]
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
@max_id_seen = {}
|
31
|
-
end
|
32
|
-
|
33
|
-
# search for all events or a specific query, defaulting to all events since
|
34
|
-
# last result set (call with since=0 for all).
|
35
|
-
def search(q = nil, since = nil)
|
36
|
-
response = @conn.get('/api/v1/events/search.json') do |r|
|
37
|
-
r.params = params_for_query(q, since)
|
38
|
-
end
|
39
|
-
|
40
|
-
if response.body
|
41
|
-
@max_id_seen[q] = response.body['max_id']
|
42
|
-
response.body['events']
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
def params_for_query(q = nil, since = nil)
|
47
|
-
params = {}
|
48
|
-
params[:q] = q if q
|
49
|
-
params[:min_id] = @max_id_seen[q] if @max_id_seen[q]
|
50
|
-
params[:min_id] = since if since
|
51
|
-
params
|
52
|
-
end
|
53
|
-
|
54
|
-
def self.format_events(events, &block)
|
55
|
-
events.each do |event|
|
56
|
-
yield "#{Time.parse(event['received_at']).strftime('%b %e %X')} #{event['hostname']} #{event['program']} #{event['message']}"
|
57
|
-
end
|
58
|
-
end
|
59
|
-
end
|
60
|
-
end
|