/// <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(); }