knife-ionoscloud 5.1.0 → 5.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (174) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/publish.yml +4 -1
  3. data/docs/README.md +21 -1
  4. data/docs/docs_generator.rb +1 -1
  5. data/docs/subcommands/backupunit_create.md +4 -1
  6. data/docs/subcommands/backupunit_delete.md +4 -1
  7. data/docs/subcommands/backupunit_list.md +4 -1
  8. data/docs/subcommands/backupunit_ssourl.md +4 -1
  9. data/docs/subcommands/composite_server_create.md +4 -1
  10. data/docs/subcommands/contract_list.md +4 -1
  11. data/docs/subcommands/datacenter_create.md +4 -1
  12. data/docs/subcommands/datacenter_delete.md +4 -1
  13. data/docs/subcommands/datacenter_list.md +4 -1
  14. data/docs/subcommands/firewall_create.md +4 -1
  15. data/docs/subcommands/firewall_delete.md +3 -0
  16. data/docs/subcommands/firewall_list.md +4 -1
  17. data/docs/subcommands/group_create.md +4 -1
  18. data/docs/subcommands/group_delete.md +4 -1
  19. data/docs/subcommands/group_get.md +4 -1
  20. data/docs/subcommands/group_list.md +4 -1
  21. data/docs/subcommands/group_user_add.md +3 -0
  22. data/docs/subcommands/group_user_remove.md +3 -0
  23. data/docs/subcommands/image_list.md +4 -1
  24. data/docs/subcommands/ipblock_create.md +4 -1
  25. data/docs/subcommands/ipblock_delete.md +4 -1
  26. data/docs/subcommands/ipblock_list.md +4 -1
  27. data/docs/subcommands/ipfailover_add.md +4 -1
  28. data/docs/subcommands/ipfailover_remove.md +4 -1
  29. data/docs/subcommands/k8s_create.md +4 -1
  30. data/docs/subcommands/k8s_delete.md +4 -1
  31. data/docs/subcommands/k8s_list.md +4 -1
  32. data/docs/subcommands/kubeconfig_get.md +4 -1
  33. data/docs/subcommands/label_add.md +4 -1
  34. data/docs/subcommands/label_list.md +4 -1
  35. data/docs/subcommands/label_remove.md +3 -0
  36. data/docs/subcommands/lan_create.md +4 -1
  37. data/docs/subcommands/lan_delete.md +3 -0
  38. data/docs/subcommands/lan_list.md +4 -1
  39. data/docs/subcommands/loadbalancer_create.md +4 -1
  40. data/docs/subcommands/loadbalancer_delete.md +3 -0
  41. data/docs/subcommands/loadbalancer_get.md +4 -1
  42. data/docs/subcommands/loadbalancer_list.md +4 -1
  43. data/docs/subcommands/loadbalancer_nic_add.md +3 -0
  44. data/docs/subcommands/loadbalancer_nic_remove.md +3 -0
  45. data/docs/subcommands/location_list.md +4 -1
  46. data/docs/subcommands/nic_create.md +4 -1
  47. data/docs/subcommands/nic_delete.md +3 -0
  48. data/docs/subcommands/nic_list.md +4 -1
  49. data/docs/subcommands/node_delete.md +3 -0
  50. data/docs/subcommands/node_list.md +4 -1
  51. data/docs/subcommands/node_replace.md +3 -0
  52. data/docs/subcommands/nodepool_create.md +7 -1
  53. data/docs/subcommands/nodepool_delete.md +3 -0
  54. data/docs/subcommands/nodepool_list.md +4 -1
  55. data/docs/subcommands/pcc_create.md +4 -1
  56. data/docs/subcommands/pcc_delete.md +4 -1
  57. data/docs/subcommands/pcc_list.md +4 -1
  58. data/docs/subcommands/request_list.md +4 -1
  59. data/docs/subcommands/request_status.md +4 -1
  60. data/docs/subcommands/request_wait.md +4 -1
  61. data/docs/subcommands/resource_list.md +4 -1
  62. data/docs/subcommands/s3key_create.md +4 -1
  63. data/docs/subcommands/s3key_delete.md +3 -0
  64. data/docs/subcommands/s3key_list.md +4 -1
  65. data/docs/subcommands/server_create.md +4 -1
  66. data/docs/subcommands/server_delete.md +3 -0
  67. data/docs/subcommands/server_list.md +4 -1
  68. data/docs/subcommands/server_reboot.md +3 -0
  69. data/docs/subcommands/server_start.md +3 -0
  70. data/docs/subcommands/server_stop.md +3 -0
  71. data/docs/subcommands/share_create.md +4 -1
  72. data/docs/subcommands/share_delete.md +3 -0
  73. data/docs/subcommands/share_list.md +4 -1
  74. data/docs/subcommands/snapshot_create.md +4 -1
  75. data/docs/subcommands/snapshot_delete.md +4 -1
  76. data/docs/subcommands/snapshot_list.md +4 -1
  77. data/docs/subcommands/snapshot_restore.md +4 -1
  78. data/docs/subcommands/user_create.md +4 -1
  79. data/docs/subcommands/user_delete.md +4 -1
  80. data/docs/subcommands/user_list.md +4 -1
  81. data/docs/subcommands/user_ssourl.md +4 -1
  82. data/docs/subcommands/volume_attach.md +3 -0
  83. data/docs/subcommands/volume_create.md +10 -1
  84. data/docs/subcommands/volume_delete.md +3 -0
  85. data/docs/subcommands/volume_detach.md +3 -0
  86. data/docs/subcommands/volume_list.md +4 -1
  87. data/lib/chef/knife/ionoscloud_backupunit_create.rb +1 -0
  88. data/lib/chef/knife/ionoscloud_backupunit_delete.rb +1 -0
  89. data/lib/chef/knife/ionoscloud_backupunit_list.rb +1 -0
  90. data/lib/chef/knife/ionoscloud_backupunit_ssourl.rb +1 -0
  91. data/lib/chef/knife/ionoscloud_base.rb +23 -0
  92. data/lib/chef/knife/ionoscloud_composite_server_create.rb +3 -18
  93. data/lib/chef/knife/ionoscloud_contract_list.rb +1 -0
  94. data/lib/chef/knife/ionoscloud_datacenter_create.rb +1 -0
  95. data/lib/chef/knife/ionoscloud_datacenter_delete.rb +1 -0
  96. data/lib/chef/knife/ionoscloud_datacenter_list.rb +1 -0
  97. data/lib/chef/knife/ionoscloud_firewall_create.rb +1 -0
  98. data/lib/chef/knife/ionoscloud_firewall_delete.rb +1 -0
  99. data/lib/chef/knife/ionoscloud_firewall_list.rb +1 -0
  100. data/lib/chef/knife/ionoscloud_group_create.rb +1 -0
  101. data/lib/chef/knife/ionoscloud_group_delete.rb +1 -0
  102. data/lib/chef/knife/ionoscloud_group_get.rb +1 -0
  103. data/lib/chef/knife/ionoscloud_group_list.rb +1 -0
  104. data/lib/chef/knife/ionoscloud_group_user_add.rb +1 -0
  105. data/lib/chef/knife/ionoscloud_group_user_remove.rb +1 -0
  106. data/lib/chef/knife/ionoscloud_image_list.rb +1 -0
  107. data/lib/chef/knife/ionoscloud_ipblock_create.rb +1 -0
  108. data/lib/chef/knife/ionoscloud_ipblock_delete.rb +1 -0
  109. data/lib/chef/knife/ionoscloud_ipblock_list.rb +1 -0
  110. data/lib/chef/knife/ionoscloud_ipfailover_add.rb +1 -0
  111. data/lib/chef/knife/ionoscloud_ipfailover_remove.rb +1 -0
  112. data/lib/chef/knife/ionoscloud_k8s_create.rb +1 -0
  113. data/lib/chef/knife/ionoscloud_k8s_delete.rb +6 -2
  114. data/lib/chef/knife/ionoscloud_k8s_list.rb +1 -0
  115. data/lib/chef/knife/ionoscloud_kubeconfig_get.rb +1 -0
  116. data/lib/chef/knife/ionoscloud_label_add.rb +1 -0
  117. data/lib/chef/knife/ionoscloud_label_list.rb +1 -0
  118. data/lib/chef/knife/ionoscloud_label_remove.rb +1 -0
  119. data/lib/chef/knife/ionoscloud_lan_create.rb +1 -0
  120. data/lib/chef/knife/ionoscloud_lan_delete.rb +1 -0
  121. data/lib/chef/knife/ionoscloud_lan_list.rb +1 -0
  122. data/lib/chef/knife/ionoscloud_loadbalancer_create.rb +3 -1
  123. data/lib/chef/knife/ionoscloud_loadbalancer_delete.rb +1 -0
  124. data/lib/chef/knife/ionoscloud_loadbalancer_get.rb +1 -0
  125. data/lib/chef/knife/ionoscloud_loadbalancer_list.rb +1 -0
  126. data/lib/chef/knife/ionoscloud_loadbalancer_nic_add.rb +1 -0
  127. data/lib/chef/knife/ionoscloud_loadbalancer_nic_remove.rb +1 -0
  128. data/lib/chef/knife/ionoscloud_location_list.rb +1 -0
  129. data/lib/chef/knife/ionoscloud_nic_create.rb +2 -3
  130. data/lib/chef/knife/ionoscloud_nic_delete.rb +1 -0
  131. data/lib/chef/knife/ionoscloud_nic_list.rb +1 -0
  132. data/lib/chef/knife/ionoscloud_node_delete.rb +1 -0
  133. data/lib/chef/knife/ionoscloud_node_list.rb +1 -0
  134. data/lib/chef/knife/ionoscloud_node_replace.rb +1 -0
  135. data/lib/chef/knife/ionoscloud_nodepool_create.rb +11 -0
  136. data/lib/chef/knife/ionoscloud_nodepool_delete.rb +1 -0
  137. data/lib/chef/knife/ionoscloud_nodepool_list.rb +1 -0
  138. data/lib/chef/knife/ionoscloud_pcc_create.rb +1 -0
  139. data/lib/chef/knife/ionoscloud_pcc_delete.rb +1 -0
  140. data/lib/chef/knife/ionoscloud_pcc_list.rb +1 -0
  141. data/lib/chef/knife/ionoscloud_request_list.rb +1 -0
  142. data/lib/chef/knife/ionoscloud_request_status.rb +1 -0
  143. data/lib/chef/knife/ionoscloud_request_wait.rb +1 -0
  144. data/lib/chef/knife/ionoscloud_resource_list.rb +1 -0
  145. data/lib/chef/knife/ionoscloud_s3key_create.rb +1 -0
  146. data/lib/chef/knife/ionoscloud_s3key_delete.rb +1 -0
  147. data/lib/chef/knife/ionoscloud_s3key_list.rb +1 -0
  148. data/lib/chef/knife/ionoscloud_server_create.rb +1 -0
  149. data/lib/chef/knife/ionoscloud_server_delete.rb +3 -2
  150. data/lib/chef/knife/ionoscloud_server_list.rb +1 -0
  151. data/lib/chef/knife/ionoscloud_server_reboot.rb +1 -0
  152. data/lib/chef/knife/ionoscloud_server_start.rb +1 -0
  153. data/lib/chef/knife/ionoscloud_server_stop.rb +1 -0
  154. data/lib/chef/knife/ionoscloud_share_create.rb +1 -0
  155. data/lib/chef/knife/ionoscloud_share_delete.rb +1 -0
  156. data/lib/chef/knife/ionoscloud_share_list.rb +1 -0
  157. data/lib/chef/knife/ionoscloud_snapshot_create.rb +1 -0
  158. data/lib/chef/knife/ionoscloud_snapshot_delete.rb +1 -0
  159. data/lib/chef/knife/ionoscloud_snapshot_list.rb +1 -0
  160. data/lib/chef/knife/ionoscloud_snapshot_restore.rb +1 -0
  161. data/lib/chef/knife/ionoscloud_user_create.rb +1 -0
  162. data/lib/chef/knife/ionoscloud_user_delete.rb +1 -0
  163. data/lib/chef/knife/ionoscloud_user_list.rb +1 -0
  164. data/lib/chef/knife/ionoscloud_user_ssourl.rb +1 -0
  165. data/lib/chef/knife/ionoscloud_volume_attach.rb +1 -0
  166. data/lib/chef/knife/ionoscloud_volume_create.rb +19 -15
  167. data/lib/chef/knife/ionoscloud_volume_delete.rb +1 -0
  168. data/lib/chef/knife/ionoscloud_volume_detach.rb +1 -0
  169. data/lib/chef/knife/ionoscloud_volume_list.rb +1 -0
  170. data/lib/knife-ionoscloud/version.rb +1 -1
  171. data/spec/chef/knife/ionoscloud_k8s_delete_spec.rb +5 -2
  172. data/spec/chef/knife/ionoscloud_nodepool_create_spec.rb +1 -1
  173. data/spec/chef/knife/ionoscloud_volume_create_spec.rb +0 -52
  174. metadata +2 -2
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  kubernetes_api = Ionoscloud::KubernetesApi.new(api_client)
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  nodepool_list = [
@@ -32,6 +32,7 @@ class Chef
32
32
 
33
33
  def run
34
34
  $stdout.sync = true
35
+ handle_extra_config
35
36
  validate_required_params(@required_options, config)
36
37
 
37
38
  print "#{ui.color('Creating private cross connect...', :magenta)}"
@@ -18,6 +18,7 @@ class Chef
18
18
 
19
19
  def run
20
20
  $stdout.sync = true
21
+ handle_extra_config
21
22
  validate_required_params(@required_options, config)
22
23
 
23
24
  pcc_api = Ionoscloud::PrivateCrossConnectApi.new(api_client)
@@ -18,6 +18,7 @@ class Chef
18
18
 
19
19
  def run
20
20
  $stdout.sync = true
21
+ handle_extra_config
21
22
  validate_required_params(@required_options, config)
22
23
 
23
24
  pcc_list = [
@@ -42,6 +42,7 @@ class Chef
42
42
 
43
43
  def run
44
44
  $stdout.sync = true
45
+ handle_extra_config
45
46
  validate_required_params(@required_options, config)
46
47
 
47
48
  request_list = [
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  begin
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  print "#{ui.color('Waiting for request...', :magenta)}"
@@ -45,6 +45,7 @@ class Chef
45
45
 
46
46
  def run
47
47
  $stdout.sync = true
48
+ handle_extra_config
48
49
  validate_required_params(@required_options, config)
49
50
 
50
51
  user_management_api = Ionoscloud::UserManagementApi.new(api_client)
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  print "#{ui.color('Creating S3key...', :magenta)}"
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  user_management_api = Ionoscloud::UserManagementApi.new(api_client)
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  s3key_list = [
@@ -61,6 +61,7 @@ class Chef
61
61
 
62
62
  def run
63
63
  $stdout.sync = true
64
+ handle_extra_config
64
65
  validate_required_params(@required_options, config)
65
66
 
66
67
  print "#{ui.color('Creating server...', :magenta)}"
@@ -25,6 +25,7 @@ class Chef
25
25
 
26
26
  def run
27
27
  $stdout.sync = true
28
+ handle_extra_config
28
29
  validate_required_params(@required_options, config)
29
30
 
30
31
  server_api = Ionoscloud::ServerApi.new(api_client)
@@ -44,8 +45,8 @@ class Chef
44
45
  msg_pair('CPU Family', server.properties.cpu_family)
45
46
  msg_pair('Ram', server.properties.ram)
46
47
  msg_pair('Availability Zone', server.properties.availability_zone)
47
- msg_pair('Boot Volume', server.properties.boot_volume.id)
48
- msg_pair('Boot CDROM', server.properties.boot_cdrom.id)
48
+ msg_pair('Boot Volume', (server.properties.boot_volume.nil? ? '' : server.properties.boot_volume.id))
49
+ msg_pair('Boot CDROM', (server.properties.boot_cdrom.nil? ? '' : server.properties.boot_cdrom.id))
49
50
 
50
51
  begin
51
52
  confirm('Do you really want to delete this server')
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  server_list = [
@@ -25,6 +25,7 @@ class Chef
25
25
 
26
26
  def run
27
27
  $stdout.sync = true
28
+ handle_extra_config
28
29
  validate_required_params(@required_options, config)
29
30
 
30
31
  server_api = Ionoscloud::ServerApi.new(api_client)
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  server_api = Ionoscloud::ServerApi.new(api_client)
@@ -24,6 +24,7 @@ class Chef
24
24
 
25
25
  def run
26
26
  $stdout.sync = true
27
+ handle_extra_config
27
28
  validate_required_params(@required_options, config)
28
29
 
29
30
  server_api = Ionoscloud::ServerApi.new(api_client)
@@ -40,6 +40,7 @@ class Chef
40
40
 
41
41
  def run
42
42
  $stdout.sync = true
43
+ handle_extra_config
43
44
  validate_required_params(@required_options, config)
44
45
 
45
46
  print "#{ui.color('Sharing Resource...', :magenta)}"
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  user_management_api = Ionoscloud::UserManagementApi.new(api_client)
@@ -24,6 +24,7 @@ class Chef
24
24
 
25
25
  def run
26
26
  $stdout.sync = true
27
+ handle_extra_config
27
28
  validate_required_params(@required_options, config)
28
29
 
29
30
  share_list = [
@@ -47,6 +47,7 @@ class Chef
47
47
 
48
48
  def run
49
49
  $stdout.sync = true
50
+ handle_extra_config
50
51
  validate_required_params(@required_options, config)
51
52
 
52
53
  print "#{ui.color('Creating Snapshot...', :magenta)}"
@@ -18,6 +18,7 @@ class Chef
18
18
 
19
19
  def run
20
20
  $stdout.sync = true
21
+ handle_extra_config
21
22
  validate_required_params(@required_options, config)
22
23
 
23
24
  snapshot_api = Ionoscloud::SnapshotApi.new(api_client)
@@ -18,6 +18,7 @@ class Chef
18
18
 
19
19
  def run
20
20
  $stdout.sync = true
21
+ handle_extra_config
21
22
  validate_required_params(@required_options, config)
22
23
 
23
24
  snapshot_list = [
@@ -34,6 +34,7 @@ class Chef
34
34
 
35
35
  def run
36
36
  $stdout.sync = true
37
+ handle_extra_config
37
38
  validate_required_params(@required_options, config)
38
39
 
39
40
  print "#{ui.color('Restoring Snapshot...', :magenta)}"
@@ -49,6 +49,7 @@ class Chef
49
49
 
50
50
  def run
51
51
  $stdout.sync = true
52
+ handle_extra_config
52
53
  validate_required_params(@required_options, config)
53
54
 
54
55
  print "#{ui.color('Creating user...', :magenta)}"
@@ -20,6 +20,7 @@ class Chef
20
20
 
21
21
  def run
22
22
  $stdout.sync = true
23
+ handle_extra_config
23
24
  validate_required_params(@required_options, config)
24
25
 
25
26
  user_management_api = Ionoscloud::UserManagementApi.new(api_client)
@@ -25,6 +25,7 @@ class Chef
25
25
 
26
26
  def run
27
27
  $stdout.sync = true
28
+ handle_extra_config
28
29
  validate_required_params(@required_options, config)
29
30
 
30
31
  user_list = [
@@ -23,6 +23,7 @@ class Chef
23
23
 
24
24
  def run
25
25
  $stdout.sync = true
26
+ handle_extra_config
26
27
  validate_required_params(@required_options, config)
27
28
 
28
29
  begin
@@ -28,6 +28,7 @@ class Chef
28
28
 
29
29
  def run
30
30
  $stdout.sync = true
31
+ handle_extra_config
31
32
  validate_required_params(@required_options, config)
32
33
 
33
34
  server_api = Ionoscloud::ServerApi.new(api_client)
@@ -59,8 +59,21 @@ class Chef
59
59
  option :availability_zone,
60
60
  short: '-Z AVAILABILITY_ZONE',
61
61
  long: '--availability-zone AVAILABILITY_ZONE',
62
- description: 'The volume availability zone of the server',
63
- required: false
62
+ description: 'The volume availability zone of the server'
63
+
64
+ option :backupunit_id,
65
+ short: '-B BACKUPUNIT_ID',
66
+ long: '--backupunit BACKUPUNIT_ID',
67
+ description: 'The uuid of the Backup Unit that user has access to. The property is immutable and is only allowed '\
68
+ 'to be set on a new volume creation. It is mandatory to provide either \'public image\' or \'imageAlias\' in '\
69
+ 'conjunction with this property.'
70
+
71
+ option :user_data,
72
+ short: '-u USER_DATA',
73
+ long: '--user-data USER_DATA',
74
+ description: 'The cloud-init configuration for the volume as base64 encoded string. The property is '\
75
+ 'immutable and is only allowed to be set on a new volume creation. It is mandatory to provide either \'public image\' '\
76
+ 'or \'imageAlias\' that has cloud-init compatibility in conjunction with this property.'
64
77
 
65
78
  attr_reader :description, :required_options
66
79
 
@@ -74,21 +87,10 @@ class Chef
74
87
 
75
88
  def run
76
89
  $stdout.sync = true
90
+ handle_extra_config
77
91
  validate_required_params(@required_options, config)
78
92
 
79
- if !config[:image] && !config[:image_alias]
80
- ui.error('Either \'--image\' or \'--image-alias\' parameter must be provided')
81
- exit(1)
82
- end
83
-
84
- if !config[:ssh_keys] && !config[:image_password]
85
- ui.error('Either \'--image-password\' or \'--ssh-keys\' parameter must be provided')
86
- exit(1)
87
- end
88
-
89
- if config[:ssh_keys]
90
- config[:ssh_keys] = config[:ssh_keys].split(',')
91
- end
93
+ config[:ssh_keys] = config[:ssh_keys].split(',') if config[:ssh_keys] && config[:ssh_keys].instance_of?(String)
92
94
 
93
95
  print "#{ui.color('Creating volume...', :magenta)}"
94
96
 
@@ -108,6 +110,8 @@ class Chef
108
110
  sshKeys: config[:sshKeys],
109
111
  imagePassword: config[:image_password],
110
112
  availabilityZone: config[:availability_zone],
113
+ backupunit_id: config[:backupunit_id],
114
+ user_data: config[:user_data],
111
115
  }.compact
112
116
  },
113
117
  )
@@ -24,6 +24,7 @@ class Chef
24
24
 
25
25
  def run
26
26
  $stdout.sync = true
27
+ handle_extra_config
27
28
  validate_required_params(@required_options, config)
28
29
 
29
30
  volume_api = Ionoscloud::VolumeApi.new(api_client)
@@ -31,6 +31,7 @@ class Chef
31
31
 
32
32
  def run
33
33
  $stdout.sync = true
34
+ handle_extra_config
34
35
  validate_required_params(@required_options, config)
35
36
 
36
37
  server_api = Ionoscloud::ServerApi.new(api_client)
@@ -29,6 +29,7 @@ class Chef
29
29
 
30
30
  def run
31
31
  $stdout.sync = true
32
+ handle_extra_config
32
33
  validate_required_params(@required_options, config)
33
34
 
34
35
  volume_list = [
@@ -1,6 +1,6 @@
1
1
  module Knife
2
2
  module Ionoscloud
3
- VERSION = '5.1.0'
3
+ VERSION = '5.1.1'
4
4
  MAJOR, MINOR, TINY = VERSION.split('.')
5
5
  end
6
6
  end
@@ -86,7 +86,7 @@ describe Chef::Knife::IonoscloudK8sDelete do
86
86
  expect { subject.run }.not_to raise_error(Exception)
87
87
  end
88
88
 
89
- it 'should not call KubernetesApi.k8s_delete when the cluster is not active' do
89
+ it 'should not call KubernetesApi.k8s_delete when the cluster is not one of ["ACTIVE", "TERMINATED"]' do
90
90
  k8s_cluster = k8s_cluster_mock(
91
91
  {
92
92
  state: 'DEPLOYING',
@@ -103,7 +103,10 @@ describe Chef::Knife::IonoscloudK8sDelete do
103
103
  subject_config.each { |key, value| subject.config[key] = value }
104
104
  subject.name_args = [k8s_cluster.id]
105
105
 
106
- expect(subject.ui).to receive(:error).with("K8s Cluster ID #{k8s_cluster.id} is not active. Skipping.")
106
+ expect(subject.ui).to receive(:error).with(
107
+ "K8s Cluster #{k8s_cluster.id} state must be one of ['ACTIVE', 'TERMINATED'], "\
108
+ "actual state is '#{k8s_cluster.metadata.state}'. Skipping."
109
+ )
107
110
 
108
111
  expect(subject.api_client).not_to receive(:wait_for)
109
112
  mock_call_api(
@@ -33,6 +33,7 @@ describe Chef::Knife::IonoscloudNodepoolCreate do
33
33
  min_node_count: nodepool.properties.auto_scaling.min_node_count,
34
34
  max_node_count: nodepool.properties.auto_scaling.max_node_count,
35
35
  lans: nodepool.properties.lans.map { |lan| lan.id }.join(','),
36
+ public_ips: nodepool.properties.public_ips.join(','),
36
37
  }
37
38
 
38
39
  subject_config.each { |key, value| subject.config[key] = value }
@@ -42,7 +43,6 @@ describe Chef::Knife::IonoscloudNodepoolCreate do
42
43
 
43
44
  expected_body = nodepool.properties.to_hash
44
45
  expected_body[:lans].map! { |lan| lan.delete(:properties); lan[:id] = Integer(lan[:id]); lan }
45
- expected_body.delete(:publicIps)
46
46
  expected_body.delete(:availableUpgradeVersions)
47
47
 
48
48
  expect(subject).to receive(:puts).with("ID: #{nodepool.id}")
@@ -70,58 +70,6 @@ describe Chef::Knife::IonoscloudVolumeCreate do
70
70
  expect { subject.run }.not_to raise_error(Exception)
71
71
  end
72
72
 
73
- it 'should not call anything when neither image not image-alias is provided' do
74
- volume = volume_mock
75
- subject_config = {
76
- ionoscloud_username: 'email',
77
- ionoscloud_password: 'password',
78
- cluster_id: 'cluster_id',
79
- datacenter_id: 'datacenter_id',
80
- name: volume.properties.name,
81
- size: volume.properties.size,
82
- type: volume.properties.type,
83
- bus: volume.properties.bus,
84
- availability_zone: volume.properties.availability_zone,
85
- image_password: 'K3tTj8G14a3EgKyNeeiY',
86
- }
87
-
88
- subject_config.each { |key, value| subject.config[key] = value }
89
- expect(subject.ui).to receive(:error).with('Either \'--image\' or \'--image-alias\' parameter must be provided')
90
-
91
- expect(subject.api_client).not_to receive(:wait_for)
92
- expect(subject.api_client).not_to receive(:call_api)
93
-
94
- expect { subject.run }.to raise_error(SystemExit) do |error|
95
- expect(error.status).to eq(1)
96
- end
97
- end
98
-
99
- it 'should not call anything when neither image not image-alias is provided' do
100
- volume = volume_mock
101
- subject_config = {
102
- ionoscloud_username: 'email',
103
- ionoscloud_password: 'password',
104
- cluster_id: 'cluster_id',
105
- datacenter_id: 'datacenter_id',
106
- name: volume.properties.name,
107
- size: volume.properties.size,
108
- type: volume.properties.type,
109
- bus: volume.properties.bus,
110
- availability_zone: volume.properties.availability_zone,
111
- image_alias: 'debian:latest',
112
- }
113
-
114
- subject_config.each { |key, value| subject.config[key] = value }
115
- expect(subject.ui).to receive(:error).with('Either \'--image-password\' or \'--ssh-keys\' parameter must be provided')
116
-
117
- expect(subject.api_client).not_to receive(:wait_for)
118
- expect(subject.api_client).not_to receive(:call_api)
119
-
120
- expect { subject.run }.to raise_error(SystemExit) do |error|
121
- expect(error.status).to eq(1)
122
- end
123
- end
124
-
125
73
  it 'should not make any call if any required option is missing' do
126
74
  required_options = subject.instance_variable_get(:@required_options)
127
75