/* * 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 vpc-lattice-2022-11-30.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.VPCLattice.Model { /// /// Container for the parameters to the CreateRule operation. /// Creates a listener rule. Each listener has a default rule for checking connection /// requests, but you can define additional rules. Each rule consists of a priority, one /// or more actions, and one or more conditions. For more information, see Listener /// rules in the Amazon VPC Lattice User Guide. /// public partial class CreateRuleRequest : AmazonVPCLatticeRequest { private RuleAction _action; private string _clientToken; private string _listenerIdentifier; private RuleMatch _match; private string _name; private int? _priority; private string _serviceIdentifier; private Dictionary _tags = new Dictionary(); /// /// Gets and sets the property Action. /// /// The action for the default rule. /// /// [AWSProperty(Required=true)] public RuleAction Action { get { return this._action; } set { this._action = value; } } // Check to see if Action property is set internal bool IsSetAction() { return this._action != null; } /// /// Gets and sets the property ClientToken. /// /// A unique, case-sensitive identifier that you provide to ensure the idempotency of /// the request. If you retry a request that completed successfully using the same client /// token and parameters, the retry succeeds without performing any actions. If the parameters /// aren't identical, the retry fails. /// /// [AWSProperty(Min=1, Max=64)] 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 ListenerIdentifier. /// /// The ID or Amazon Resource Name (ARN) of the listener. /// /// [AWSProperty(Required=true, Min=20, Max=2048)] public string ListenerIdentifier { get { return this._listenerIdentifier; } set { this._listenerIdentifier = value; } } // Check to see if ListenerIdentifier property is set internal bool IsSetListenerIdentifier() { return this._listenerIdentifier != null; } /// /// Gets and sets the property Match. /// /// The rule match. /// /// [AWSProperty(Required=true)] public RuleMatch Match { get { return this._match; } set { this._match = value; } } // Check to see if Match property is set internal bool IsSetMatch() { return this._match != null; } /// /// Gets and sets the property Name. /// /// The name of the rule. The name must be unique within the listener. The valid characters /// are a-z, 0-9, and hyphens (-). You can't use a hyphen as the first or last character, /// or immediately after another hyphen. /// /// [AWSProperty(Required=true, Min=3, Max=63)] 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 Priority. /// /// The priority assigned to the rule. Each rule for a specific listener must have a unique /// priority. The lower the priority number the higher the priority. /// /// [AWSProperty(Required=true, Min=1, Max=100)] public int Priority { get { return this._priority.GetValueOrDefault(); } set { this._priority = value; } } // Check to see if Priority property is set internal bool IsSetPriority() { return this._priority.HasValue; } /// /// Gets and sets the property ServiceIdentifier. /// /// The ID or Amazon Resource Name (ARN) of the service. /// /// [AWSProperty(Required=true, Min=17, Max=2048)] public string ServiceIdentifier { get { return this._serviceIdentifier; } set { this._serviceIdentifier = value; } } // Check to see if ServiceIdentifier property is set internal bool IsSetServiceIdentifier() { return this._serviceIdentifier != null; } /// /// Gets and sets the property Tags. /// /// The tags for the rule. /// /// [AWSProperty(Min=0, Max=200)] 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; } } }