dogapi 1.0.4 → 1.1.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.
- data/README.rdoc +81 -16
- data/lib/dogapi/common.rb +10 -18
- data/lib/dogapi/facade.rb +0 -3
- data/tests/tc_client.rb +1 -11
- data/tests/tc_env.rb +1 -7
- data/tests/tc_event.rb +1 -11
- data/tests/tc_metric.rb +1 -19
- metadata +12 -7
data/README.rdoc
CHANGED
@@ -1,35 +1,100 @@
|
|
1
|
-
Ruby client for Datadog API v1.0
|
1
|
+
= Ruby client for Datadog API v1.1.0
|
2
2
|
|
3
3
|
The Ruby client is a library suitable for inclusion in existing Ruby projects or for development of standalone scripts. It provides an abstraction on top of Datadog's raw HTTP interface for reporting events and metrics.
|
4
4
|
|
5
5
|
= Installation
|
6
6
|
|
7
|
-
== Source
|
7
|
+
== From Source
|
8
8
|
|
9
9
|
Available at: https://github.com/DataDog/dogapi-rb
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
11
|
+
$ cd dogapi-rb
|
12
|
+
$ rake gem
|
13
|
+
$ gem install pkg/dogapi-*.gem
|
14
14
|
|
15
|
-
== RubyGems
|
15
|
+
== Using RubyGems
|
16
16
|
|
17
17
|
Gem page: https://rubygems.org/gems/dogapi
|
18
18
|
|
19
|
-
|
19
|
+
$ gem install dogapi
|
20
20
|
|
21
21
|
= Usage
|
22
22
|
|
23
|
-
|
23
|
+
== How to find your API Key
|
24
24
|
|
25
|
-
|
25
|
+
Go to your setup page[https://app.datadoghq.com/account/settings].
|
26
26
|
|
27
|
-
|
27
|
+
== A word about hosts and devices
|
28
28
|
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
dog = Dogapi::Client.new(@api_key)
|
33
|
-
dog.emit_point 'some.metric.name', 50.0
|
29
|
+
Events and metric data points can be attached to hosts
|
30
|
+
to take advantage of automatic tagging with the host's tags.
|
34
31
|
|
35
|
-
|
32
|
+
If you want to attach events and points to a specific device
|
33
|
+
on a host, simply specify the device when calling emit functions.
|
34
|
+
|
35
|
+
== Submit an event to Datadog
|
36
|
+
|
37
|
+
=== If the event has no duration
|
38
|
+
|
39
|
+
require 'rubygems'
|
40
|
+
require 'dogapi'
|
41
|
+
|
42
|
+
api_key = "abcdef123456"
|
43
|
+
|
44
|
+
dog = Dogapi::Client.new(api_key)
|
45
|
+
|
46
|
+
dog.emit_event(Dogapi::Event.new('Testing done, FTW'), host => "my_host")
|
47
|
+
|
48
|
+
=== If the event has a duration
|
49
|
+
|
50
|
+
require 'rubygems'
|
51
|
+
require 'dogapi'
|
52
|
+
|
53
|
+
api_key = "abcdef123456"
|
54
|
+
|
55
|
+
dog = Dogapi::Client.new(api_key)
|
56
|
+
|
57
|
+
dog.start_event(Dogapi::Event.new('My event with a duration'), host => "my_host") do
|
58
|
+
# do your work here...
|
59
|
+
# e.g. sleep 1
|
60
|
+
end
|
61
|
+
# stop_event will be sent automatically
|
62
|
+
|
63
|
+
== Submit a metric to Datadog
|
64
|
+
|
65
|
+
You want to track a new metric called +some.metric.name+ and have just sampled it from +my_device+ on +my_host+.
|
66
|
+
Its value is 50. Here is how you submit the value to Datadog.
|
67
|
+
|
68
|
+
require 'rubygems'
|
69
|
+
require 'dogapi'
|
70
|
+
|
71
|
+
api_key = "abcdef123456"
|
72
|
+
|
73
|
+
dog = Dogapi::Client.new(api_key)
|
74
|
+
|
75
|
+
dog.emit_point 'some.metric.name', 50.0, host => "my_host", device => "my_device"
|
76
|
+
|
77
|
+
Let us now assume that you have sampled the metric multiple times and you would like to submit the results.
|
78
|
+
You can use the +emit_points+ method (instead of +emit_point+). Since you are submitting more than one
|
79
|
+
data point you will need to pass a list of +Time+, +float+ pairs, instead of a simple +float+ value.
|
80
|
+
|
81
|
+
require 'rubygems'
|
82
|
+
require 'dogapi'
|
83
|
+
|
84
|
+
= Actual sampling takes place
|
85
|
+
t1 = Time.now
|
86
|
+
val1 = 50.0
|
87
|
+
|
88
|
+
= some time elapses
|
89
|
+
t2 = Time.now
|
90
|
+
val2 = 51.0
|
91
|
+
|
92
|
+
= some more time elapses
|
93
|
+
t3 = Time.now
|
94
|
+
val3 = -60.0
|
95
|
+
|
96
|
+
api_key = "abcdef123456"
|
97
|
+
|
98
|
+
dog = Dogapi::Client.new(api_key)
|
99
|
+
|
100
|
+
dog.emit_points 'some.metric.name', [[t1, val1], [t2, val2], [t3, val3]], host => "my_host", device => "my_device"
|
data/lib/dogapi/common.rb
CHANGED
@@ -20,24 +20,21 @@ module Dogapi
|
|
20
20
|
|
21
21
|
# Superclass that deals with the details of communicating with the DataDog API
|
22
22
|
class Service
|
23
|
-
def initialize(api_host=find_datadog_host)
|
23
|
+
def initialize(api_key, api_host=Dogapi.find_datadog_host)
|
24
|
+
@api_key = api_key
|
24
25
|
@host = api_host
|
25
26
|
end
|
26
27
|
|
27
28
|
# Manages the HTTP connection
|
28
|
-
def connect
|
29
|
-
|
30
|
-
@api_key = api_key
|
31
|
-
host = host || @host
|
32
|
-
|
33
|
-
uri = URI.parse(host)
|
29
|
+
def connect
|
30
|
+
uri = URI.parse(@host)
|
34
31
|
session = Net::HTTP.new(uri.host, uri.port)
|
35
32
|
if 'https' == uri.scheme
|
36
33
|
session.use_ssl = true
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
34
|
+
# FIXME - turn off SSL verification for now until we can spend
|
35
|
+
# some time figuring out how to find certs across platforms.
|
36
|
+
# - matt 10/06/2011
|
37
|
+
session.verify_mode = OpenSSL::SSL::VERIFY_NONE
|
41
38
|
end
|
42
39
|
session.start do |conn|
|
43
40
|
yield(conn)
|
@@ -75,14 +72,9 @@ module Dogapi
|
|
75
72
|
end
|
76
73
|
end
|
77
74
|
|
78
|
-
private
|
79
|
-
|
80
75
|
def Dogapi.find_datadog_host
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
def Dogapi.find_api_key
|
85
|
-
ENV['DATADOG_KEY'] rescue nil
|
76
|
+
# allow env-based overriding, useful for tests
|
77
|
+
ENV["DATADOG_HOST"] || "https://app.datadoghq.com"
|
86
78
|
end
|
87
79
|
|
88
80
|
def Dogapi.find_localhost
|
data/lib/dogapi/facade.rb
CHANGED
data/tests/tc_client.rb
CHANGED
@@ -4,17 +4,7 @@ require 'dogapi'
|
|
4
4
|
class TestClient < Test::Unit::TestCase
|
5
5
|
|
6
6
|
def config_client_test_env
|
7
|
-
@api_key =
|
8
|
-
if !@api_key
|
9
|
-
@api_key = 'apikey_2'
|
10
|
-
ENV['DATADOG_KEY'] = @api_key
|
11
|
-
end
|
12
|
-
|
13
|
-
@host = Dogapi.find_datadog_host
|
14
|
-
if !@host
|
15
|
-
@host = 'localhost:5000'
|
16
|
-
ENV['DATADOG_HOST'] = @host
|
17
|
-
end
|
7
|
+
@api_key = ENV['DATADOG_KEY']
|
18
8
|
end
|
19
9
|
|
20
10
|
def setup
|
data/tests/tc_env.rb
CHANGED
@@ -5,25 +5,19 @@ class TestEnvironment < Test::Unit::TestCase
|
|
5
5
|
|
6
6
|
def setup
|
7
7
|
@host = ENV['DATADOG_HOST']
|
8
|
-
@key = ENV['DATADOG_KEY']
|
9
8
|
end
|
10
9
|
|
11
10
|
def teardown
|
12
11
|
ENV['DATADOG_HOST'] = @host
|
13
|
-
ENV['DATADOG_KEY'] = @key
|
14
12
|
end
|
15
13
|
|
16
14
|
def test_unset
|
17
15
|
ENV['DATADOG_HOST'] = nil
|
18
|
-
|
19
|
-
assert_equal nil, Dogapi.find_datadog_host
|
20
|
-
assert_equal nil, Dogapi.find_api_key
|
16
|
+
assert_equal "https://app.datadoghq.com", Dogapi.find_datadog_host
|
21
17
|
end
|
22
18
|
|
23
19
|
def test_set
|
24
20
|
ENV['DATADOG_HOST'] = 'test.host'
|
25
|
-
ENV['DATADOG_KEY'] = 'test_key'
|
26
21
|
assert_equal 'test.host', Dogapi.find_datadog_host
|
27
|
-
assert_equal 'test_key', Dogapi.find_api_key
|
28
22
|
end
|
29
23
|
end
|
data/tests/tc_event.rb
CHANGED
@@ -4,17 +4,7 @@ require 'dogapi'
|
|
4
4
|
class TestEventClient < Test::Unit::TestCase
|
5
5
|
|
6
6
|
def config_client_test_env
|
7
|
-
@api_key =
|
8
|
-
if !@api_key
|
9
|
-
@api_key = 'apikey_2'
|
10
|
-
ENV['DATADOG_KEY'] = @api_key
|
11
|
-
end
|
12
|
-
|
13
|
-
@host = Dogapi.find_datadog_host
|
14
|
-
if !@host
|
15
|
-
@host = 'localhost:5000'
|
16
|
-
ENV['DATADOG_HOST'] = @host
|
17
|
-
end
|
7
|
+
@api_key = ENV['DATADOG_KEY']
|
18
8
|
end
|
19
9
|
|
20
10
|
def setup
|
data/tests/tc_metric.rb
CHANGED
@@ -5,17 +5,7 @@ require 'dogapi'
|
|
5
5
|
class TestMetricClient < Test::Unit::TestCase
|
6
6
|
|
7
7
|
def config_client_test_env
|
8
|
-
@api_key =
|
9
|
-
if !@api_key
|
10
|
-
@api_key = 'apikey_2'
|
11
|
-
ENV['DATADOG_KEY'] = @api_key
|
12
|
-
end
|
13
|
-
|
14
|
-
@host = Dogapi.find_datadog_host
|
15
|
-
if !@host
|
16
|
-
@host = 'localhost:5000'
|
17
|
-
ENV['DATADOG_HOST'] = @host
|
18
|
-
end
|
8
|
+
@api_key = ENV['DATADOG_KEY']
|
19
9
|
end
|
20
10
|
|
21
11
|
def setup
|
@@ -34,14 +24,6 @@ class TestMetricClient < Test::Unit::TestCase
|
|
34
24
|
]
|
35
25
|
res = metric_service.submit(@api_key, scope, metric, points)
|
36
26
|
assert_equal(res['status'], 'ok')
|
37
|
-
assert_equal(res['results'].size, 1)
|
38
|
-
r = res['results'][0]
|
39
|
-
assert_equal(r['host'], scope.host)
|
40
|
-
if scope.device
|
41
|
-
assert_equal(r['device'], scope.device)
|
42
|
-
end
|
43
|
-
assert_equal(r['metric'], metric)
|
44
|
-
assert_equal(r['length'], points.size)
|
45
27
|
end
|
46
28
|
|
47
29
|
end
|
metadata
CHANGED
@@ -1,12 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: dogapi
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
|
4
|
+
hash: 19
|
5
|
+
prerelease:
|
5
6
|
segments:
|
6
7
|
- 1
|
8
|
+
- 1
|
7
9
|
- 0
|
8
|
-
|
9
|
-
version: 1.0.4
|
10
|
+
version: 1.1.0
|
10
11
|
platform: ruby
|
11
12
|
authors:
|
12
13
|
- Datadog, Inc.
|
@@ -14,16 +15,17 @@ autorequire:
|
|
14
15
|
bindir: bin
|
15
16
|
cert_chain: []
|
16
17
|
|
17
|
-
date: 2011-10-06 00:00:00
|
18
|
-
default_executable:
|
18
|
+
date: 2011-10-06 00:00:00 Z
|
19
19
|
dependencies:
|
20
20
|
- !ruby/object:Gem::Dependency
|
21
21
|
name: json
|
22
22
|
prerelease: false
|
23
23
|
requirement: &id001 !ruby/object:Gem::Requirement
|
24
|
+
none: false
|
24
25
|
requirements:
|
25
26
|
- - ">="
|
26
27
|
- !ruby/object:Gem::Version
|
28
|
+
hash: 1
|
27
29
|
segments:
|
28
30
|
- 1
|
29
31
|
- 5
|
@@ -51,7 +53,6 @@ files:
|
|
51
53
|
- tests/tc_metric.rb
|
52
54
|
- tests/ts_dogapi.rb
|
53
55
|
- README.rdoc
|
54
|
-
has_rdoc: true
|
55
56
|
homepage: http://datadoghq.com/
|
56
57
|
licenses:
|
57
58
|
- BSD
|
@@ -66,23 +67,27 @@ rdoc_options:
|
|
66
67
|
require_paths:
|
67
68
|
- lib
|
68
69
|
required_ruby_version: !ruby/object:Gem::Requirement
|
70
|
+
none: false
|
69
71
|
requirements:
|
70
72
|
- - ">="
|
71
73
|
- !ruby/object:Gem::Version
|
74
|
+
hash: 3
|
72
75
|
segments:
|
73
76
|
- 0
|
74
77
|
version: "0"
|
75
78
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
79
|
+
none: false
|
76
80
|
requirements:
|
77
81
|
- - ">="
|
78
82
|
- !ruby/object:Gem::Version
|
83
|
+
hash: 3
|
79
84
|
segments:
|
80
85
|
- 0
|
81
86
|
version: "0"
|
82
87
|
requirements: []
|
83
88
|
|
84
89
|
rubyforge_project:
|
85
|
-
rubygems_version: 1.
|
90
|
+
rubygems_version: 1.8.6
|
86
91
|
signing_key:
|
87
92
|
specification_version: 3
|
88
93
|
summary: Ruby bindings for Datadog's API
|