/* * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ /* * Do not modify this file. This file is generated from the imagebuilder-2019-12-02.normal.json service model. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; using System.Net; using Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.Imagebuilder.Model { /// /// Container for the parameters to the ImportVmImage operation. /// When you export your virtual machine (VM) from its virtualization environment, that /// process creates a set of one or more disk container files that act as snapshots of /// your VM’s environment, settings, and data. The Amazon EC2 API ImportImage /// action uses those files to import your VM and create an AMI. To import using the CLI /// command, see import-image /// /// /// /// /// You can reference the task ID from the VM import to pull in the AMI that the import /// created as the base image for your Image Builder recipe. /// /// public partial class ImportVmImageRequest : AmazonImagebuilderRequest { private string _clientToken; private string _description; private string _name; private string _osVersion; private Platform _platform; private string _semanticVersion; private Dictionary _tags = new Dictionary(); private string _vmImportTaskId; /// /// Gets and sets the property ClientToken. /// /// Unique, case-sensitive identifier you provide to ensure idempotency of the request. /// For more information, see Ensuring /// idempotency in the Amazon EC2 API Reference. /// /// [AWSProperty(Min=1, Max=36)] public string ClientToken { get { return this._clientToken; } set { this._clientToken = value; } } // Check to see if ClientToken property is set internal bool IsSetClientToken() { return this._clientToken != null; } /// /// Gets and sets the property Description. /// /// The description for the base image that is created by the import process. /// /// [AWSProperty(Min=1, Max=1024)] public string Description { get { return this._description; } set { this._description = value; } } // Check to see if Description property is set internal bool IsSetDescription() { return this._description != null; } /// /// Gets and sets the property Name. /// /// The name of the base image that is created by the import process. /// /// [AWSProperty(Required=true, Min=1, Max=1024)] public string Name { get { return this._name; } set { this._name = value; } } // Check to see if Name property is set internal bool IsSetName() { return this._name != null; } /// /// Gets and sets the property OsVersion. /// /// The operating system version for the imported VM. /// /// [AWSProperty(Min=1)] public string OsVersion { get { return this._osVersion; } set { this._osVersion = value; } } // Check to see if OsVersion property is set internal bool IsSetOsVersion() { return this._osVersion != null; } /// /// Gets and sets the property Platform. /// /// The operating system platform for the imported VM. /// /// [AWSProperty(Required=true)] public Platform Platform { get { return this._platform; } set { this._platform = value; } } // Check to see if Platform property is set internal bool IsSetPlatform() { return this._platform != null; } /// /// Gets and sets the property SemanticVersion. /// /// The semantic version to attach to the base image that was created during the import /// process. This version follows the semantic version syntax. /// /// /// /// The semantic version has four nodes: <major>.<minor>.<patch>/<build>. /// You can assign values for the first three, and can filter on all of them. /// /// /// /// Assignment: For the first three nodes you can assign any positive integer /// value, including zero, with an upper limit of 2^30-1, or 1073741823 for each node. /// Image Builder automatically assigns the build number to the fourth node. /// /// /// /// Patterns: You can use any numeric pattern that adheres to the assignment requirements /// for the nodes that you can assign. For example, you might choose a software version /// pattern, such as 1.0.0, or a date, such as 2021.01.01. /// /// /// [AWSProperty(Required=true)] public string SemanticVersion { get { return this._semanticVersion; } set { this._semanticVersion = value; } } // Check to see if SemanticVersion property is set internal bool IsSetSemanticVersion() { return this._semanticVersion != null; } /// /// Gets and sets the property Tags. /// /// Tags that are attached to the import resources. /// /// [AWSProperty(Min=1, Max=50)] public Dictionary Tags { get { return this._tags; } set { this._tags = value; } } // Check to see if Tags property is set internal bool IsSetTags() { return this._tags != null && this._tags.Count > 0; } /// /// Gets and sets the property VmImportTaskId. /// /// The importTaskId (API) or ImportTaskId (CLI) from the Amazon /// EC2 VM import process. Image Builder retrieves information from the import process /// to pull in the AMI that is created from the VM source as the base image for your recipe. /// /// [AWSProperty(Required=true, Min=1, Max=1024)] public string VmImportTaskId { get { return this._vmImportTaskId; } set { this._vmImportTaskId = value; } } // Check to see if VmImportTaskId property is set internal bool IsSetVmImportTaskId() { return this._vmImportTaskId != null; } } }