/// <summary>
 /// Update a certificate.  (see
 /// http://aka.ms/azureautomationsdk/certificateoperations for more
 /// information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.Azure.Management.Automation.ICertificateOperations.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Required. The name of the resource group
 /// </param>
 /// <param name='automationAccount'>
 /// Required. The automation account name.
 /// </param>
 /// <param name='parameters'>
 /// Required. The parameters supplied to the patch certificate
 /// operation.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static Task<AzureOperationResponse> PatchAsync(this ICertificateOperations operations, string resourceGroupName, string automationAccount, CertificatePatchParameters parameters)
 {
     return operations.PatchAsync(resourceGroupName, automationAccount, parameters, CancellationToken.None);
 }
        public CertificateInfo UpdateCertificate(string resourceGroupName, string automationAccountName, string name, string path,
            SecureString password,
            string description, bool? exportable)
        {
            if (String.IsNullOrWhiteSpace(path) && (password != null || exportable.HasValue))
            {
                throw new ResourceCommonException(typeof (CertificateInfo),
                    string.Format(CultureInfo.CurrentCulture, Resources.SetCertificateInvalidArgs, name));
            }

            var certificateModel = this.TryGetCertificateModel(resourceGroupName, automationAccountName, name);
            if (certificateModel == null)
            {
                throw new ResourceCommonException(typeof (CertificateInfo),
                    string.Format(CultureInfo.CurrentCulture, Resources.CertificateNotFound, name));
            }

            var createOrUpdateDescription = description ?? certificateModel.Properties.Description;
            var createOrUpdateIsExportable = (exportable.HasValue)
                ? exportable.Value
                : certificateModel.Properties.IsExportable;

            if (path != null)
            {
                return this.CreateCertificateInternal(resourceGroupName, automationAccountName, name, path, password,
                    createOrUpdateDescription,
                    createOrUpdateIsExportable);
            }

            var cuparam = new CertificatePatchParameters()
            {
                Name = name,
                Properties = new CertificatePatchProperties()
                {
                    Description = createOrUpdateDescription
                }
            };

            this.automationManagementClient.Certificates.Patch(resourceGroupName, automationAccountName, cuparam);

            return new CertificateInfo(resourceGroupName, automationAccountName,
                this.automationManagementClient.Certificates.Get(resourceGroupName, automationAccountName, name).Certificate);
        }
 /// <summary>
 /// Update a certificate.  (see
 /// http://aka.ms/azureautomationsdk/certificateoperations for more
 /// information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.Azure.Management.Automation.ICertificateOperations.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Required. The name of the resource group
 /// </param>
 /// <param name='automationAccount'>
 /// Required. The automation account name.
 /// </param>
 /// <param name='parameters'>
 /// Required. The parameters supplied to the patch certificate
 /// operation.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static AzureOperationResponse Patch(this ICertificateOperations operations, string resourceGroupName, string automationAccount, CertificatePatchParameters parameters)
 {
     return Task.Factory.StartNew((object s) => 
     {
         return ((ICertificateOperations)s).PatchAsync(resourceGroupName, automationAccount, parameters);
     }
     , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult();
 }