/// <summary>
 /// Update a job collection.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Scheduler.IJobCollectionOperations.
 /// </param>
 /// <param name='cloudServiceName'>
 /// The name of the cloud service containing the job collection.
 /// </param>
 /// <param name='jobCollectionName'>
 /// The name of the job collection to update.
 /// </param>
 /// <param name='parameters'>
 /// Parameters supplied to the Update Job Collection operation.
 /// </param>
 /// <returns>
 /// The response body contains the status of the specified asynchronous
 /// operation, indicating whether it has succeeded, is inprogress, or
 /// has failed. Note that this status is distinct from the HTTP status
 /// code returned for the Get Operation Status operation itself.  If
 /// the asynchronous operation succeeded, the response body includes
 /// the HTTP status code for the successful request.  If the
 /// asynchronous operation failed, the response body includes the HTTP
 /// status code for the failed request, and also includes error
 /// information regarding the failure.
 /// </returns>
 public static Task<SchedulerOperationStatusResponse> UpdateAsync(this IJobCollectionOperations operations, string cloudServiceName, string jobCollectionName, JobCollectionUpdateParameters parameters)
 {
     return operations.UpdateAsync(cloudServiceName, jobCollectionName, parameters, CancellationToken.None);
 }
 /// <summary>
 /// Update a job collection.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Scheduler.IJobCollectionOperations.
 /// </param>
 /// <param name='cloudServiceName'>
 /// The name of the cloud service containing the job collection.
 /// </param>
 /// <param name='jobCollectionName'>
 /// The name of the job collection to update.
 /// </param>
 /// <param name='parameters'>
 /// Parameters supplied to the Update Job Collection operation.
 /// </param>
 /// <returns>
 /// The response body contains the status of the specified asynchronous
 /// operation, indicating whether it has succeeded, is inprogress, or
 /// has failed. Note that this status is distinct from the HTTP status
 /// code returned for the Get Operation Status operation itself.  If
 /// the asynchronous operation succeeded, the response body includes
 /// the HTTP status code for the successful request.  If the
 /// asynchronous operation failed, the response body includes the HTTP
 /// status code for the failed request, and also includes error
 /// information regarding the failure.
 /// </returns>
 public static SchedulerOperationStatusResponse Update(this IJobCollectionOperations operations, string cloudServiceName, string jobCollectionName, JobCollectionUpdateParameters parameters)
 {
     try
     {
         return operations.UpdateAsync(cloudServiceName, jobCollectionName, parameters).Result;
     }
     catch (AggregateException ex)
     {
         if (ex.InnerExceptions.Count > 1)
         {
             throw;
         }
         else
         {
             throw ex.InnerException;
         }
     }
 }
        /// <summary>
        /// Updates a job collection
        /// </summary>
        /// <param name="jobCollectionRequest">The job collection request</param>
        /// <param name="status">Status of update operation</param>
        /// <returns>The updated job collection</returns>
        public PSJobCollection UpdateJobCollection(PSCreateJobCollectionParams jobCollectionRequest, out string status)
        {
            if (!this.AvailableRegions.Contains(jobCollectionRequest.Region, StringComparer.OrdinalIgnoreCase))
                throw new Exception(Resources.SchedulerInvalidLocation);

            //Get existing job collection
            JobCollectionGetResponse jcGetResponse = schedulerManagementClient.JobCollections.Get(
                cloudServiceName: jobCollectionRequest.Region.ToCloudServiceName(),
                jobCollectionName: jobCollectionRequest.JobCollectionName);

            JobCollectionUpdateParameters jcUpdateParams = new JobCollectionUpdateParameters
            {
                IntrinsicSettings = jcGetResponse.IntrinsicSettings,
                ETag = jcGetResponse.ETag,
                Label = jcGetResponse.Label                
            };

            if (!string.IsNullOrWhiteSpace(jobCollectionRequest.JobCollectionPlan))
            {
                jcUpdateParams.IntrinsicSettings.Plan = (JobCollectionPlan)Enum.Parse(typeof(JobCollectionPlan), jobCollectionRequest.JobCollectionPlan);
            }

            if (jobCollectionRequest.MaxJobCount.HasValue)
            {
                if (jcUpdateParams.IntrinsicSettings.Quota != null)
                {
                    jcUpdateParams.IntrinsicSettings.Quota.MaxJobCount = jobCollectionRequest.MaxJobCount;
                }
                else
                {
                    jcUpdateParams.IntrinsicSettings.Quota = new JobCollectionQuota { MaxJobCount = jobCollectionRequest.MaxJobCount };
                }
            }

            if (jobCollectionRequest.MaxJobInterval.HasValue)
            {
                if (jcUpdateParams.IntrinsicSettings.Quota != null)
                {
                    if (jcUpdateParams.IntrinsicSettings.Quota.MaxRecurrence != null)
                    {
                        jcUpdateParams.IntrinsicSettings.Quota.MaxRecurrence.Interval = jobCollectionRequest.MaxJobInterval.Value;
                    }
                    else
                    {
                        jcUpdateParams.IntrinsicSettings.Quota.MaxRecurrence = new JobCollectionMaxRecurrence
                        {
                            Interval = jobCollectionRequest.MaxJobInterval.Value
                        };
                    }
                }
                else
                {
                    jcUpdateParams.IntrinsicSettings.Quota = new JobCollectionQuota
                    {
                        MaxRecurrence = new JobCollectionMaxRecurrence
                        {
                            Interval = jobCollectionRequest.MaxJobInterval.Value
                        }
                    };
                }
            }

            if (!string.IsNullOrWhiteSpace(jobCollectionRequest.MaxJobFrequency))
            {
                if (jcUpdateParams.IntrinsicSettings.Quota != null)
                {
                    if (jcUpdateParams.IntrinsicSettings.Quota.MaxRecurrence != null)
                    {
                        jcUpdateParams.IntrinsicSettings.Quota.MaxRecurrence.Frequency = (JobCollectionRecurrenceFrequency)Enum.Parse(typeof(JobCollectionRecurrenceFrequency), jobCollectionRequest.MaxJobFrequency);
                    }
                    else
                    {
                        jcUpdateParams.IntrinsicSettings.Quota.MaxRecurrence = new JobCollectionMaxRecurrence
                        {
                            Frequency = (JobCollectionRecurrenceFrequency)Enum.Parse(typeof(JobCollectionRecurrenceFrequency), jobCollectionRequest.MaxJobFrequency)
                        };
                    }
                }
                else
                {
                    jcUpdateParams.IntrinsicSettings.Quota = new JobCollectionQuota
                    {
                        MaxRecurrence = new JobCollectionMaxRecurrence
                        {
                            Frequency = (JobCollectionRecurrenceFrequency)Enum.Parse(typeof(JobCollectionRecurrenceFrequency), jobCollectionRequest.MaxJobFrequency)
                        }                    
                    };
                }
            }

            SchedulerOperationStatusResponse response = schedulerManagementClient.JobCollections.Update(
                cloudServiceName: jobCollectionRequest.Region.ToCloudServiceName(), 
                jobCollectionName: jobCollectionRequest.JobCollectionName,
                parameters: jcUpdateParams);

            status = response.StatusCode.ToString().Equals("OK") ? "Job Collection has been updated" : response.StatusCode.ToString();

            return GetJobCollection(jobCollectionRequest.Region, jobCollectionRequest.JobCollectionName).FirstOrDefault();
        }
 /// <summary>
 /// Update a job collection.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Scheduler.IJobCollectionOperations.
 /// </param>
 /// <param name='cloudServiceName'>
 /// The name of the cloud service containing the job collection.
 /// </param>
 /// <param name='jobCollectionName'>
 /// The name of the job collection to update.
 /// </param>
 /// <param name='parameters'>
 /// Parameters supplied to the Update Job Collection operation.
 /// </param>
 /// <returns>
 /// The Update Job Collection operation response.
 /// </returns>
 public static Task<JobCollectionUpdateResponse> BeginUpdatingAsync(this IJobCollectionOperations operations, string cloudServiceName, string jobCollectionName, JobCollectionUpdateParameters parameters)
 {
     return operations.BeginUpdatingAsync(cloudServiceName, jobCollectionName, parameters, CancellationToken.None);
 }
 /// <summary>
 /// Update a job collection.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Scheduler.IJobCollectionOperations.
 /// </param>
 /// <param name='cloudServiceName'>
 /// Required. The name of the cloud service containing the job
 /// collection.
 /// </param>
 /// <param name='jobCollectionName'>
 /// Required. The name of the job collection to update.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the Update Job Collection
 /// operation.
 /// </param>
 /// <returns>
 /// The response body contains the status of the specified asynchronous
 /// operation, indicating whether it has succeeded, is inprogress, or
 /// has failed. Note that this status is distinct from the HTTP status
 /// code returned for the Get Operation Status operation itself.  If
 /// the asynchronous operation succeeded, the response body includes
 /// the HTTP status code for the successful request.  If the
 /// asynchronous operation failed, the response body includes the HTTP
 /// status code for the failed request, and also includes error
 /// information regarding the failure.
 /// </returns>
 public static SchedulerOperationStatusResponse Update(this IJobCollectionOperations operations, string cloudServiceName, string jobCollectionName, JobCollectionUpdateParameters parameters)
 {
     return Task.Factory.StartNew((object s) => 
     {
         return ((IJobCollectionOperations)s).UpdateAsync(cloudServiceName, jobCollectionName, parameters);
     }
     , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult();
 }