/// <summary>
 /// The Begin Capturing Role operation creates a copy of the operating
 /// system virtual hard disk (VHD) that is deployed in the virtual
 /// machine, saves the VHD copy in the same storage location as the
 /// operating system VHD, and registers the copy as an image in your
 /// image gallery. From the captured image, you can create additional
 /// customized virtual machines. For more information about images and
 /// disks, see Manage Disks and Images at
 /// http://msdn.microsoft.com/en-us/library/windowsazure/jj672979.aspx.
 /// For more information about capturing images, see How to Capture an
 /// Image of a Virtual Machine Running Windows Server 2008 R2 at
 /// http://www.windowsazure.com/en-us/documentation/articles/virtual-machines-capture-image-windows-server/
 /// or How to Capture an Image of a Virtual Machine Running Linux at
 /// http://www.windowsazure.com/en-us/documentation/articles/virtual-machines-linux-capture-image/.
 /// (see
 /// http://msdn.microsoft.com/en-us/library/windowsazure/jj157201.aspx
 /// for more information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Compute.IVirtualMachineOperations.
 /// </param>
 /// <param name='serviceName'>
 /// Required. The name of your service.
 /// </param>
 /// <param name='deploymentName'>
 /// Required. The name of your deployment.
 /// </param>
 /// <param name='virtualMachineName'>
 /// Required. The name of the virtual machine to restart.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the Begin Capturing Virtual
 /// Machine operation.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static OperationResponse BeginCapturingOSImage(this IVirtualMachineOperations operations, string serviceName, string deploymentName, string virtualMachineName, VirtualMachineCaptureOSImageParameters parameters)
 {
     return Task.Factory.StartNew((object s) => 
     {
         return ((IVirtualMachineOperations)s).BeginCapturingOSImageAsync(serviceName, deploymentName, virtualMachineName, parameters);
     }
     , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult();
 }
        protected PSArgument[] CreateVirtualMachineCaptureOSImageParameters()
        {
            string serviceName = string.Empty;
            string deploymentName = string.Empty;
            string virtualMachineName = string.Empty;
            VirtualMachineCaptureOSImageParameters parameters = new VirtualMachineCaptureOSImageParameters();

            return ConvertFromObjectsToArguments(new string[] { "ServiceName", "DeploymentName", "VirtualMachineName", "Parameters" }, new object[] { serviceName, deploymentName, virtualMachineName, parameters });
        }
 /// <summary>
 /// The Capture Role operation creates a copy of the operating system
 /// virtual hard disk (VHD) that is deployed in the virtual machine,
 /// saves the VHD copy in the same storage location as the operating
 /// system VHD, and registers the copy as an image in your image
 /// gallery. From the captured image, you can create additional
 /// customized virtual machines. For more information about images and
 /// disks, see Manage Disks and Images at
 /// http://msdn.microsoft.com/en-us/library/windowsazure/jj672979.aspx.
 /// For more information about capturing images, see How to Capture an
 /// Image of a Virtual Machine Running Windows Server 2008 R2 at
 /// http://www.windowsazure.com/en-us/documentation/articles/virtual-machines-capture-image-windows-server/
 /// or How to Capture an Image of a Virtual Machine Running Linux at
 /// http://www.windowsazure.com/en-us/documentation/articles/virtual-machines-linux-capture-image/.
 /// (see
 /// http://msdn.microsoft.com/en-us/library/windowsazure/jj157201.aspx
 /// for more information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Compute.IVirtualMachineOperations.
 /// </param>
 /// <param name='serviceName'>
 /// Required. The name of your service.
 /// </param>
 /// <param name='deploymentName'>
 /// Required. The name of your deployment.
 /// </param>
 /// <param name='virtualMachineName'>
 /// Required. The name of the virtual machine to restart.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the Capture Virtual Machine
 /// 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 error information regarding
 /// the failure.
 /// </returns>
 public static Task<OperationStatusResponse> CaptureOSImageAsync(this IVirtualMachineOperations operations, string serviceName, string deploymentName, string virtualMachineName, VirtualMachineCaptureOSImageParameters parameters)
 {
     return operations.CaptureOSImageAsync(serviceName, deploymentName, virtualMachineName, parameters, CancellationToken.None);
 }