fog-azure-rm 0.0.4 → 0.0.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.DS_Store +0 -0
- data/.travis.yml +11 -1
- data/CHANGELOG.md +35 -14
- data/fog-azure-rm.gemspec +8 -9
- data/lib/fog/azurerm.rb +3 -0
- data/lib/fog/azurerm/application_gateway.rb +64 -0
- data/lib/fog/azurerm/compute.rb +1 -0
- data/lib/fog/azurerm/config.rb +17 -0
- data/lib/fog/azurerm/core.rb +1 -0
- data/lib/fog/azurerm/dns.rb +4 -2
- data/lib/fog/azurerm/docs/application_gateway.md +139 -0
- data/lib/fog/azurerm/docs/dns.md +28 -6
- data/lib/fog/azurerm/docs/network.md +151 -143
- data/lib/fog/azurerm/docs/resources.md +3 -3
- data/lib/fog/azurerm/docs/storage.md +15 -3
- data/lib/fog/azurerm/docs/traffic_manager.md +118 -0
- data/lib/fog/azurerm/fog_azure_rm_exception.rb +13 -0
- data/lib/fog/azurerm/models/application_gateway/backend_address_pool.rb +22 -0
- data/lib/fog/azurerm/models/application_gateway/backend_http_setting.rb +26 -0
- data/lib/fog/azurerm/models/application_gateway/frontend_ip_configuration.rb +22 -0
- data/lib/fog/azurerm/models/application_gateway/frontend_port.rb +18 -0
- data/lib/fog/azurerm/models/{network/application_gateway.rb → application_gateway/gateway.rb} +74 -78
- data/lib/fog/azurerm/models/{network/application_gateways.rb → application_gateway/gateways.rb} +6 -6
- data/lib/fog/azurerm/models/application_gateway/http_listener.rb +28 -0
- data/lib/fog/azurerm/models/application_gateway/ip_configuration.rb +18 -0
- data/lib/fog/azurerm/models/application_gateway/probe.rb +28 -0
- data/lib/fog/azurerm/models/application_gateway/request_routing_rule.rb +25 -0
- data/lib/fog/azurerm/models/application_gateway/ssl_certificate.rb +22 -0
- data/lib/fog/azurerm/models/application_gateway/url_path_map.rb +28 -0
- data/lib/fog/azurerm/models/compute/availability_set.rb +8 -8
- data/lib/fog/azurerm/models/compute/availability_sets.rb +3 -1
- data/lib/fog/azurerm/models/compute/server.rb +50 -34
- data/lib/fog/azurerm/models/dns/record_set.rb +30 -2
- data/lib/fog/azurerm/models/dns/record_sets.rb +4 -2
- data/lib/fog/azurerm/models/dns/zone.rb +1 -1
- data/lib/fog/azurerm/models/dns/zones.rb +4 -2
- data/lib/fog/azurerm/models/network/express_route_circuit.rb +89 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_peering.rb +93 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_peerings.rb +31 -0
- data/lib/fog/azurerm/models/network/express_route_circuits.rb +29 -0
- data/lib/fog/azurerm/models/network/express_route_service_provider.rb +29 -0
- data/lib/fog/azurerm/models/network/express_route_service_providers.rb +21 -0
- data/lib/fog/azurerm/models/network/frontend_ip_configuration.rb +5 -15
- data/lib/fog/azurerm/models/network/inbound_nat_pool.rb +6 -7
- data/lib/fog/azurerm/models/network/inbound_nat_rule.rb +6 -9
- data/lib/fog/azurerm/models/network/load_balancer.rb +17 -19
- data/lib/fog/azurerm/models/network/load_balancing_rule.rb +11 -16
- data/lib/fog/azurerm/models/network/network_interface.rb +24 -24
- data/lib/fog/azurerm/models/network/network_security_group.rb +9 -9
- data/lib/fog/azurerm/models/network/network_security_rule.rb +13 -13
- data/lib/fog/azurerm/models/network/probe.rb +7 -8
- data/lib/fog/azurerm/models/network/public_ip.rb +15 -16
- data/lib/fog/azurerm/models/network/public_ips.rb +4 -2
- data/lib/fog/azurerm/models/network/subnet.rb +8 -8
- data/lib/fog/azurerm/models/network/virtual_network.rb +9 -9
- data/lib/fog/azurerm/models/network/virtual_network_gateway.rb +138 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateways.rb +29 -0
- data/lib/fog/azurerm/models/network/vpn_client_configuration.rb +34 -0
- data/lib/fog/azurerm/models/network/vpn_client_revoked_certificates.rb +22 -0
- data/lib/fog/azurerm/models/network/vpn_client_root_certificates.rb +22 -0
- data/lib/fog/azurerm/models/resources/azure_resource.rb +5 -5
- data/lib/fog/azurerm/models/resources/dependency.rb +5 -5
- data/lib/fog/azurerm/models/resources/deployment.rb +14 -14
- data/lib/fog/azurerm/models/resources/provider.rb +4 -4
- data/lib/fog/azurerm/models/resources/provider_resource_type.rb +4 -4
- data/lib/fog/azurerm/models/resources/resource_group.rb +9 -1
- data/lib/fog/azurerm/models/resources/resource_groups.rb +5 -1
- data/lib/fog/azurerm/models/storage/data_disk.rb +6 -6
- data/lib/fog/azurerm/models/storage/storage_account.rb +41 -10
- data/lib/fog/azurerm/models/storage/storage_accounts.rb +1 -6
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_point.rb +75 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_points.rb +31 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profile.rb +59 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profiles.rb +26 -0
- data/lib/fog/azurerm/network.rb +25 -25
- data/lib/fog/azurerm/requests/{network → application_gateway}/create_application_gateway.rb +59 -95
- data/lib/fog/azurerm/requests/application_gateway/delete_application_gateway.rb +26 -0
- data/lib/fog/azurerm/requests/application_gateway/list_application_gateways.rb +29 -0
- data/lib/fog/azurerm/requests/compute/attach_data_disk_to_vm.rb +38 -38
- data/lib/fog/azurerm/requests/compute/check_vm_status.rb +8 -10
- data/lib/fog/azurerm/requests/compute/create_availability_set.rb +15 -20
- data/lib/fog/azurerm/requests/compute/create_virtual_machine.rb +50 -45
- data/lib/fog/azurerm/requests/compute/deallocate_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/compute/delete_availability_set.rb +7 -8
- data/lib/fog/azurerm/requests/compute/delete_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/compute/detach_data_disk_from_vm.rb +20 -19
- data/lib/fog/azurerm/requests/compute/generalize_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/compute/get_availability_set.rb +32 -0
- data/lib/fog/azurerm/requests/compute/get_virtual_machine.rb +17 -14
- data/lib/fog/azurerm/requests/compute/list_availability_sets.rb +7 -6
- data/lib/fog/azurerm/requests/compute/list_available_sizes_for_virtual_machine.rb +37 -31
- data/lib/fog/azurerm/requests/compute/list_virtual_machines.rb +47 -42
- data/lib/fog/azurerm/requests/compute/power_off_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/compute/redeploy_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/compute/restart_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/compute/start_virtual_machine.rb +9 -10
- data/lib/fog/azurerm/requests/dns/{create_record_set.rb → create_or_update_record_set.rb} +2 -2
- data/lib/fog/azurerm/requests/dns/{create_zone.rb → create_or_update_zone.rb} +3 -3
- data/lib/fog/azurerm/requests/dns/get_record_set.rb +56 -0
- data/lib/fog/azurerm/requests/dns/get_zone.rb +50 -0
- data/lib/fog/azurerm/requests/dns/list_record_sets.rb +2 -2
- data/lib/fog/azurerm/requests/network/add_address_prefixes_in_virtual_network.rb +3 -3
- data/lib/fog/azurerm/requests/network/add_dns_servers_in_virtual_network.rb +8 -6
- data/lib/fog/azurerm/requests/network/add_security_rules.rb +15 -13
- data/lib/fog/azurerm/requests/network/add_subnets_in_virtual_network.rb +6 -4
- data/lib/fog/azurerm/requests/network/attach_network_security_group_to_subnet.rb +13 -15
- data/lib/fog/azurerm/requests/network/attach_resource_to_nic.rb +17 -16
- data/lib/fog/azurerm/requests/network/attach_route_table_to_subnet.rb +13 -15
- data/lib/fog/azurerm/requests/network/check_for_public_ip.rb +2 -4
- data/lib/fog/azurerm/requests/network/check_for_virtual_network.rb +5 -5
- data/lib/fog/azurerm/requests/network/create_load_balancer.rb +43 -62
- data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit.rb +98 -0
- data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit_peering.rb +69 -0
- data/lib/fog/azurerm/requests/network/create_or_update_network_interface.rb +14 -19
- data/lib/fog/azurerm/requests/network/create_or_update_network_security_group.rb +29 -26
- data/lib/fog/azurerm/requests/network/create_or_update_virtual_network.rb +19 -25
- data/lib/fog/azurerm/requests/network/create_or_update_virtual_network_gateway.rb +151 -0
- data/lib/fog/azurerm/requests/network/create_public_ip.rb +8 -10
- data/lib/fog/azurerm/requests/network/create_subnet.rb +13 -15
- data/lib/fog/azurerm/requests/network/delete_express_route_circuit.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_express_route_circuit_peering.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_load_balancer.rb +8 -7
- data/lib/fog/azurerm/requests/network/delete_network_interface.rb +7 -8
- data/lib/fog/azurerm/requests/network/delete_network_security_group.rb +8 -7
- data/lib/fog/azurerm/requests/network/delete_public_ip.rb +4 -6
- data/lib/fog/azurerm/requests/network/delete_subnet.rb +6 -7
- data/lib/fog/azurerm/requests/network/delete_virtual_network.rb +6 -7
- data/lib/fog/azurerm/requests/network/delete_virtual_network_gateway.rb +28 -0
- data/lib/fog/azurerm/requests/network/detach_network_security_group_from_subnet.rb +15 -17
- data/lib/fog/azurerm/requests/network/detach_resource_from_nic.rb +15 -14
- data/lib/fog/azurerm/requests/network/detach_route_table_from_subnet.rb +15 -17
- data/lib/fog/azurerm/requests/network/get_express_route_circuit.rb +51 -0
- data/lib/fog/azurerm/requests/network/get_express_route_circuit_peering.rb +48 -0
- data/lib/fog/azurerm/requests/network/get_network_interface.rb +7 -7
- data/lib/fog/azurerm/requests/network/get_network_security_group.rb +11 -7
- data/lib/fog/azurerm/requests/network/get_public_ip.rb +41 -0
- data/lib/fog/azurerm/requests/network/get_subnet.rb +10 -9
- data/lib/fog/azurerm/requests/network/get_virtual_network.rb +12 -14
- data/lib/fog/azurerm/requests/network/get_virtual_network_gateway.rb +45 -0
- data/lib/fog/azurerm/requests/network/list_express_route_circuit_peerings.rb +44 -0
- data/lib/fog/azurerm/requests/network/list_express_route_circuits.rb +53 -0
- data/lib/fog/azurerm/requests/network/list_express_route_service_providers.rb +37 -0
- data/lib/fog/azurerm/requests/network/list_load_balancers.rb +6 -6
- data/lib/fog/azurerm/requests/network/list_network_interfaces.rb +42 -37
- data/lib/fog/azurerm/requests/network/list_network_security_groups.rb +149 -143
- data/lib/fog/azurerm/requests/network/list_public_ips.rb +26 -22
- data/lib/fog/azurerm/requests/network/list_subnets.rb +35 -31
- data/lib/fog/azurerm/requests/network/list_virtual_network_gateways.rb +43 -0
- data/lib/fog/azurerm/requests/network/list_virtual_networks.rb +52 -51
- data/lib/fog/azurerm/requests/network/remove_address_prefixes_from_virtual_network.rb +6 -4
- data/lib/fog/azurerm/requests/network/remove_dns_servers_from_virtual_network.rb +6 -4
- data/lib/fog/azurerm/requests/network/remove_security_rule.rb +15 -13
- data/lib/fog/azurerm/requests/network/remove_subnets_from_virtual_network.rb +6 -4
- data/lib/fog/azurerm/requests/resources/create_deployment.rb +27 -21
- data/lib/fog/azurerm/requests/resources/create_resource_group.rb +9 -9
- data/lib/fog/azurerm/requests/resources/delete_deployment.rb +3 -4
- data/lib/fog/azurerm/requests/resources/delete_resource_group.rb +3 -5
- data/lib/fog/azurerm/requests/resources/delete_resource_tag.rb +14 -20
- data/lib/fog/azurerm/requests/resources/list_deployments.rb +8 -7
- data/lib/fog/azurerm/requests/resources/list_resource_groups.rb +27 -23
- data/lib/fog/azurerm/requests/resources/list_tagged_resources.rb +30 -27
- data/lib/fog/azurerm/requests/resources/tag_resource.rb +15 -20
- data/lib/fog/azurerm/requests/storage/check_storage_account_name_availability.rb +13 -15
- data/lib/fog/azurerm/requests/storage/create_container.rb +6 -5
- data/lib/fog/azurerm/requests/storage/create_storage_account.rb +36 -22
- data/lib/fog/azurerm/requests/storage/delete_container.rb +6 -5
- data/lib/fog/azurerm/requests/storage/delete_disk.rb +13 -12
- data/lib/fog/azurerm/requests/storage/delete_storage_account.rb +8 -9
- data/lib/fog/azurerm/requests/storage/get_blob_metadata.rb +10 -9
- data/lib/fog/azurerm/requests/storage/get_container_access_control_list.rb +6 -5
- data/lib/fog/azurerm/requests/storage/get_container_metadata.rb +8 -7
- data/lib/fog/azurerm/requests/storage/get_container_properties.rb +6 -5
- data/lib/fog/azurerm/requests/storage/get_storage_access_keys.rb +7 -7
- data/lib/fog/azurerm/requests/storage/list_containers.rb +6 -5
- data/lib/fog/azurerm/requests/storage/list_storage_account_for_rg.rb +7 -12
- data/lib/fog/azurerm/requests/storage/list_storage_accounts.rb +7 -13
- data/lib/fog/azurerm/requests/storage/set_blob_metadata.rb +8 -7
- data/lib/fog/azurerm/requests/storage/set_container_metadata.rb +8 -7
- data/lib/fog/azurerm/requests/traffic_manager/create_traffic_manager_endpoint.rb +54 -0
- data/lib/fog/azurerm/requests/traffic_manager/create_traffic_manager_profile.rb +107 -0
- data/lib/fog/azurerm/requests/traffic_manager/delete_traffic_manager_endpoint.rb +28 -0
- data/lib/fog/azurerm/requests/traffic_manager/delete_traffic_manager_profile.rb +26 -0
- data/lib/fog/azurerm/requests/traffic_manager/get_traffic_manager_endpoint.rb +39 -0
- data/lib/fog/azurerm/requests/traffic_manager/get_traffic_manager_profile.rb +80 -0
- data/lib/fog/azurerm/requests/traffic_manager/list_traffic_manager_profiles.rb +82 -0
- data/lib/fog/azurerm/storage.rb +1 -1
- data/lib/fog/azurerm/traffic_manager.rb +56 -0
- data/lib/fog/azurerm/utilities/general.rb +28 -0
- data/lib/fog/azurerm/version.rb +1 -1
- data/test/api_stub.rb +14 -7
- data/test/api_stub/models/{network/application_gateway.rb → application_gateway/gateway.rb} +8 -7
- data/test/api_stub/models/compute/availability_set.rb +35 -6
- data/test/api_stub/models/compute/server.rb +15 -16
- data/test/api_stub/models/dns/record_set.rb +20 -0
- data/test/api_stub/models/network/express_route_circuit.rb +47 -0
- data/test/api_stub/models/network/express_route_circuit_peering.rb +33 -0
- data/test/api_stub/models/network/express_route_service_provider.rb +29 -0
- data/test/api_stub/models/network/load_balancer.rb +137 -115
- data/test/api_stub/models/network/network_interface.rb +3 -2
- data/test/api_stub/models/network/network_security_group.rb +4 -3
- data/test/api_stub/models/network/public_ip.rb +5 -4
- data/test/api_stub/models/network/subnet.rb +3 -2
- data/test/api_stub/models/network/virtual_network.rb +3 -2
- data/test/api_stub/models/network/virtual_network_gateway.rb +26 -0
- data/test/api_stub/models/resources/deployment.rb +56 -50
- data/test/api_stub/models/resources/resource.rb +17 -14
- data/test/api_stub/models/resources/resource_group.rb +4 -18
- data/test/api_stub/models/storage/storageaccount.rb +8 -15
- data/test/api_stub/models/{network → traffic_manager}/traffic_manager_end_point.rb +4 -3
- data/test/api_stub/models/{network → traffic_manager}/traffic_manager_profile.rb +4 -3
- data/test/api_stub/requests/application_gateway/gateway.rb +431 -0
- data/test/api_stub/requests/compute/availability_set.rb +34 -23
- data/test/api_stub/requests/compute/virtual_machine.rb +73 -30
- data/test/api_stub/requests/dns/record_set.rb +6 -6
- data/test/api_stub/requests/dns/zone.rb +2 -2
- data/test/api_stub/requests/network/express_route_circuit.rb +100 -0
- data/test/api_stub/requests/network/express_route_circuit_peering.rb +62 -0
- data/test/api_stub/requests/network/express_route_service_provider.rb +30 -0
- data/test/api_stub/requests/network/load_balancer.rb +273 -251
- data/test/api_stub/requests/network/network_interface.rb +12 -16
- data/test/api_stub/requests/network/network_security_group.rb +12 -27
- data/test/api_stub/requests/network/public_ip.rb +7 -9
- data/test/api_stub/requests/network/subnet.rb +6 -8
- data/test/api_stub/requests/network/virtual_network.rb +6 -8
- data/test/api_stub/requests/network/virtual_network_gateway.rb +49 -0
- data/test/api_stub/requests/resources/deployment.rb +56 -11
- data/test/api_stub/requests/resources/resource.rb +6 -8
- data/test/api_stub/requests/resources/resource_group.rb +6 -8
- data/test/api_stub/requests/storage/storageaccount.rb +44 -31
- data/test/api_stub/requests/traffic_manager/traffic_manager_endpoint.rb +41 -0
- data/test/api_stub/requests/{network → traffic_manager}/traffic_manager_profile.rb +7 -5
- data/test/integration/application_gateway.rb +16 -8
- data/test/integration/availability_set.rb +1 -1
- data/test/integration/container.rb +2 -1
- data/test/integration/deployment.rb +54 -0
- data/test/integration/express_route_circuit.rb +80 -0
- data/test/integration/external_load_balancer.rb +7 -6
- data/test/integration/internal_load_balancer.rb +6 -5
- data/test/integration/network_interface.rb +2 -2
- data/test/integration/public_ip.rb +2 -2
- data/test/integration/record_set.rb +26 -8
- data/test/integration/resource_group.rb +39 -0
- data/test/integration/resource_tag.rb +62 -0
- data/test/integration/server.rb +6 -4
- data/test/integration/storage_account.rb +33 -5
- data/test/integration/subnet.rb +2 -2
- data/test/integration/traffic_manager.rb +12 -12
- data/test/integration/virtual_network.rb +6 -6
- data/test/integration/virtual_network_gateway.rb +101 -0
- data/test/integration/zone.rb +1 -1
- data/test/models/application_gateway/test_gateway.rb +57 -0
- data/test/models/{network/test_application_gateways.rb → application_gateway/test_gateways.rb} +10 -10
- data/test/models/compute/test_availability_set.rb +2 -1
- data/test/models/compute/test_availability_sets.rb +5 -4
- data/test/models/compute/test_server.rb +6 -5
- data/test/models/compute/test_servers.rb +3 -2
- data/test/models/dns/test_record_set.rb +27 -1
- data/test/models/dns/test_record_sets.rb +3 -2
- data/test/models/dns/test_zone.rb +1 -1
- data/test/models/dns/test_zones.rb +2 -1
- data/test/models/network/test_express_route_circuit.rb +58 -0
- data/test/models/network/test_express_route_circuit_peering.rb +59 -0
- data/test/models/network/test_express_route_circuit_peerings.rb +43 -0
- data/test/models/network/test_express_route_circuits.rb +42 -0
- data/test/models/network/test_express_route_service_providers.rb +30 -0
- data/test/models/network/test_load_balancer.rb +7 -12
- data/test/models/network/test_load_balancers.rb +4 -4
- data/test/models/network/test_network_interface.rb +10 -16
- data/test/models/network/test_network_interfaces.rb +3 -2
- data/test/models/network/test_network_security_group.rb +6 -8
- data/test/models/network/test_network_security_groups.rb +2 -1
- data/test/models/network/test_public_ip.rb +5 -6
- data/test/models/network/test_public_ips.rb +6 -6
- data/test/models/network/test_subnet.rb +9 -15
- data/test/models/network/test_subnets.rb +3 -2
- data/test/models/network/test_virtual_network.rb +10 -16
- data/test/models/network/test_virtual_network_gateway.rb +62 -0
- data/test/models/network/test_virtual_network_gateways.rb +42 -0
- data/test/models/network/test_virtual_networks.rb +3 -2
- data/test/models/resources/test_deployment.rb +2 -1
- data/test/models/resources/test_deployments.rb +2 -1
- data/test/models/resources/test_resource_group.rb +2 -1
- data/test/models/resources/test_resource_groups.rb +2 -1
- data/test/models/resources/test_resources.rb +2 -1
- data/test/models/storage/test_data_disk.rb +0 -6
- data/test/models/storage/test_storage_account.rb +29 -8
- data/test/models/storage/test_storage_accounts.rb +5 -5
- data/test/models/{network → traffic_manager}/test_traffic_manager_end_point.rb +4 -3
- data/test/models/traffic_manager/test_traffic_manager_end_points.rb +43 -0
- data/test/models/{network → traffic_manager}/test_traffic_manager_profile.rb +5 -4
- data/test/models/traffic_manager/test_traffic_manager_profiles.rb +42 -0
- data/test/requests/application_gateway/test_create_application_gateway.rb +51 -0
- data/test/requests/application_gateway/test_delete_application_gateway.rb +23 -0
- data/test/requests/application_gateway/test_list_application_gateways.rb +24 -0
- data/test/requests/compute/test_attach_data_disk_to_vm.rb +40 -123
- data/test/requests/compute/test_create_availability_set.rb +9 -11
- data/test/requests/compute/test_create_virtual_machine.rb +13 -29
- data/test/requests/compute/test_deallocate_virtual_machine.rb +7 -13
- data/test/requests/compute/test_delete_availability_set.rb +5 -11
- data/test/requests/compute/test_delete_virtual_machine.rb +7 -13
- data/test/requests/compute/test_detach_data_disk_from_vm.rb +13 -34
- data/test/requests/compute/test_generalize_virtual_machine.rb +7 -13
- data/test/requests/compute/test_get_availability_set.rb +24 -0
- data/test/requests/compute/test_get_virtual_machine.rb +8 -15
- data/test/requests/compute/test_get_vm_status.rb +8 -14
- data/test/requests/compute/test_list_availability_sets.rb +8 -14
- data/test/requests/compute/test_list_available_sizes_for_virtual_machine.rb +8 -15
- data/test/requests/compute/test_list_virtual_machines.rb +8 -14
- data/test/requests/compute/test_power_off_virtual_machine.rb +7 -13
- data/test/requests/compute/test_redeploy_virtual_machine.rb +7 -13
- data/test/requests/compute/test_restart_virtual_machine.rb +7 -13
- data/test/requests/compute/test_start_virtual_machine.rb +7 -13
- data/test/requests/dns/test_create_record_set.rb +8 -8
- data/test/requests/dns/test_create_zone.rb +6 -6
- data/test/requests/dns/test_delete_record_set.rb +2 -2
- data/test/requests/dns/test_delete_zone.rb +2 -2
- data/test/requests/dns/test_get_record_set.rb +46 -0
- data/test/requests/dns/test_get_zone.rb +46 -0
- data/test/requests/network/test_add_address_prefixes_in_virtual_network.rb +11 -27
- data/test/requests/network/test_add_dns_servers_in_virtual_network.rb +11 -27
- data/test/requests/network/test_add_security_rules.rb +11 -31
- data/test/requests/network/test_add_subnets_in_virtual_network.rb +11 -27
- data/test/requests/network/test_attach_network_security_group_to_subnet.rb +9 -16
- data/test/requests/network/test_attach_resource_to_nic.rb +15 -37
- data/test/requests/network/test_attach_route_table_to_subnet.rb +9 -16
- data/test/requests/network/test_check_for_public_ip.rb +10 -18
- data/test/requests/network/test_check_for_virtual_network.rb +10 -18
- data/test/requests/network/test_create_express_route_circuit.rb +39 -0
- data/test/requests/network/test_create_express_route_circuit_peering.rb +37 -0
- data/test/requests/network/test_create_load_balancer.rb +27 -34
- data/test/requests/network/test_create_network_interface.rb +16 -28
- data/test/requests/network/test_create_or_update_network_security_group.rb +38 -0
- data/test/requests/network/test_create_or_update_virtual_network.rb +20 -28
- data/test/requests/network/test_create_public_ip.rb +13 -22
- data/test/requests/network/test_create_subnet.rb +13 -22
- data/test/requests/network/test_create_virtual_network_gateway.rb +37 -0
- data/test/requests/network/test_delete_express_route_circuit.rb +24 -0
- data/test/requests/network/test_delete_express_route_circuit_peering.rb +24 -0
- data/test/requests/network/test_delete_load_balancer.rb +7 -13
- data/test/requests/network/test_delete_network_interface.rb +7 -13
- data/test/requests/network/test_delete_network_security_group.rb +6 -13
- data/test/requests/network/test_delete_public_ip.rb +7 -13
- data/test/requests/network/test_delete_subnet.rb +7 -13
- data/test/requests/network/test_delete_virtual_network.rb +7 -13
- data/test/requests/network/test_delete_virtual_network_gateway.rb +24 -0
- data/test/requests/network/test_detach_network_security_group_from_subnet.rb +9 -16
- data/test/requests/network/test_detach_resource_from_nic.rb +15 -34
- data/test/requests/network/test_detach_route_table_from_subnet.rb +9 -16
- data/test/requests/network/test_get_express_route_circuit.rb +24 -0
- data/test/requests/network/test_get_express_route_circuit_peering.rb +24 -0
- data/test/requests/network/test_get_network_interface.rb +8 -15
- data/test/requests/network/test_get_network_security_group.rb +9 -16
- data/test/requests/network/test_get_public_ip.rb +26 -0
- data/test/requests/network/test_get_subnet.rb +9 -16
- data/test/requests/network/test_get_virtual_network.rb +26 -0
- data/test/requests/network/test_get_virtual_network_gateway.rb +24 -0
- data/test/requests/network/test_list_express_route_circuit_peerings.rb +24 -0
- data/test/requests/network/test_list_express_route_circuits.rb +26 -0
- data/test/requests/network/test_list_express_route_service_providers.rb +24 -0
- data/test/requests/network/test_list_load_balancers.rb +8 -15
- data/test/requests/network/test_list_network_interfaces.rb +8 -15
- data/test/requests/network/test_list_network_security_groups.rb +9 -16
- data/test/requests/network/test_list_public_ips.rb +8 -15
- data/test/requests/network/test_list_subnets.rb +8 -15
- data/test/requests/network/test_list_virtual_network_gateways.rb +24 -0
- data/test/requests/network/test_list_virtual_networks.rb +8 -15
- data/test/requests/network/test_remove_address_prefixes_from_virtual_network.rb +11 -27
- data/test/requests/network/test_remove_dns_servers_from_virtual_network.rb +11 -27
- data/test/requests/network/test_remove_security_rule.rb +11 -31
- data/test/requests/network/test_remove_subnets_from_virtual_network.rb +11 -27
- data/test/requests/resources/test_create_deployment.rb +10 -27
- data/test/requests/resources/test_create_resource_group.rb +8 -15
- data/test/requests/resources/test_delete_deployment.rb +5 -11
- data/test/requests/resources/test_delete_resource_group.rb +8 -14
- data/test/requests/resources/test_delete_resource_tag.rb +12 -28
- data/test/requests/resources/test_list_deployments.rb +8 -15
- data/test/requests/resources/test_list_resource_groups.rb +8 -15
- data/test/requests/resources/test_list_tagged_resources.rb +8 -15
- data/test/requests/resources/test_tag_resource.rb +12 -28
- data/test/requests/storage/test_check_storage_account_name_availability.rb +14 -29
- data/test/requests/storage/test_create_storage_account.rb +13 -35
- data/test/requests/storage/test_delete_storage_account.rb +8 -14
- data/test/requests/storage/test_get_storage_access_keys.rb +7 -14
- data/test/requests/storage/test_list_storage_accounts.rb +12 -22
- data/test/requests/storage/test_list_storage_accounts_for_rg.rb +15 -29
- data/test/requests/traffic_manager/test_create_traffic_manager_endpoint.rb +25 -0
- data/test/requests/traffic_manager/test_create_traffic_manager_profile.rb +25 -0
- data/test/requests/traffic_manager/test_delete_traffic_manager_endpoint.rb +23 -0
- data/test/requests/traffic_manager/test_delete_traffic_manager_profile.rb +23 -0
- data/test/requests/traffic_manager/test_get_traffic_manager_endpoint.rb +24 -0
- data/test/requests/traffic_manager/test_get_traffic_manager_profile.rb +24 -0
- data/test/requests/traffic_manager/test_list_traffic_manager_profiles.rb +24 -0
- data/test/test_helper.rb +113 -4
- metadata +147 -86
- data/lib/fog/azurerm/models/network/application_gateway_backend_address_pool.rb +0 -24
- data/lib/fog/azurerm/models/network/application_gateway_backend_http_setting.rb +0 -30
- data/lib/fog/azurerm/models/network/application_gateway_frontend_ip_configuration.rb +0 -30
- data/lib/fog/azurerm/models/network/application_gateway_frontend_port.rb +0 -22
- data/lib/fog/azurerm/models/network/application_gateway_http_listener.rb +0 -37
- data/lib/fog/azurerm/models/network/application_gateway_ip_configuration.rb +0 -21
- data/lib/fog/azurerm/models/network/application_gateway_probe.rb +0 -32
- data/lib/fog/azurerm/models/network/application_gateway_request_routing_rule.rb +0 -35
- data/lib/fog/azurerm/models/network/application_gateway_ssl_certificate.rb +0 -26
- data/lib/fog/azurerm/models/network/application_gateway_url_path_map.rb +0 -32
- data/lib/fog/azurerm/models/network/traffic_manager_end_point.rb +0 -63
- data/lib/fog/azurerm/models/network/traffic_manager_end_points.rb +0 -29
- data/lib/fog/azurerm/models/network/traffic_manager_profile.rb +0 -59
- data/lib/fog/azurerm/models/network/traffic_manager_profiles.rb +0 -24
- data/lib/fog/azurerm/requests/network/create_traffic_manager_endpoint.rb +0 -78
- data/lib/fog/azurerm/requests/network/create_traffic_manager_profile.rb +0 -127
- data/lib/fog/azurerm/requests/network/delete_application_gateway.rb +0 -27
- data/lib/fog/azurerm/requests/network/delete_traffic_manager_endpoint.rb +0 -37
- data/lib/fog/azurerm/requests/network/delete_traffic_manager_profile.rb +0 -37
- data/lib/fog/azurerm/requests/network/get_traffic_manager_profile.rb +0 -96
- data/lib/fog/azurerm/requests/network/list_application_gateways.rb +0 -31
- data/lib/fog/azurerm/requests/network/list_traffic_manager_profiles.rb +0 -98
- data/test/api_stub/models/storage/data_disk.rb +0 -30
- data/test/api_stub/requests/network/application_gateway.rb +0 -433
- data/test/api_stub/requests/network/traffic_manager_endpoint.rb +0 -25
- data/test/models/network/test_application_gateway.rb +0 -62
- data/test/models/network/test_traffic_manager_end_points.rb +0 -42
- data/test/models/network/test_traffic_manager_profiles.rb +0 -41
- data/test/requests/network/test_create_application_gateway.rb +0 -61
- data/test/requests/network/test_create_network_security_group.rb +0 -45
- data/test/requests/network/test_create_traffic_manager_endpoint.rb +0 -32
- data/test/requests/network/test_create_traffic_manager_profile.rb +0 -32
- data/test/requests/network/test_delete_application_gateway.rb +0 -30
- data/test/requests/network/test_delete_traffic_manager_endpoint.rb +0 -28
- data/test/requests/network/test_delete_traffic_manager_profile.rb +0 -28
- data/test/requests/network/test_get_traffic_manager_profile.rb +0 -29
- data/test/requests/network/test_list_application_gateways.rb +0 -31
- data/test/requests/network/test_list_traffic_manager_profiles.rb +0 -29
@@ -12,15 +12,15 @@ module Fog
|
|
12
12
|
attribute :platform_update_domain_count
|
13
13
|
attribute :platform_fault_domain_count
|
14
14
|
|
15
|
-
def self.parse(
|
15
|
+
def self.parse(availability_set)
|
16
16
|
hash = {}
|
17
|
-
hash['id'] =
|
18
|
-
hash['name'] =
|
19
|
-
hash['type'] =
|
20
|
-
hash['location'] =
|
21
|
-
hash['resource_group'] =
|
22
|
-
hash['platform_update_domain_count'] =
|
23
|
-
hash['platform_fault_domain_count'] =
|
17
|
+
hash['id'] = availability_set.id
|
18
|
+
hash['name'] = availability_set.name
|
19
|
+
hash['type'] = availability_set.type
|
20
|
+
hash['location'] = availability_set.location
|
21
|
+
hash['resource_group'] = get_resource_group_from_id(availability_set.id)
|
22
|
+
hash['platform_update_domain_count'] = availability_set.platform_update_domain_count
|
23
|
+
hash['platform_fault_domain_count'] = availability_set.platform_fault_domain_count
|
24
24
|
hash
|
25
25
|
end
|
26
26
|
|
@@ -23,7 +23,9 @@ module Fog
|
|
23
23
|
end
|
24
24
|
|
25
25
|
def get(resource_group, identity)
|
26
|
-
|
26
|
+
availability_set = service.get_availability_set(resource_group, identity)
|
27
|
+
availability_set_obj = Fog::Compute::AzureRM::AvailabilitySet.new(service: service)
|
28
|
+
availability_set_obj.merge_attributes(Fog::Compute::AzureRM::AvailabilitySet.parse(availability_set))
|
27
29
|
end
|
28
30
|
end
|
29
31
|
end
|
@@ -31,37 +31,33 @@ module Fog
|
|
31
31
|
|
32
32
|
def self.parse(vm)
|
33
33
|
hash = {}
|
34
|
-
hash['id'] = vm
|
35
|
-
hash['name'] = vm
|
36
|
-
hash['location'] = vm
|
37
|
-
hash['resource_group'] = vm
|
38
|
-
hash['vm_size'] = vm
|
39
|
-
hash['os_disk_name'] = vm
|
40
|
-
hash['os_disk_vhd_uri'] = vm
|
41
|
-
hash['publisher'] = vm
|
42
|
-
hash['offer'] = vm
|
43
|
-
hash['sku'] = vm
|
44
|
-
hash['version'] = vm
|
45
|
-
hash['username'] = vm
|
34
|
+
hash['id'] = vm.id
|
35
|
+
hash['name'] = vm.name
|
36
|
+
hash['location'] = vm.location
|
37
|
+
hash['resource_group'] = get_resource_group_from_id(vm.id)
|
38
|
+
hash['vm_size'] = vm.hardware_profile.vm_size
|
39
|
+
hash['os_disk_name'] = vm.storage_profile.os_disk.name
|
40
|
+
hash['os_disk_vhd_uri'] = vm.storage_profile.os_disk.vhd.uri
|
41
|
+
hash['publisher'] = vm.storage_profile.image_reference.publisher
|
42
|
+
hash['offer'] = vm.storage_profile.image_reference.offer
|
43
|
+
hash['sku'] = vm.storage_profile.image_reference.sku
|
44
|
+
hash['version'] = vm.storage_profile.image_reference.version
|
45
|
+
hash['username'] = vm.os_profile.admin_username
|
46
46
|
hash['data_disks'] = []
|
47
47
|
|
48
|
-
vm
|
48
|
+
vm.storage_profile.data_disks.each do |disk|
|
49
49
|
data_disk = Fog::Storage::AzureRM::DataDisk.new
|
50
50
|
hash['data_disks'] << data_disk.merge_attributes(Fog::Storage::AzureRM::DataDisk.parse(disk))
|
51
|
-
end unless vm
|
52
|
-
|
53
|
-
hash['disable_password_authentication'] =
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
end
|
59
|
-
if vm['properties']['osProfile']['windowsConfiguration']
|
60
|
-
hash['provision_vm_agent'] = vm['properties']['osProfile']['windowsConfiguration']['provisionVMAgent']
|
61
|
-
hash['enable_automatic_updates'] = vm['properties']['osProfile']['windowsConfiguration']['enableAutomaticUpdates']
|
51
|
+
end unless vm.storage_profile.data_disks.nil?
|
52
|
+
|
53
|
+
hash['disable_password_authentication'] = false
|
54
|
+
hash['disable_password_authentication'] = vm.os_profile.linux_configuration.disable_password_authentication unless vm.os_profile.linux_configuration.nil?
|
55
|
+
if vm.os_profile.windows_configuration
|
56
|
+
hash['provision_vm_agent'] = vm.os_profile.windows_configuration.provision_vmagent
|
57
|
+
hash['enable_automatic_updates'] = vm.os_profile.windows_configuration.enable_automatic_updates
|
62
58
|
end
|
63
|
-
hash['network_interface_card_id'] = vm[
|
64
|
-
hash['availability_set_id'] = vm
|
59
|
+
hash['network_interface_card_id'] = vm.network_profile.network_interfaces[0].id
|
60
|
+
hash['availability_set_id'] = vm.availability_set.id unless vm.availability_set.nil?
|
65
61
|
hash
|
66
62
|
end
|
67
63
|
|
@@ -69,15 +65,9 @@ module Fog
|
|
69
65
|
requires :name, :location, :resource_group, :vm_size, :storage_account_name,
|
70
66
|
:username, :password, :network_interface_card_id, :publisher, :offer, :sku, :version
|
71
67
|
requires :disable_password_authentication if platform.casecmp('linux') == 0
|
72
|
-
|
73
68
|
ssh_key_path = "/home/#{username}/.ssh/authorized_keys" unless ssh_key_data.nil?
|
74
|
-
|
75
|
-
|
76
|
-
username, password, disable_password_authentication,
|
77
|
-
ssh_key_path, ssh_key_data, network_interface_card_id,
|
78
|
-
availability_set_id, publisher, offer, sku, version,
|
79
|
-
platform, provision_vm_agent, enable_automatic_updates
|
80
|
-
)
|
69
|
+
virtual_machine_params = get_virtual_machine_params(ssh_key_path)
|
70
|
+
vm = service.create_virtual_machine(virtual_machine_params)
|
81
71
|
merge_attributes(Fog::Compute::AzureRM::Server.parse(vm))
|
82
72
|
end
|
83
73
|
|
@@ -126,6 +116,32 @@ module Fog
|
|
126
116
|
vm = service.detach_data_disk_from_vm(resource_group, name, disk_name)
|
127
117
|
merge_attributes(Fog::Compute::AzureRM::Server.parse(vm))
|
128
118
|
end
|
119
|
+
|
120
|
+
private
|
121
|
+
|
122
|
+
def get_virtual_machine_params(ssh_key_path)
|
123
|
+
{
|
124
|
+
resource_group: resource_group,
|
125
|
+
name: name,
|
126
|
+
location: location,
|
127
|
+
vm_size: vm_size,
|
128
|
+
storage_account_name: storage_account_name,
|
129
|
+
username: username,
|
130
|
+
password: password,
|
131
|
+
disable_password_authentication: disable_password_authentication,
|
132
|
+
ssh_key_path: ssh_key_path,
|
133
|
+
ssh_key_data: ssh_key_data,
|
134
|
+
network_interface_card_id: network_interface_card_id,
|
135
|
+
availability_set_id: availability_set_id,
|
136
|
+
publisher: publisher,
|
137
|
+
offer: offer,
|
138
|
+
sku: sku,
|
139
|
+
version: version,
|
140
|
+
platform: platform,
|
141
|
+
provision_vm_agent: provision_vm_agent,
|
142
|
+
enable_automatic_updates: enable_automatic_updates
|
143
|
+
}
|
144
|
+
end
|
129
145
|
end
|
130
146
|
end
|
131
147
|
end
|
@@ -25,6 +25,17 @@ module Fog
|
|
25
25
|
hash['zone_name'] = recordset['id'].split('/')[8]
|
26
26
|
hash['type'] = recordset['type']
|
27
27
|
type = recordset['type'].split('/')[2]
|
28
|
+
hash['records'] = []
|
29
|
+
if type == 'A'
|
30
|
+
record_entries = recordset['properties']['ARecords']
|
31
|
+
record_entries.each do |record|
|
32
|
+
hash['records'] << record['ipv4Address']
|
33
|
+
end
|
34
|
+
end
|
35
|
+
if type == 'CNAME'
|
36
|
+
record_entries = recordset['properties']['CNAMERecord']['cname']
|
37
|
+
hash['records'] << record_entries
|
38
|
+
end
|
28
39
|
hash['a_record'] = recordset['properties']['ARecords'] if type == 'A'
|
29
40
|
hash['cname_record'] = recordset['properties']['CNAMERecord'] if type == 'CNAME'
|
30
41
|
hash['ttl'] = recordset['properties']['TTL']
|
@@ -39,17 +50,34 @@ module Fog
|
|
39
50
|
requires :records
|
40
51
|
requires :type
|
41
52
|
requires :ttl
|
42
|
-
record_set = service.
|
53
|
+
record_set = service.create_or_update_record_set(resource_group, name, zone_name, records, type, ttl)
|
43
54
|
merge_attributes(Fog::DNS::AzureRM::RecordSet.parse(record_set))
|
44
55
|
end
|
45
56
|
|
46
57
|
def destroy
|
47
|
-
service.delete_record_set(resource_group, name, zone_name, type
|
58
|
+
service.delete_record_set(resource_group, name, zone_name, get_record_type(type))
|
48
59
|
end
|
49
60
|
|
50
61
|
def get_records(resource_group, name, zone_name, record_type)
|
51
62
|
service.get_records_from_record_set(resource_group, name, zone_name, record_type)
|
52
63
|
end
|
64
|
+
|
65
|
+
def update_ttl(ttl)
|
66
|
+
record_set = service.create_or_update_record_set(resource_group, name, zone_name, records, get_record_type(type), ttl)
|
67
|
+
merge_attributes(Fog::DNS::AzureRM::RecordSet.parse(record_set))
|
68
|
+
end
|
69
|
+
|
70
|
+
def add_a_type_record(record)
|
71
|
+
records << record
|
72
|
+
record_set = service.create_or_update_record_set(resource_group, name, zone_name, records, get_record_type(type), ttl)
|
73
|
+
merge_attributes(Fog::DNS::AzureRM::RecordSet.parse(record_set))
|
74
|
+
end
|
75
|
+
|
76
|
+
def remove_a_type_record(record)
|
77
|
+
records.delete(record)
|
78
|
+
record_set = service.create_or_update_record_set(resource_group, name, zone_name, records, get_record_type(type), ttl)
|
79
|
+
merge_attributes(Fog::DNS::AzureRM::RecordSet.parse(record_set))
|
80
|
+
end
|
53
81
|
end
|
54
82
|
end
|
55
83
|
end
|
@@ -23,8 +23,10 @@ module Fog
|
|
23
23
|
load(record_sets)
|
24
24
|
end
|
25
25
|
|
26
|
-
def get(
|
27
|
-
|
26
|
+
def get(resource_group, name, zone_name, record_type)
|
27
|
+
record_set = service.get_record_set(resource_group, name, zone_name, record_type)
|
28
|
+
record_set_obj = Fog::DNS::AzureRM::RecordSet.new(service: service)
|
29
|
+
record_set_obj.merge_attributes(Fog::DNS::AzureRM::RecordSet.parse(record_set))
|
28
30
|
end
|
29
31
|
end
|
30
32
|
end
|
@@ -17,8 +17,10 @@ module Fog
|
|
17
17
|
load(zones)
|
18
18
|
end
|
19
19
|
|
20
|
-
def get(resource_group,
|
21
|
-
|
20
|
+
def get(resource_group, name)
|
21
|
+
zone = service.get_zone(resource_group, name)
|
22
|
+
zone_obj = Fog::DNS::AzureRM::Zone.new(service: service)
|
23
|
+
zone_obj.merge_attributes(Fog::DNS::AzureRM::Zone.parse(zone))
|
22
24
|
end
|
23
25
|
|
24
26
|
def check_for_zone(resource_group, name)
|
@@ -0,0 +1,89 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class AzureRM
|
4
|
+
# Express Route Circuit model class for Network Service
|
5
|
+
class ExpressRouteCircuit < Fog::Model
|
6
|
+
identity :name
|
7
|
+
attribute :id
|
8
|
+
attribute :location
|
9
|
+
attribute :resource_group
|
10
|
+
attribute :tags
|
11
|
+
attribute :sku_name
|
12
|
+
attribute :sku_tier
|
13
|
+
attribute :sku_family
|
14
|
+
attribute :service_provider_name
|
15
|
+
attribute :provisioning_state
|
16
|
+
attribute :circuit_provisioning_state
|
17
|
+
attribute :service_provider_provisioning_state
|
18
|
+
attribute :service_key
|
19
|
+
attribute :service_provider_notes
|
20
|
+
attribute :peering_location
|
21
|
+
attribute :bandwidth_in_mbps
|
22
|
+
attribute :peerings
|
23
|
+
|
24
|
+
def self.parse(circuit)
|
25
|
+
hash = {}
|
26
|
+
hash['id'] = circuit.id
|
27
|
+
hash['name'] = circuit.name
|
28
|
+
hash['location'] = circuit.location
|
29
|
+
hash['service_key'] = circuit.service_key
|
30
|
+
hash['service_provider_notes'] = circuit.service_provider_notes
|
31
|
+
hash['resource_group'] = get_resource_group_from_id(circuit.id)
|
32
|
+
hash['resource_group'] = circuit.id.split('/')[4]
|
33
|
+
hash['tags'] = circuit.tags
|
34
|
+
sku = circuit.sku
|
35
|
+
unless sku.nil?
|
36
|
+
hash['sku_name'] = sku.name
|
37
|
+
hash['sku_tier'] = sku.tier
|
38
|
+
hash['sku_family'] = sku.family
|
39
|
+
end
|
40
|
+
hash['provisioning_state'] = circuit.provisioning_state
|
41
|
+
hash['circuit_provisioning_state'] = circuit.circuit_provisioning_state
|
42
|
+
hash['service_provider_provisioning_state'] = circuit.service_provider_provisioning_state
|
43
|
+
service_provider_properties = circuit.service_provider_properties
|
44
|
+
unless service_provider_properties.nil?
|
45
|
+
hash['service_provider_name'] = service_provider_properties.service_provider_name
|
46
|
+
hash['peering_location'] = service_provider_properties.peering_location
|
47
|
+
hash['bandwidth_in_mbps'] = service_provider_properties.bandwidth_in_mbps
|
48
|
+
end
|
49
|
+
hash['peerings'] = []
|
50
|
+
circuit.peerings.each do |peering|
|
51
|
+
circuit_peering = Fog::Network::AzureRM::ExpressRouteCircuitPeering.new
|
52
|
+
hash['peerings'] << circuit_peering.merge_attributes(Fog::Network::AzureRM::ExpressRouteCircuitPeering.parse(peering))
|
53
|
+
end unless circuit.peerings.nil?
|
54
|
+
hash
|
55
|
+
end
|
56
|
+
|
57
|
+
def save
|
58
|
+
requires :location, :tags, :resource_group, :service_provider_name, :peering_location, :bandwidth_in_mbps
|
59
|
+
express_route_parameters = express_route_circuit_params
|
60
|
+
circuit = service.create_or_update_express_route_circuit(express_route_parameters)
|
61
|
+
merge_attributes(Fog::Network::AzureRM::ExpressRouteCircuit.parse(circuit))
|
62
|
+
end
|
63
|
+
|
64
|
+
def destroy
|
65
|
+
service.delete_express_route_circuit(resource_group, name)
|
66
|
+
end
|
67
|
+
|
68
|
+
private
|
69
|
+
|
70
|
+
def express_route_circuit_params
|
71
|
+
express_route_parameters = {
|
72
|
+
resource_group_name: resource_group,
|
73
|
+
circuit_name: name,
|
74
|
+
location: location,
|
75
|
+
tags: tags,
|
76
|
+
sku_name: sku_name,
|
77
|
+
sku_tier: sku_tier,
|
78
|
+
sku_family: sku_family,
|
79
|
+
service_provider_name: service_provider_name,
|
80
|
+
peering_location: peering_location,
|
81
|
+
bandwidth_in_mbps: bandwidth_in_mbps,
|
82
|
+
peerings: peerings
|
83
|
+
}
|
84
|
+
express_route_parameters
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
@@ -0,0 +1,93 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class AzureRM
|
4
|
+
# Express Route Circuit model class for Network Service
|
5
|
+
class ExpressRouteCircuitPeering < Fog::Model
|
6
|
+
identity :name
|
7
|
+
attribute :id
|
8
|
+
attribute :resource_group
|
9
|
+
attribute :etag
|
10
|
+
attribute :circuit_name
|
11
|
+
attribute :provisioning_state
|
12
|
+
attribute :peering_type
|
13
|
+
attribute :shared_key
|
14
|
+
attribute :azure_asn
|
15
|
+
attribute :peer_asn
|
16
|
+
attribute :primary_peer_address_prefix
|
17
|
+
attribute :secondary_peer_address_prefix
|
18
|
+
attribute :primary_azure_port
|
19
|
+
attribute :secondary_azure_port
|
20
|
+
attribute :state
|
21
|
+
attribute :vlan_id
|
22
|
+
attribute :advertised_public_prefixes
|
23
|
+
attribute :advertised_public_prefix_state
|
24
|
+
attribute :customer_asn
|
25
|
+
attribute :routing_registry_name
|
26
|
+
|
27
|
+
def self.parse(circuit_peering)
|
28
|
+
hash = {}
|
29
|
+
hash['id'] = circuit_peering.id
|
30
|
+
hash['name'] = circuit_peering.name
|
31
|
+
hash['resource_group'] = get_resource_group_from_id(circuit_peering.id)
|
32
|
+
hash['circuit_name'] = circuit_peering.id.split('/')[8]
|
33
|
+
hash['provisioning_state'] = circuit_peering.provisioning_state
|
34
|
+
hash['peering_type'] = circuit_peering.peering_type
|
35
|
+
hash['peer_asn'] = circuit_peering.peer_asn
|
36
|
+
hash['azure_asn'] = circuit_peering.azure_asn
|
37
|
+
hash['primary_azure_port'] = circuit_peering.primary_azure_port
|
38
|
+
hash['secondary_azure_port'] = circuit_peering.secondary_azure_port
|
39
|
+
hash['state'] = circuit_peering.state
|
40
|
+
hash['primary_peer_address_prefix'] = circuit_peering.primary_peer_address_prefix
|
41
|
+
hash['secondary_peer_address_prefix'] = circuit_peering.secondary_peer_address_prefix
|
42
|
+
hash['vlan_id'] = circuit_peering.vlan_id
|
43
|
+
|
44
|
+
microsoft_peering_config = circuit_peering.microsoft_peering_config
|
45
|
+
unless microsoft_peering_config.nil?
|
46
|
+
public_prefixes = microsoft_peering_config.advertised_public_prefixes
|
47
|
+
hash['advertised_public_prefixes'] = []
|
48
|
+
public_prefixes.each do |public_prefix|
|
49
|
+
hash['advertised_public_prefixes'] << public_prefix
|
50
|
+
end unless public_prefixes.nil?
|
51
|
+
|
52
|
+
hash['advertised_public_prefix_state'] = microsoft_peering_config.advertised_public_prefixes_state
|
53
|
+
hash['customer_asn'] = microsoft_peering_config.customer_asn
|
54
|
+
hash['routing_registry_name'] = microsoft_peering_config.routing_registry_name
|
55
|
+
end
|
56
|
+
hash
|
57
|
+
end
|
58
|
+
|
59
|
+
def save
|
60
|
+
requires :name, :resource_group, :circuit_name, :peering_type, :peer_asn, :primary_peer_address_prefix, :secondary_peer_address_prefix, :vlan_id
|
61
|
+
requires :advertised_public_prefixes if peering_type.casecmp(MICROSOFT_PEERING) == 0
|
62
|
+
circuit_peering_parameters = express_route_circuit_peering_params
|
63
|
+
circuit_peering = service.create_or_update_express_route_circuit_peering(circuit_peering_parameters)
|
64
|
+
merge_attributes(Fog::Network::AzureRM::ExpressRouteCircuitPeering.parse(circuit_peering))
|
65
|
+
end
|
66
|
+
|
67
|
+
def destroy
|
68
|
+
service.delete_express_route_circuit_peering(resource_group, name, circuit_name)
|
69
|
+
end
|
70
|
+
|
71
|
+
private
|
72
|
+
|
73
|
+
def express_route_circuit_peering_params
|
74
|
+
circuit_peering_parameters = {
|
75
|
+
resource_group_name: resource_group,
|
76
|
+
peering_name: name,
|
77
|
+
circuit_name: circuit_name,
|
78
|
+
peering_type: peering_type,
|
79
|
+
peer_asn: peer_asn,
|
80
|
+
primary_peer_address_prefix: primary_peer_address_prefix,
|
81
|
+
secondary_peer_address_prefix: secondary_peer_address_prefix,
|
82
|
+
vlan_id: vlan_id,
|
83
|
+
advertised_public_prefixes: advertised_public_prefixes,
|
84
|
+
advertised_public_prefix_state: advertised_public_prefix_state,
|
85
|
+
customer_asn: customer_asn,
|
86
|
+
routing_registry_name: routing_registry_name
|
87
|
+
}
|
88
|
+
circuit_peering_parameters
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
93
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/azurerm/models/network/express_route_circuit_peering'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Network
|
6
|
+
class AzureRM
|
7
|
+
# ExpressRouteCircuitPeering collection class for Network Service
|
8
|
+
class ExpressRouteCircuitPeerings < Fog::Collection
|
9
|
+
model Fog::Network::AzureRM::ExpressRouteCircuitPeering
|
10
|
+
attribute :resource_group
|
11
|
+
attribute :circuit_name
|
12
|
+
|
13
|
+
def all
|
14
|
+
requires :resource_group
|
15
|
+
requires :circuit_name
|
16
|
+
circuit_peerings = []
|
17
|
+
service.list_express_route_circuit_peerings(resource_group, circuit_name).each do |circuit_peering|
|
18
|
+
circuit_peerings << Fog::Network::AzureRM::ExpressRouteCircuitPeering.parse(circuit_peering)
|
19
|
+
end
|
20
|
+
load(circuit_peerings)
|
21
|
+
end
|
22
|
+
|
23
|
+
def get(resource_group_name, peering_name, circuit_name)
|
24
|
+
circuit_peering = service.get_express_route_circuit_peering(resource_group_name, peering_name, circuit_name)
|
25
|
+
express_route_circuit_peering = Fog::Network::AzureRM::ExpressRouteCircuitPeering.new(service: service)
|
26
|
+
express_route_circuit_peering.merge_attributes(Fog::Network::AzureRM::ExpressRouteCircuitPeering.parse(circuit_peering))
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|