3scale_toolbox 0.15.0 → 0.18.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/3scale_toolbox.gemspec +2 -2
- data/README.md +15 -9
- data/lib/3scale_toolbox.rb +3 -1
- data/lib/3scale_toolbox/3scale_client_factory.rb +3 -4
- data/lib/3scale_toolbox/cli.rb +4 -0
- data/lib/3scale_toolbox/cli/custom_table_printer.rb +32 -0
- data/lib/3scale_toolbox/cli/error_handler.rb +17 -14
- data/lib/3scale_toolbox/cli/json_printer.rb +13 -0
- data/lib/3scale_toolbox/cli/output_flag.rb +20 -0
- data/lib/3scale_toolbox/cli/yaml_printer.rb +13 -0
- data/lib/3scale_toolbox/commands.rb +7 -1
- data/lib/3scale_toolbox/commands/activedocs_command/apply_command.rb +33 -10
- data/lib/3scale_toolbox/commands/activedocs_command/create_command.rb +22 -7
- data/lib/3scale_toolbox/commands/activedocs_command/list_command.rb +10 -17
- data/lib/3scale_toolbox/commands/application_command/apply_command.rb +27 -4
- data/lib/3scale_toolbox/commands/application_command/create_command.rb +16 -1
- data/lib/3scale_toolbox/commands/application_command/list_command.rb +10 -13
- data/lib/3scale_toolbox/commands/application_command/show_command.rb +8 -14
- data/lib/3scale_toolbox/commands/backend_command.rb +22 -0
- data/lib/3scale_toolbox/commands/backend_command/copy_command.rb +65 -0
- data/lib/3scale_toolbox/commands/backend_command/copy_command/copy_mapping_rules_task.rb +36 -0
- data/lib/3scale_toolbox/commands/backend_command/copy_command/copy_methods_task.rb +35 -0
- data/lib/3scale_toolbox/commands/backend_command/copy_command/copy_metrics_task.rb +30 -0
- data/lib/3scale_toolbox/commands/backend_command/copy_command/create_or_update_target_backend_task.rb +46 -0
- data/lib/3scale_toolbox/commands/backend_command/copy_command/task.rb +67 -0
- data/lib/3scale_toolbox/commands/copy_command.rb +2 -2
- data/lib/3scale_toolbox/commands/copy_command/service_command.rb +40 -0
- data/lib/3scale_toolbox/commands/import_command/issuer_type_transformer.rb +16 -0
- data/lib/3scale_toolbox/commands/import_command/openapi.rb +6 -2
- data/lib/3scale_toolbox/commands/import_command/openapi/create_mapping_rule_step.rb +2 -1
- data/lib/3scale_toolbox/commands/import_command/openapi/create_method_step.rb +5 -14
- data/lib/3scale_toolbox/commands/import_command/openapi/step.rb +4 -0
- data/lib/3scale_toolbox/commands/import_command/openapi/update_service_proxy_step.rb +1 -0
- data/lib/3scale_toolbox/commands/methods_command/apply_command.rb +28 -8
- data/lib/3scale_toolbox/commands/methods_command/create_command.rb +23 -3
- data/lib/3scale_toolbox/commands/methods_command/delete_command.rb +1 -1
- data/lib/3scale_toolbox/commands/methods_command/list_command.rb +7 -13
- data/lib/3scale_toolbox/commands/metrics_command/apply_command.rb +26 -4
- data/lib/3scale_toolbox/commands/metrics_command/create_command.rb +23 -1
- data/lib/3scale_toolbox/commands/metrics_command/list_command.rb +7 -12
- data/lib/3scale_toolbox/commands/plans_command/apply_command.rb +36 -7
- data/lib/3scale_toolbox/commands/plans_command/create_command.rb +23 -1
- data/lib/3scale_toolbox/commands/plans_command/export/read_plan_limits_step.rb +1 -1
- data/lib/3scale_toolbox/commands/plans_command/export/read_plan_methods_step.rb +2 -2
- data/lib/3scale_toolbox/commands/plans_command/export/read_plan_metrics_step.rb +2 -2
- data/lib/3scale_toolbox/commands/plans_command/export/read_plan_pricing_rules_step.rb +1 -2
- data/lib/3scale_toolbox/commands/plans_command/export/step.rb +8 -20
- data/lib/3scale_toolbox/commands/plans_command/import/import_plan_limits_step.rb +12 -14
- data/lib/3scale_toolbox/commands/plans_command/import/import_plan_metrics_step.rb +6 -13
- data/lib/3scale_toolbox/commands/plans_command/import/import_plan_pricing_rules_step.rb +12 -20
- data/lib/3scale_toolbox/commands/plans_command/import/step.rb +2 -22
- data/lib/3scale_toolbox/commands/plans_command/list_command.rb +8 -13
- data/lib/3scale_toolbox/commands/plans_command/show_command.rb +7 -15
- data/lib/3scale_toolbox/commands/policies_command.rb +24 -0
- data/lib/3scale_toolbox/commands/policies_command/export_command.rb +98 -0
- data/lib/3scale_toolbox/commands/policies_command/import_command.rb +61 -0
- data/lib/3scale_toolbox/commands/product_command.rb +26 -0
- data/lib/3scale_toolbox/commands/product_command/copy_command.rb +82 -0
- data/lib/3scale_toolbox/commands/product_command/copy_command/copy_backends_task.rb +88 -0
- data/lib/3scale_toolbox/commands/product_command/copy_command/delete_target_backend_usages_task.rb +48 -0
- data/lib/3scale_toolbox/commands/product_command/export_command.rb +81 -0
- data/lib/3scale_toolbox/commands/product_command/import_command.rb +125 -0
- data/lib/3scale_toolbox/commands/proxy_config_command.rb +5 -0
- data/lib/3scale_toolbox/commands/proxy_config_command/deploy_command.rb +54 -0
- data/lib/3scale_toolbox/commands/proxy_config_command/export_command.rb +74 -0
- data/lib/3scale_toolbox/commands/proxy_config_command/helper.rb +15 -0
- data/lib/3scale_toolbox/commands/proxy_config_command/list_command.rb +13 -29
- data/lib/3scale_toolbox/commands/proxy_config_command/show_command.rb +20 -23
- data/lib/3scale_toolbox/commands/service_command.rb +7 -5
- data/lib/3scale_toolbox/commands/service_command/apply_command.rb +69 -58
- data/lib/3scale_toolbox/commands/service_command/copy_command.rb +95 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/bump_proxy_version_task.rb +36 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_activedocs_task.rb +49 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_app_plans_task.rb +35 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_limits_task.rb +38 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_mapping_rules_task.rb +35 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_methods_task.rb +37 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_metrics_task.rb +37 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_policies_task.rb +17 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_pricingrules_task.rb +41 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/copy_service_proxy_task.rb +32 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/create_or_update_service_task.rb +49 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/destroy_mapping_rules_task.rb +38 -0
- data/lib/3scale_toolbox/commands/service_command/copy_command/task.rb +85 -0
- data/lib/3scale_toolbox/commands/service_command/create_command.rb +58 -44
- data/lib/3scale_toolbox/commands/service_command/delete_command.rb +31 -33
- data/lib/3scale_toolbox/commands/service_command/list_command.rb +24 -34
- data/lib/3scale_toolbox/commands/service_command/show_command.rb +39 -44
- data/lib/3scale_toolbox/commands/update_command.rb +3 -3
- data/lib/3scale_toolbox/commands/update_command/{update_service.rb → service_command.rb} +22 -18
- data/lib/3scale_toolbox/commands/update_command/service_command/copy_service_settings_task.rb +35 -0
- data/lib/3scale_toolbox/commands/update_command/service_command/delete_activedocs_task.rb +24 -0
- data/lib/3scale_toolbox/crds.rb +16 -0
- data/lib/3scale_toolbox/crds/application_plan_dump.rb +19 -0
- data/lib/3scale_toolbox/crds/backend_dump.rb +39 -0
- data/lib/3scale_toolbox/crds/backend_mapping_rule_dump.rb +26 -0
- data/lib/3scale_toolbox/crds/backend_method_dump.rb +12 -0
- data/lib/3scale_toolbox/crds/backend_metric_dump.rb +13 -0
- data/lib/3scale_toolbox/crds/backend_parser.rb +55 -0
- data/lib/3scale_toolbox/crds/backend_usage_dump.rb +11 -0
- data/lib/3scale_toolbox/crds/limit_dump.rb +37 -0
- data/lib/3scale_toolbox/crds/mapping_rule_dump.rb +26 -0
- data/lib/3scale_toolbox/crds/method_dump.rb +12 -0
- data/lib/3scale_toolbox/crds/metric_dump.rb +13 -0
- data/lib/3scale_toolbox/crds/pricing_rule_dump.rb +38 -0
- data/lib/3scale_toolbox/crds/product_deployment_parser.rb +329 -0
- data/lib/3scale_toolbox/crds/product_dump.rb +157 -0
- data/lib/3scale_toolbox/crds/product_parser.rb +114 -0
- data/lib/3scale_toolbox/crds/remote.rb +682 -0
- data/lib/3scale_toolbox/entities.rb +8 -0
- data/lib/3scale_toolbox/entities/activedocs.rb +12 -0
- data/lib/3scale_toolbox/entities/application_plan.rb +74 -39
- data/lib/3scale_toolbox/entities/backend.rb +187 -0
- data/lib/3scale_toolbox/entities/backend_mapping_rule.rb +102 -0
- data/lib/3scale_toolbox/entities/backend_method.rb +99 -0
- data/lib/3scale_toolbox/entities/backend_metric.rb +98 -0
- data/lib/3scale_toolbox/entities/backend_usage.rb +105 -0
- data/lib/3scale_toolbox/entities/limit.rb +71 -0
- data/lib/3scale_toolbox/entities/mapping_rule.rb +90 -0
- data/lib/3scale_toolbox/entities/method.rb +33 -19
- data/lib/3scale_toolbox/entities/metric.rb +29 -18
- data/lib/3scale_toolbox/entities/pricing_rule.rb +63 -0
- data/lib/3scale_toolbox/entities/proxy_config.rb +0 -1
- data/lib/3scale_toolbox/entities/service.rb +166 -48
- data/lib/3scale_toolbox/error.rb +53 -0
- data/lib/3scale_toolbox/helper.rb +17 -0
- data/lib/3scale_toolbox/openapi/oas3.rb +1 -1
- data/lib/3scale_toolbox/proxy_logger.rb +5 -1
- data/lib/3scale_toolbox/remote_cache.rb +157 -0
- data/lib/3scale_toolbox/remotes.rb +2 -2
- data/lib/3scale_toolbox/version.rb +1 -1
- data/licenses.xml +113 -45
- metadata +75 -26
- data/lib/3scale_toolbox/commands/copy_command/copy_service.rb +0 -144
- data/lib/3scale_toolbox/tasks.rb +0 -15
- data/lib/3scale_toolbox/tasks/bump_proxy_version_task.rb +0 -32
- data/lib/3scale_toolbox/tasks/copy_activedocs_task.rb +0 -42
- data/lib/3scale_toolbox/tasks/copy_app_plans_task.rb +0 -31
- data/lib/3scale_toolbox/tasks/copy_limits_task.rb +0 -36
- data/lib/3scale_toolbox/tasks/copy_mapping_rules_task.rb +0 -32
- data/lib/3scale_toolbox/tasks/copy_methods_task.rb +0 -36
- data/lib/3scale_toolbox/tasks/copy_metrics_task.rb +0 -33
- data/lib/3scale_toolbox/tasks/copy_policies_task.rb +0 -13
- data/lib/3scale_toolbox/tasks/copy_pricingrules_task.rb +0 -41
- data/lib/3scale_toolbox/tasks/copy_service_proxy_task.rb +0 -13
- data/lib/3scale_toolbox/tasks/copy_service_settings_task.rb +0 -38
- data/lib/3scale_toolbox/tasks/copy_task.rb +0 -66
- data/lib/3scale_toolbox/tasks/delete_activedocs_task.rb +0 -22
- data/lib/3scale_toolbox/tasks/destroy_mapping_rules_task.rb +0 -22
- data/lib/3scale_toolbox/tasks/helper_task.rb +0 -25
data/lib/3scale_toolbox/commands/service_command/copy_command/create_or_update_service_task.rb
ADDED
@@ -0,0 +1,49 @@
|
|
1
|
+
module ThreeScaleToolbox
|
2
|
+
module Commands
|
3
|
+
module ServiceCommand
|
4
|
+
module CopyCommand
|
5
|
+
class CreateOrUpdateTargetServiceTask
|
6
|
+
include Task
|
7
|
+
|
8
|
+
def call
|
9
|
+
service = Entities::Service.find(remote: target_remote,
|
10
|
+
ref: target_service_ref)
|
11
|
+
if service == source
|
12
|
+
raise ThreeScaleToolbox::Error, 'Source and destination services are the same: ' \
|
13
|
+
"ID: #{source.id} system_name: #{source.attrs['system_name']}"
|
14
|
+
end
|
15
|
+
|
16
|
+
if service.nil?
|
17
|
+
service = Entities::Service.create(remote: target_remote,
|
18
|
+
service_params: create_attrs)
|
19
|
+
# Notify that mapping rules should be deleted before being copied
|
20
|
+
force_delete_mapping_rules
|
21
|
+
else
|
22
|
+
service.update update_attrs
|
23
|
+
end
|
24
|
+
|
25
|
+
# assign target service for other tasks to have it available
|
26
|
+
self.target = service
|
27
|
+
|
28
|
+
logger.info "new service id #{service.id}"
|
29
|
+
report['product_id'] = service.id
|
30
|
+
end
|
31
|
+
|
32
|
+
private
|
33
|
+
|
34
|
+
def target_service_ref
|
35
|
+
option_target_system_name || source.attrs.fetch('system_name')
|
36
|
+
end
|
37
|
+
|
38
|
+
def create_attrs
|
39
|
+
source.attrs.merge('system_name' => target_service_ref)
|
40
|
+
end
|
41
|
+
|
42
|
+
def update_attrs
|
43
|
+
source.attrs.merge('system_name' => target_service_ref)
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
module ThreeScaleToolbox
|
2
|
+
module Commands
|
3
|
+
module ServiceCommand
|
4
|
+
module CopyCommand
|
5
|
+
class DestroyMappingRulesTask
|
6
|
+
attr_reader :context
|
7
|
+
|
8
|
+
def initialize(context)
|
9
|
+
@context = context
|
10
|
+
end
|
11
|
+
|
12
|
+
def call
|
13
|
+
return unless delete_mapping_rules
|
14
|
+
|
15
|
+
logger.info 'destroying all mapping rules'
|
16
|
+
target.mapping_rules.each(&:delete)
|
17
|
+
end
|
18
|
+
|
19
|
+
private
|
20
|
+
|
21
|
+
def delete_mapping_rules
|
22
|
+
context.fetch(:delete_mapping_rules, false)
|
23
|
+
end
|
24
|
+
|
25
|
+
def target
|
26
|
+
context.fetch(:target)
|
27
|
+
end
|
28
|
+
|
29
|
+
def logger
|
30
|
+
context[:logger] ||= Logger.new($stdout).tap do |logger|
|
31
|
+
logger.formatter = proc { |severity, datetime, progname, msg| "#{msg}\n" }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -0,0 +1,85 @@
|
|
1
|
+
module ThreeScaleToolbox
|
2
|
+
module Commands
|
3
|
+
module ServiceCommand
|
4
|
+
module CopyCommand
|
5
|
+
module Task
|
6
|
+
attr_reader :context
|
7
|
+
|
8
|
+
def initialize(context)
|
9
|
+
@context = context
|
10
|
+
end
|
11
|
+
|
12
|
+
def source
|
13
|
+
context[:source] ||= find_source_service
|
14
|
+
end
|
15
|
+
|
16
|
+
def find_source_service
|
17
|
+
Entities::Service.find(remote: source_remote, ref: source_service_ref).tap do |svc|
|
18
|
+
raise ThreeScaleToolbox::Error, "Service #{source_service_ref} does not exist" if svc.nil?
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def target
|
23
|
+
context[:target] ||= raise ThreeScaleToolbox::Error, 'Unexpected error. ' \
|
24
|
+
'Target service should have been created or updated'
|
25
|
+
end
|
26
|
+
|
27
|
+
def target=(target)
|
28
|
+
context[:target] = target
|
29
|
+
end
|
30
|
+
|
31
|
+
def delete_mapping_rules
|
32
|
+
context.fetch(:delete_mapping_rules, false)
|
33
|
+
end
|
34
|
+
|
35
|
+
def force_delete_mapping_rules
|
36
|
+
context[:delete_mapping_rules] = true
|
37
|
+
end
|
38
|
+
|
39
|
+
def source_metrics_and_methods
|
40
|
+
source.metrics + source.methods
|
41
|
+
end
|
42
|
+
|
43
|
+
def target_metrics_and_methods
|
44
|
+
target.metrics + target.methods
|
45
|
+
end
|
46
|
+
|
47
|
+
def source_remote
|
48
|
+
context[:source_remote]
|
49
|
+
end
|
50
|
+
|
51
|
+
def target_remote
|
52
|
+
context[:target_remote]
|
53
|
+
end
|
54
|
+
|
55
|
+
def source_service_ref
|
56
|
+
context[:source_service_ref] ||= raise ThreeScaleToolbox::Error, 'Unexpected error. ' \
|
57
|
+
'source_service_ref not found'
|
58
|
+
end
|
59
|
+
|
60
|
+
def option_target_system_name
|
61
|
+
context[:option_target_system_name]
|
62
|
+
end
|
63
|
+
|
64
|
+
def logger
|
65
|
+
context[:logger] ||= Logger.new($stdout).tap do |logger|
|
66
|
+
logger.formatter = proc { |severity, datetime, progname, msg| "#{msg}\n" }
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
def plans_report
|
71
|
+
report['application_plans'] ||= {}
|
72
|
+
end
|
73
|
+
|
74
|
+
def activedocs_report
|
75
|
+
report['activedocs'] ||= {}
|
76
|
+
end
|
77
|
+
|
78
|
+
def report
|
79
|
+
context[:report] ||= {}
|
80
|
+
end
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
@@ -1,58 +1,72 @@
|
|
1
1
|
module ThreeScaleToolbox
|
2
2
|
module Commands
|
3
3
|
module ServiceCommand
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
Cri::Command.define do
|
10
|
-
name 'create'
|
11
|
-
usage 'create [options] <remote> <service-name>'
|
12
|
-
summary 'Create a service'
|
13
|
-
description 'Create a service'
|
14
|
-
runner CreateSubcommand
|
15
|
-
|
16
|
-
param :remote
|
17
|
-
param :service_name
|
18
|
-
|
19
|
-
option :d, :'deployment-mode', "Specify the deployment mode of the service", argument: :required
|
20
|
-
option :s, :'system-name', "Specify the system-name of the service", argument: :required
|
21
|
-
option :a, :'authentication-mode', "Specify authentication mode of the service ('1' for API key, '2' for App Id / App Key, 'oauth' for OAuth mode, 'oidc' for OpenID Connect)", argument: :required
|
22
|
-
option nil, :description, "Specify the description of the service", argument: :required
|
23
|
-
option nil, :'support-email', "Specify the support email of the service", argument: :required
|
24
|
-
end
|
25
|
-
end
|
4
|
+
class CreateSubcommand < Cri::CommandRunner
|
5
|
+
include ThreeScaleToolbox::Command
|
6
|
+
|
7
|
+
class CustomPrinter
|
8
|
+
attr_reader :option_default, :option_disabled
|
26
9
|
|
27
|
-
def
|
28
|
-
|
29
|
-
result = Entities::Service.create(remote: remote, service_params: create_service_params)
|
30
|
-
puts "Service '#{arguments[:service_name]}' has been created with ID: #{result.id}"
|
10
|
+
def print_record(service)
|
11
|
+
puts "Service '#{service['name']}' has been created with ID: #{service['id']}"
|
31
12
|
end
|
32
13
|
|
33
|
-
|
14
|
+
def print_collection(collection) end
|
15
|
+
end
|
34
16
|
|
35
|
-
|
36
|
-
|
37
|
-
|
17
|
+
def self.command
|
18
|
+
Cri::Command.define do
|
19
|
+
name 'create'
|
20
|
+
usage 'create [options] <remote> <service-name>'
|
21
|
+
summary 'Create a service'
|
22
|
+
description 'Create a service'
|
38
23
|
|
39
|
-
|
40
|
-
|
41
|
-
"deployment_option" => options[:'deployment-mode'],
|
42
|
-
"system_name" => options[:'system-name'],
|
43
|
-
"backend_version" => options[:'authentication-mode'],
|
44
|
-
"description" => options[:description],
|
45
|
-
"support_email" => options[:'support-email'],
|
46
|
-
}.compact
|
47
|
-
end
|
24
|
+
param :remote
|
25
|
+
param :service_name
|
48
26
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
27
|
+
ThreeScaleToolbox::CLI.output_flag(self)
|
28
|
+
option :d, :'deployment-mode', "Specify the deployment mode of the service", argument: :required
|
29
|
+
option :s, :'system-name', "Specify the system-name of the service", argument: :required
|
30
|
+
option :a, :'authentication-mode', "Specify authentication mode of the service ('1' for API key, '2' for App Id / App Key, 'oauth' for OAuth mode, 'oidc' for OpenID Connect)", argument: :required
|
31
|
+
option nil, :description, "Specify the description of the service", argument: :required
|
32
|
+
option nil, :'support-email', "Specify the support email of the service", argument: :required
|
33
|
+
|
34
|
+
runner CreateSubcommand
|
54
35
|
end
|
55
36
|
end
|
37
|
+
|
38
|
+
def run
|
39
|
+
service = Entities::Service.create(remote: remote, service_params: create_params)
|
40
|
+
printer.print_record service.attrs
|
41
|
+
end
|
42
|
+
|
43
|
+
private
|
44
|
+
|
45
|
+
def remote
|
46
|
+
@remote ||= threescale_client(arguments[:remote])
|
47
|
+
end
|
48
|
+
|
49
|
+
def parse_options
|
50
|
+
{
|
51
|
+
"deployment_option" => options[:'deployment-mode'],
|
52
|
+
"system_name" => options[:'system-name'],
|
53
|
+
"backend_version" => options[:'authentication-mode'],
|
54
|
+
"description" => options[:description],
|
55
|
+
"support_email" => options[:'support-email'],
|
56
|
+
}.compact
|
57
|
+
end
|
58
|
+
|
59
|
+
def create_params
|
60
|
+
service_name = arguments[:service_name]
|
61
|
+
create_service_attrs = parse_options
|
62
|
+
create_service_attrs['name'] = service_name
|
63
|
+
create_service_attrs
|
64
|
+
end
|
65
|
+
|
66
|
+
def printer
|
67
|
+
# keep backwards compatibility
|
68
|
+
options.fetch(:output, CustomPrinter.new)
|
69
|
+
end
|
56
70
|
end
|
57
71
|
end
|
58
72
|
end
|
@@ -1,46 +1,44 @@
|
|
1
1
|
module ThreeScaleToolbox
|
2
2
|
module Commands
|
3
3
|
module ServiceCommand
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
param :service_id_or_system_name
|
18
|
-
end
|
4
|
+
class DeleteSubcommand < Cri::CommandRunner
|
5
|
+
include ThreeScaleToolbox::Command
|
6
|
+
|
7
|
+
def self.command
|
8
|
+
Cri::Command.define do
|
9
|
+
name 'delete'
|
10
|
+
usage 'delete <remote> <service-id_or_system-name>'
|
11
|
+
summary 'Delete a service'
|
12
|
+
description 'Delete a service'
|
13
|
+
runner DeleteSubcommand
|
14
|
+
|
15
|
+
param :remote
|
16
|
+
param :service_id_or_system_name
|
19
17
|
end
|
18
|
+
end
|
20
19
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
20
|
+
def run
|
21
|
+
service.delete
|
22
|
+
puts "Service with id: #{service.id} deleted"
|
23
|
+
end
|
25
24
|
|
26
|
-
|
25
|
+
private
|
27
26
|
|
28
|
-
|
29
|
-
|
30
|
-
|
27
|
+
def remote
|
28
|
+
@remote ||= threescale_client(arguments[:remote])
|
29
|
+
end
|
31
30
|
|
32
|
-
|
33
|
-
|
34
|
-
|
31
|
+
def ref
|
32
|
+
@ref ||= arguments[:service_id_or_system_name]
|
33
|
+
end
|
35
34
|
|
36
|
-
|
37
|
-
|
38
|
-
|
35
|
+
def service
|
36
|
+
@service ||= find_service
|
37
|
+
end
|
39
38
|
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
end
|
39
|
+
def find_service
|
40
|
+
Entities::Service::find(remote: remote, ref: ref).tap do |svc|
|
41
|
+
raise ThreeScaleToolbox::Error, "Service #{ref} does not exist" if svc.nil?
|
44
42
|
end
|
45
43
|
end
|
46
44
|
end
|
@@ -1,48 +1,38 @@
|
|
1
1
|
module ThreeScaleToolbox
|
2
2
|
module Commands
|
3
3
|
module ServiceCommand
|
4
|
-
|
5
|
-
|
6
|
-
include ThreeScaleToolbox::Command
|
7
|
-
|
8
|
-
def self.command
|
9
|
-
Cri::Command.define do
|
10
|
-
name 'list'
|
11
|
-
usage 'list <remote>'
|
12
|
-
summary 'List all services'
|
13
|
-
description 'List all services'
|
14
|
-
runner ListSubcommand
|
15
|
-
|
16
|
-
param :remote
|
17
|
-
end
|
18
|
-
end
|
4
|
+
class ListSubcommand < Cri::CommandRunner
|
5
|
+
include ThreeScaleToolbox::Command
|
19
6
|
|
20
|
-
|
21
|
-
print_header
|
22
|
-
print_data
|
23
|
-
end
|
7
|
+
FIELDS = %w[id name system_name]
|
24
8
|
|
25
|
-
|
9
|
+
def self.command
|
10
|
+
Cri::Command.define do
|
11
|
+
name 'list'
|
12
|
+
usage 'list <remote>'
|
13
|
+
summary 'List all services'
|
14
|
+
description 'List all services'
|
26
15
|
|
27
|
-
|
16
|
+
ThreeScaleToolbox::CLI.output_flag(self)
|
17
|
+
param :remote
|
28
18
|
|
29
|
-
|
30
|
-
@services ||= remote.list_services()
|
19
|
+
runner ListSubcommand
|
31
20
|
end
|
21
|
+
end
|
32
22
|
|
33
|
-
|
34
|
-
|
35
|
-
|
23
|
+
def run
|
24
|
+
printer.print_collection remote.list_services
|
25
|
+
end
|
36
26
|
|
37
|
-
|
38
|
-
puts SERVICE_FIELDS_TO_SHOW.map { |e| e.upcase }.join("\t")
|
39
|
-
end
|
27
|
+
private
|
40
28
|
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
29
|
+
def remote
|
30
|
+
@remote ||= threescale_client(arguments[:remote])
|
31
|
+
end
|
32
|
+
|
33
|
+
def printer
|
34
|
+
# keep backwards compatibility
|
35
|
+
options.fetch(:output, CLI::CustomTablePrinter.new(FIELDS))
|
46
36
|
end
|
47
37
|
end
|
48
38
|
end
|
@@ -1,62 +1,57 @@
|
|
1
1
|
module ThreeScaleToolbox
|
2
2
|
module Commands
|
3
3
|
module ServiceCommand
|
4
|
-
|
5
|
-
|
6
|
-
include ThreeScaleToolbox::Command
|
7
|
-
|
8
|
-
def self.command
|
9
|
-
Cri::Command.define do
|
10
|
-
name 'show'
|
11
|
-
usage 'show <remote> <service-id_or_system-name>'
|
12
|
-
summary 'Show the information of a service'
|
13
|
-
description "Show the information of a service"
|
14
|
-
runner ShowSubcommand
|
15
|
-
|
16
|
-
param :remote
|
17
|
-
param :service_id_or_system_name
|
18
|
-
end
|
19
|
-
end
|
4
|
+
class ShowSubcommand < Cri::CommandRunner
|
5
|
+
include ThreeScaleToolbox::Command
|
20
6
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
7
|
+
FIELDS = %w[
|
8
|
+
id name state system_name end_user_registration_required
|
9
|
+
backend_version deployment_option support_email description
|
10
|
+
created_at updated_at
|
11
|
+
]
|
25
12
|
|
26
|
-
|
13
|
+
def self.command
|
14
|
+
Cri::Command.define do
|
15
|
+
name 'show'
|
16
|
+
usage 'show <remote> <service-id_or_system-name>'
|
17
|
+
summary 'Show the information of a service'
|
18
|
+
description "Show the information of a service"
|
27
19
|
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
created_at updated_at
|
32
|
-
]
|
20
|
+
ThreeScaleToolbox::CLI.output_flag(self)
|
21
|
+
param :remote
|
22
|
+
param :service_id_or_system_name
|
33
23
|
|
34
|
-
|
35
|
-
@remote ||= threescale_client(arguments[:remote])
|
24
|
+
runner ShowSubcommand
|
36
25
|
end
|
26
|
+
end
|
37
27
|
|
38
|
-
|
39
|
-
|
40
|
-
|
28
|
+
def run
|
29
|
+
printer.print_record service.attrs
|
30
|
+
end
|
41
31
|
|
42
|
-
|
43
|
-
@service ||= find_service
|
44
|
-
end
|
32
|
+
private
|
45
33
|
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
end
|
50
|
-
end
|
34
|
+
def remote
|
35
|
+
@remote ||= threescale_client(arguments[:remote])
|
36
|
+
end
|
51
37
|
|
52
|
-
|
53
|
-
|
54
|
-
|
38
|
+
def ref
|
39
|
+
@ref ||= arguments[:service_id_or_system_name]
|
40
|
+
end
|
55
41
|
|
56
|
-
|
57
|
-
|
42
|
+
def service
|
43
|
+
@service ||= find_service
|
44
|
+
end
|
45
|
+
|
46
|
+
def find_service
|
47
|
+
Entities::Service::find(remote: remote, ref: ref).tap do |svc|
|
48
|
+
raise ThreeScaleToolbox::Error, "Service #{ref} does not exist" if svc.nil?
|
58
49
|
end
|
59
50
|
end
|
51
|
+
|
52
|
+
def printer
|
53
|
+
options.fetch(:output, CLI::CustomTablePrinter.new(FIELDS))
|
54
|
+
end
|
60
55
|
end
|
61
56
|
end
|
62
57
|
end
|