diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql.rb index 40b6ad68a6..1964299cc8 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql.rb @@ -26,44 +26,47 @@ module Azure::ARM::SQL autoload :Servers, 'generated/azure_mgmt_sql/servers.rb' autoload :ElasticPools, 'generated/azure_mgmt_sql/elastic_pools.rb' autoload :RecommendedElasticPools, 'generated/azure_mgmt_sql/recommended_elastic_pools.rb' + autoload :Operations, 'generated/azure_mgmt_sql/operations.rb' autoload :FailoverGroups, 'generated/azure_mgmt_sql/failover_groups.rb' + autoload :VnetFirewallRules, 'generated/azure_mgmt_sql/vnet_firewall_rules.rb' autoload :SqlManagementClient, 'generated/azure_mgmt_sql/sql_management_client.rb' module Models - autoload :ElasticPoolListResult, 'generated/azure_mgmt_sql/models/elastic_pool_list_result.rb' - autoload :ServiceObjectiveListResult, 'generated/azure_mgmt_sql/models/service_objective_list_result.rb' - autoload :ServiceObjectiveCapability, 'generated/azure_mgmt_sql/models/service_objective_capability.rb' + autoload :OperationListResult, 'generated/azure_mgmt_sql/models/operation_list_result.rb' + autoload :MaxSizeCapability, 'generated/azure_mgmt_sql/models/max_size_capability.rb' + autoload :TransparentDataEncryptionActivityListResult, 'generated/azure_mgmt_sql/models/transparent_data_encryption_activity_list_result.rb' + autoload :EditionCapability, 'generated/azure_mgmt_sql/models/edition_capability.rb' autoload :Operation, 'generated/azure_mgmt_sql/models/operation.rb' + autoload :LocationCapabilities, 'generated/azure_mgmt_sql/models/location_capabilities.rb' + autoload :RecommendedElasticPoolListResult, 'generated/azure_mgmt_sql/models/recommended_elastic_pool_list_result.rb' + autoload :OperationImpact, 'generated/azure_mgmt_sql/models/operation_impact.rb' + autoload :ServiceObjectiveCapability, 'generated/azure_mgmt_sql/models/service_objective_capability.rb' autoload :ServerVersionCapability, 'generated/azure_mgmt_sql/models/server_version_capability.rb' - autoload :OperationDisplay, 'generated/azure_mgmt_sql/models/operation_display.rb' + autoload :FailoverGroupReadWriteEndpoint, 'generated/azure_mgmt_sql/models/failover_group_read_write_endpoint.rb' autoload :SubResource, 'generated/azure_mgmt_sql/models/sub_resource.rb' - autoload :RecommendedElasticPoolListResult, 'generated/azure_mgmt_sql/models/recommended_elastic_pool_list_result.rb' - autoload :FirewallRuleListResult, 'generated/azure_mgmt_sql/models/firewall_rule_list_result.rb' + autoload :ServiceTierAdvisorListResult, 'generated/azure_mgmt_sql/models/service_tier_advisor_list_result.rb' + autoload :RestorePointListResult, 'generated/azure_mgmt_sql/models/restore_point_list_result.rb' + autoload :ExportRequest, 'generated/azure_mgmt_sql/models/export_request.rb' autoload :RecommendedElasticPoolListMetricsResult, 'generated/azure_mgmt_sql/models/recommended_elastic_pool_list_metrics_result.rb' - autoload :LocationCapabilities, 'generated/azure_mgmt_sql/models/location_capabilities.rb' - autoload :OperationListResult, 'generated/azure_mgmt_sql/models/operation_list_result.rb' - autoload :ImportExtensionRequest, 'generated/azure_mgmt_sql/models/import_extension_request.rb' + autoload :ReplicationLinkListResult, 'generated/azure_mgmt_sql/models/replication_link_list_result.rb' + autoload :OperationDisplay, 'generated/azure_mgmt_sql/models/operation_display.rb' + autoload :SloUsageMetric, 'generated/azure_mgmt_sql/models/slo_usage_metric.rb' + autoload :ElasticPoolListResult, 'generated/azure_mgmt_sql/models/elastic_pool_list_result.rb' autoload :FailoverGroupReadOnlyEndpoint, 'generated/azure_mgmt_sql/models/failover_group_read_only_endpoint.rb' + autoload :ServiceObjectiveListResult, 'generated/azure_mgmt_sql/models/service_objective_list_result.rb' + autoload :ElasticPoolActivityListResult, 'generated/azure_mgmt_sql/models/elastic_pool_activity_list_result.rb' autoload :ServerMetricListResult, 'generated/azure_mgmt_sql/models/server_metric_list_result.rb' - autoload :ServerMetric, 'generated/azure_mgmt_sql/models/server_metric.rb' - autoload :RestorePointListResult, 'generated/azure_mgmt_sql/models/restore_point_list_result.rb' + autoload :VnetFirewallRuleListResult, 'generated/azure_mgmt_sql/models/vnet_firewall_rule_list_result.rb' autoload :RecommendedElasticPoolMetric, 'generated/azure_mgmt_sql/models/recommended_elastic_pool_metric.rb' - autoload :TransparentDataEncryptionActivityListResult, 'generated/azure_mgmt_sql/models/transparent_data_encryption_activity_list_result.rb' - autoload :DatabaseMetricListResult, 'generated/azure_mgmt_sql/models/database_metric_list_result.rb' - autoload :MaxSizeCapability, 'generated/azure_mgmt_sql/models/max_size_capability.rb' - autoload :OperationImpact, 'generated/azure_mgmt_sql/models/operation_impact.rb' - autoload :ServiceTierAdvisorListResult, 'generated/azure_mgmt_sql/models/service_tier_advisor_list_result.rb' - autoload :ElasticPoolActivityListResult, 'generated/azure_mgmt_sql/models/elastic_pool_activity_list_result.rb' - autoload :ReplicationLinkListResult, 'generated/azure_mgmt_sql/models/replication_link_list_result.rb' - autoload :FailoverGroupResourceList, 'generated/azure_mgmt_sql/models/failover_group_resource_list.rb' - autoload :FailoverGroupReadWriteEndpoint, 'generated/azure_mgmt_sql/models/failover_group_read_write_endpoint.rb' autoload :ElasticPoolDatabaseActivityListResult, 'generated/azure_mgmt_sql/models/elastic_pool_database_activity_list_result.rb' - autoload :ExportRequest, 'generated/azure_mgmt_sql/models/export_request.rb' - autoload :PartnerInfo, 'generated/azure_mgmt_sql/models/partner_info.rb' - autoload :EditionCapability, 'generated/azure_mgmt_sql/models/edition_capability.rb' + autoload :FirewallRuleListResult, 'generated/azure_mgmt_sql/models/firewall_rule_list_result.rb' + autoload :FailoverGroupListResult, 'generated/azure_mgmt_sql/models/failover_group_list_result.rb' + autoload :ServerMetric, 'generated/azure_mgmt_sql/models/server_metric.rb' autoload :ServerListResult, 'generated/azure_mgmt_sql/models/server_list_result.rb' - autoload :SloUsageMetric, 'generated/azure_mgmt_sql/models/slo_usage_metric.rb' + autoload :ImportExtensionRequest, 'generated/azure_mgmt_sql/models/import_extension_request.rb' autoload :DatabaseListResult, 'generated/azure_mgmt_sql/models/database_list_result.rb' + autoload :DatabaseMetricListResult, 'generated/azure_mgmt_sql/models/database_metric_list_result.rb' + autoload :PartnerInfo, 'generated/azure_mgmt_sql/models/partner_info.rb' autoload :FirewallRule, 'generated/azure_mgmt_sql/models/firewall_rule.rb' autoload :TrackedResource, 'generated/azure_mgmt_sql/models/tracked_resource.rb' autoload :ProxyResource, 'generated/azure_mgmt_sql/models/proxy_resource.rb' @@ -85,7 +88,8 @@ module Models autoload :TransparentDataEncryptionActivity, 'generated/azure_mgmt_sql/models/transparent_data_encryption_activity.rb' autoload :DatabaseSecurityAlertPolicy, 'generated/azure_mgmt_sql/models/database_security_alert_policy.rb' autoload :DatabaseBlobAuditingPolicy, 'generated/azure_mgmt_sql/models/database_blob_auditing_policy.rb' - autoload :FailoverGroupResource, 'generated/azure_mgmt_sql/models/failover_group_resource.rb' + autoload :FailoverGroup, 'generated/azure_mgmt_sql/models/failover_group.rb' + autoload :VnetFirewallRule, 'generated/azure_mgmt_sql/models/vnet_firewall_rule.rb' autoload :CapabilityStatus, 'generated/azure_mgmt_sql/models/capability_status.rb' autoload :MaxSizeUnits, 'generated/azure_mgmt_sql/models/max_size_units.rb' autoload :PerformanceLevelUnit, 'generated/azure_mgmt_sql/models/performance_level_unit.rb' diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/failover_groups.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/failover_groups.rb index 61f1280771..081977202a 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/failover_groups.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/failover_groups.rb @@ -30,12 +30,13 @@ def initialize(client) # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # def get(resource_group_name, server_name, failover_group_name, custom_headers = nil) response = get_async(resource_group_name, server_name, failover_group_name, custom_headers).value! @@ -48,7 +49,8 @@ def get(resource_group_name, server_name, failover_group_name, custom_headers = # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -65,7 +67,8 @@ def get_with_http_info(resource_group_name, server_name, failover_group_name, cu # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. @@ -73,11 +76,11 @@ def get_with_http_info(resource_group_name, server_name, failover_group_name, cu # @return [Concurrent::Promise] Promise object which holds the HTTP response. # def get_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? fail ArgumentError, 'failover_group_name is nil' if failover_group_name.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -91,7 +94,7 @@ def get_async(resource_group_name, server_name, failover_group_name, custom_head options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, headers: request_headers.merge(custom_headers || {}), base_url: request_url @@ -112,7 +115,7 @@ def get_async(resource_group_name, server_name, failover_group_name, custom_head if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -131,15 +134,17 @@ def get_async(resource_group_name, server_name, failover_group_name, custom_head # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # - def create_or_update(resource_group_name, server_name, failover_group_name, custom_headers = nil) - response = create_or_update_async(resource_group_name, server_name, failover_group_name, custom_headers).value! + def create_or_update(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) + response = create_or_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers).value! response.body unless response.nil? end @@ -147,22 +152,24 @@ def create_or_update(resource_group_name, server_name, failover_group_name, cust # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # # @return [Concurrent::Promise] promise which provides async access to http # response. # - def create_or_update_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) + def create_or_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) # Send request - promise = begin_create_or_update_async(resource_group_name, server_name, failover_group_name, custom_headers) + promise = begin_create_or_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers) promise = promise.then do |response| # Defining deserialization method. deserialize_method = lambda do |parsed_response| - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() parsed_response = @client.deserialize(result_mapper, parsed_response, 'parsed_response') end @@ -179,7 +186,8 @@ def create_or_update_async(resource_group_name, server_name, failover_group_name # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -193,7 +201,8 @@ def delete(resource_group_name, server_name, failover_group_name, custom_headers # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -223,15 +232,17 @@ def delete_async(resource_group_name, server_name, failover_group_name, custom_h # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # - def update(resource_group_name, server_name, failover_group_name, custom_headers = nil) - response = update_async(resource_group_name, server_name, failover_group_name, custom_headers).value! + def update(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) + response = update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers).value! response.body unless response.nil? end @@ -239,22 +250,24 @@ def update(resource_group_name, server_name, failover_group_name, custom_headers # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # # @return [Concurrent::Promise] promise which provides async access to http # response. # - def update_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) + def update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) # Send request - promise = begin_update_async(resource_group_name, server_name, failover_group_name, custom_headers) + promise = begin_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers) promise = promise.then do |response| # Defining deserialization method. deserialize_method = lambda do |parsed_response| - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() parsed_response = @client.deserialize(result_mapper, parsed_response, 'parsed_response') end @@ -271,15 +284,16 @@ def update_async(resource_group_name, server_name, failover_group_name, custom_h # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResourceList] operation results. + # @return [Array] operation results. # def list_by_server(resource_group_name, server_name, custom_headers = nil) - response = list_by_server_async(resource_group_name, server_name, custom_headers).value! - response.body unless response.nil? + first_page = list_by_server_as_lazy(resource_group_name, server_name, custom_headers) + first_page.get_all_items end # @@ -288,7 +302,8 @@ def list_by_server(resource_group_name, server_name, custom_headers = nil) # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # @@ -304,17 +319,18 @@ def list_by_server_with_http_info(resource_group_name, server_name, custom_heade # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. # # @return [Concurrent::Promise] Promise object which holds the HTTP response. # def list_by_server_async(resource_group_name, server_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -328,7 +344,7 @@ def list_by_server_async(resource_group_name, server_name, custom_headers = nil) options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, headers: request_headers.merge(custom_headers || {}), base_url: request_url @@ -349,7 +365,7 @@ def list_by_server_async(resource_group_name, server_name, custom_headers = nil) if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResourceList.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroupListResult.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -363,17 +379,18 @@ def list_by_server_async(resource_group_name, server_name, custom_headers = nil) end # - # Sets which server is primary by failing over from the current primary server. + # Fails over from the current primary server to this server. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # def failover(resource_group_name, server_name, failover_group_name, custom_headers = nil) response = failover_async(resource_group_name, server_name, failover_group_name, custom_headers).value! @@ -384,7 +401,8 @@ def failover(resource_group_name, server_name, failover_group_name, custom_heade # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -399,7 +417,7 @@ def failover_async(resource_group_name, server_name, failover_group_name, custom promise = promise.then do |response| # Defining deserialization method. deserialize_method = lambda do |parsed_response| - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() parsed_response = @client.deserialize(result_mapper, parsed_response, 'parsed_response') end @@ -411,18 +429,19 @@ def failover_async(resource_group_name, server_name, failover_group_name, custom end # - # Sets which server is primary by failing over from the current primary server. - # This operation might result in data loss. + # Fails over from the current primary server to this server. This operation + # might result in data loss. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # def force_failover_allow_data_loss(resource_group_name, server_name, failover_group_name, custom_headers = nil) response = force_failover_allow_data_loss_async(resource_group_name, server_name, failover_group_name, custom_headers).value! @@ -433,7 +452,8 @@ def force_failover_allow_data_loss(resource_group_name, server_name, failover_gr # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -448,7 +468,7 @@ def force_failover_allow_data_loss_async(resource_group_name, server_name, failo promise = promise.then do |response| # Defining deserialization method. deserialize_method = lambda do |parsed_response| - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() parsed_response = @client.deserialize(result_mapper, parsed_response, 'parsed_response') end @@ -465,15 +485,17 @@ def force_failover_allow_data_loss_async(resource_group_name, server_name, failo # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # - def begin_create_or_update(resource_group_name, server_name, failover_group_name, custom_headers = nil) - response = begin_create_or_update_async(resource_group_name, server_name, failover_group_name, custom_headers).value! + def begin_create_or_update(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) + response = begin_create_or_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers).value! response.body unless response.nil? end @@ -483,15 +505,17 @@ def begin_create_or_update(resource_group_name, server_name, failover_group_name # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # # @return [MsRestAzure::AzureOperationResponse] HTTP response information. # - def begin_create_or_update_with_http_info(resource_group_name, server_name, failover_group_name, custom_headers = nil) - begin_create_or_update_async(resource_group_name, server_name, failover_group_name, custom_headers).value! + def begin_create_or_update_with_http_info(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) + begin_create_or_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers).value! end # @@ -500,20 +524,22 @@ def begin_create_or_update_with_http_info(resource_group_name, server_name, fail # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. # # @return [Concurrent::Promise] Promise object which holds the HTTP response. # - def begin_create_or_update_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + def begin_create_or_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? fail ArgumentError, 'failover_group_name is nil' if failover_group_name.nil? - fail ArgumentError, '@client.failover_group is nil' if @client.failover_group.nil? + fail ArgumentError, 'parameters is nil' if parameters.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -525,8 +551,8 @@ def begin_create_or_update_async(resource_group_name, server_name, failover_grou request_headers['Content-Type'] = 'application/json; charset=utf-8' # Serialize Request - request_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() - request_content = @client.serialize(request_mapper, @client.failover_group, '@client.failover_group') + request_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() + request_content = @client.serialize(request_mapper, parameters, 'parameters') request_content = request_content != nil ? JSON.generate(request_content, quirks_mode: true) : nil path_template = 'subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/failoverGroups/{failoverGroupName}' @@ -535,7 +561,7 @@ def begin_create_or_update_async(resource_group_name, server_name, failover_grou options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, body: request_content, headers: request_headers.merge(custom_headers || {}), @@ -547,7 +573,7 @@ def begin_create_or_update_async(resource_group_name, server_name, failover_grou http_response = result.response status_code = http_response.status response_content = http_response.body - unless status_code == 200 || status_code == 201 + unless status_code == 200 || status_code == 202 || status_code == 201 error_model = JSON.load(response_content) fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) end @@ -557,7 +583,7 @@ def begin_create_or_update_async(resource_group_name, server_name, failover_grou if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -567,7 +593,7 @@ def begin_create_or_update_async(resource_group_name, server_name, failover_grou if status_code == 201 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -586,7 +612,8 @@ def begin_create_or_update_async(resource_group_name, server_name, failover_grou # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -603,7 +630,8 @@ def begin_delete(resource_group_name, server_name, failover_group_name, custom_h # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -620,7 +648,8 @@ def begin_delete_with_http_info(resource_group_name, server_name, failover_group # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. @@ -628,11 +657,11 @@ def begin_delete_with_http_info(resource_group_name, server_name, failover_group # @return [Concurrent::Promise] Promise object which holds the HTTP response. # def begin_delete_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? fail ArgumentError, 'failover_group_name is nil' if failover_group_name.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -646,7 +675,7 @@ def begin_delete_async(resource_group_name, server_name, failover_group_name, cu options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, headers: request_headers.merge(custom_headers || {}), base_url: request_url @@ -657,7 +686,7 @@ def begin_delete_async(resource_group_name, server_name, failover_group_name, cu http_response = result.response status_code = http_response.status response_content = http_response.body - unless status_code == 200 || status_code == 204 + unless status_code == 200 || status_code == 202 || status_code == 204 error_model = JSON.load(response_content) fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) end @@ -676,15 +705,17 @@ def begin_delete_async(resource_group_name, server_name, failover_group_name, cu # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # - def begin_update(resource_group_name, server_name, failover_group_name, custom_headers = nil) - response = begin_update_async(resource_group_name, server_name, failover_group_name, custom_headers).value! + def begin_update(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) + response = begin_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers).value! response.body unless response.nil? end @@ -694,15 +725,17 @@ def begin_update(resource_group_name, server_name, failover_group_name, custom_h # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # # @return [MsRestAzure::AzureOperationResponse] HTTP response information. # - def begin_update_with_http_info(resource_group_name, server_name, failover_group_name, custom_headers = nil) - begin_update_async(resource_group_name, server_name, failover_group_name, custom_headers).value! + def begin_update_with_http_info(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) + begin_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers).value! end # @@ -711,20 +744,22 @@ def begin_update_with_http_info(resource_group_name, server_name, failover_group # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. + # @param parameters [FailoverGroup] The failover group parameters. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. # # @return [Concurrent::Promise] Promise object which holds the HTTP response. # - def begin_update_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + def begin_update_async(resource_group_name, server_name, failover_group_name, parameters, custom_headers = nil) fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? fail ArgumentError, 'failover_group_name is nil' if failover_group_name.nil? - fail ArgumentError, '@client.failover_group is nil' if @client.failover_group.nil? + fail ArgumentError, 'parameters is nil' if parameters.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -736,8 +771,8 @@ def begin_update_async(resource_group_name, server_name, failover_group_name, cu request_headers['Content-Type'] = 'application/json; charset=utf-8' # Serialize Request - request_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() - request_content = @client.serialize(request_mapper, @client.failover_group, '@client.failover_group') + request_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() + request_content = @client.serialize(request_mapper, parameters, 'parameters') request_content = request_content != nil ? JSON.generate(request_content, quirks_mode: true) : nil path_template = 'subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/failoverGroups/{failoverGroupName}' @@ -746,7 +781,7 @@ def begin_update_async(resource_group_name, server_name, failover_group_name, cu options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, body: request_content, headers: request_headers.merge(custom_headers || {}), @@ -758,7 +793,7 @@ def begin_update_async(resource_group_name, server_name, failover_group_name, cu http_response = result.response status_code = http_response.status response_content = http_response.body - unless status_code == 200 + unless status_code == 200 || status_code == 202 error_model = JSON.load(response_content) fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) end @@ -768,7 +803,7 @@ def begin_update_async(resource_group_name, server_name, failover_group_name, cu if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -782,17 +817,18 @@ def begin_update_async(resource_group_name, server_name, failover_group_name, cu end # - # Sets which server is primary by failing over from the current primary server. + # Fails over from the current primary server to this server. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # def begin_failover(resource_group_name, server_name, failover_group_name, custom_headers = nil) response = begin_failover_async(resource_group_name, server_name, failover_group_name, custom_headers).value! @@ -800,12 +836,13 @@ def begin_failover(resource_group_name, server_name, failover_group_name, custom end # - # Sets which server is primary by failing over from the current primary server. + # Fails over from the current primary server to this server. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -817,12 +854,13 @@ def begin_failover_with_http_info(resource_group_name, server_name, failover_gro end # - # Sets which server is primary by failing over from the current primary server. + # Fails over from the current primary server to this server. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. @@ -830,11 +868,11 @@ def begin_failover_with_http_info(resource_group_name, server_name, failover_gro # @return [Concurrent::Promise] Promise object which holds the HTTP response. # def begin_failover_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? fail ArgumentError, 'failover_group_name is nil' if failover_group_name.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -848,7 +886,7 @@ def begin_failover_async(resource_group_name, server_name, failover_group_name, options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, headers: request_headers.merge(custom_headers || {}), base_url: request_url @@ -859,7 +897,7 @@ def begin_failover_async(resource_group_name, server_name, failover_group_name, http_response = result.response status_code = http_response.status response_content = http_response.body - unless status_code == 200 + unless status_code == 200 || status_code == 202 error_model = JSON.load(response_content) fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) end @@ -869,7 +907,7 @@ def begin_failover_async(resource_group_name, server_name, failover_group_name, if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -883,18 +921,19 @@ def begin_failover_async(resource_group_name, server_name, failover_group_name, end # - # Sets which server is primary by failing over from the current primary server. - # This operation might result in data loss. + # Fails over from the current primary server to this server. This operation + # might result in data loss. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. # - # @return [FailoverGroupResource] operation results. + # @return [FailoverGroup] operation results. # def begin_force_failover_allow_data_loss(resource_group_name, server_name, failover_group_name, custom_headers = nil) response = begin_force_failover_allow_data_loss_async(resource_group_name, server_name, failover_group_name, custom_headers).value! @@ -902,13 +941,14 @@ def begin_force_failover_allow_data_loss(resource_group_name, server_name, failo end # - # Sets which server is primary by failing over from the current primary server. - # This operation might result in data loss. + # Fails over from the current primary server to this server. This operation + # might result in data loss. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param custom_headers [Hash{String => String}] A hash of custom headers that # will be added to the HTTP request. @@ -920,13 +960,14 @@ def begin_force_failover_allow_data_loss_with_http_info(resource_group_name, ser end # - # Sets which server is primary by failing over from the current primary server. - # This operation might result in data loss. + # Fails over from the current primary server to this server. This operation + # might result in data loss. # # @param resource_group_name [String] The name of the resource group that # contains the resource. You can obtain this value from the Azure Resource # Manager API or the portal. - # @param server_name [String] The name of the server. + # @param server_name [String] The name of the server containing the failover + # group. # @param failover_group_name [String] The name of the failover group. # @param [Hash{String => String}] A hash of custom headers that will be added # to the HTTP request. @@ -934,11 +975,11 @@ def begin_force_failover_allow_data_loss_with_http_info(resource_group_name, ser # @return [Concurrent::Promise] Promise object which holds the HTTP response. # def begin_force_failover_allow_data_loss_async(resource_group_name, server_name, failover_group_name, custom_headers = nil) - api_version = '2015-05-01-preview' - fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? fail ArgumentError, 'server_name is nil' if server_name.nil? fail ArgumentError, 'failover_group_name is nil' if failover_group_name.nil? + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + api_version = '2015-05-01-preview' request_headers = {} @@ -952,13 +993,100 @@ def begin_force_failover_allow_data_loss_async(resource_group_name, server_name, options = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name}, + path_params: {'resourceGroupName' => resource_group_name,'serverName' => server_name,'failoverGroupName' => failover_group_name,'subscriptionId' => @client.subscription_id}, query_params: {'api-version' => api_version}, headers: request_headers.merge(custom_headers || {}), base_url: request_url } promise = @client.make_request_async(:post, path_template, options) + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 || status_code == 202 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + # Deserialize Response + if status_code == 200 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::FailoverGroup.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + + result + end + + promise.execute + end + + # + # Lists the failover groups in a server. + # + # @param next_page_link [String] The NextLink from the previous successful call + # to List operation. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [FailoverGroupListResult] operation results. + # + def list_by_server_next(next_page_link, custom_headers = nil) + response = list_by_server_next_async(next_page_link, custom_headers).value! + response.body unless response.nil? + end + + # + # Lists the failover groups in a server. + # + # @param next_page_link [String] The NextLink from the previous successful call + # to List operation. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def list_by_server_next_with_http_info(next_page_link, custom_headers = nil) + list_by_server_next_async(next_page_link, custom_headers).value! + end + + # + # Lists the failover groups in a server. + # + # @param next_page_link [String] The NextLink from the previous successful call + # to List operation. + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def list_by_server_next_async(next_page_link, custom_headers = nil) + fail ArgumentError, 'next_page_link is nil' if next_page_link.nil? + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + path_template = '{nextLink}' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + skip_encoding_path_params: {'nextLink' => next_page_link}, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:get, path_template, options) + promise = promise.then do |result| http_response = result.response status_code = http_response.status @@ -973,7 +1101,7 @@ def begin_force_failover_allow_data_loss_async(resource_group_name, server_name, if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::FailoverGroupResource.mapper() + result_mapper = Azure::ARM::SQL::Models::FailoverGroupListResult.mapper() result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) @@ -986,5 +1114,30 @@ def begin_force_failover_allow_data_loss_async(resource_group_name, server_name, promise.execute end + # + # Lists the failover groups in a server. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server containing the failover + # group. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [FailoverGroupListResult] which provide lazy access to pages of the + # response. + # + def list_by_server_as_lazy(resource_group_name, server_name, custom_headers = nil) + response = list_by_server_async(resource_group_name, server_name, custom_headers).value! + unless response.nil? + page = response.body + page.next_method = Proc.new do |next_page_link| + list_by_server_next_async(next_page_link, custom_headers) + end + page + end + end + end end diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_resource.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group.rb similarity index 93% rename from management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_resource.rb rename to management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group.rb index 0b05a626ce..3ba23596cb 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_resource.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group.rb @@ -6,13 +6,13 @@ module Azure::ARM::SQL module Models # - # Contains information about failover group. + # A failover group. # - class FailoverGroupResource < ProxyResource + class FailoverGroup < ProxyResource include MsRestAzure - # @return [String] The geo-location where the resource lives. + # @return [String] Resource location. attr_accessor :location # @return [Hash{String => String}] Resource tags. @@ -43,16 +43,16 @@ class FailoverGroupResource < ProxyResource # - # Mapper for FailoverGroupResource class as Ruby Hash. + # Mapper for FailoverGroup class as Ruby Hash. # This will be used for serialization/deserialization. # def self.mapper() { required: false, - serialized_name: 'FailoverGroupResource', + serialized_name: 'FailoverGroup', type: { name: 'Composite', - class_name: 'FailoverGroupResource', + class_name: 'FailoverGroup', model_properties: { id: { required: false, @@ -80,6 +80,7 @@ def self.mapper() }, location: { required: false, + read_only: true, serialized_name: 'location', type: { name: 'String' diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_list_result.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_list_result.rb new file mode 100755 index 0000000000..8345d7b70c --- /dev/null +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_list_result.rb @@ -0,0 +1,95 @@ +# encoding: utf-8 +# Code generated by Microsoft (R) AutoRest Code Generator 1.0.1.0 +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. + +module Azure::ARM::SQL + module Models + # + # A list of failover groups. + # + class FailoverGroupListResult + + include MsRestAzure + + # @return [Array] Array of results. + attr_accessor :value + + # @return [String] Link to retrieve next page of results. + attr_accessor :next_link + + # return [Proc] with next page method call. + attr_accessor :next_method + + # + # Gets the rest of the items for the request, enabling auto-pagination. + # + # @return [Array] operation results. + # + def get_all_items + items = @value + page = self + while page.next_link != nil do + page = page.get_next_page + items.concat(page.value) + end + items + end + + # + # Gets the next page of results. + # + # @return [FailoverGroupListResult] with next page content. + # + def get_next_page + response = @next_method.call(@next_link).value! unless @next_method.nil? + unless response.nil? + @next_link = response.body.next_link + @value = response.body.value + self + end + end + + # + # Mapper for FailoverGroupListResult class as Ruby Hash. + # This will be used for serialization/deserialization. + # + def self.mapper() + { + required: false, + serialized_name: 'FailoverGroupListResult', + type: { + name: 'Composite', + class_name: 'FailoverGroupListResult', + model_properties: { + value: { + required: false, + read_only: true, + serialized_name: 'value', + type: { + name: 'Sequence', + element: { + required: false, + serialized_name: 'FailoverGroupElementType', + type: { + name: 'Composite', + class_name: 'FailoverGroup' + } + } + } + }, + next_link: { + required: false, + read_only: true, + serialized_name: 'nextLink', + type: { + name: 'String' + } + } + } + } + } + end + end + end +end diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_only_endpoint.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_only_endpoint.rb index b82ba16225..c75b64ccb3 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_only_endpoint.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_only_endpoint.rb @@ -6,8 +6,7 @@ module Azure::ARM::SQL module Models # - # Model object. - # + # Read-only endpoint of the failover group instance. # class FailoverGroupReadOnlyEndpoint diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_write_endpoint.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_write_endpoint.rb index 860cebfbda..5972ac47af 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_write_endpoint.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_read_write_endpoint.rb @@ -6,8 +6,7 @@ module Azure::ARM::SQL module Models # - # Model object. - # + # Read-write endpoint of the failover group instance. # class FailoverGroupReadWriteEndpoint diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_resource_list.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_resource_list.rb deleted file mode 100755 index 3895caf144..0000000000 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/failover_group_resource_list.rb +++ /dev/null @@ -1,62 +0,0 @@ -# encoding: utf-8 -# Code generated by Microsoft (R) AutoRest Code Generator 1.0.1.0 -# Changes may cause incorrect behavior and will be lost if the code is -# regenerated. - -module Azure::ARM::SQL - module Models - # - # A list of failover groups. - # - class FailoverGroupResourceList - - include MsRestAzure - - # @return [Array] - attr_accessor :value - - # @return [String] - attr_accessor :next_link - - - # - # Mapper for FailoverGroupResourceList class as Ruby Hash. - # This will be used for serialization/deserialization. - # - def self.mapper() - { - required: false, - serialized_name: 'FailoverGroupResourceList', - type: { - name: 'Composite', - class_name: 'FailoverGroupResourceList', - model_properties: { - value: { - required: false, - serialized_name: 'value', - type: { - name: 'Sequence', - element: { - required: false, - serialized_name: 'FailoverGroupResourceElementType', - type: { - name: 'Composite', - class_name: 'FailoverGroupResource' - } - } - } - }, - next_link: { - required: false, - serialized_name: 'nextLink', - type: { - name: 'String' - } - } - } - } - } - end - end - end -end diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/partner_info.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/partner_info.rb index 30fefda3a4..679df9cddc 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/partner_info.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/partner_info.rb @@ -6,8 +6,7 @@ module Azure::ARM::SQL module Models # - # Model object. - # + # Partner server information for the failover group. # class PartnerInfo diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/vnet_firewall_rule.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/vnet_firewall_rule.rb new file mode 100755 index 0000000000..539c4a319c --- /dev/null +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/vnet_firewall_rule.rb @@ -0,0 +1,68 @@ +# encoding: utf-8 +# Code generated by Microsoft (R) AutoRest Code Generator 1.0.1.0 +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. + +module Azure::ARM::SQL + module Models + # + # A Vnet Firewall Rule Resource. + # + class VnetFirewallRule < ProxyResource + + include MsRestAzure + + # @return [String] The VnetSubnetId + attr_accessor :virtual_network_subnet_id + + + # + # Mapper for VnetFirewallRule class as Ruby Hash. + # This will be used for serialization/deserialization. + # + def self.mapper() + { + required: false, + serialized_name: 'VnetFirewallRule', + type: { + name: 'Composite', + class_name: 'VnetFirewallRule', + model_properties: { + id: { + required: false, + read_only: true, + serialized_name: 'id', + type: { + name: 'String' + } + }, + name: { + required: false, + read_only: true, + serialized_name: 'name', + type: { + name: 'String' + } + }, + type: { + required: false, + read_only: true, + serialized_name: 'type', + type: { + name: 'String' + } + }, + virtual_network_subnet_id: { + required: false, + serialized_name: 'properties.virtualNetworkSubnetId', + type: { + name: 'String' + } + } + } + } + } + end + end + end +end diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/vnet_firewall_rule_list_result.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/vnet_firewall_rule_list_result.rb new file mode 100755 index 0000000000..25e1bf09ed --- /dev/null +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/models/vnet_firewall_rule_list_result.rb @@ -0,0 +1,94 @@ +# encoding: utf-8 +# Code generated by Microsoft (R) AutoRest Code Generator 1.0.1.0 +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. + +module Azure::ARM::SQL + module Models + # + # A list of Vnet Firewall Rule Resource. + # + class VnetFirewallRuleListResult + + include MsRestAzure + + # @return [String] Link to retrieve next page of results. + attr_accessor :next_link + + # @return [Array] Array of results. + attr_accessor :value + + # return [Proc] with next page method call. + attr_accessor :next_method + + # + # Gets the rest of the items for the request, enabling auto-pagination. + # + # @return [Array] operation results. + # + def get_all_items + items = @value + page = self + while page.next_link != nil do + page = page.get_next_page + items.concat(page.value) + end + items + end + + # + # Gets the next page of results. + # + # @return [VnetFirewallRuleListResult] with next page content. + # + def get_next_page + response = @next_method.call(@next_link).value! unless @next_method.nil? + unless response.nil? + @next_link = response.body.next_link + @value = response.body.value + self + end + end + + # + # Mapper for VnetFirewallRuleListResult class as Ruby Hash. + # This will be used for serialization/deserialization. + # + def self.mapper() + { + required: false, + serialized_name: 'VnetFirewallRuleListResult', + type: { + name: 'Composite', + class_name: 'VnetFirewallRuleListResult', + model_properties: { + next_link: { + required: false, + read_only: true, + serialized_name: 'nextLink', + type: { + name: 'String' + } + }, + value: { + required: false, + serialized_name: 'value', + type: { + name: 'Sequence', + element: { + required: false, + serialized_name: 'VnetFirewallRuleElementType', + type: { + name: 'Composite', + class_name: 'VnetFirewallRule' + } + } + } + } + } + } + } + end + end + end +end diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/operations.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/operations.rb new file mode 100755 index 0000000000..7f7cc0f40d --- /dev/null +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/operations.rb @@ -0,0 +1,109 @@ +# encoding: utf-8 +# Code generated by Microsoft (R) AutoRest Code Generator 1.0.1.0 +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. + +module Azure::ARM::SQL + # + # The Azure SQL Database management API provides a RESTful set of web + # services that interact with Azure SQL Database services to manage your + # databases. The API enables you to create, retrieve, update, and delete + # databases. + # + class Operations + include MsRestAzure + + # + # Creates and initializes a new instance of the Operations class. + # @param client service class for accessing basic functionality. + # + def initialize(client) + @client = client + end + + # @return [SqlManagementClient] reference to the SqlManagementClient + attr_reader :client + + # + # Lists all of the available SQL Rest API operations. + # + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [OperationListResult] operation results. + # + def list(custom_headers = nil) + response = list_async(custom_headers).value! + response.body unless response.nil? + end + + # + # Lists all of the available SQL Rest API operations. + # + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def list_with_http_info(custom_headers = nil) + list_async(custom_headers).value! + end + + # + # Lists all of the available SQL Rest API operations. + # + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def list_async(custom_headers = nil) + api_version = '2014-04-01' + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + path_template = 'providers/Microsoft.Sql/operations' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + query_params: {'api-version' => api_version}, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:get, path_template, options) + + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + # Deserialize Response + if status_code == 200 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::OperationListResult.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + + result + end + + promise.execute + end + + end +end diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/sql_management_client.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/sql_management_client.rb index 3360c0daed..c10dccd81a 100755 --- a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/sql_management_client.rb +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/sql_management_client.rb @@ -21,9 +21,6 @@ class SqlManagementClient < MsRestAzure::AzureServiceClient # subscription. attr_accessor :subscription_id - # @return [FailoverGroupResource] The failover group. - attr_accessor :failover_group - # @return [String] Gets or sets the preferred language for the response. attr_accessor :accept_language @@ -53,9 +50,15 @@ class SqlManagementClient < MsRestAzure::AzureServiceClient # @return [RecommendedElasticPools] recommended_elastic_pools attr_reader :recommended_elastic_pools + # @return [Operations] operations + attr_reader :operations + # @return [FailoverGroups] failover_groups attr_reader :failover_groups + # @return [VnetFirewallRules] vnet_firewall_rules + attr_reader :vnet_firewall_rules + # # Creates initializes a new instance of the SqlManagementClient class. # @param credentials [MsRest::ServiceClientCredentials] credentials to authorize HTTP requests made by the service client. @@ -75,7 +78,9 @@ def initialize(credentials = nil, base_url = nil, options = nil) @servers = Servers.new(self) @elastic_pools = ElasticPools.new(self) @recommended_elastic_pools = RecommendedElasticPools.new(self) + @operations = Operations.new(self) @failover_groups = FailoverGroups.new(self) + @vnet_firewall_rules = VnetFirewallRules.new(self) @accept_language = 'en-US' @long_running_operation_retry_timeout = 30 @generate_client_request_id = true @@ -137,87 +142,6 @@ def make_request_async(method, path, options = {}) super(request_url, method, path, options) end - # - # Lists all of the available SQL Rest API operations. - # - # @param custom_headers [Hash{String => String}] A hash of custom headers that - # will be added to the HTTP request. - # - # @return [OperationListResult] operation results. - # - def list_operations(custom_headers = nil) - response = list_operations_async(custom_headers).value! - response.body unless response.nil? - end - - # - # Lists all of the available SQL Rest API operations. - # - # @param custom_headers [Hash{String => String}] A hash of custom headers that - # will be added to the HTTP request. - # - # @return [MsRestAzure::AzureOperationResponse] HTTP response information. - # - def list_operations_with_http_info(custom_headers = nil) - list_operations_async(custom_headers).value! - end - - # - # Lists all of the available SQL Rest API operations. - # - # @param [Hash{String => String}] A hash of custom headers that will be added - # to the HTTP request. - # - # @return [Concurrent::Promise] Promise object which holds the HTTP response. - # - def list_operations_async(custom_headers = nil) - api_version = '2014-04-01' - - - request_headers = {} - - # Set Headers - request_headers['x-ms-client-request-id'] = SecureRandom.uuid - request_headers['accept-language'] = accept_language unless accept_language.nil? - path_template = 'providers/Microsoft.Sql/operations' - - request_url = @base_url || self.base_url - - options = { - middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], - query_params: {'api-version' => api_version}, - headers: request_headers.merge(custom_headers || {}), - base_url: request_url - } - promise = self.make_request_async(:get, path_template, options) - - promise = promise.then do |result| - http_response = result.response - status_code = http_response.status - response_content = http_response.body - unless status_code == 200 - error_model = JSON.load(response_content) - fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) - end - - result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? - # Deserialize Response - if status_code == 200 - begin - parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) - result_mapper = Azure::ARM::SQL::Models::OperationListResult.mapper() - result.body = self.deserialize(result_mapper, parsed_response, 'result.body') - rescue Exception => e - fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) - end - end - - result - end - - promise.execute - end - private # diff --git a/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/vnet_firewall_rules.rb b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/vnet_firewall_rules.rb new file mode 100755 index 0000000000..ee3195ee18 --- /dev/null +++ b/management/azure_mgmt_sql/lib/generated/azure_mgmt_sql/vnet_firewall_rules.rb @@ -0,0 +1,650 @@ +# encoding: utf-8 +# Code generated by Microsoft (R) AutoRest Code Generator 1.0.1.0 +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. + +module Azure::ARM::SQL + # + # The Azure SQL Database management API provides a RESTful set of web + # services that interact with Azure SQL Database services to manage your + # databases. The API enables you to create, retrieve, update, and delete + # databases. + # + class VnetFirewallRules + include MsRestAzure + + # + # Creates and initializes a new instance of the VnetFirewallRules class. + # @param client service class for accessing basic functionality. + # + def initialize(client) + @client = client + end + + # @return [SqlManagementClient] reference to the SqlManagementClient + attr_reader :client + + # + # Gets a virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [VnetFirewallRule] operation results. + # + def get(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + response = get_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers).value! + response.body unless response.nil? + end + + # + # Gets a virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def get_with_http_info(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + get_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers).value! + end + + # + # Gets a virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def get_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? + fail ArgumentError, 'server_name is nil' if server_name.nil? + fail ArgumentError, 'vnet_firewall_rule_name is nil' if vnet_firewall_rule_name.nil? + api_version = '2015-05-01-preview' + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + path_template = 'subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/virtualNetworkRules/{vnetFirewallRuleName}' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'vnetFirewallRuleName' => vnet_firewall_rule_name}, + query_params: {'api-version' => api_version}, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:get, path_template, options) + + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + # Deserialize Response + if status_code == 200 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::VnetFirewallRule.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + + result + end + + promise.execute + end + + # + # Creates or updates an existing virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param parameters [VnetFirewallRule] The requested vnetFirewall Resource + # state. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [VnetFirewallRule] operation results. + # + def create_or_update(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers = nil) + response = create_or_update_async(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers).value! + response.body unless response.nil? + end + + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param parameters [VnetFirewallRule] The requested vnetFirewall Resource + # state. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [Concurrent::Promise] promise which provides async access to http + # response. + # + def create_or_update_async(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers = nil) + # Send request + promise = begin_create_or_update_async(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers) + + promise = promise.then do |response| + # Defining deserialization method. + deserialize_method = lambda do |parsed_response| + result_mapper = Azure::ARM::SQL::Models::VnetFirewallRule.mapper() + parsed_response = @client.deserialize(result_mapper, parsed_response, 'parsed_response') + end + + # Waiting for response. + @client.get_long_running_operation_result(response, deserialize_method) + end + + promise + end + + # + # Deletes the virtual network rule with the given name. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + def delete(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + response = delete_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers).value! + nil + end + + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [Concurrent::Promise] promise which provides async access to http + # response. + # + def delete_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + # Send request + promise = begin_delete_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers) + + promise = promise.then do |response| + # Defining deserialization method. + deserialize_method = lambda do |parsed_response| + end + + # Waiting for response. + @client.get_long_running_operation_result(response, deserialize_method) + end + + promise + end + + # + # Gets a list of virtual network rules in a server. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [Array] operation results. + # + def list_by_server(resource_group_name, server_name, custom_headers = nil) + first_page = list_by_server_as_lazy(resource_group_name, server_name, custom_headers) + first_page.get_all_items + end + + # + # Gets a list of virtual network rules in a server. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def list_by_server_with_http_info(resource_group_name, server_name, custom_headers = nil) + list_by_server_async(resource_group_name, server_name, custom_headers).value! + end + + # + # Gets a list of virtual network rules in a server. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def list_by_server_async(resource_group_name, server_name, custom_headers = nil) + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? + fail ArgumentError, 'server_name is nil' if server_name.nil? + api_version = '2015-05-01-preview' + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + path_template = 'subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/virtualNetworkRules' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name}, + query_params: {'api-version' => api_version}, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:get, path_template, options) + + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + # Deserialize Response + if status_code == 200 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::VnetFirewallRuleListResult.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + + result + end + + promise.execute + end + + # + # Creates or updates an existing virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param parameters [VnetFirewallRule] The requested vnetFirewall Resource + # state. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [VnetFirewallRule] operation results. + # + def begin_create_or_update(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers = nil) + response = begin_create_or_update_async(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers).value! + response.body unless response.nil? + end + + # + # Creates or updates an existing virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param parameters [VnetFirewallRule] The requested vnetFirewall Resource + # state. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def begin_create_or_update_with_http_info(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers = nil) + begin_create_or_update_async(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers).value! + end + + # + # Creates or updates an existing virtual network rule. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param parameters [VnetFirewallRule] The requested vnetFirewall Resource + # state. + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def begin_create_or_update_async(resource_group_name, server_name, vnet_firewall_rule_name, parameters, custom_headers = nil) + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? + fail ArgumentError, 'server_name is nil' if server_name.nil? + fail ArgumentError, 'vnet_firewall_rule_name is nil' if vnet_firewall_rule_name.nil? + fail ArgumentError, 'parameters is nil' if parameters.nil? + api_version = '2015-05-01-preview' + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + + request_headers['Content-Type'] = 'application/json; charset=utf-8' + + # Serialize Request + request_mapper = Azure::ARM::SQL::Models::VnetFirewallRule.mapper() + request_content = @client.serialize(request_mapper, parameters, 'parameters') + request_content = request_content != nil ? JSON.generate(request_content, quirks_mode: true) : nil + + path_template = 'subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/virtualNetworkRules/{vnetFirewallRuleName}' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'vnetFirewallRuleName' => vnet_firewall_rule_name}, + query_params: {'api-version' => api_version}, + body: request_content, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:put, path_template, options) + + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 || status_code == 202 || status_code == 201 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + # Deserialize Response + if status_code == 200 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::VnetFirewallRule.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + # Deserialize Response + if status_code == 201 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::VnetFirewallRule.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + + result + end + + promise.execute + end + + # + # Deletes the virtual network rule with the given name. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # + def begin_delete(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + response = begin_delete_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers).value! + nil + end + + # + # Deletes the virtual network rule with the given name. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def begin_delete_with_http_info(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + begin_delete_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers).value! + end + + # + # Deletes the virtual network rule with the given name. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param vnet_firewall_rule_name [String] The name of the virtual network rule. + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def begin_delete_async(resource_group_name, server_name, vnet_firewall_rule_name, custom_headers = nil) + fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil? + fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil? + fail ArgumentError, 'server_name is nil' if server_name.nil? + fail ArgumentError, 'vnet_firewall_rule_name is nil' if vnet_firewall_rule_name.nil? + api_version = '2015-05-01-preview' + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + path_template = 'subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/virtualNetworkRules/{vnetFirewallRuleName}' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + path_params: {'subscriptionId' => @client.subscription_id,'resourceGroupName' => resource_group_name,'serverName' => server_name,'vnetFirewallRuleName' => vnet_firewall_rule_name}, + query_params: {'api-version' => api_version}, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:delete, path_template, options) + + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 || status_code == 202 || status_code == 204 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + + result + end + + promise.execute + end + + # + # Gets a list of virtual network rules in a server. + # + # @param next_page_link [String] The NextLink from the previous successful call + # to List operation. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [VnetFirewallRuleListResult] operation results. + # + def list_by_server_next(next_page_link, custom_headers = nil) + response = list_by_server_next_async(next_page_link, custom_headers).value! + response.body unless response.nil? + end + + # + # Gets a list of virtual network rules in a server. + # + # @param next_page_link [String] The NextLink from the previous successful call + # to List operation. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [MsRestAzure::AzureOperationResponse] HTTP response information. + # + def list_by_server_next_with_http_info(next_page_link, custom_headers = nil) + list_by_server_next_async(next_page_link, custom_headers).value! + end + + # + # Gets a list of virtual network rules in a server. + # + # @param next_page_link [String] The NextLink from the previous successful call + # to List operation. + # @param [Hash{String => String}] A hash of custom headers that will be added + # to the HTTP request. + # + # @return [Concurrent::Promise] Promise object which holds the HTTP response. + # + def list_by_server_next_async(next_page_link, custom_headers = nil) + fail ArgumentError, 'next_page_link is nil' if next_page_link.nil? + + + request_headers = {} + + # Set Headers + request_headers['x-ms-client-request-id'] = SecureRandom.uuid + request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? + path_template = '{nextLink}' + + request_url = @base_url || @client.base_url + + options = { + middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], + skip_encoding_path_params: {'nextLink' => next_page_link}, + headers: request_headers.merge(custom_headers || {}), + base_url: request_url + } + promise = @client.make_request_async(:get, path_template, options) + + promise = promise.then do |result| + http_response = result.response + status_code = http_response.status + response_content = http_response.body + unless status_code == 200 + error_model = JSON.load(response_content) + fail MsRestAzure::AzureOperationError.new(result.request, http_response, error_model) + end + + result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? + # Deserialize Response + if status_code == 200 + begin + parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) + result_mapper = Azure::ARM::SQL::Models::VnetFirewallRuleListResult.mapper() + result.body = @client.deserialize(result_mapper, parsed_response, 'result.body') + rescue Exception => e + fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result) + end + end + + result + end + + promise.execute + end + + # + # Gets a list of virtual network rules in a server. + # + # @param resource_group_name [String] The name of the resource group that + # contains the resource. You can obtain this value from the Azure Resource + # Manager API or the portal. + # @param server_name [String] The name of the server. + # @param custom_headers [Hash{String => String}] A hash of custom headers that + # will be added to the HTTP request. + # + # @return [VnetFirewallRuleListResult] which provide lazy access to pages of + # the response. + # + def list_by_server_as_lazy(resource_group_name, server_name, custom_headers = nil) + response = list_by_server_async(resource_group_name, server_name, custom_headers).value! + unless response.nil? + page = response.body + page.next_method = Proc.new do |next_page_link| + list_by_server_next_async(next_page_link, custom_headers) + end + page + end + end + + end +end