/* * 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 m2-2021-04-28.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.MainframeModernization.Model { /// <summary> /// Container for the parameters to the CreateApplication operation. /// Creates a new application with given parameters. Requires an existing runtime environment /// and application definition file. /// </summary> public partial class CreateApplicationRequest : AmazonMainframeModernizationRequest { private string _clientToken; private Definition _definition; private string _description; private EngineType _engineType; private string _kmsKeyId; private string _name; private string _roleArn; private Dictionary<string, string> _tags = new Dictionary<string, string>(); /// <summary> /// Gets and sets the property ClientToken. /// <para> /// Unique, case-sensitive identifier the service generates to ensure the idempotency /// of the request to create an application. The service generates the clientToken when /// the API call is triggered. The token expires after one hour, so if you retry the API /// within this timeframe with the same clientToken, you will get the same response. The /// service also handles deleting the clientToken after it expires. /// </para> /// </summary> 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; } /// <summary> /// Gets and sets the property Definition. /// <para> /// The application definition for this application. You can specify either inline JSON /// or an S3 bucket location. /// </para> /// </summary> [AWSProperty(Required=true)] public Definition Definition { get { return this._definition; } set { this._definition = value; } } // Check to see if Definition property is set internal bool IsSetDefinition() { return this._definition != null; } /// <summary> /// Gets and sets the property Description. /// <para> /// The description of the application. /// </para> /// </summary> [AWSProperty(Min=0, Max=500)] 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; } /// <summary> /// Gets and sets the property EngineType. /// <para> /// The type of the target platform for this application. /// </para> /// </summary> [AWSProperty(Required=true)] public EngineType EngineType { get { return this._engineType; } set { this._engineType = value; } } // Check to see if EngineType property is set internal bool IsSetEngineType() { return this._engineType != null; } /// <summary> /// Gets and sets the property KmsKeyId. /// <para> /// The identifier of a customer managed key. /// </para> /// </summary> public string KmsKeyId { get { return this._kmsKeyId; } set { this._kmsKeyId = value; } } // Check to see if KmsKeyId property is set internal bool IsSetKmsKeyId() { return this._kmsKeyId != null; } /// <summary> /// Gets and sets the property Name. /// <para> /// The unique identifier of the application. /// </para> /// </summary> [AWSProperty(Required=true)] 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; } /// <summary> /// Gets and sets the property RoleArn. /// <para> /// The Amazon Resource Name (ARN) that identifies a role that the application uses to /// access Amazon Web Services resources that are not part of the application or are in /// a different Amazon Web Services account. /// </para> /// </summary> public string RoleArn { get { return this._roleArn; } set { this._roleArn = value; } } // Check to see if RoleArn property is set internal bool IsSetRoleArn() { return this._roleArn != null; } /// <summary> /// Gets and sets the property Tags. /// <para> /// A list of tags to apply to the application. /// </para> /// </summary> [AWSProperty(Min=0, Max=200)] public Dictionary<string, string> 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; } } }