/// <summary> /// Updates an add-on plan. /// </summary> /// <param name="name">The add-on name</param> /// <param name="plan">The add-on new plan id</param> /// <param name="promotionCode">The plan promotion code</param> public virtual void UpdateAddOn(string name, string plan, string promotionCode) { List<WindowsAzureAddOn> addons = GetAddOn(new AddOnSearchOptions(name)); if (addons.Count != 1) { throw new Exception(string.Format(Resources.AddOnNotFound, name)); } WindowsAzureAddOn addon = addons[0]; if (!string.IsNullOrEmpty(promotionCode) && addon.Plan.Equals(plan, StringComparison.OrdinalIgnoreCase)) { throw new Exception(Resources.PromotionCodeWithCurrentPlanMessage); } string type; string cloudServiceName; addon.AddOn = GetResourceInformation(addon.AddOn, addon.Location, out type, out cloudServiceName); AddOnUpdateParameters parameters = new AddOnUpdateParameters() { Plan = plan, Type = type, PromotionCode = promotionCode }; try { storeClient.AddOns.Update(cloudServiceName, addon.AddOn, name, parameters); } catch (Exception ex) { if (ex.Message.Equals(Resources.FirstPurchaseErrorMessage, StringComparison.OrdinalIgnoreCase)) { throw new Exception(Resources.FirstPurchaseMessage); } } }
/// <summary> /// The Update Store Item operation creates Windows Azure Store entries /// in a Windows Azure subscription. /// </summary> /// <param name='operations'> /// Reference to the /// Microsoft.WindowsAzure.Management.Store.IAddOnOperations. /// </param> /// <param name='cloudServiceName'> /// The name of the cloud service to which this store item will be /// assigned. /// </param> /// <param name='resourceName'> /// The name of this resource. /// </param> /// <param name='addOnName'> /// The addon name. /// </param> /// <param name='parameters'> /// Parameters used to specify how the Create procedure will function. /// </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 AddOnOperationStatusResponse Update(this IAddOnOperations operations, string cloudServiceName, string resourceName, string addOnName, AddOnUpdateParameters parameters) { try { return operations.UpdateAsync(cloudServiceName, resourceName, addOnName, parameters).Result; } catch (AggregateException ex) { if (ex.InnerExceptions.Count > 1) { throw; } else { throw ex.InnerException; } } }
/// <summary> /// The Update Store Item operation creates Windows Azure Store entries /// in a Windows Azure subscription. /// </summary> /// <param name='operations'> /// Reference to the /// Microsoft.WindowsAzure.Management.Store.IAddOnOperations. /// </param> /// <param name='cloudServiceName'> /// The name of the cloud service to which this store item will be /// assigned. /// </param> /// <param name='resourceName'> /// The name of this resource. /// </param> /// <param name='addOnName'> /// The addon name. /// </param> /// <param name='parameters'> /// Parameters used to specify how the Create procedure will function. /// </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<AddOnOperationStatusResponse> UpdateAsync(this IAddOnOperations operations, string cloudServiceName, string resourceName, string addOnName, AddOnUpdateParameters parameters) { return operations.UpdateAsync(cloudServiceName, resourceName, addOnName, parameters, CancellationToken.None); }
/// <summary> /// The Update Store Item operation creates Windows Azure Store entries /// in a Windows Azure subscription. /// </summary> /// <param name='operations'> /// Reference to the /// Microsoft.WindowsAzure.Management.Store.IAddOnOperations. /// </param> /// <param name='cloudServiceName'> /// Required. The name of the cloud service to which this store item /// will be assigned. /// </param> /// <param name='resourceName'> /// Required. The name of this resource. /// </param> /// <param name='addOnName'> /// Required. The addon name. /// </param> /// <param name='parameters'> /// Required. Parameters used to specify how the Create procedure will /// function. /// </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 OperationStatusResponse Update(this IAddOnOperations operations, string cloudServiceName, string resourceName, string addOnName, AddOnUpdateParameters parameters) { return Task.Factory.StartNew((object s) => { return ((IAddOnOperations)s).UpdateAsync(cloudServiceName, resourceName, addOnName, parameters); } , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult(); }