fog-azure-rm 0.1.2 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +11 -0
- data/Gemfile +1 -1
- data/README.md +0 -1
- data/fog-azure-rm.gemspec +4 -1
- data/lib/fog/azurerm.rb +7 -0
- data/lib/fog/azurerm/application_gateway.rb +10 -2
- data/lib/fog/azurerm/compute.rb +14 -4
- data/lib/fog/azurerm/config.rb +0 -51
- data/lib/fog/azurerm/constants.rb +51 -0
- data/lib/fog/azurerm/dns.rb +12 -4
- data/lib/fog/azurerm/docs/application_gateway.md +38 -4
- data/lib/fog/azurerm/docs/compute.md +23 -4
- data/lib/fog/azurerm/docs/dns.md +18 -4
- data/lib/fog/azurerm/docs/key_vault.md +88 -0
- data/lib/fog/azurerm/docs/network.md +98 -9
- data/lib/fog/azurerm/docs/resources.md +24 -4
- data/lib/fog/azurerm/docs/sql.md +5 -6
- data/lib/fog/azurerm/docs/storage.md +12 -0
- data/lib/fog/azurerm/docs/traffic_manager.md +22 -4
- data/lib/fog/azurerm/key_vault.rb +51 -0
- data/lib/fog/azurerm/models/application_gateway/backend_address_pool.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/backend_http_setting.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/frontend_ip_configuration.rb +4 -0
- data/lib/fog/azurerm/models/application_gateway/frontend_port.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/gateway.rb +2 -6
- data/lib/fog/azurerm/models/application_gateway/gateways.rb +4 -0
- data/lib/fog/azurerm/models/application_gateway/http_listener.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/ip_configuration.rb +3 -0
- data/lib/fog/azurerm/models/application_gateway/probe.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/request_routing_rule.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/ssl_certificate.rb +2 -0
- data/lib/fog/azurerm/models/application_gateway/url_path_map.rb +2 -0
- data/lib/fog/azurerm/models/compute/availability_sets.rb +4 -0
- data/lib/fog/azurerm/models/compute/servers.rb +4 -0
- data/lib/fog/azurerm/models/compute/virtual_machine_extensions.rb +4 -0
- data/lib/fog/azurerm/models/dns/record_sets.rb +4 -0
- data/lib/fog/azurerm/models/dns/zones.rb +2 -2
- data/lib/fog/azurerm/models/key_vault/access_policy_entry.rb +31 -0
- data/lib/fog/azurerm/models/key_vault/vault.rb +76 -0
- data/lib/fog/azurerm/models/key_vault/vaults.rb +27 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_authorizations.rb +4 -0
- data/lib/fog/azurerm/models/network/express_route_circuits.rb +4 -0
- data/lib/fog/azurerm/models/network/load_balancers.rb +12 -2
- data/lib/fog/azurerm/models/network/local_network_gateways.rb +4 -0
- data/lib/fog/azurerm/models/network/network_interfaces.rb +4 -0
- data/lib/fog/azurerm/models/network/network_security_groups.rb +4 -0
- data/lib/fog/azurerm/models/network/network_security_rules.rb +4 -0
- data/lib/fog/azurerm/models/network/public_ips.rb +2 -9
- data/lib/fog/azurerm/models/network/subnets.rb +4 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateway_connections.rb +4 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateways.rb +4 -0
- data/lib/fog/azurerm/models/network/virtual_networks.rb +9 -11
- data/lib/fog/azurerm/models/resources/azure_resources.rb +4 -0
- data/lib/fog/azurerm/models/resources/deployments.rb +4 -0
- data/lib/fog/azurerm/models/resources/resource_groups.rb +4 -0
- data/lib/fog/azurerm/models/sql/firewall_rule.rb +5 -17
- data/lib/fog/azurerm/models/sql/firewall_rules.rb +4 -0
- data/lib/fog/azurerm/models/sql/sql_database.rb +4 -21
- data/lib/fog/azurerm/models/sql/sql_databases.rb +4 -0
- data/lib/fog/azurerm/models/sql/sql_server.rb +5 -18
- data/lib/fog/azurerm/models/sql/sql_servers.rb +4 -0
- data/lib/fog/azurerm/models/storage/directories.rb +4 -0
- data/lib/fog/azurerm/models/storage/storage_accounts.rb +4 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_points.rb +4 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profiles.rb +4 -0
- data/lib/fog/azurerm/network.rb +22 -4
- data/lib/fog/azurerm/requests/application_gateway/check_ag_exists.rb +31 -0
- data/lib/fog/azurerm/requests/application_gateway/create_or_update_application_gateway.rb +6 -0
- data/lib/fog/azurerm/requests/compute/check_availability_set_exists.rb +31 -0
- data/lib/fog/azurerm/requests/compute/check_vm_exists.rb +31 -0
- data/lib/fog/azurerm/requests/compute/check_vm_extension_exists.rb +31 -0
- data/lib/fog/azurerm/requests/dns/check_record_set_exists.rb +31 -0
- data/lib/fog/azurerm/requests/dns/{check_for_zone.rb → check_zone_exists.rb} +4 -2
- data/lib/fog/azurerm/requests/dns/list_record_sets.rb +1 -1
- data/lib/fog/azurerm/requests/dns/list_zones.rb +2 -2
- data/lib/fog/azurerm/requests/key_vault/check_vault_exists.rb +31 -0
- data/lib/fog/azurerm/requests/key_vault/create_or_update_vault.rb +105 -0
- data/lib/fog/azurerm/requests/key_vault/delete_vault.rb +28 -0
- data/lib/fog/azurerm/requests/key_vault/get_vault.rb +54 -0
- data/lib/fog/azurerm/requests/key_vault/list_vaults.rb +56 -0
- data/lib/fog/azurerm/requests/network/check_express_route_cir_auth_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_express_route_circuit_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_load_balancer_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_local_net_gateway_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_net_sec_group_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_net_sec_rule_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_network_interface_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/{check_for_public_ip.rb → check_public_ip_exists.rb} +12 -5
- data/lib/fog/azurerm/requests/network/check_subnet_exists.rb +32 -0
- data/lib/fog/azurerm/requests/network/{check_for_virtual_network.rb → check_virtual_network_exists.rb} +11 -6
- data/lib/fog/azurerm/requests/network/check_vnet_gateway_connection_exists.rb +32 -0
- data/lib/fog/azurerm/requests/network/check_vnet_gateway_exists.rb +32 -0
- data/lib/fog/azurerm/requests/network/list_load_balancers_in_subscription.rb +31 -0
- data/lib/fog/azurerm/requests/network/list_virtual_networks_in_subscription.rb +74 -0
- data/lib/fog/azurerm/requests/resources/check_azure_resource_exists.rb +40 -0
- data/lib/fog/azurerm/requests/resources/check_deployment_exists.rb +30 -0
- data/lib/fog/azurerm/requests/resources/check_resource_group_exists.rb +30 -0
- data/lib/fog/azurerm/requests/sql/check_database_exists.rb +21 -0
- data/lib/fog/azurerm/requests/sql/check_firewall_rule_exists.rb +21 -0
- data/lib/fog/azurerm/requests/sql/check_sql_server_exists.rb +21 -0
- data/lib/fog/azurerm/requests/sql/create_or_update_database.rb +26 -32
- data/lib/fog/azurerm/requests/sql/create_or_update_firewall_rule.rb +8 -22
- data/lib/fog/azurerm/requests/sql/create_or_update_sql_server.rb +14 -24
- data/lib/fog/azurerm/requests/sql/delete_database.rb +2 -9
- data/lib/fog/azurerm/requests/sql/delete_firewall_rule.rb +2 -9
- data/lib/fog/azurerm/requests/sql/delete_sql_server.rb +3 -9
- data/lib/fog/azurerm/requests/sql/get_database.rb +4 -10
- data/lib/fog/azurerm/requests/sql/get_firewall_rule.rb +4 -10
- data/lib/fog/azurerm/requests/sql/get_sql_server.rb +3 -10
- data/lib/fog/azurerm/requests/sql/list_databases.rb +3 -10
- data/lib/fog/azurerm/requests/sql/list_firewall_rules.rb +4 -10
- data/lib/fog/azurerm/requests/sql/list_sql_servers.rb +3 -10
- data/lib/fog/azurerm/requests/storage/check_container_exists.rb +30 -0
- data/lib/fog/azurerm/requests/storage/check_storage_account_exists.rb +31 -0
- data/lib/fog/azurerm/requests/storage/create_or_update_recovery_vault.rb +1 -1
- data/lib/fog/azurerm/requests/storage/delete_recovery_vault.rb +1 -1
- data/lib/fog/azurerm/requests/storage/disable_backup_protection.rb +1 -1
- data/lib/fog/azurerm/requests/storage/enable_backup_protection.rb +1 -1
- data/lib/fog/azurerm/requests/storage/get_all_backup_jobs.rb +1 -1
- data/lib/fog/azurerm/requests/storage/get_backup_container.rb +1 -1
- data/lib/fog/azurerm/requests/storage/get_backup_item.rb +1 -1
- data/lib/fog/azurerm/requests/storage/get_backup_protection_policy.rb +1 -1
- data/lib/fog/azurerm/requests/storage/get_recovery_vault.rb +1 -1
- data/lib/fog/azurerm/requests/storage/list_recovery_vaults.rb +1 -1
- data/lib/fog/azurerm/requests/storage/set_recovery_vault_context.rb +1 -1
- data/lib/fog/azurerm/requests/storage/start_backup.rb +1 -1
- data/lib/fog/azurerm/requests/traffic_manager/check_traffic_manager_endpoint_exists.rb +31 -0
- data/lib/fog/azurerm/requests/traffic_manager/check_traffic_manager_profile_exists.rb +31 -0
- data/lib/fog/azurerm/resources.rb +10 -2
- data/lib/fog/azurerm/sql.rb +18 -10
- data/lib/fog/azurerm/storage.rb +4 -0
- data/lib/fog/azurerm/traffic_manager.rb +9 -2
- data/lib/fog/azurerm/version.rb +1 -1
- data/rake-script.sh +3 -10
- data/test/api_stub.rb +8 -0
- data/test/api_stub/models/key_vault/vault.rb +39 -0
- data/test/api_stub/models/sql/sql_database.rb +18 -16
- data/test/api_stub/models/sql/sql_firewall_rule.rb +12 -10
- data/test/api_stub/models/sql/sql_server.rb +12 -10
- data/test/api_stub/requests/key_vault/vault.rb +95 -0
- data/test/api_stub/requests/sql/database.rb +8 -6
- data/test/api_stub/requests/sql/firewall_rule.rb +8 -4
- data/test/api_stub/requests/sql/sql_server.rb +8 -4
- data/test/integration/Virtual_network_gateway_connection.rb +7 -0
- data/test/integration/application_gateway.rb +8 -0
- data/test/integration/availability_set.rb +13 -2
- data/test/integration/blob.rb +0 -6
- data/test/integration/container.rb +7 -0
- data/test/integration/deployment.rb +7 -0
- data/test/integration/express_route_circuit.rb +16 -0
- data/test/integration/external_load_balancer.rb +18 -0
- data/test/integration/key_vault.rb +98 -0
- data/test/integration/local_network_gateway.rb +8 -0
- data/test/integration/network_interface.rb +8 -0
- data/test/integration/network_security_group.rb +8 -0
- data/test/integration/network_security_rule.rb +8 -0
- data/test/integration/public_ip.rb +3 -2
- data/test/integration/record_set.rb +8 -0
- data/test/integration/resource_group.rb +12 -4
- data/test/integration/resource_tag.rb +7 -0
- data/test/integration/server.rb +8 -0
- data/test/integration/sql_server.rb +23 -3
- data/test/integration/storage_account.rb +8 -1
- data/test/integration/subnet.rb +7 -0
- data/test/integration/traffic_manager.rb +14 -0
- data/test/integration/virtual_machine_extension.rb +8 -0
- data/test/integration/virtual_network.rb +13 -4
- data/test/integration/virtual_network_gateway.rb +7 -0
- data/test/integration/zone.rb +8 -0
- data/test/models/application_gateway/test_gateway.rb +1 -0
- data/test/models/application_gateway/test_gateways.rb +14 -1
- data/test/models/compute/test_availability_sets.rb +14 -1
- data/test/models/compute/test_servers.rb +14 -1
- data/test/models/compute/test_virtual_machine_extensions.rb +14 -1
- data/test/models/dns/test_record_sets.rb +14 -1
- data/test/models/dns/test_zones.rb +7 -7
- data/test/models/key_vault/test_vault.rb +39 -0
- data/test/models/key_vault/test_vaults.rb +55 -0
- data/test/models/network/test_express_route_circuit_authorizations.rb +14 -1
- data/test/models/network/test_express_route_circuits.rb +14 -1
- data/test/models/network/test_load_balancers.rb +14 -1
- data/test/models/network/test_local_network_gateways.rb +14 -1
- data/test/models/network/test_network_interfaces.rb +14 -1
- data/test/models/network/test_network_security_groups.rb +14 -1
- data/test/models/network/test_network_security_rules.rb +14 -1
- data/test/models/network/test_public_ips.rb +6 -6
- data/test/models/network/test_subnets.rb +14 -1
- data/test/models/network/test_virtual_network_gateway_connections.rb +14 -1
- data/test/models/network/test_virtual_network_gateways.rb +14 -1
- data/test/models/network/test_virtual_networks.rb +20 -8
- data/test/models/resources/test_deployments.rb +14 -1
- data/test/models/resources/test_resource_groups.rb +14 -1
- data/test/models/resources/test_resources.rb +16 -3
- data/test/models/sql/test_database.rb +3 -4
- data/test/models/sql/test_databases.rb +5 -5
- data/test/models/sql/test_firewall_rule.rb +2 -1
- data/test/models/sql/test_firewall_rules.rb +3 -2
- data/test/models/sql/test_sql_server.rb +2 -1
- data/test/models/sql/test_sql_servers.rb +5 -5
- data/test/models/storage/test_directories.rb +14 -1
- data/test/models/storage/test_storage_accounts.rb +14 -1
- data/test/models/traffic_manager/test_traffic_manager_end_points.rb +14 -1
- data/test/models/traffic_manager/test_traffic_manager_profiles.rb +14 -1
- data/test/requests/application_gateway/test_check_ag_exists.rb +31 -0
- data/test/requests/compute/test_check_availability_set_exists.rb +31 -0
- data/test/requests/compute/test_check_vm_exists.rb +31 -0
- data/test/requests/compute/test_check_vm_extension_exists.rb +31 -0
- data/test/requests/dns/test_check_record_set_exists.rb +31 -0
- data/test/requests/dns/test_check_zone_exists.rb +35 -0
- data/test/requests/dns/test_list_record_sets.rb +35 -0
- data/test/requests/dns/{test_check_for_zone.rb → test_list_zones.rb} +10 -8
- data/test/requests/key_vault/test_check_vault_exists.rb +31 -0
- data/test/requests/key_vault/test_create_or_update_vault.rb +25 -0
- data/test/requests/key_vault/test_delete_vault.rb +23 -0
- data/test/requests/key_vault/test_get_vault.rb +24 -0
- data/test/requests/key_vault/test_list_vaults.rb +24 -0
- data/test/requests/network/test_check_express_route_cir_auth_exists.rb +31 -0
- data/test/requests/network/test_check_express_route_circuit_exists.rb +31 -0
- data/test/requests/network/test_check_load_balancer_exists.rb +31 -0
- data/test/requests/network/test_check_local_net_gateway_exists.rb +31 -0
- data/test/requests/network/test_check_net_sec_group_exists.rb +31 -0
- data/test/requests/network/test_check_net_sec_rule_exists.rb +31 -0
- data/test/requests/network/test_check_network_interface_exists.rb +31 -0
- data/test/requests/network/{test_check_for_public_ip.rb → test_check_public_ip_exists.rb} +8 -8
- data/test/requests/network/test_check_subnet_exists.rb +31 -0
- data/test/requests/network/{test_check_for_virtual_network.rb → test_check_virtual_network_exists.rb} +8 -8
- data/test/requests/network/test_check_vnet_gateway_connection_exists.rb +31 -0
- data/test/requests/network/test_check_vnet_gateway_exists.rb +31 -0
- data/test/requests/network/test_list_virtual_networks_in_subscription.rb +24 -0
- data/test/requests/resources/test_check_azure_resource_exists.rb +22 -0
- data/test/requests/resources/test_check_deployment_exists.rb +29 -0
- data/test/requests/resources/test_check_resource_group_exists.rb +29 -0
- data/test/requests/sql/test_create_or_update_database.rb +9 -12
- data/test/requests/sql/test_create_or_update_firewall_rule.rb +9 -11
- data/test/requests/sql/test_create_or_update_sql_server.rb +9 -12
- data/test/requests/sql/test_delete_database.rb +6 -17
- data/test/requests/sql/test_delete_firewall_rule.rb +6 -17
- data/test/requests/sql/test_delete_sql_server.rb +6 -17
- data/test/requests/sql/test_get_database.rb +7 -18
- data/test/requests/sql/test_get_firewall_rule.rb +7 -18
- data/test/requests/sql/test_get_sql_server.rb +7 -18
- data/test/requests/sql/test_list_databases.rb +7 -18
- data/test/requests/sql/test_list_firewall_rules.rb +7 -18
- data/test/requests/sql/test_list_sql_servers.rb +7 -18
- data/test/requests/storage/test_check_container_exists.rb +18 -0
- data/test/requests/storage/test_check_storage_account_exists.rb +32 -0
- data/test/requests/traffic_manager/test_check_traffic_manager_endpoint_exists.rb +31 -0
- data/test/requests/traffic_manager/test_check_traffic_manager_profile_exists.rb +31 -0
- data/test/test_helper.rb +39 -4
- metadata +125 -10
@@ -0,0 +1,31 @@
|
|
1
|
+
module Fog
|
2
|
+
module ApplicationGateway
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def check_ag_exists(resource_group_name, application_gateway_name)
|
7
|
+
msg = "Checking Application Gateway: #{application_gateway_name}"
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@network_client.application_gateways.get(resource_group_name, application_gateway_name)
|
11
|
+
Fog::Logger.debug "Application Gateway #{application_gateway_name} exists."
|
12
|
+
true
|
13
|
+
rescue MsRestAzure::AzureOperationError => e
|
14
|
+
if e.body['error']['code'] == 'ResourceNotFound'
|
15
|
+
Fog::Logger.debug "Application Gateway #{application_gateway_name} doesn't exist."
|
16
|
+
false
|
17
|
+
else
|
18
|
+
raise_azure_exception(e, msg)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
# This class provides the mock implementation for unit tests.
|
24
|
+
class Mock
|
25
|
+
def check_ag_exists(*)
|
26
|
+
true
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -82,6 +82,12 @@ module Fog
|
|
82
82
|
frontend_ip_configuration.private_ipaddress = fic[:private_ip_address]
|
83
83
|
frontend_ip_configuration.private_ipallocation_method = fic[:private_ip_allocation_method]
|
84
84
|
|
85
|
+
if fic[:subnet_id]
|
86
|
+
subnet = Azure::ARM::Network::Models::Subnet.new
|
87
|
+
subnet.id = fic[:subnet_id]
|
88
|
+
frontend_ip_configuration.subnet = subnet
|
89
|
+
end
|
90
|
+
|
85
91
|
unless fic[:public_ip_address_id].nil?
|
86
92
|
pip = Azure::ARM::Network::Models::PublicIPAddress.new
|
87
93
|
pip.id = fic[:public_ip_address_id]
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def check_availability_set_exists(resource_group, name)
|
7
|
+
msg = "Checking Availability set: #{name}"
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@compute_mgmt_client.availability_sets.get(resource_group, name)
|
11
|
+
Fog::Logger.debug "Availability set #{name} exists."
|
12
|
+
true
|
13
|
+
rescue MsRestAzure::AzureOperationError => e
|
14
|
+
if e.body['error']['code'] == 'ResourceNotFound'
|
15
|
+
Fog::Logger.debug "Availability set #{name} doesn't exist."
|
16
|
+
false
|
17
|
+
else
|
18
|
+
raise_azure_exception(e, msg)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
# This class provides the mock implementation for unit tests.
|
24
|
+
class Mock
|
25
|
+
def check_availability_set_exists(_resource_group, _name)
|
26
|
+
true
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def check_vm_exists(resource_group, name)
|
7
|
+
msg = "Checking Virtual Machine #{name}"
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@compute_mgmt_client.virtual_machines.get(resource_group, name, 'instanceView')
|
11
|
+
Fog::Logger.debug "Virtual machine #{name} exists."
|
12
|
+
true
|
13
|
+
rescue MsRestAzure::AzureOperationError => e
|
14
|
+
if e.body['error']['code'] == 'ResourceNotFound'
|
15
|
+
Fog::Logger.debug "Virtual machine #{name} doesn't exist."
|
16
|
+
false
|
17
|
+
else
|
18
|
+
raise_azure_exception(e, msg)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
# This class provides the mock implementation for unit tests.
|
24
|
+
class Mock
|
25
|
+
def check_vm_exists(_resource_group, _name)
|
26
|
+
true
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def check_vm_extension_exists(resource_group_name, virtual_machine_name, vm_extension_name)
|
7
|
+
msg = "Checking Virtual Machine Extension #{vm_extension_name}"
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@compute_mgmt_client.virtual_machine_extensions.get(resource_group_name, virtual_machine_name, vm_extension_name)
|
11
|
+
Fog::Logger.debug "Virtual Machine Extension #{vm_extension_name} exists."
|
12
|
+
true
|
13
|
+
rescue MsRestAzure::AzureOperationError => e
|
14
|
+
if e.body['error']['code'] == 'ResourceNotFound'
|
15
|
+
Fog::Logger.debug "Virtual machine #{vm_extension_name} doesn't exist."
|
16
|
+
false
|
17
|
+
else
|
18
|
+
raise_azure_exception(e, msg)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
# This class provides the mock implementation for unit tests.
|
24
|
+
class Mock
|
25
|
+
def check_vm_extension_exists(*)
|
26
|
+
true
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module Fog
|
2
|
+
module DNS
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def check_record_set_exists(resource_group, name, zone_name, record_type)
|
7
|
+
msg = "Checking Record set #{name}"
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@dns_client.record_sets.get(resource_group, zone_name, name, record_type)
|
11
|
+
Fog::Logger.debug "Record set #{name} exists."
|
12
|
+
true
|
13
|
+
rescue MsRestAzure::AzureOperationError => e
|
14
|
+
if e.body['code'] == 'NotFound'
|
15
|
+
Fog::Logger.debug "Record set #{name} doesn't exist."
|
16
|
+
false
|
17
|
+
else
|
18
|
+
raise_azure_exception(e, msg)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
# This class provides the mock implementation for unit tests.
|
24
|
+
class Mock
|
25
|
+
def check_record_set_exists(_resource_group, _name)
|
26
|
+
true
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -3,13 +3,15 @@ module Fog
|
|
3
3
|
class AzureRM
|
4
4
|
# Real class for DNS Request
|
5
5
|
class Real
|
6
|
-
def
|
6
|
+
def check_zone_exists(resource_group, name)
|
7
7
|
msg = "Getting Zone #{name} from Resource Group #{resource_group}."
|
8
8
|
Fog::Logger.debug msg
|
9
9
|
begin
|
10
10
|
zone = @dns_client.zones.get(resource_group, name)
|
11
11
|
rescue MsRestAzure::AzureOperationError => e
|
12
12
|
raise_azure_exception(e, msg)
|
13
|
+
rescue => e
|
14
|
+
Fog::Logger.debug e[:error][:code]
|
13
15
|
end
|
14
16
|
!zone.nil?
|
15
17
|
end
|
@@ -17,7 +19,7 @@ module Fog
|
|
17
19
|
|
18
20
|
# Mock class for DNS Request
|
19
21
|
class Mock
|
20
|
-
def
|
22
|
+
def check_zone_exists(*)
|
21
23
|
Fog::Logger.debug 'Zone name name is available.'
|
22
24
|
true
|
23
25
|
end
|
@@ -7,7 +7,7 @@ module Fog
|
|
7
7
|
msg = 'Getting list of Record sets.'
|
8
8
|
Fog::Logger.debug msg
|
9
9
|
begin
|
10
|
-
zones = @dns_client.record_sets.
|
10
|
+
zones = @dns_client.record_sets.list_by_dns_zone(resource_group, zone_name)
|
11
11
|
rescue MsRestAzure::AzureOperationError => e
|
12
12
|
raise_azure_exception(e, msg)
|
13
13
|
end
|
@@ -7,7 +7,7 @@ module Fog
|
|
7
7
|
msg = 'Getting list of Zones.'
|
8
8
|
Fog::Logger.debug msg
|
9
9
|
begin
|
10
|
-
zones = @dns_client.zones.
|
10
|
+
zones = @dns_client.zones.list
|
11
11
|
rescue MsRestAzure::AzureOperationError => e
|
12
12
|
raise_azure_exception(e, msg)
|
13
13
|
end
|
@@ -20,7 +20,7 @@ module Fog
|
|
20
20
|
msg = "Getting list of Zones in Resource Group #{resource_group}."
|
21
21
|
Fog::Logger.debug msg
|
22
22
|
begin
|
23
|
-
zones = @dns_client.zones.
|
23
|
+
zones = @dns_client.zones.list_by_resource_group(resource_group)
|
24
24
|
rescue MsRestAzure::AzureOperationError => e
|
25
25
|
raise_azure_exception(e, msg)
|
26
26
|
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module Fog
|
2
|
+
module KeyVault
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def check_vault_exists(resource_group, vault_name)
|
7
|
+
msg = "Checking Vault #{vault_name}"
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@key_vault_client.vaults.get(resource_group, vault_name)
|
11
|
+
Fog::Logger.debug "Vault #{vault_name} exists."
|
12
|
+
true
|
13
|
+
rescue MsRestAzure::AzureOperationError => e
|
14
|
+
if e.body['error']['code'] == 'ResourceNotFound'
|
15
|
+
Fog::Logger.debug "Vault #{vault_name} doesn't exist."
|
16
|
+
false
|
17
|
+
else
|
18
|
+
raise_azure_exception(e, msg)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
# This class provides the mock implementation for unit tests.
|
24
|
+
class Mock
|
25
|
+
def check_vault_exists(*)
|
26
|
+
true
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,105 @@
|
|
1
|
+
module Fog
|
2
|
+
module KeyVault
|
3
|
+
class AzureRM
|
4
|
+
# This class provides the actual implementation for service calls.
|
5
|
+
class Real
|
6
|
+
def create_or_update_vault(vault_hash)
|
7
|
+
msg = "Creating Vault: #{vault_hash[:name]}."
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
vault_parameters = get_vault_param_object(vault_hash)
|
10
|
+
begin
|
11
|
+
vault = @key_vault_client.vaults.create_or_update(vault_hash[:resource_group], vault_hash[:name], vault_parameters)
|
12
|
+
rescue MsRestAzure::AzureOperationError => e
|
13
|
+
raise_azure_exception(e, msg)
|
14
|
+
end
|
15
|
+
Fog::Logger.debug "Vault: #{vault_hash[:name]} created successfully."
|
16
|
+
vault
|
17
|
+
end
|
18
|
+
|
19
|
+
private
|
20
|
+
|
21
|
+
def get_vault_param_object(vault_hash)
|
22
|
+
vault_param = Azure::ARM::KeyVault::Models::VaultCreateOrUpdateParameters.new
|
23
|
+
vault_param.location = vault_hash[:location]
|
24
|
+
vault_param.properties = get_vault_properties_object(vault_hash)
|
25
|
+
vault_param
|
26
|
+
end
|
27
|
+
|
28
|
+
def get_vault_properties_object(vault_hash)
|
29
|
+
vault_properties = Azure::ARM::KeyVault::Models::VaultProperties.new
|
30
|
+
vault_properties.tenant_id = vault_hash[:tenant_id]
|
31
|
+
vault_properties.sku = get_sku_object(vault_hash)
|
32
|
+
vault_properties.access_policies = get_access_policies_object(vault_hash[:access_policies])
|
33
|
+
vault_properties
|
34
|
+
end
|
35
|
+
|
36
|
+
def get_sku_object(vault_hash)
|
37
|
+
sku = Azure::ARM::KeyVault::Models::Sku.new
|
38
|
+
sku.family = vault_hash[:sku_family]
|
39
|
+
sku.name = vault_hash[:sku_name]
|
40
|
+
sku
|
41
|
+
end
|
42
|
+
|
43
|
+
def get_access_policies_object(access_policies_hash)
|
44
|
+
access_policies_arr = []
|
45
|
+
unless access_policies_hash.nil?
|
46
|
+
access_policies_hash.each do |access_policy_hash|
|
47
|
+
access_policies_arr.push(get_access_policy_entry_object(access_policy_hash))
|
48
|
+
end
|
49
|
+
end
|
50
|
+
access_policies_arr
|
51
|
+
end
|
52
|
+
|
53
|
+
def get_access_policy_entry_object(access_policy_hash)
|
54
|
+
access_policy_entry = Azure::ARM::KeyVault::Models::AccessPolicyEntry.new
|
55
|
+
access_policy_entry.tenant_id = access_policy_hash[:tenant_id]
|
56
|
+
access_policy_entry.object_id = access_policy_hash[:object_id]
|
57
|
+
access_policy_entry.permissions = get_permission_object(access_policy_hash[:permissions])
|
58
|
+
access_policy_entry
|
59
|
+
end
|
60
|
+
|
61
|
+
def get_permission_object(permission_hash)
|
62
|
+
permission = Azure::ARM::KeyVault::Models::Permissions.new
|
63
|
+
permission.keys = permission_hash[:keys]
|
64
|
+
permission.secrets = permission_hash[:secrets]
|
65
|
+
permission.certificates = permission_hash[:certificates]
|
66
|
+
permission
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
# This class provides the mock implementation for unit tests.
|
71
|
+
class Mock
|
72
|
+
def create_or_update_vault(*)
|
73
|
+
vault = {
|
74
|
+
'id' => '/subscriptions/<AZURE_SUBSCRIPTION_ID>/resourceGroups/RubySDKTest_azure_mgmt_kv/providers/Microsoft.KeyVault/vaults/sampleVault758347',
|
75
|
+
'name' => 'sampleVault758347',
|
76
|
+
'type' => 'Microsoft.KeyVault/vaults',
|
77
|
+
'location' => 'westus',
|
78
|
+
'tags' => {},
|
79
|
+
'properties' => {
|
80
|
+
'sku' => {
|
81
|
+
'family' => 'A',
|
82
|
+
'name' => 'standard'
|
83
|
+
},
|
84
|
+
'tenantId' => '<AZURE_TENANT_ID>',
|
85
|
+
'accessPolicies' => [
|
86
|
+
{
|
87
|
+
'tenantId' => '<AZURE_TENANT_ID>',
|
88
|
+
'objectId' => '<AZURE_OBJECT_ID>',
|
89
|
+
'permissions' => {
|
90
|
+
'keys' => ['all'],
|
91
|
+
'secrets' => ['all']
|
92
|
+
}
|
93
|
+
}
|
94
|
+
],
|
95
|
+
'enabledForDeployment' => false,
|
96
|
+
'vaultUri' => 'https =>//samplevault758347.vault.azure.net/'
|
97
|
+
}
|
98
|
+
}
|
99
|
+
vault_mapper = Azure::ARM::KeyVault::Models::Vault.mapper
|
100
|
+
@key_vault_client.deserialize(vault_mapper, vault, 'result.body')
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module Fog
|
2
|
+
module KeyVault
|
3
|
+
class AzureRM
|
4
|
+
# Real class for KeyVault Request
|
5
|
+
class Real
|
6
|
+
def delete_vault(resource_group, vault_name)
|
7
|
+
msg = "Deleting Vault: #{vault_name}."
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
@key_vault_client.vaults.delete(resource_group, vault_name)
|
11
|
+
rescue MsRestAzure::AzureOperationError => e
|
12
|
+
raise_azure_exception(e, msg)
|
13
|
+
end
|
14
|
+
Fog::Logger.debug "Vault: #{vault_name} deleted successfully."
|
15
|
+
true
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
# Mock class for KeyVault Request
|
20
|
+
class Mock
|
21
|
+
def delete_vault(resource_group, vault_name)
|
22
|
+
Fog::Logger.debug "Vault #{vault_name} from Resource group #{resource_group} deleted successfully."
|
23
|
+
true
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,54 @@
|
|
1
|
+
module Fog
|
2
|
+
module KeyVault
|
3
|
+
class AzureRM
|
4
|
+
# Real class for KeyVault Request
|
5
|
+
class Real
|
6
|
+
def get_vault(resource_group, vault_name)
|
7
|
+
msg = "Getting Vault => #{vault_name} from Resource Group => #{resource_group}..."
|
8
|
+
Fog::Logger.debug msg
|
9
|
+
begin
|
10
|
+
vault = @key_vault_client.vaults.get(resource_group, vault_name)
|
11
|
+
rescue MsRestAzure::AzureOperationError => e
|
12
|
+
raise_azure_exception(e, msg)
|
13
|
+
end
|
14
|
+
Fog::Logger.debug "Vault fetched successfully from Resource Group => #{resource_group}"
|
15
|
+
vault
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
# Mock class for KeyVault Request
|
20
|
+
class Mock
|
21
|
+
def get_vault(*)
|
22
|
+
vault = {
|
23
|
+
'id' => '/subscriptions/<AZURE_SUBSCRIPTION_ID>/resourceGroups/RubySDKTest_azure_mgmt_kv/providers/Microsoft.KeyVault/vaults/sampleVault758347',
|
24
|
+
'name' => 'sampleVault758347',
|
25
|
+
'type' => 'Microsoft.KeyVault/vaults',
|
26
|
+
'location' => 'westus',
|
27
|
+
'tags' => {},
|
28
|
+
'properties' => {
|
29
|
+
'sku' => {
|
30
|
+
'family' => 'A',
|
31
|
+
'name' => 'standard'
|
32
|
+
},
|
33
|
+
'tenantId' => '<AZURE_TENANT_ID>',
|
34
|
+
'accessPolicies' => [
|
35
|
+
{
|
36
|
+
'tenantId' => '<AZURE_TENANT_ID>',
|
37
|
+
'objectId' => '<AZURE_OBJECT_ID>',
|
38
|
+
'permissions' => {
|
39
|
+
'keys' => ['all'],
|
40
|
+
'secrets' => ['all']
|
41
|
+
}
|
42
|
+
}
|
43
|
+
],
|
44
|
+
'enabledForDeployment' => false,
|
45
|
+
'vaultUri' => 'https =>//samplevault758347.vault.azure.net/'
|
46
|
+
}
|
47
|
+
}
|
48
|
+
vault_mapper = Azure::ARM::KeyVault::Models::Vault.mapper
|
49
|
+
@key_vault_client.deserialize(vault_mapper, vault, 'result.body')
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|