/* * 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 ec2-2016-11-15.normal.json service model. */ using System; using System.Collections.Generic; using System.Globalization; using System.IO; using System.Text; using System.Xml.Serialization; using Amazon.EC2.Model; using Amazon.Runtime; using Amazon.Runtime.Internal; using Amazon.Runtime.Internal.Transform; using Amazon.Runtime.Internal.Util; namespace Amazon.EC2.Model.Internal.MarshallTransformations { /// /// CreateClientVpnEndpoint Request Marshaller /// public class CreateClientVpnEndpointRequestMarshaller : IMarshaller , IMarshaller { /// /// Marshaller the request object to the HTTP request. /// /// /// public IRequest Marshall(AmazonWebServiceRequest input) { return this.Marshall((CreateClientVpnEndpointRequest)input); } /// /// Marshaller the request object to the HTTP request. /// /// /// public IRequest Marshall(CreateClientVpnEndpointRequest publicRequest) { IRequest request = new DefaultRequest(publicRequest, "Amazon.EC2"); request.Parameters.Add("Action", "CreateClientVpnEndpoint"); request.Parameters.Add("Version", "2016-11-15"); if(publicRequest != null) { if(publicRequest.IsSetAuthenticationOptions()) { int publicRequestlistValueIndex = 1; foreach(var publicRequestlistValue in publicRequest.AuthenticationOptions) { if(publicRequestlistValue.IsSetActiveDirectory()) { if(publicRequestlistValue.ActiveDirectory.IsSetDirectoryId()) { request.Parameters.Add("Authentication" + "." + publicRequestlistValueIndex + "." + "ActiveDirectory" + "." + "DirectoryId", StringUtils.FromString(publicRequestlistValue.ActiveDirectory.DirectoryId)); } } if(publicRequestlistValue.IsSetFederatedAuthentication()) { if(publicRequestlistValue.FederatedAuthentication.IsSetSAMLProviderArn()) { request.Parameters.Add("Authentication" + "." + publicRequestlistValueIndex + "." + "FederatedAuthentication" + "." + "SAMLProviderArn", StringUtils.FromString(publicRequestlistValue.FederatedAuthentication.SAMLProviderArn)); } if(publicRequestlistValue.FederatedAuthentication.IsSetSelfServiceSAMLProviderArn()) { request.Parameters.Add("Authentication" + "." + publicRequestlistValueIndex + "." + "FederatedAuthentication" + "." + "SelfServiceSAMLProviderArn", StringUtils.FromString(publicRequestlistValue.FederatedAuthentication.SelfServiceSAMLProviderArn)); } } if(publicRequestlistValue.IsSetMutualAuthentication()) { if(publicRequestlistValue.MutualAuthentication.IsSetClientRootCertificateChainArn()) { request.Parameters.Add("Authentication" + "." + publicRequestlistValueIndex + "." + "MutualAuthentication" + "." + "ClientRootCertificateChainArn", StringUtils.FromString(publicRequestlistValue.MutualAuthentication.ClientRootCertificateChainArn)); } } if(publicRequestlistValue.IsSetType()) { request.Parameters.Add("Authentication" + "." + publicRequestlistValueIndex + "." + "Type", StringUtils.FromString(publicRequestlistValue.Type)); } publicRequestlistValueIndex++; } } if(publicRequest.IsSetClientCidrBlock()) { request.Parameters.Add("ClientCidrBlock", StringUtils.FromString(publicRequest.ClientCidrBlock)); } if(publicRequest.IsSetClientConnectOptions()) { if(publicRequest.ClientConnectOptions.IsSetEnabled()) { request.Parameters.Add("ClientConnectOptions" + "." + "Enabled", StringUtils.FromBool(publicRequest.ClientConnectOptions.Enabled)); } if(publicRequest.ClientConnectOptions.IsSetLambdaFunctionArn()) { request.Parameters.Add("ClientConnectOptions" + "." + "LambdaFunctionArn", StringUtils.FromString(publicRequest.ClientConnectOptions.LambdaFunctionArn)); } } if(publicRequest.IsSetClientLoginBannerOptions()) { if(publicRequest.ClientLoginBannerOptions.IsSetBannerText()) { request.Parameters.Add("ClientLoginBannerOptions" + "." + "BannerText", StringUtils.FromString(publicRequest.ClientLoginBannerOptions.BannerText)); } if(publicRequest.ClientLoginBannerOptions.IsSetEnabled()) { request.Parameters.Add("ClientLoginBannerOptions" + "." + "Enabled", StringUtils.FromBool(publicRequest.ClientLoginBannerOptions.Enabled)); } } if(publicRequest.IsSetClientToken()) { request.Parameters.Add("ClientToken", StringUtils.FromString(publicRequest.ClientToken)); } else if(!(publicRequest.IsSetClientToken())) { request.Parameters.Add("ClientToken", StringUtils.FromString(Guid.NewGuid().ToString())); } if(publicRequest.IsSetConnectionLogOptions()) { if(publicRequest.ConnectionLogOptions.IsSetCloudwatchLogGroup()) { request.Parameters.Add("ConnectionLogOptions" + "." + "CloudwatchLogGroup", StringUtils.FromString(publicRequest.ConnectionLogOptions.CloudwatchLogGroup)); } if(publicRequest.ConnectionLogOptions.IsSetCloudwatchLogStream()) { request.Parameters.Add("ConnectionLogOptions" + "." + "CloudwatchLogStream", StringUtils.FromString(publicRequest.ConnectionLogOptions.CloudwatchLogStream)); } if(publicRequest.ConnectionLogOptions.IsSetEnabled()) { request.Parameters.Add("ConnectionLogOptions" + "." + "Enabled", StringUtils.FromBool(publicRequest.ConnectionLogOptions.Enabled)); } } if(publicRequest.IsSetDescription()) { request.Parameters.Add("Description", StringUtils.FromString(publicRequest.Description)); } if(publicRequest.IsSetDnsServers()) { int publicRequestlistValueIndex = 1; foreach(var publicRequestlistValue in publicRequest.DnsServers) { request.Parameters.Add("DnsServers" + "." + publicRequestlistValueIndex, StringUtils.FromString(publicRequestlistValue)); publicRequestlistValueIndex++; } } if(publicRequest.IsSetSecurityGroupIds()) { int publicRequestlistValueIndex = 1; foreach(var publicRequestlistValue in publicRequest.SecurityGroupIds) { request.Parameters.Add("SecurityGroupId" + "." + publicRequestlistValueIndex, StringUtils.FromString(publicRequestlistValue)); publicRequestlistValueIndex++; } } if(publicRequest.IsSetSelfServicePortal()) { request.Parameters.Add("SelfServicePortal", StringUtils.FromString(publicRequest.SelfServicePortal)); } if(publicRequest.IsSetServerCertificateArn()) { request.Parameters.Add("ServerCertificateArn", StringUtils.FromString(publicRequest.ServerCertificateArn)); } if(publicRequest.IsSetSessionTimeoutHours()) { request.Parameters.Add("SessionTimeoutHours", StringUtils.FromInt(publicRequest.SessionTimeoutHours)); } if(publicRequest.IsSetSplitTunnel()) { request.Parameters.Add("SplitTunnel", StringUtils.FromBool(publicRequest.SplitTunnel)); } if(publicRequest.IsSetTagSpecifications()) { int publicRequestlistValueIndex = 1; foreach(var publicRequestlistValue in publicRequest.TagSpecifications) { if(publicRequestlistValue.IsSetResourceType()) { request.Parameters.Add("TagSpecification" + "." + publicRequestlistValueIndex + "." + "ResourceType", StringUtils.FromString(publicRequestlistValue.ResourceType)); } if(publicRequestlistValue.IsSetTags()) { int publicRequestlistValuelistValueIndex = 1; foreach(var publicRequestlistValuelistValue in publicRequestlistValue.Tags) { if(publicRequestlistValuelistValue.IsSetKey()) { request.Parameters.Add("TagSpecification" + "." + publicRequestlistValueIndex + "." + "Tag" + "." + publicRequestlistValuelistValueIndex + "." + "Key", StringUtils.FromString(publicRequestlistValuelistValue.Key)); } if(publicRequestlistValuelistValue.IsSetValue()) { request.Parameters.Add("TagSpecification" + "." + publicRequestlistValueIndex + "." + "Tag" + "." + publicRequestlistValuelistValueIndex + "." + "Value", StringUtils.FromString(publicRequestlistValuelistValue.Value)); } publicRequestlistValuelistValueIndex++; } } publicRequestlistValueIndex++; } } if(publicRequest.IsSetTransportProtocol()) { request.Parameters.Add("TransportProtocol", StringUtils.FromString(publicRequest.TransportProtocol)); } if(publicRequest.IsSetVpcId()) { request.Parameters.Add("VpcId", StringUtils.FromString(publicRequest.VpcId)); } if(publicRequest.IsSetVpnPort()) { request.Parameters.Add("VpnPort", StringUtils.FromInt(publicRequest.VpnPort)); } } return request; } private static CreateClientVpnEndpointRequestMarshaller _instance = new CreateClientVpnEndpointRequestMarshaller(); internal static CreateClientVpnEndpointRequestMarshaller GetInstance() { return _instance; } /// /// Gets the singleton. /// public static CreateClientVpnEndpointRequestMarshaller Instance { get { return _instance; } } } }