Class: Azure::ResourceManagement::ARMInterface
- Inherits:
-
AzureInterface
show all
- Includes:
- ARM::ARMDeploymentTemplate, ARM::VnetConfig, Compute::Mgmt::V2018_06_01, Compute::Mgmt::V2018_06_01::Models, Network::Mgmt::V2018_08_01, Network::Mgmt::V2018_08_01::Models, Azure::Resources::Mgmt::V2018_05_01, Azure::Resources::Mgmt::V2018_05_01::Models, Storage::Mgmt::V2018_07_01, Storage::Mgmt::V2018_07_01::Models
- Defined in:
- lib/azure/resource_management/ARM_interface.rb
Instance Attribute Summary collapse
#ui
Instance Method Summary
collapse
-
#common_arm_rescue_block(error) ⇒ Object
-
#compute_management_client ⇒ Object
-
#create_resource_group(params = {}) ⇒ Object
-
#create_server(params = {}) ⇒ Object
-
#create_virtual_machine_using_template(params) ⇒ Object
-
#create_vm_extension(params) ⇒ Object
-
#delete_resource_group(resource_group_name) ⇒ Object
-
#delete_server(resource_group_name, vm_name) ⇒ Object
-
#extension_already_installed?(server) ⇒ Boolean
-
#fetch_chef_client_logs(resource_group_name, virtual_machine_name, chef_extension_name, fetch_process_start_time, fetch_process_wait_timeout = 30) ⇒ Object
-
#fetch_substatus(resource_group_name, virtual_machine_name, chef_extension_name) ⇒ Object
-
#find_server(resource_group, name) ⇒ Object
-
#get_latest_chef_extension_version(params) ⇒ Object
-
#initialize(params = {}) ⇒ ARMInterface
constructor
A new instance of ARMInterface.
-
#list_images ⇒ Object
-
#list_servers(resource_group_name = nil) ⇒ Object
-
#network_resource_client ⇒ Object
-
#parse_substatus_code(code, index) ⇒ Object
-
#platform(image_reference) ⇒ Object
-
#resource_group_exist?(resource_group_name) ⇒ Boolean
-
#resource_management_client ⇒ Object
-
#security_group_exist?(resource_group_name, security_group_name) ⇒ Boolean
-
#show_server(name, resource_group) ⇒ Object
-
#storage_management_client ⇒ Object
-
#virtual_machine_exist?(resource_group_name, vm_name) ⇒ Boolean
-
#vm_default_port(params = {}) ⇒ Object
-
#vm_public_ip(params = {}) ⇒ Object
#add_subnet, #create_vnet_config, #divide_network, #get_vnet, #in_use_network?, #new_subnet_address_prefix, #sort_available_networks, #sort_pools, #sort_subnets_by_cidr_prefix, #sort_used_networks_by_hosts_size, #subnet, #subnet_address_prefix, #subnet_cidr_prefix, #subnets_list, #subnets_list_for_specific_address_space, #vnet_address_spaces
#create_deployment_parameters, #create_deployment_template, #ohai_hints, #tcp_ports
#create_affinity_group, #create_internal_lb, #create_vnet, #list_affinity_groups, #list_internal_lb, #list_vnets
Methods included from Helpers
#display_list, #msg_pair, #random_string, #strip_non_ascii
included
Constructor Details
#initialize(params = {}) ⇒ ARMInterface
Returns a new instance of ARMInterface.
46
47
48
49
50
51
52
53
54
55
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 46
def initialize(params = {})
if params[:azure_client_secret]
token_provider = MsRestAzure::ApplicationTokenProvider.new(params[:azure_tenant_id], params[:azure_client_id], params[:azure_client_secret])
else
token_provider = MsRest::StringTokenProvider.new(params[:token], params[:tokentype])
end
@credentials = MsRest::TokenCredentials.new(token_provider)
@azure_subscription_id = params[:azure_subscription_id]
super
end
|
Instance Attribute Details
#connection ⇒ Object
Returns the value of attribute connection.
44
45
46
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 44
def connection
@connection
end
|
Instance Method Details
#common_arm_rescue_block(error) ⇒ Object
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 483
def common_arm_rescue_block(error)
if error.class == MsRestAzure::AzureOperationError && error.body
err_json = JSON.parse(error.response.body)
err_details = err_json["error"]["details"] if err_json["error"]
if err_details
err_details.each do |err|
begin
ui.error(JSON.parse(err["message"])["error"]["message"])
rescue JSON::ParserError => e
ui.error(err["message"])
end
end
else
ui.error(err_json["error"]["message"])
end
Chef::Log.debug(error.response.body)
else
message = begin
JSON.parse(error.message)
rescue JSON::ParserError => e
error.message
end
ui.error(message)
Chef::Log.debug(message)
end
rescue Exception => e
ui.error("Something went wrong. Please use -VV option for more details.")
Chef::Log.debug(error.backtrace.join("\n").to_s)
end
|
#compute_management_client ⇒ Object
65
66
67
68
69
70
71
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 65
def compute_management_client
@compute_management_client ||= begin
compute_management_client = ComputeManagementClient.new(@credentials)
compute_management_client.subscription_id = @azure_subscription_id
compute_management_client
end
end
|
#create_resource_group(params = {}) ⇒ Object
398
399
400
401
402
403
404
405
406
407
408
409
410
411
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 398
def create_resource_group(params = {})
resource_group = ResourceGroup.new
resource_group.name = params[:azure_resource_group_name]
resource_group.location = params[:azure_service_location]
begin
resource_group = resource_management_client.resource_groups.create_or_update(resource_group.name, resource_group)
rescue Exception => e
Chef::Log.error("Failed to create the Resource Group -- exception being rescued: #{e}")
common_arm_rescue_block(e)
end
resource_group
end
|
#create_server(params = {}) ⇒ Object
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 317
def create_server(params = {})
platform(params[:azure_image_reference_offer])
if resource_group_exist?(params[:azure_resource_group_name])
ui.log("INFO:Resource Group #{params[:azure_resource_group_name]} already exist. Skipping its creation.")
ui.log("INFO:Adding new VM #{params[:azure_vm_name]} to this resource group.")
else
ui.log("Creating ResourceGroup....\n\n")
resource_group = create_resource_group(params)
Chef::Log.info("ResourceGroup creation successfull.")
Chef::Log.info("Resource Group name is: #{resource_group.name}")
Chef::Log.info("Resource Group ID is: #{resource_group.id}")
end
if virtual_machine_exist?(params[:azure_resource_group_name], params[:azure_vm_name])
ui.log("INFO:Virtual Machine #{params[:azure_vm_name]} already exist under the Resource Group #{params[:azure_resource_group_name]}. Exiting for now.")
else
params[:chef_extension_version] = params[:chef_extension_version].nil? ? get_latest_chef_extension_version(params) : params[:chef_extension_version]
params[:vm_size] = params[:azure_vm_size]
params[:vnet_config] = create_vnet_config(
params[:azure_resource_group_name],
params[:azure_vnet_name],
params[:azure_vnet_subnet_name]
)
if params[:tcp_endpoints]
params[:tcp_endpoints] = if @platform == "Windows"
params[:tcp_endpoints] + ",3389"
else
params[:tcp_endpoints] + ",22,16001"
end
random_no = rand(100..1000)
params[:azure_sec_group_name] = params[:azure_vm_name] + "_sec_grp_" + random_no.to_s
if security_group_exist?(params[:azure_resource_group_name], params[:azure_sec_group_name])
random_no = rand(100..1000)
params[:azure_sec_group_name] = params[:azure_vm_name] + "_sec_grp_" + random_no.to_s
end
end
ui.log("Creating Virtual Machine....")
deployment = create_virtual_machine_using_template(params)
ui.log("Virtual Machine creation successfull.") unless deployment.nil?
unless deployment.nil?
ui.log("Deployment name is: #{deployment.name}")
ui.log("Deployment ID is: #{deployment.id}")
deployment.properties.dependencies.each do |deploy|
next unless deploy.resource_type == "Microsoft.Compute/virtualMachines"
if params[:chef_extension_public_param][:extendedLogs] == "true"
print "\n\nWaiting for the first chef-client run on virtual machine #{deploy.resource_name}"
fetch_chef_client_logs(params[:azure_resource_group_name],
deploy.resource_name,
params[:chef_extension],
Time.now)
end
ui.log("VM Details ...")
ui.log("-------------------------------")
ui.log("Virtual Machine name is: #{deploy.resource_name}")
ui.log("Virtual Machine ID is: #{deploy.id}")
show_server(deploy.resource_name, params[:azure_resource_group_name])
end
end
end
end
|
#create_virtual_machine_using_template(params) ⇒ Object
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 413
def create_virtual_machine_using_template(params)
template = create_deployment_template(params)
parameters = create_deployment_parameters(params)
deploy_prop = DeploymentProperties.new
deploy_prop.template = template
deploy_prop.parameters = parameters
deploy_prop.mode = "Incremental"
deploy_params = Deployment.new
deploy_params.properties = deploy_prop
deployment = resource_management_client.deployments.create_or_update(params[:azure_resource_group_name], "#{params[:azure_vm_name]}_deploy", deploy_params)
deployment
end
|
#create_vm_extension(params) ⇒ Object
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 429
def create_vm_extension(params)
vm_ext = VirtualMachineExtension.new
vm_ext.name = params[:chef_extension]
vm_ext.location = params[:azure_service_location]
vm_ext.publisher = params[:chef_extension_publisher]
vm_ext.virtual_machine_extension_type = params[:chef_extension]
vm_ext.type_handler_version = params[:chef_extension_version].nil? ? get_latest_chef_extension_version(params) : params[:chef_extension_version]
vm_ext.auto_upgrade_minor_version = false
vm_ext.settings = params[:chef_extension_public_param]
vm_ext.protected_settings = params[:chef_extension_private_param]
begin
vm_extension = compute_management_client.virtual_machine_extensions.create_or_update(
params[:azure_resource_group_name],
params[:azure_vm_name],
vm_ext.name,
vm_ext
)
rescue Exception => e
Chef::Log.error("Failed to create the Virtual Machine Extension -- exception being rescued.")
common_arm_rescue_block(e)
end
vm_extension
end
|
#delete_resource_group(resource_group_name) ⇒ Object
474
475
476
477
478
479
480
481
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 474
def delete_resource_group(resource_group_name)
ui.info "Resource group deletion takes some time. Please wait ..."
begin
server = resource_management_client.resource_groups.delete(resource_group_name)
end until server.nil?
puts "\n"
end
|
#delete_server(resource_group_name, vm_name) ⇒ Object
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 121
def delete_server(resource_group_name, vm_name)
server = compute_management_client.virtual_machines.get(resource_group_name, vm_name)
if server && server.name == vm_name
puts "\n\n"
msg_pair(ui, "VM Name", server.name)
msg_pair(ui, "VM Size", server.hardware_profile.vm_size)
msg_pair(ui, "VM OS", server.storage_profile.os_disk.os_type)
puts "\n"
begin
ui.confirm("Do you really want to delete this server")
rescue SystemExit server = nil exit!
end
ui.info "Deleting .."
begin
server_detail = compute_management_client.virtual_machines.delete(resource_group_name, vm_name)
end until server_detail.nil?
puts "\n"
ui.warn "Deleted server #{vm_name}"
end
end
|
#extension_already_installed?(server) ⇒ Boolean
454
455
456
457
458
459
460
461
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 454
def extension_already_installed?(server)
if server.resources
server.resources.each do |extension|
return true if extension.virtual_machine_extension_type == "ChefClient" || extension.virtual_machine_extension_type == "LinuxChefClient"
end
end
false
end
|
#fetch_chef_client_logs(resource_group_name, virtual_machine_name, chef_extension_name, fetch_process_start_time, fetch_process_wait_timeout = 30) ⇒ Object
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 277
def fetch_chef_client_logs(resource_group_name, virtual_machine_name, chef_extension_name, fetch_process_start_time, fetch_process_wait_timeout = 30)
substatus = fetch_substatus(resource_group_name, virtual_machine_name, chef_extension_name)
if substatus.nil?
fetch_process_wait_time = ((Time.now - fetch_process_start_time) / 60).round
if fetch_process_wait_time <= fetch_process_wait_timeout
print ui.color(".", :bold).to_s
sleep 30
fetch_chef_client_logs(resource_group_name, virtual_machine_name, chef_extension_name, fetch_process_start_time, fetch_process_wait_timeout)
else
ui.error "\nchef-client run logs could not be fetched since fetch process exceeded wait timeout of #{fetch_process_wait_timeout} minutes.\n"
end
else
status = parse_substatus_code(substatus.code, 2)
message = substatus.message
puts "\n\n******** Please find the chef-client run details below ********\n\n"
print "----> chef-client run status: "
case status
when "succeeded"
color = :green
when "failed"
color = :red
when "transitioning"
color = :yellow
end
puts ui.color(status, color, :bold).to_s
puts "----> chef-client run logs: "
puts "\n#{message}\n" end
end
|
#fetch_substatus(resource_group_name, virtual_machine_name, chef_extension_name) ⇒ Object
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 258
def fetch_substatus(resource_group_name, virtual_machine_name, chef_extension_name)
substatuses = compute_management_client.virtual_machine_extensions.get(
resource_group_name,
virtual_machine_name,
chef_extension_name,
expand: "instanceView"
).instance_view.substatuses
return nil if substatuses.nil?
substatuses.each do |substatus|
if parse_substatus_code(substatus.code, 1) == "Chef Client run logs"
return substatus
end
end
nil
end
|
#find_server(resource_group, name) ⇒ Object
207
208
209
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 207
def find_server(resource_group, name)
compute_management_client.virtual_machines.get(resource_group, name)
end
|
#get_latest_chef_extension_version(params) ⇒ Object
463
464
465
466
467
468
469
470
471
472
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 463
def get_latest_chef_extension_version(params)
ext_version = compute_management_client.virtual_machine_extension_images.list_versions(
params[:azure_service_location],
params[:chef_extension_publisher],
params[:chef_extension]
).last.name
ext_version_split_values = ext_version.split(".")
ext_version = ext_version_split_values[0] + "." + ext_version_split_values[1]
ext_version
end
|
#list_images ⇒ Object
89
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 89
def list_images; end
|
#list_servers(resource_group_name = nil) ⇒ Object
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 91
def list_servers(resource_group_name = nil)
servers = if resource_group_name.nil?
compute_management_client.virtual_machines.list_all
else
compute_management_client.virtual_machines.list(resource_group_name)
end
cols = ["VM Name", "Resource Group Name", "Location", "Provisioning State", "OS Type"]
rows = []
servers.each do |server|
rows << server.name.to_s
rows << server.id.split("/")[4].downcase
rows << server.location.to_s
rows << begin
state = server.provisioning_state.to_s.downcase
case state
when "failed"
ui.color(state, :red)
when "succeeded"
ui.color(state, :green)
else
ui.color(state, :yellow)
end
end
rows << server.storage_profile.os_disk.os_type.to_s
end
display_list(ui, cols, rows)
end
|
#network_resource_client ⇒ Object
81
82
83
84
85
86
87
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 81
def network_resource_client
@network_resource_client ||= begin
network_resource_client = NetworkManagementClient.new(@credentials)
network_resource_client.subscription_id = @azure_subscription_id
network_resource_client
end
end
|
#parse_substatus_code(code, index) ⇒ Object
254
255
256
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 254
def parse_substatus_code(code, index)
code.split("/")[index]
end
|
243
244
245
246
247
248
249
250
251
252
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 243
def platform(image_reference)
@platform ||= begin
platform = if image_reference =~ /WindowsServer.*/
"Windows"
else
"Linux"
end
platform
end
end
|
#resource_group_exist?(resource_group_name) ⇒ Boolean
239
240
241
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 239
def resource_group_exist?(resource_group_name)
resource_management_client.resource_groups.check_existence(resource_group_name)
end
|
#resource_management_client ⇒ Object
57
58
59
60
61
62
63
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 57
def resource_management_client
@resource_management_client ||= begin
resource_management_client = ResourceManagementClient.new(@credentials)
resource_management_client.subscription_id = @azure_subscription_id
resource_management_client
end
end
|
#security_group_exist?(resource_group_name, security_group_name) ⇒ Boolean
225
226
227
228
229
230
231
232
233
234
235
236
237
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 225
def security_group_exist?(resource_group_name, security_group_name)
network_resource_client.network_security_groups.get(resource_group_name, security_group_name)
true
rescue MsRestAzure::AzureOperationError => e
if e.body
err_json = JSON.parse(e.response.body)
if err_json["error"]["code"] == "ResourceNotFound"
return false
else
raise e
end
end
end
|
#show_server(name, resource_group) ⇒ Object
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 148
def show_server(name, resource_group)
server = find_server(resource_group, name)
if server
network_interface_name = server.network_profile.network_interfaces[0].id.split("/")[-1]
network_interface_data = network_resource_client.network_interfaces.get(resource_group, network_interface_name)
public_ip_id_data = network_interface_data.ip_configurations[0].public_ipaddress
if public_ip_id_data.nil?
public_ip_data = nil
else
public_ip_name = public_ip_id_data.id.split("/")[-1]
public_ip_data = network_resource_client.public_ipaddresses.get(resource_group, public_ip_name)
end
details = []
details << ui.color("Server Name", :bold, :cyan)
details << server.name
details << ui.color("Size", :bold, :cyan)
details << server.hardware_profile.vm_size
details << ui.color("Provisioning State", :bold, :cyan)
details << server.provisioning_state
details << ui.color("Location", :bold, :cyan)
details << server.location
details << ui.color("Publisher", :bold, :cyan)
details << server.storage_profile.image_reference.publisher
details << ui.color("Offer", :bold, :cyan)
details << server.storage_profile.image_reference.offer
details << ui.color("Sku", :bold, :cyan)
details << server.storage_profile.image_reference.sku
details << ui.color("Version", :bold, :cyan)
details << server.storage_profile.image_reference.version
details << ui.color("OS Type", :bold, :cyan)
details << server.storage_profile.os_disk.os_type
details << ui.color("Public IP address", :bold, :cyan)
details << if public_ip_data.nil?
" -- "
else
public_ip_data.ip_address
end
details << ui.color("FQDN", :bold, :cyan)
details << if public_ip_data.nil? || public_ip_data.dns_settings.nil?
" -- "
else
public_ip_data.dns_settings.fqdn
end
puts ui.list(details, :columns_across, 2)
end
end
|
#storage_management_client ⇒ Object
73
74
75
76
77
78
79
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 73
def storage_management_client
@storage_management_client ||= begin
storage_management_client = StorageManagementClient.new(@credentials)
storage_management_client.subscription_id = @azure_subscription_id
storage_management_client
end
end
|
#virtual_machine_exist?(resource_group_name, vm_name) ⇒ Boolean
211
212
213
214
215
216
217
218
219
220
221
222
223
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 211
def virtual_machine_exist?(resource_group_name, vm_name)
compute_management_client.virtual_machines.get(resource_group_name, vm_name)
true
rescue MsRestAzure::AzureOperationError => e
if e.body
err_json = JSON.parse(e.response.body)
if err_json["error"]["code"] == "ResourceNotFound"
return false
else
raise e
end
end
end
|
#vm_default_port(params = {}) ⇒ Object
391
392
393
394
395
396
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 391
def vm_default_port(params = {})
network_resource_client.network_security_groups.get(
params[:azure_resource_group_name],
params[:azure_vm_name]
).value!.body.properties.security_rules[0].properties.destination_port_range
end
|
#vm_public_ip(params = {}) ⇒ Object
384
385
386
387
388
389
|
# File 'lib/azure/resource_management/ARM_interface.rb', line 384
def vm_public_ip(params = {})
network_resource_client.public_ipaddresses.get(
params[:azure_resource_group_name],
params[:azure_vm_name]
).value!.body.properties.ip_address
end
|