aptible-cli 0.18.3 → 0.19.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +63 -50
- data/lib/aptible/cli/agent.rb +6 -2
- data/lib/aptible/cli/helpers/log_drain.rb +85 -0
- data/lib/aptible/cli/helpers/metric_drain.rb +39 -0
- data/lib/aptible/cli/resource_formatter.rb +43 -3
- data/lib/aptible/cli/subcommands/apps.rb +5 -40
- data/lib/aptible/cli/subcommands/backup.rb +15 -7
- data/lib/aptible/cli/subcommands/db.rb +23 -20
- data/lib/aptible/cli/subcommands/log_drain.rb +159 -0
- data/lib/aptible/cli/subcommands/metric_drain.rb +137 -0
- data/lib/aptible/cli/version.rb +1 -1
- data/spec/aptible/cli/subcommands/apps_spec.rb +0 -47
- data/spec/aptible/cli/subcommands/backup_spec.rb +1 -1
- data/spec/aptible/cli/subcommands/db_spec.rb +0 -26
- data/spec/aptible/cli/subcommands/log_drain_spec.rb +207 -0
- data/spec/aptible/cli/subcommands/metric_drain_spec.rb +183 -0
- data/spec/fabricators/account_fabricator.rb +2 -0
- data/spec/fabricators/log_drain_fabricator.rb +21 -0
- data/spec/fabricators/metric_drain_fabricator.rb +8 -0
- metadata +14 -5
- data/lib/aptible/cli/subcommands/domains.rb +0 -40
- data/spec/aptible/cli/subcommands/domains_spec.rb +0 -76
@@ -59,8 +59,8 @@ module Aptible
|
|
59
59
|
option :type, type: :string
|
60
60
|
option :version, type: :string
|
61
61
|
option :container_size, type: :numeric
|
62
|
-
option :size, type: :numeric
|
63
62
|
option :disk_size, default: 10, type: :numeric
|
63
|
+
option :size, type: :numeric
|
64
64
|
option :key_arn, type: :string
|
65
65
|
option :environment
|
66
66
|
define_method 'db:create' do |handle|
|
@@ -69,15 +69,16 @@ module Aptible
|
|
69
69
|
db_opts = {
|
70
70
|
handle: handle,
|
71
71
|
initial_container_size: options[:container_size],
|
72
|
-
initial_disk_size: options[:disk_size]
|
72
|
+
initial_disk_size: options[:disk_size],
|
73
73
|
current_kms_arn: options[:key_arn]
|
74
74
|
}.delete_if { |_, v| v.nil? }
|
75
75
|
|
76
|
-
|
77
|
-
'You have used the "--size" option to specify a disk size.'
|
78
|
-
|
79
|
-
|
80
|
-
|
76
|
+
if options[:size]
|
77
|
+
m = 'You have used the "--size" option to specify a disk size.'\
|
78
|
+
'This abiguous option has been removed.'\
|
79
|
+
'Please use the "--disk-size" option, instead.'
|
80
|
+
raise Thor::Error, m
|
81
|
+
end
|
81
82
|
|
82
83
|
type = options[:type]
|
83
84
|
version = options[:version]
|
@@ -97,7 +98,7 @@ module Aptible
|
|
97
98
|
op_opts = {
|
98
99
|
type: 'provision',
|
99
100
|
container_size: options[:container_size],
|
100
|
-
disk_size: options[:disk_size]
|
101
|
+
disk_size: options[:disk_size]
|
101
102
|
}.delete_if { |_, v| v.nil? }
|
102
103
|
op = database.create_operation(op_opts)
|
103
104
|
|
@@ -156,17 +157,18 @@ module Aptible
|
|
156
157
|
opts = {
|
157
158
|
environment: options[:environment],
|
158
159
|
container_size: options[:container_size],
|
159
|
-
size: options[:disk_size]
|
160
|
+
size: options[:disk_size],
|
160
161
|
logical: options[:logical],
|
161
162
|
database_image: image || nil,
|
162
163
|
key_arn: options[:key_arn]
|
163
164
|
}.delete_if { |_, v| v.nil? }
|
164
165
|
|
165
|
-
|
166
|
-
'You have used the "--size" option to specify a disk size.'
|
167
|
-
|
168
|
-
|
169
|
-
|
166
|
+
if options[:size]
|
167
|
+
m = 'You have used the "--size" option to specify a disk size.'\
|
168
|
+
'This abiguous option has been removed.'\
|
169
|
+
'Please use the "--disk-size" option, instead.'
|
170
|
+
raise Thor::Error, m
|
171
|
+
end
|
170
172
|
|
171
173
|
database = replicate_database(source, dest_handle, opts)
|
172
174
|
render_database(database.reload, database.account)
|
@@ -294,16 +296,17 @@ module Aptible
|
|
294
296
|
opts = {
|
295
297
|
type: 'restart',
|
296
298
|
container_size: options[:container_size],
|
297
|
-
disk_size: options[:disk_size]
|
299
|
+
disk_size: options[:disk_size],
|
298
300
|
provisioned_iops: options[:iops],
|
299
301
|
ebs_volume_type: options[:volume_type]
|
300
302
|
}.delete_if { |_, v| v.nil? }
|
301
303
|
|
302
|
-
|
303
|
-
'You have used the "--size" option to specify a disk size.'
|
304
|
-
|
305
|
-
|
306
|
-
|
304
|
+
if options[:size]
|
305
|
+
m = 'You have used the "--size" option to specify a disk size.'\
|
306
|
+
'This abiguous option has been removed.'\
|
307
|
+
'Please use the "--disk-size" option, instead.'
|
308
|
+
raise Thor::Error, m
|
309
|
+
end
|
307
310
|
|
308
311
|
CLI.logger.info "Restarting #{database.handle}..."
|
309
312
|
op = database.create_operation!(opts)
|
@@ -0,0 +1,159 @@
|
|
1
|
+
module Aptible
|
2
|
+
module CLI
|
3
|
+
module Subcommands
|
4
|
+
module LogDrain
|
5
|
+
def self.included(thor)
|
6
|
+
thor.class_eval do
|
7
|
+
include Helpers::Token
|
8
|
+
include Helpers::Database
|
9
|
+
include Helpers::LogDrain
|
10
|
+
|
11
|
+
drain_flags = '--environment ENVIRONMENT ' \
|
12
|
+
'[--drain-apps true/false] ' \
|
13
|
+
'[--drain_databases true/false] ' \
|
14
|
+
'[--drain_ephemeral_sessions true/false] ' \
|
15
|
+
'[--drain_proxies true/false]'
|
16
|
+
|
17
|
+
def self.drain_options
|
18
|
+
option :drain_apps, default: true, type: :boolean
|
19
|
+
option :drain_databases, default: true, type: :boolean
|
20
|
+
option :drain_ephemeral_sessions, default: true, type: :boolean
|
21
|
+
option :drain_proxies, default: true, type: :boolean
|
22
|
+
option :environment
|
23
|
+
end
|
24
|
+
|
25
|
+
desc 'log_drain:list', 'List all Log Drains'
|
26
|
+
option :environment
|
27
|
+
define_method 'log_drain:list' do
|
28
|
+
Formatter.render(Renderer.current) do |root|
|
29
|
+
root.grouped_keyed_list(
|
30
|
+
{ 'environment' => 'handle' },
|
31
|
+
'handle'
|
32
|
+
) do |node|
|
33
|
+
scoped_environments(options).each do |account|
|
34
|
+
account.log_drains.each do |drain|
|
35
|
+
node.object do |n|
|
36
|
+
ResourceFormatter.inject_log_drain(n, drain, account)
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
desc 'log_drain:create:elasticsearch HANDLE '\
|
45
|
+
'--db DATABASE_HANDLE ' \
|
46
|
+
+ drain_flags,
|
47
|
+
'Create an Elasticsearch Log Drain'
|
48
|
+
drain_options
|
49
|
+
option :db, type: :string
|
50
|
+
option :pipeline, type: :string
|
51
|
+
define_method 'log_drain:create:elasticsearch' do |handle|
|
52
|
+
account = ensure_environment(options)
|
53
|
+
database = ensure_database(options)
|
54
|
+
|
55
|
+
opts = {
|
56
|
+
handle: handle,
|
57
|
+
database_id: database.id,
|
58
|
+
logging_token: options[:pipeline],
|
59
|
+
drain_apps: options[:drain_apps],
|
60
|
+
drain_databases: options[:drain_databases],
|
61
|
+
drain_ephemeral_sessions: options[:drain_ephemeral_sessions],
|
62
|
+
drain_proxies: options[:drain_proxies],
|
63
|
+
drain_type: :elasticsearch_database
|
64
|
+
}
|
65
|
+
|
66
|
+
create_log_drain(account, opts)
|
67
|
+
end
|
68
|
+
|
69
|
+
desc 'log_drain:create:datadog HANDLE ' \
|
70
|
+
'--url DATADOG_URL ' \
|
71
|
+
+ drain_flags,
|
72
|
+
'Create a Datadog Log Drain'
|
73
|
+
drain_options
|
74
|
+
option :url, type: :string
|
75
|
+
define_method 'log_drain:create:datadog' do |handle|
|
76
|
+
msg = 'Must be in the format of ' \
|
77
|
+
'"https://http-intake.logs.datadoghq.com' \
|
78
|
+
'/v1/input/<DD_API_KEY>".'
|
79
|
+
create_https_based_log_drain(handle, options, url_format_msg: msg)
|
80
|
+
end
|
81
|
+
|
82
|
+
desc 'log_drain:create:https HANDLE ' \
|
83
|
+
'--url URL ' \
|
84
|
+
+ drain_flags,
|
85
|
+
'Create a HTTPS Drain'
|
86
|
+
option :url, type: :string
|
87
|
+
drain_options
|
88
|
+
define_method 'log_drain:create:https' do |handle|
|
89
|
+
create_https_based_log_drain(handle, options)
|
90
|
+
end
|
91
|
+
|
92
|
+
desc 'log_drain:create:sumologic HANDLE ' \
|
93
|
+
'--url SUMOLOGIC_URL ' \
|
94
|
+
+ drain_flags,
|
95
|
+
'Create a Sumologic Drain'
|
96
|
+
option :url, type: :string
|
97
|
+
drain_options
|
98
|
+
define_method 'log_drain:create:sumologic' do |handle|
|
99
|
+
create_https_based_log_drain(handle, options)
|
100
|
+
end
|
101
|
+
|
102
|
+
desc 'log_drain:create:logdna HANDLE ' \
|
103
|
+
'--url LOGDNA_URL ' \
|
104
|
+
+ drain_flags,
|
105
|
+
'Create a LogDNA Log Drain'
|
106
|
+
option :url, type: :string
|
107
|
+
drain_options
|
108
|
+
define_method 'log_drain:create:logdna' do |handle|
|
109
|
+
msg = 'Must be in the format of ' \
|
110
|
+
'"https://logs.logdna.com/aptible/ingest/<INGESTION KEY>".'
|
111
|
+
create_https_based_log_drain(handle, options, url_format_msg: msg)
|
112
|
+
end
|
113
|
+
|
114
|
+
desc 'log_drain:create:papertrail HANDLE ' \
|
115
|
+
'--host PAPERTRAIL_HOST --port PAPERTRAIL_PORT ' \
|
116
|
+
+ drain_flags,
|
117
|
+
'Create a Papertrail Log Drain'
|
118
|
+
option :host, type: :string
|
119
|
+
option :port, type: :string
|
120
|
+
drain_options
|
121
|
+
define_method 'log_drain:create:papertrail' do |handle|
|
122
|
+
create_syslog_based_log_drain(handle, options)
|
123
|
+
end
|
124
|
+
|
125
|
+
desc 'log_drain:create:syslog HANDLE ' \
|
126
|
+
'--host SYSLOG_HOST --port SYSLOG_PORT ' \
|
127
|
+
'[--token TOKEN] ' \
|
128
|
+
+ drain_flags,
|
129
|
+
'Create a Papertrail Log Drain'
|
130
|
+
option :host, type: :string
|
131
|
+
option :port, type: :string
|
132
|
+
option :token, type: :string
|
133
|
+
drain_options
|
134
|
+
define_method 'log_drain:create:syslog' do |handle|
|
135
|
+
create_syslog_based_log_drain(handle, options)
|
136
|
+
end
|
137
|
+
|
138
|
+
desc 'log_drain:deprovision HANDLE --environment ENVIRONMENT',
|
139
|
+
'Deprovisions a log drain'
|
140
|
+
option :environment
|
141
|
+
define_method 'log_drain:deprovision' do |handle|
|
142
|
+
account = ensure_environment(options)
|
143
|
+
drain = ensure_log_drain(account, handle)
|
144
|
+
op = drain.create_operation(type: :deprovision)
|
145
|
+
begin
|
146
|
+
attach_to_operation_logs(op)
|
147
|
+
rescue HyperResource::ClientError => e
|
148
|
+
# A 404 here means that the operation completed successfully,
|
149
|
+
# and was removed faster than attach_to_operation_logs
|
150
|
+
# could attach to the logs.
|
151
|
+
raise if e.response.status != 404
|
152
|
+
end
|
153
|
+
end
|
154
|
+
end
|
155
|
+
end
|
156
|
+
end
|
157
|
+
end
|
158
|
+
end
|
159
|
+
end
|
@@ -0,0 +1,137 @@
|
|
1
|
+
module Aptible
|
2
|
+
module CLI
|
3
|
+
module Subcommands
|
4
|
+
module MetricDrain
|
5
|
+
SITES = {
|
6
|
+
'US1' => 'https://app.datadoghq.com',
|
7
|
+
'US3' => 'https://us3.datadoghq.com',
|
8
|
+
'EU1' => 'https://app.datadoghq.eu',
|
9
|
+
'US1-FED' => 'https://app.ddog-gov.com'
|
10
|
+
}.freeze
|
11
|
+
|
12
|
+
def self.included(thor)
|
13
|
+
thor.class_eval do
|
14
|
+
include Helpers::Token
|
15
|
+
include Helpers::Database
|
16
|
+
include Helpers::MetricDrain
|
17
|
+
|
18
|
+
desc 'metric_drain:list', 'List all Metric Drains'
|
19
|
+
option :environment
|
20
|
+
define_method 'metric_drain:list' do
|
21
|
+
Formatter.render(Renderer.current) do |root|
|
22
|
+
root.grouped_keyed_list(
|
23
|
+
{ 'environment' => 'handle' },
|
24
|
+
'handle'
|
25
|
+
) do |node|
|
26
|
+
scoped_environments(options).each do |account|
|
27
|
+
account.metric_drains.each do |drain|
|
28
|
+
node.object do |n|
|
29
|
+
ResourceFormatter.inject_metric_drain(n, drain, account)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
desc 'metric_drain:create:influxdb HANDLE '\
|
38
|
+
'--db DATABASE_HANDLE --environment ENVIRONMENT',
|
39
|
+
'Create an InfluxDB Metric Drain'
|
40
|
+
option :db, type: :string
|
41
|
+
option :environment
|
42
|
+
|
43
|
+
define_method 'metric_drain:create:influxdb' do |handle|
|
44
|
+
account = ensure_environment(options)
|
45
|
+
database = ensure_database(options)
|
46
|
+
|
47
|
+
opts = {
|
48
|
+
handle: handle,
|
49
|
+
database_id: database.id,
|
50
|
+
drain_type: :influxdb_database
|
51
|
+
}
|
52
|
+
|
53
|
+
create_metric_drain(account, opts)
|
54
|
+
end
|
55
|
+
|
56
|
+
desc 'metric_drain:create:influxdb:custom HANDLE '\
|
57
|
+
'--username USERNAME --password PASSWORD ' \
|
58
|
+
'--url URL_INCLUDING_PORT',
|
59
|
+
'Create an InfluxDB Metric Drain'
|
60
|
+
option :db, type: :string
|
61
|
+
option :username, type: :string
|
62
|
+
option :password, type: :string
|
63
|
+
option :url, type: :string
|
64
|
+
option :db, type: :string
|
65
|
+
option :environment
|
66
|
+
define_method 'metric_drain:create:influxdb:custom' do |handle|
|
67
|
+
account = ensure_environment(options)
|
68
|
+
|
69
|
+
config = {
|
70
|
+
address: options[:url],
|
71
|
+
username: options[:username],
|
72
|
+
password: options[:password],
|
73
|
+
database: options[:db]
|
74
|
+
}
|
75
|
+
opts = {
|
76
|
+
handle: handle,
|
77
|
+
drain_configuration: config,
|
78
|
+
drain_type: :influxdb
|
79
|
+
}
|
80
|
+
|
81
|
+
create_metric_drain(account, opts)
|
82
|
+
end
|
83
|
+
|
84
|
+
desc 'metric_drain:create:datadog HANDLE '\
|
85
|
+
'--api_key DATADOG_API_KEY --environment ENVIRONMENT',
|
86
|
+
'Create a Datadog Metric Drain'
|
87
|
+
option :api_key, type: :string
|
88
|
+
option :site, type: :string
|
89
|
+
option :environment
|
90
|
+
define_method 'metric_drain:create:datadog' do |handle|
|
91
|
+
account = ensure_environment(options)
|
92
|
+
|
93
|
+
config = {
|
94
|
+
api_key: options[:api_key]
|
95
|
+
}
|
96
|
+
unless options[:site].nil?
|
97
|
+
site = SITES[options[:site]]
|
98
|
+
|
99
|
+
unless site
|
100
|
+
sites = SITES.keys.join(', ')
|
101
|
+
raise Thor::Error, 'Invalid Datadog site. ' \
|
102
|
+
"Valid options are #{sites}"
|
103
|
+
end
|
104
|
+
|
105
|
+
config[:series_url] = site
|
106
|
+
end
|
107
|
+
opts = {
|
108
|
+
handle: handle,
|
109
|
+
drain_type: :datadog,
|
110
|
+
drain_configuration: config
|
111
|
+
}
|
112
|
+
|
113
|
+
create_metric_drain(account, opts)
|
114
|
+
end
|
115
|
+
|
116
|
+
desc 'metric_drain:deprovision HANDLE --environment ENVIRONMENT',
|
117
|
+
'Deprovisions a Metric Drain'
|
118
|
+
option :environment
|
119
|
+
define_method 'metric_drain:deprovision' do |handle|
|
120
|
+
account = ensure_environment(options)
|
121
|
+
drain = ensure_metric_drain(account, handle)
|
122
|
+
op = drain.create_operation(type: :deprovision)
|
123
|
+
begin
|
124
|
+
attach_to_operation_logs(op)
|
125
|
+
rescue HyperResource::ClientError => e
|
126
|
+
# A 404 here means that the operation completed successfully,
|
127
|
+
# and was removed faster than attach_to_operation_logs
|
128
|
+
# could attach to the logs.
|
129
|
+
raise if e.response.status != 404
|
130
|
+
end
|
131
|
+
end
|
132
|
+
end
|
133
|
+
end
|
134
|
+
end
|
135
|
+
end
|
136
|
+
end
|
137
|
+
end
|
data/lib/aptible/cli/version.rb
CHANGED
@@ -253,42 +253,6 @@ describe Aptible::CLI::Agent do
|
|
253
253
|
.to raise_error(/provide at least/im)
|
254
254
|
end
|
255
255
|
|
256
|
-
it 'should scale container count (legacy)' do
|
257
|
-
stub_options
|
258
|
-
expect(service).to receive(:create_operation!)
|
259
|
-
.with(type: 'scale', container_count: 3)
|
260
|
-
.and_return(op)
|
261
|
-
subject.send('apps:scale', 'web', '3')
|
262
|
-
expect(captured_logs).to match(/deprecated/i)
|
263
|
-
end
|
264
|
-
|
265
|
-
it 'should scale container size (legacy)' do
|
266
|
-
stub_options(size: 90210)
|
267
|
-
expect(service).to receive(:create_operation!)
|
268
|
-
.with(type: 'scale', container_size: 90210)
|
269
|
-
.and_return(op)
|
270
|
-
subject.send('apps:scale', 'web')
|
271
|
-
expect(captured_logs).to match(/deprecated/i)
|
272
|
-
end
|
273
|
-
|
274
|
-
it 'should fail when using both current and legacy count' do
|
275
|
-
stub_options(container_count: 2)
|
276
|
-
expect { subject.send('apps:scale', 'web', '3') }
|
277
|
-
.to raise_error(/count was passed via both/im)
|
278
|
-
end
|
279
|
-
|
280
|
-
it 'should fail when using both current and legacy size' do
|
281
|
-
stub_options(container_size: 1024, size: 512)
|
282
|
-
expect { subject.send('apps:scale', 'web') }
|
283
|
-
.to raise_error(/size was passed via both/im)
|
284
|
-
end
|
285
|
-
|
286
|
-
it 'should fail when using too many arguments' do
|
287
|
-
stub_options
|
288
|
-
expect { subject.send('apps:scale', 'web', '3', '4') }
|
289
|
-
.to raise_error(/usage:.*apps:scale/im)
|
290
|
-
end
|
291
|
-
|
292
256
|
it 'should fail if the service does not exist' do
|
293
257
|
stub_options(container_count: 2)
|
294
258
|
|
@@ -323,17 +287,6 @@ describe Aptible::CLI::Agent do
|
|
323
287
|
subject.send('apps:scale', 'web')
|
324
288
|
end.to raise_error(Thor::Error)
|
325
289
|
end
|
326
|
-
|
327
|
-
it 'should fail if number is not a valid number (legacy)' do
|
328
|
-
allow(subject).to receive(:options) { { app: 'hello' } }
|
329
|
-
allow(service).to receive(:create_operation) { op }
|
330
|
-
|
331
|
-
expect do
|
332
|
-
subject.send('apps:scale', 'web', 'potato')
|
333
|
-
end.to raise_error(ArgumentError)
|
334
|
-
|
335
|
-
expect(captured_logs).to match(/deprecated/i)
|
336
|
-
end
|
337
290
|
end
|
338
291
|
|
339
292
|
describe '#apps:deprovision' do
|