/// <summary>
 /// Begins creating a new Azure SQL Database Failover Group or updating
 /// an existing Azure SQL Database Failover Group. To determine the
 /// status of the operation call GetFailoverGroupOperationStatus.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.Azure.Management.Sql.IFailoverGroupOperations.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Required. The name of the Resource Group to which the Azure SQL
 /// Database Server belongs.
 /// </param>
 /// <param name='serverName'>
 /// Required. The name of the Azure SQL Database Server on which the
 /// database is hosted.
 /// </param>
 /// <param name='failoverGroupName'>
 /// Required. The name of the Azure SQL Database Failover Group to be
 /// operated on (Updated or created).
 /// </param>
 /// <param name='parameters'>
 /// Required. The required parameters for createing or updating an
 /// Failover Group.
 /// </param>
 /// <returns>
 /// Response for long running Azure Sql Database Failover Group
 /// operation.
 /// </returns>
 public static FailoverGroupCreateOrUpdateResponse BeginCreateOrUpdate(this IFailoverGroupOperations operations, string resourceGroupName, string serverName, string failoverGroupName, FailoverGroupCreateOrUpdateParameters parameters)
 {
     return(Task.Factory.StartNew((object s) =>
     {
         return ((IFailoverGroupOperations)s).BeginCreateOrUpdateAsync(resourceGroupName, serverName, failoverGroupName, parameters);
     }
                                  , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult());
 }
        /// <summary>
        /// Creates or updates an Failover Group
        /// </summary>
        public Management.Sql.Models.FailoverGroup CreateOrUpdate(string resourceGroupName, string serverName, string FailoverGroupName, string clientRequestId, FailoverGroupCreateOrUpdateParameters parameters)
        {
            var resp = GetCurrentSqlClient(clientRequestId).FailoverGroups.CreateOrUpdate(resourceGroupName, serverName, FailoverGroupName, parameters);

            return(resp.FailoverGroup);
        }
 /// <summary>
 /// Creates a new Azure SQL Database Failover Group or updates an
 /// existing Azure SQL Database Failover Group.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.Azure.Management.Sql.IFailoverGroupOperations.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Required. The name of the Resource Group to which the Azure SQL
 /// Database Server belongs.
 /// </param>
 /// <param name='serverName'>
 /// Required. The name of the Azure SQL Database Server on which the
 /// Azure SQL Database Failover Group is hosted.
 /// </param>
 /// <param name='failoverGroupName'>
 /// Required. The name of the Azure SQL Database Failover Group to be
 /// operated on (updated or created).
 /// </param>
 /// <param name='parameters'>
 /// Required. The required parameters for creating or updating an Azure
 /// Sql Databaser Failover Group.
 /// </param>
 /// <returns>
 /// Response for long running Azure Sql Database Failover Group
 /// operation.
 /// </returns>
 public static Task <FailoverGroupCreateOrUpdateResponse> CreateOrUpdateAsync(this IFailoverGroupOperations operations, string resourceGroupName, string serverName, string failoverGroupName, FailoverGroupCreateOrUpdateParameters parameters)
 {
     return(operations.CreateOrUpdateAsync(resourceGroupName, serverName, failoverGroupName, parameters, CancellationToken.None));
 }