protected void ExecuteVirtualMachineVMImageCreateMethod(object[] invokeMethodInputParameters)
        {
            VirtualMachineVMImageCreateParameters parameters = (VirtualMachineVMImageCreateParameters)ParseParameter(invokeMethodInputParameters[0]);

            var result = VirtualMachineVMImageClient.Create(parameters);

            WriteObject(result);
        }
        protected PSArgument[] CreateVirtualMachineVMImageCreateParameters()
        {
            VirtualMachineVMImageCreateParameters parameters = new VirtualMachineVMImageCreateParameters();

            return(ConvertFromObjectsToArguments(new string[] { "Parameters" }, new object[] { parameters }));
        }
Пример #3
0
        protected override void OnProcessRecord()
        {
            ServiceManagementProfile.Initialize();

            if (string.Equals(ParameterSetName, VMImageParamSet, StringComparison.OrdinalIgnoreCase))
            {
                var osDiskConfig    = DiskConfig == null ? null : DiskConfig.OSDiskConfiguration;
                var dataDiskConfigs =
                    (DiskConfig == null || DiskConfig.DataDiskConfigurations == null)
                    ? null
                    : DiskConfig.DataDiskConfigurations.ToList();

                var parameters = new VirtualMachineVMImageCreateParameters
                {
                    Name = this.ImageName,
                    OSDiskConfiguration = osDiskConfig == null ? null : new OSDiskConfigurationCreateParameters
                    {
                        OS          = osDiskConfig.OS,
                        OSState     = osDiskConfig.OSState,
                        HostCaching = osDiskConfig.HostCaching,
                        MediaLink   = osDiskConfig.MediaLink
                    },
                    DataDiskConfigurations = dataDiskConfigs == null ? null : dataDiskConfigs.Select(d => new DataDiskConfigurationCreateParameters
                    {
                        HostCaching       = d.HostCaching,
                        LogicalUnitNumber = d.Lun,
                        MediaLink         = d.MediaLink
                    }).ToList(),
                    Label             = string.IsNullOrEmpty(this.Label) ? this.ImageName : this.Label,
                    Eula              = this.Eula,
                    Description       = this.Description,
                    ImageFamily       = this.ImageFamily,
                    PublishedDate     = this.PublishedDate,
                    PrivacyUri        = this.PrivacyUri,
                    RecommendedVMSize = this.RecommendedVMSize,
                    IconUri           = this.IconName,
                    SmallIconUri      = this.SmallIconName,
                    ShowInGui         = this.ShowInGui
                };

                this.ExecuteClientActionNewSM(
                    null,
                    this.CommandRuntime.ToString(),
                    () => this.ComputeClient.VirtualMachineVMImages.Create(parameters));
            }
            else
            {
                var parameters = new VirtualMachineOSImageCreateParameters
                {
                    Name                = this.ImageName,
                    MediaLinkUri        = new Uri(this.MediaLocation),
                    Label               = string.IsNullOrEmpty(this.Label) ? this.ImageName : this.Label,
                    OperatingSystemType = this.OS,
                    Eula                = this.Eula,
                    Description         = this.Description,
                    ImageFamily         = this.ImageFamily,
                    PublishedDate       = this.PublishedDate,
                    PrivacyUri          = this.PrivacyUri,
                    RecommendedVMSize   = this.RecommendedVMSize,
                    IconUri             = this.IconName,
                    SmallIconUri        = this.SmallIconName,
                    ShowInGui           = this.ShowInGui
                };

                this.ExecuteClientActionNewSM(
                    null,
                    this.CommandRuntime.ToString(),
                    () => this.ComputeClient.VirtualMachineOSImages.Create(parameters),
                    (s, response) => this.ContextFactory(response, s,
                                                         ServiceManagementProfile.Mapper.Map <VirtualMachineOSImageCreateResponse, OSImageContext>,
                                                         ServiceManagementProfile.Mapper.Map));
            }
        }
Пример #4
0
 /// <summary>
 /// The Create VM Image operation creates a VM image that in your image
 /// repository.  (see
 /// http://msdn.microsoft.com/en-us/library/azure/dn775054.aspx for
 /// more information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Compute.IVirtualMachineVMImageOperations.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the virtual machine VM image
 /// create operation.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static Task <AzureOperationResponse> BeginCreatingAsync(this IVirtualMachineVMImageOperations operations, VirtualMachineVMImageCreateParameters parameters)
 {
     return(operations.BeginCreatingAsync(parameters, CancellationToken.None));
 }
Пример #5
0
 /// <summary>
 /// The Create VM Image operation creates a VM image that in your image
 /// repository.  (see
 /// http://msdn.microsoft.com/en-us/library/azure/dn775054.aspx for
 /// more information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Compute.IVirtualMachineVMImageOperations.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the virtual machine VM image
 /// create operation.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static AzureOperationResponse BeginCreating(this IVirtualMachineVMImageOperations operations, VirtualMachineVMImageCreateParameters parameters)
 {
     return(Task.Factory.StartNew((object s) =>
     {
         return ((IVirtualMachineVMImageOperations)s).BeginCreatingAsync(parameters);
     }
                                  , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult());
 }
Пример #6
0
 /// <summary>
 /// The Create VM Image operation creates a VM image that in your image
 /// repository.  (see
 /// http://msdn.microsoft.com/en-us/library/azure/dn775054.aspx for
 /// more information)
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Compute.IVirtualMachineVMImageOperations.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the Create Virtual Machine Image
 /// 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> CreateAsync(this IVirtualMachineVMImageOperations operations, VirtualMachineVMImageCreateParameters parameters)
 {
     return(operations.CreateAsync(parameters, CancellationToken.None));
 }