kontena-cli 0.15.5 → 0.16.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (207) hide show
  1. checksums.yaml +4 -4
  2. data/Dockerfile +0 -3
  3. data/Gemfile +3 -0
  4. data/LOGO +8 -0
  5. data/VERSION +1 -1
  6. data/kontena-cli.gemspec +2 -3
  7. data/lib/kontena/callback.rb +57 -0
  8. data/lib/kontena/callbacks/.gitkeep +0 -0
  9. data/lib/kontena/callbacks/auth/01_list_and_select_grid_after_master_auth.rb +27 -0
  10. data/lib/kontena/callbacks/master/01_clear_current_master_after_terminate.rb +20 -0
  11. data/lib/kontena/callbacks/master/deploy/01_show_logo_before_deploy.rb +15 -0
  12. data/lib/kontena/callbacks/master/deploy/05_before_deploy_configuration_wizard.rb +124 -0
  13. data/lib/kontena/callbacks/master/deploy/50_authenticate_after_deploy.rb +53 -0
  14. data/lib/kontena/callbacks/master/deploy/55_create_initial_grid_after_deploy.rb +32 -0
  15. data/lib/kontena/callbacks/master/deploy/60_configure_auth_provider_after_deploy.rb +49 -0
  16. data/lib/kontena/callbacks/master/deploy/90_suggest_inviting_yourself_after_deploy.rb +24 -0
  17. data/lib/kontena/cli/app_command.rb +2 -1
  18. data/lib/kontena/cli/apps/build_command.rb +1 -1
  19. data/lib/kontena/cli/apps/common.rb +6 -1
  20. data/lib/kontena/cli/apps/config_command.rb +1 -1
  21. data/lib/kontena/cli/apps/deploy_command.rb +1 -1
  22. data/lib/kontena/cli/apps/init_command.rb +3 -5
  23. data/lib/kontena/cli/apps/list_command.rb +1 -1
  24. data/lib/kontena/cli/apps/logs_command.rb +1 -1
  25. data/lib/kontena/cli/apps/monitor_command.rb +1 -1
  26. data/lib/kontena/cli/apps/remove_command.rb +2 -3
  27. data/lib/kontena/cli/apps/restart_command.rb +1 -1
  28. data/lib/kontena/cli/apps/scale_command.rb +1 -1
  29. data/lib/kontena/cli/apps/show_command.rb +1 -1
  30. data/lib/kontena/cli/apps/start_command.rb +1 -1
  31. data/lib/kontena/cli/apps/stop_command.rb +1 -1
  32. data/lib/kontena/cli/apps/yaml/reader.rb +3 -13
  33. data/lib/kontena/cli/apps/yaml/validator.rb +0 -4
  34. data/lib/kontena/cli/apps/yaml/validator_v2.rb +1 -5
  35. data/lib/kontena/cli/certificate/authorize_command.rb +1 -1
  36. data/lib/kontena/cli/certificate/get_command.rb +1 -1
  37. data/lib/kontena/cli/certificate/register_command.rb +1 -1
  38. data/lib/kontena/cli/certificate_command.rb +1 -1
  39. data/lib/kontena/cli/cloud/login_command.rb +128 -0
  40. data/lib/kontena/cli/cloud/master/add_command.rb +54 -0
  41. data/lib/kontena/cli/cloud/master/delete_command.rb +20 -0
  42. data/lib/kontena/cli/cloud/master/list_command.rb +29 -0
  43. data/lib/kontena/cli/cloud/master/show_command.rb +23 -0
  44. data/lib/kontena/cli/cloud/master/update_command.rb +58 -0
  45. data/lib/kontena/cli/cloud/master_command.rb +21 -0
  46. data/lib/kontena/cli/cloud_command.rb +10 -0
  47. data/lib/kontena/cli/common.rb +230 -88
  48. data/lib/kontena/cli/config.rb +537 -0
  49. data/lib/kontena/cli/container_command.rb +1 -1
  50. data/lib/kontena/cli/containers/exec_command.rb +1 -1
  51. data/lib/kontena/cli/containers/inspect_command.rb +1 -1
  52. data/lib/kontena/cli/etcd/get_command.rb +1 -1
  53. data/lib/kontena/cli/etcd/list_command.rb +1 -1
  54. data/lib/kontena/cli/etcd/mkdir_command.rb +1 -1
  55. data/lib/kontena/cli/etcd/remove_command.rb +1 -1
  56. data/lib/kontena/cli/etcd/set_command.rb +1 -1
  57. data/lib/kontena/cli/etcd_command.rb +1 -1
  58. data/lib/kontena/cli/external_registries/add_command.rb +1 -1
  59. data/lib/kontena/cli/external_registries/delete_command.rb +1 -1
  60. data/lib/kontena/cli/external_registries/list_command.rb +1 -1
  61. data/lib/kontena/cli/external_registries/remove_command.rb +1 -1
  62. data/lib/kontena/cli/external_registry_command.rb +1 -1
  63. data/lib/kontena/cli/grid_command.rb +1 -1
  64. data/lib/kontena/cli/grids/audit_log_command.rb +6 -5
  65. data/lib/kontena/cli/grids/cloud_config_command.rb +1 -1
  66. data/lib/kontena/cli/grids/common.rb +1 -1
  67. data/lib/kontena/cli/grids/create_command.rb +8 -4
  68. data/lib/kontena/cli/grids/current_command.rb +1 -1
  69. data/lib/kontena/cli/grids/env_command.rb +1 -1
  70. data/lib/kontena/cli/grids/list_command.rb +35 -10
  71. data/lib/kontena/cli/grids/logs_command.rb +1 -1
  72. data/lib/kontena/cli/grids/remove_command.rb +2 -2
  73. data/lib/kontena/cli/grids/show_command.rb +1 -1
  74. data/lib/kontena/cli/grids/trusted_subnet_command.rb +1 -1
  75. data/lib/kontena/cli/grids/trusted_subnets/add_command.rb +1 -1
  76. data/lib/kontena/cli/grids/trusted_subnets/list_command.rb +1 -1
  77. data/lib/kontena/cli/grids/trusted_subnets/remove_command.rb +1 -1
  78. data/lib/kontena/cli/grids/update_command.rb +1 -1
  79. data/lib/kontena/cli/grids/use_command.rb +11 -6
  80. data/lib/kontena/cli/grids/user_command.rb +1 -1
  81. data/lib/kontena/cli/grids/users/add_command.rb +1 -1
  82. data/lib/kontena/cli/grids/users/list_command.rb +1 -1
  83. data/lib/kontena/cli/grids/users/remove_command.rb +1 -1
  84. data/lib/kontena/cli/localhost_web_server.rb +93 -0
  85. data/lib/kontena/cli/login_command.rb +5 -118
  86. data/lib/kontena/cli/logout_command.rb +33 -2
  87. data/lib/kontena/cli/master/audit_log_command.rb +19 -0
  88. data/lib/kontena/cli/master/config/export_command.rb +47 -0
  89. data/lib/kontena/cli/master/config/get_command.rb +24 -0
  90. data/lib/kontena/cli/master/config/import_command.rb +69 -0
  91. data/lib/kontena/cli/master/config/set_command.rb +19 -0
  92. data/lib/kontena/cli/master/config/unset_command.rb +20 -0
  93. data/lib/kontena/cli/master/config_command.rb +24 -0
  94. data/lib/kontena/cli/master/create_command.rb +76 -0
  95. data/lib/kontena/cli/master/current_command.rb +10 -2
  96. data/lib/kontena/cli/master/join_command.rb +20 -0
  97. data/lib/kontena/cli/master/list_command.rb +4 -4
  98. data/lib/kontena/cli/master/login_command.rb +274 -0
  99. data/lib/kontena/cli/master/use_command.rb +8 -19
  100. data/lib/kontena/cli/master/users/invite_command.rb +33 -6
  101. data/lib/kontena/cli/master/users/list_command.rb +2 -2
  102. data/lib/kontena/cli/master/users/remove_command.rb +1 -1
  103. data/lib/kontena/cli/master/users/role_command.rb +1 -1
  104. data/lib/kontena/cli/master/users/roles/add_command.rb +18 -16
  105. data/lib/kontena/cli/master/users/roles/remove_command.rb +1 -1
  106. data/lib/kontena/cli/master/users_command.rb +1 -1
  107. data/lib/kontena/cli/master_command.rb +21 -1
  108. data/lib/kontena/cli/node_command.rb +1 -1
  109. data/lib/kontena/cli/nodes/label_command.rb +1 -1
  110. data/lib/kontena/cli/nodes/labels/add_command.rb +1 -1
  111. data/lib/kontena/cli/nodes/labels/remove_command.rb +1 -1
  112. data/lib/kontena/cli/nodes/list_command.rb +1 -1
  113. data/lib/kontena/cli/nodes/remove_command.rb +1 -1
  114. data/lib/kontena/cli/nodes/show_command.rb +1 -1
  115. data/lib/kontena/cli/nodes/ssh_command.rb +1 -1
  116. data/lib/kontena/cli/nodes/update_command.rb +1 -1
  117. data/lib/kontena/cli/plugin_command.rb +1 -1
  118. data/lib/kontena/cli/plugins/install_command.rb +2 -2
  119. data/lib/kontena/cli/plugins/list_command.rb +2 -2
  120. data/lib/kontena/cli/plugins/search_command.rb +1 -1
  121. data/lib/kontena/cli/plugins/uninstall_command.rb +2 -2
  122. data/lib/kontena/cli/registry/create_command.rb +2 -4
  123. data/lib/kontena/cli/registry/delete_command.rb +1 -1
  124. data/lib/kontena/cli/registry/remove_command.rb +1 -1
  125. data/lib/kontena/cli/registry_command.rb +1 -1
  126. data/lib/kontena/cli/service_command.rb +1 -1
  127. data/lib/kontena/cli/services/container_command.rb +1 -1
  128. data/lib/kontena/cli/services/containers_command.rb +1 -1
  129. data/lib/kontena/cli/services/create_command.rb +1 -1
  130. data/lib/kontena/cli/services/delete_command.rb +1 -1
  131. data/lib/kontena/cli/services/deploy_command.rb +1 -1
  132. data/lib/kontena/cli/services/env_command.rb +1 -1
  133. data/lib/kontena/cli/services/envs/add_command.rb +1 -1
  134. data/lib/kontena/cli/services/envs/list_command.rb +1 -1
  135. data/lib/kontena/cli/services/envs/remove_command.rb +1 -1
  136. data/lib/kontena/cli/services/link_command.rb +1 -1
  137. data/lib/kontena/cli/services/list_command.rb +1 -1
  138. data/lib/kontena/cli/services/logs_command.rb +1 -1
  139. data/lib/kontena/cli/services/monitor_command.rb +1 -1
  140. data/lib/kontena/cli/services/remove_command.rb +1 -1
  141. data/lib/kontena/cli/services/restart_command.rb +1 -1
  142. data/lib/kontena/cli/services/scale_command.rb +1 -1
  143. data/lib/kontena/cli/services/secret_command.rb +1 -1
  144. data/lib/kontena/cli/services/secrets/link_command.rb +1 -1
  145. data/lib/kontena/cli/services/secrets/unlink_command.rb +1 -1
  146. data/lib/kontena/cli/services/services_helper.rb +6 -3
  147. data/lib/kontena/cli/services/show_command.rb +1 -1
  148. data/lib/kontena/cli/services/start_command.rb +1 -1
  149. data/lib/kontena/cli/services/stats_command.rb +1 -1
  150. data/lib/kontena/cli/services/stop_command.rb +1 -1
  151. data/lib/kontena/cli/services/unlink_command.rb +1 -1
  152. data/lib/kontena/cli/services/update_command.rb +1 -1
  153. data/lib/kontena/cli/spinner.rb +122 -0
  154. data/lib/kontena/cli/stack_command.rb +1 -1
  155. data/lib/kontena/cli/stacks/create_command.rb +1 -1
  156. data/lib/kontena/cli/stacks/deploy_command.rb +1 -1
  157. data/lib/kontena/cli/stacks/list_command.rb +1 -1
  158. data/lib/kontena/cli/stacks/remove_command.rb +1 -1
  159. data/lib/kontena/cli/stacks/show_command.rb +1 -1
  160. data/lib/kontena/cli/stacks/update_command.rb +1 -1
  161. data/lib/kontena/cli/vault/list_command.rb +1 -1
  162. data/lib/kontena/cli/vault/read_command.rb +1 -1
  163. data/lib/kontena/cli/vault/remove_command.rb +1 -1
  164. data/lib/kontena/cli/vault/update_command.rb +1 -1
  165. data/lib/kontena/cli/vault/write_command.rb +1 -1
  166. data/lib/kontena/cli/vault_command.rb +1 -1
  167. data/lib/kontena/cli/version.rb +1 -1
  168. data/lib/kontena/cli/version_command.rb +1 -1
  169. data/lib/kontena/cli/vpn/config_command.rb +1 -1
  170. data/lib/kontena/cli/vpn/create_command.rb +2 -4
  171. data/lib/kontena/cli/vpn/delete_command.rb +1 -1
  172. data/lib/kontena/cli/vpn/remove_command.rb +1 -1
  173. data/lib/kontena/cli/vpn_command.rb +1 -1
  174. data/lib/kontena/cli/whoami_command.rb +16 -13
  175. data/lib/kontena/client.rb +410 -90
  176. data/lib/kontena/command.rb +172 -0
  177. data/lib/kontena/main_command.rb +7 -8
  178. data/lib/kontena/presets/github_auth_provider.yml +11 -0
  179. data/lib/kontena/presets/kontena_auth_provider.yml +11 -0
  180. data/lib/kontena_cli.rb +51 -1
  181. data/spec/kontena/cli/app/deploy_command_spec.rb +14 -44
  182. data/spec/kontena/cli/app/scale_spec.rb +1 -1
  183. data/spec/kontena/cli/app/yaml/reader_spec.rb +0 -48
  184. data/spec/kontena/cli/common_spec.rb +63 -59
  185. data/spec/kontena/cli/grids/use_command_spec.rb +43 -0
  186. data/spec/kontena/cli/master/current_command_spec.rb +3 -24
  187. data/spec/kontena/cli/master/use_command_spec.rb +2 -27
  188. data/spec/kontena/cli/master/users/invite_command_spec.rb +4 -18
  189. data/spec/kontena/cli/master/users/roles/add_command_spec.rb +2 -16
  190. data/spec/kontena/cli/master/users/roles/remove_command_spec.rb +2 -13
  191. data/spec/kontena/cli/services/restart_command_spec.rb +1 -1
  192. data/spec/kontena/cli/services/update_command_spec.rb +5 -5
  193. data/spec/kontena/client_spec.rb +104 -35
  194. data/spec/kontena/config_spec.rb +65 -0
  195. data/spec/spec_helper.rb +25 -3
  196. data/spec/support/client_helpers.rb +10 -3
  197. data/spec/support/requirements_helper.rb +32 -0
  198. metadata +61 -48
  199. data/lib/kontena/cli/register_command.rb +0 -23
  200. data/lib/kontena/cli/user/forgot_password_command.rb +0 -16
  201. data/lib/kontena/cli/user/reset_password_command.rb +0 -23
  202. data/lib/kontena/cli/user/verify_command.rb +0 -20
  203. data/lib/kontena/cli/user_command.rb +0 -13
  204. data/spec/fixtures/kontena-malformed-yaml.yml +0 -6
  205. data/spec/fixtures/kontena-not-hash-service-config.yml +0 -3
  206. data/spec/kontena/cli/login_command_spec.rb +0 -32
  207. data/spec/kontena/cli/register_command_spec.rb +0 -57
@@ -1,31 +1,20 @@
1
1
  module Kontena::Cli::Master
2
- class UseCommand < Clamp::Command
2
+ class UseCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
 
5
5
  parameter "NAME", "Master name to use"
6
6
 
7
7
  def execute
8
- master = settings['servers'].find { |s| s['name'] == name }
9
-
10
- if master
11
- self.current_master = master['name']
12
- puts "Using master: #{master['name'].cyan} (#{master['url']})"
13
- puts "Using grid: #{current_grid.cyan}" if current_grid
14
-
15
- grids = client(require_token).get('grids')['grids']
16
- if grids.size > 1
17
- puts ""
18
- puts "You have access to following grids:"
19
- puts ""
20
- grids.each do |grid|
21
- puts " * #{grid['name']}"
22
- end
23
- end
8
+ master = config.find_server(name)
9
+ if master.nil?
10
+ abort pastel.red("Could not resolve master by name '#{name}'.") +
11
+ "\nFor a list of known masters please run: kontena master list"
24
12
  else
25
- abort "Could not resolve master with name: #{name}".colorize(:red)
13
+ self.current_master = master['name']
14
+ puts "Using master: #{pastel.cyan(master['name'])} (#{master['url']})"
15
+ puts "Using grid: #{current_grid ? pastel.cyan(current_grid) : "<none>"}"
26
16
  end
27
17
  end
28
-
29
18
  end
30
19
 
31
20
  end
@@ -1,24 +1,51 @@
1
1
  require_relative '../../common'
2
+ require_relative 'roles/add_command'
2
3
 
3
4
  module Kontena::Cli::Master::Users
4
- class InviteCommand < Clamp::Command
5
+ class InviteCommand < Kontena::Command
5
6
  include Kontena::Cli::Common
6
7
 
7
8
  parameter "EMAIL ...", "List of emails"
8
9
 
10
+ banner <<-EOB.gsub(/^\s+/, "")
11
+ If the email address matches the one returned from authentication provider
12
+ then the user can authenticate using 'kontena master auth <url>'.
13
+ If it doesn't, the user must use the invitation code:
14
+ $ kontena master join <url> <invite_code>
15
+ EOB
16
+
17
+ option ['-r', '--roles'], '[ROLES]', 'Comma separated list of roles to assign to the invited users'
18
+ option ['-c', '--code'], :flag, 'Only output the invite code'
19
+
9
20
  def execute
10
21
  require_api_url
11
22
  token = require_token
23
+
24
+ if self.roles
25
+ roles = self.roles.split(',')
26
+ else
27
+ roles = []
28
+ end
29
+
12
30
  email_list.each do |email|
13
31
  begin
14
- data = { email: email }
15
- response = client(token).post('users', data)
16
- puts "Invited #{email} (no email gets sent)"
32
+ data = { email: email, response_type: 'invite' }
33
+ response = client(token).post('/oauth2/authorize', data)
34
+ if self.code?
35
+ puts response['invite_code']
36
+ else
37
+ puts "Invitation created for #{response['email']}".colorize(:green)
38
+ puts " * code: #{response['invite_code']}"
39
+ puts " * command: kontena master join #{current_master.url} #{response['invite_code']}"
40
+ end
41
+ roles.each do |role|
42
+ Kontena.run("master users role add #{role.shellescape} #{email.shellescape}")
43
+ end
17
44
  rescue
18
45
  puts "Failed to invite #{email}".colorize(:red)
19
- puts exc.message
46
+ ENV["DEBUG"] && puts("#{$!} - #{$!.message} -- #{$!.backtrace}")
20
47
  end
21
48
  end
22
49
  end
23
50
  end
24
- end
51
+ end
@@ -1,7 +1,7 @@
1
1
  require_relative '../../common'
2
2
 
3
3
  module Kontena::Cli::Master::Users
4
- class ListCommand < Clamp::Command
4
+ class ListCommand < Kontena::Command
5
5
  include Kontena::Cli::Common
6
6
 
7
7
  def execute
@@ -15,4 +15,4 @@ module Kontena::Cli::Master::Users
15
15
  end
16
16
  end
17
17
  end
18
- end
18
+ end
@@ -1,7 +1,7 @@
1
1
  require_relative '../../common'
2
2
 
3
3
  module Kontena::Cli::Master::Users
4
- class RemoveCommand < Clamp::Command
4
+ class RemoveCommand < Kontena::Command
5
5
  include Kontena::Cli::Common
6
6
 
7
7
  parameter "EMAIL ...", "List of emails"
@@ -3,7 +3,7 @@ module Kontena::Cli::Master::Users
3
3
  require_relative 'roles/add_command'
4
4
  require_relative 'roles/remove_command'
5
5
 
6
- class RoleCommand < Clamp::Command
6
+ class RoleCommand < Kontena::Command
7
7
  subcommand "add", "Add role to user", Roles::AddCommand
8
8
  subcommand ["remove", "rm"], "Remove role from user", Roles::RemoveCommand
9
9
  end
@@ -1,24 +1,26 @@
1
1
  require_relative '../../../common'
2
2
 
3
- module Kontena::Cli::Master::Users::Roles
4
- class AddCommand < Clamp::Command
5
- include Kontena::Cli::Common
3
+ module Kontena::Cli::Master::Users
4
+ module Roles
5
+ class AddCommand < Kontena::Command
6
+ include Kontena::Cli::Common
6
7
 
7
- parameter "ROLE", "Role name"
8
- parameter "USER ...", "List of users"
8
+ parameter "ROLE", "Role name"
9
+ parameter "USER ...", "List of users"
9
10
 
10
- def execute
11
- require_api_url
12
- token = require_token
13
- data = { role: role }
11
+ def execute
12
+ require_api_url
13
+ token = require_token
14
+ data = { role: role }
14
15
 
15
- user_list.each do |email|
16
- begin
17
- response = client(token).post("users/#{email}/roles", data)
18
- puts "Added role #{role} to #{email}"
19
- rescue => exc
20
- puts "Failed to add role #{role} to #{email}".colorize(:red)
21
- puts exc.message
16
+ user_list.each do |email|
17
+ begin
18
+ response = client(token).post("users/#{email}/roles", data)
19
+ puts "Added role #{role} to #{email}"
20
+ rescue => exc
21
+ puts "Failed to add role #{role} to #{email}".colorize(:red)
22
+ puts exc.message
23
+ end
22
24
  end
23
25
  end
24
26
  end
@@ -1,7 +1,7 @@
1
1
  require_relative '../../../common'
2
2
 
3
3
  module Kontena::Cli::Master::Users::Roles
4
- class RemoveCommand < Clamp::Command
4
+ class RemoveCommand < Kontena::Command
5
5
  include Kontena::Cli::Common
6
6
 
7
7
  parameter "ROLE", "Role name"
@@ -5,7 +5,7 @@ module Kontena::Cli::Master
5
5
  require_relative 'users/list_command'
6
6
  require_relative 'users/role_command'
7
7
 
8
- class UsersCommand < Clamp::Command
8
+ class UsersCommand < Kontena::Command
9
9
  subcommand "invite", "Invite user to Kontena Master", Users::InviteCommand
10
10
  subcommand ["remove", "rm"], "Remove user from Kontena Master", Users::RemoveCommand
11
11
  subcommand ["list", "ls"], "List users", Users::ListCommand
@@ -1,14 +1,34 @@
1
+ require_relative '../main_command'
1
2
  require_relative 'master/use_command'
2
3
  require_relative 'master/list_command'
3
4
  require_relative 'master/users_command'
4
5
  require_relative 'master/current_command'
6
+ require_relative 'master/config_command'
7
+ require_relative 'master/login_command'
8
+ require_relative 'master/join_command'
9
+ require_relative 'master/audit_log_command'
5
10
 
6
- class Kontena::Cli::MasterCommand < Clamp::Command
11
+ if ENV["DEV"]
12
+ begin
13
+ require_relative 'master/create_command'
14
+ rescue LoadError
15
+ end
16
+ end
17
+
18
+ class Kontena::Cli::MasterCommand < Kontena::Command
7
19
 
8
20
  subcommand ["list", "ls"], "List masters where client has logged in", Kontena::Cli::Master::ListCommand
21
+ subcommand ["config", "cfg"], "Configure master settings", Kontena::Cli::Master::ConfigCommand
9
22
  subcommand "use", "Switch to use selected master", Kontena::Cli::Master::UseCommand
10
23
  subcommand "users", "Users specific commands", Kontena::Cli::Master::UsersCommand
11
24
  subcommand "current", "Show current master details", Kontena::Cli::Master::CurrentCommand
25
+ subcommand "login", "Authenticate to Kontena Master", Kontena::Cli::Master::LoginCommand
26
+ subcommand "join", "Join Kontena Master using an invitation code", Kontena::Cli::Master::JoinCommand
27
+ subcommand "audit-log", "Show master audit logs", Kontena::Cli::Master::AuditLogCommand
28
+
29
+ if ENV["DEV"]
30
+ subcommand "create", "Install a new Kontena Master", Kontena::Cli::Master::CreateCommand
31
+ end
12
32
 
13
33
  def execute
14
34
  end
@@ -5,7 +5,7 @@ require_relative 'nodes/update_command'
5
5
  require_relative 'nodes/ssh_command'
6
6
  require_relative 'nodes/label_command'
7
7
 
8
- class Kontena::Cli::NodeCommand < Clamp::Command
8
+ class Kontena::Cli::NodeCommand < Kontena::Command
9
9
 
10
10
  subcommand ["list","ls"], "List grid nodes", Kontena::Cli::Nodes::ListCommand
11
11
  subcommand "show", "Show node", Kontena::Cli::Nodes::ShowCommand
@@ -3,7 +3,7 @@ module Kontena::Cli::Nodes
3
3
  require_relative 'labels/add_command'
4
4
  require_relative 'labels/remove_command'
5
5
 
6
- class LabelCommand < Clamp::Command
6
+ class LabelCommand < Kontena::Command
7
7
 
8
8
  subcommand "add", "Add label to node", Labels::AddCommand
9
9
  subcommand ["remove", "rm"], "Remove label from node", Labels::RemoveCommand
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes::Labels
2
- class AddCommand < Clamp::Command
2
+ class AddCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
 
5
5
  parameter "NODE_ID", "Node id"
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes::Labels
2
- class RemoveCommand < Clamp::Command
2
+ class RemoveCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
 
5
5
  parameter "NODE_ID", "Node id"
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes
2
- class ListCommand < Clamp::Command
2
+ class ListCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
  include Kontena::Cli::GridOptions
5
5
 
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes
2
- class RemoveCommand < Clamp::Command
2
+ class RemoveCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
  include Kontena::Cli::GridOptions
5
5
 
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes
2
- class ShowCommand < Clamp::Command
2
+ class ShowCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
  include Kontena::Cli::GridOptions
5
5
  include Kontena::Cli::BytesHelper
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes
2
- class SshCommand < Clamp::Command
2
+ class SshCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
  include Kontena::Cli::GridOptions
5
5
 
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Nodes
2
- class UpdateCommand < Clamp::Command
2
+ class UpdateCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
  include Kontena::Cli::GridOptions
5
5
 
@@ -3,7 +3,7 @@ require_relative 'plugins/search_command'
3
3
  require_relative 'plugins/install_command'
4
4
  require_relative 'plugins/uninstall_command'
5
5
 
6
- class Kontena::Cli::PluginCommand < Clamp::Command
6
+ class Kontena::Cli::PluginCommand < Kontena::Command
7
7
 
8
8
  subcommand ["list","ls"], "List plugins", Kontena::Cli::Plugins::ListCommand
9
9
  subcommand "search", "Search plugins", Kontena::Cli::Plugins::SearchCommand
@@ -1,7 +1,7 @@
1
1
  require 'open3'
2
2
 
3
3
  module Kontena::Cli::Plugins
4
- class InstallCommand < Clamp::Command
4
+ class InstallCommand < Kontena::Command
5
5
  include Kontena::Util
6
6
 
7
7
  parameter 'NAME', 'Plugin name'
@@ -15,7 +15,7 @@ module Kontena::Cli::Plugins
15
15
  gem_bin = which('gem')
16
16
  install_command = "#{gem_bin} install --no-ri --no-doc #{plugin}"
17
17
  success = false
18
- ShellSpinner "Installing plugin #{name.colorize(:cyan)}" do
18
+ spinner "Installing plugin #{name.colorize(:cyan)}" do
19
19
  stdout, stderr, status = Open3.capture3(install_command)
20
20
  unless stderr.empty?
21
21
  raise stderr
@@ -1,6 +1,5 @@
1
-
2
1
  module Kontena::Cli::Plugins
3
- class ListCommand < Clamp::Command
2
+ class ListCommand < Kontena::Command
4
3
 
5
4
  def execute
6
5
  titles = ['NAME', 'VERSION', 'DESCRIPTION']
@@ -9,5 +8,6 @@ module Kontena::Cli::Plugins
9
8
  puts "%-40s %-10s %-40s" % [plugin.name, plugin.version, plugin.description]
10
9
  end
11
10
  end
11
+
12
12
  end
13
13
  end
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Plugins
2
- class SearchCommand < Clamp::Command
2
+ class SearchCommand < Kontena::Command
3
3
 
4
4
  parameter '[NAME]', 'Search text'
5
5
 
@@ -1,7 +1,7 @@
1
1
  require 'open3'
2
2
 
3
3
  module Kontena::Cli::Plugins
4
- class UninstallCommand < Clamp::Command
4
+ class UninstallCommand < Kontena::Command
5
5
  include Kontena::Cli::Common
6
6
 
7
7
  parameter 'NAME', 'Plugin name'
@@ -17,7 +17,7 @@ module Kontena::Cli::Plugins
17
17
  gem_bin = `which gem`.strip
18
18
  install_command = "#{gem_bin} install -q #{plugin}"
19
19
  success = false
20
- ShellSpinner "Uninstalling plugin #{name.colorize(:cyan)}" do
20
+ spinner "Uninstalling plugin #{name.colorize(:cyan)}" do
21
21
  stdout, stderr, status = Open3.capture3(install_command)
22
22
  unless stderr.empty?
23
23
  raise stderr
@@ -1,7 +1,5 @@
1
- require 'shell-spinner'
2
-
3
1
  module Kontena::Cli::Registry
4
- class CreateCommand < Clamp::Command
2
+ class CreateCommand < Kontena::Command
5
3
  include Kontena::Cli::Common
6
4
  include Kontena::Cli::GridOptions
7
5
 
@@ -98,7 +96,7 @@ module Kontena::Cli::Registry
98
96
  }
99
97
  client(token).post("grids/#{current_grid}/services", data)
100
98
  client(token).post("services/#{current_grid}/registry/deploy", {})
101
- ShellSpinner "Deploying registry service " do
99
+ spinner "Deploying registry service " do
102
100
  sleep 1 until client(token).get("services/#{current_grid}/registry")['state'] != 'deploying'
103
101
  end
104
102
  puts "\n"
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Registry
2
- class DeleteCommand < Clamp::Command
2
+ class DeleteCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
  include Kontena::Cli::GridOptions
5
5
 
@@ -1,5 +1,5 @@
1
1
  module Kontena::Cli::Registry
2
- class RemoveCommand < Clamp::Command
2
+ class RemoveCommand < Kontena::Command
3
3
  include Kontena::Cli::Common
4
4
 
5
5
  option "--force", :flag, "Force remove", default: false, attribute_name: :forced
@@ -2,7 +2,7 @@ require_relative 'registry/create_command'
2
2
  require_relative 'registry/delete_command'
3
3
  require_relative 'registry/remove_command'
4
4
 
5
- class Kontena::Cli::RegistryCommand < Clamp::Command
5
+ class Kontena::Cli::RegistryCommand < Kontena::Command
6
6
 
7
7
  subcommand "create", "Create Docker image registry service", Kontena::Cli::Registry::CreateCommand
8
8
  subcommand ["remove","rm"], "Remove Docker image registry service", Kontena::Cli::Registry::RemoveCommand
@@ -20,7 +20,7 @@ require_relative 'services/secret_command'
20
20
  require_relative 'services/link_command'
21
21
  require_relative 'services/unlink_command'
22
22
 
23
- class Kontena::Cli::ServiceCommand < Clamp::Command
23
+ class Kontena::Cli::ServiceCommand < Kontena::Command
24
24
 
25
25
  subcommand ["list","ls"], "List services", Kontena::Cli::Services::ListCommand
26
26
  subcommand "create", "Create a new service", Kontena::Cli::Services::CreateCommand
@@ -1,6 +1,6 @@
1
1
  require_relative 'containers/exec_command'
2
2
 
3
- class Kontena::Cli::ContainerCommand < Clamp::Command
3
+ class Kontena::Cli::ContainerCommand < Kontena::Command
4
4
 
5
5
  subcommand "exec", "Execute command inside a container", Kontena::Cli::Containers::ExecCommand
6
6
 
@@ -1,7 +1,7 @@
1
1
  require_relative 'services_helper'
2
2
 
3
3
  module Kontena::Cli::Services
4
- class ContainersCommand < Clamp::Command
4
+ class ContainersCommand < Kontena::Command
5
5
  include Kontena::Cli::Common
6
6
  include Kontena::Cli::GridOptions
7
7
  include ServicesHelper