/*
* 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
{
///
/// ModifyVerifiedAccessEndpoint Request Marshaller
///
public class ModifyVerifiedAccessEndpointRequestMarshaller : IMarshaller , IMarshaller
{
///
/// Marshaller the request object to the HTTP request.
///
///
///
public IRequest Marshall(AmazonWebServiceRequest input)
{
return this.Marshall((ModifyVerifiedAccessEndpointRequest)input);
}
///
/// Marshaller the request object to the HTTP request.
///
///
///
public IRequest Marshall(ModifyVerifiedAccessEndpointRequest publicRequest)
{
IRequest request = new DefaultRequest(publicRequest, "Amazon.EC2");
request.Parameters.Add("Action", "ModifyVerifiedAccessEndpoint");
request.Parameters.Add("Version", "2016-11-15");
if(publicRequest != null)
{
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.IsSetDescription())
{
request.Parameters.Add("Description", StringUtils.FromString(publicRequest.Description));
}
if(publicRequest.IsSetLoadBalancerOptions())
{
if(publicRequest.LoadBalancerOptions.IsSetPort())
{
request.Parameters.Add("LoadBalancerOptions" + "." + "Port", StringUtils.FromInt(publicRequest.LoadBalancerOptions.Port));
}
if(publicRequest.LoadBalancerOptions.IsSetProtocol())
{
request.Parameters.Add("LoadBalancerOptions" + "." + "Protocol", StringUtils.FromString(publicRequest.LoadBalancerOptions.Protocol));
}
if(publicRequest.LoadBalancerOptions.IsSetSubnetIds())
{
int publicRequestLoadBalancerOptionslistValueIndex = 1;
foreach(var publicRequestLoadBalancerOptionslistValue in publicRequest.LoadBalancerOptions.SubnetIds)
{
request.Parameters.Add("LoadBalancerOptions" + "." + "SubnetId" + "." + publicRequestLoadBalancerOptionslistValueIndex, StringUtils.FromString(publicRequestLoadBalancerOptionslistValue));
publicRequestLoadBalancerOptionslistValueIndex++;
}
}
}
if(publicRequest.IsSetNetworkInterfaceOptions())
{
if(publicRequest.NetworkInterfaceOptions.IsSetPort())
{
request.Parameters.Add("NetworkInterfaceOptions" + "." + "Port", StringUtils.FromInt(publicRequest.NetworkInterfaceOptions.Port));
}
if(publicRequest.NetworkInterfaceOptions.IsSetProtocol())
{
request.Parameters.Add("NetworkInterfaceOptions" + "." + "Protocol", StringUtils.FromString(publicRequest.NetworkInterfaceOptions.Protocol));
}
}
if(publicRequest.IsSetVerifiedAccessEndpointId())
{
request.Parameters.Add("VerifiedAccessEndpointId", StringUtils.FromString(publicRequest.VerifiedAccessEndpointId));
}
if(publicRequest.IsSetVerifiedAccessGroupId())
{
request.Parameters.Add("VerifiedAccessGroupId", StringUtils.FromString(publicRequest.VerifiedAccessGroupId));
}
}
return request;
}
private static ModifyVerifiedAccessEndpointRequestMarshaller _instance = new ModifyVerifiedAccessEndpointRequestMarshaller();
internal static ModifyVerifiedAccessEndpointRequestMarshaller GetInstance()
{
return _instance;
}
///
/// Gets the singleton.
///
public static ModifyVerifiedAccessEndpointRequestMarshaller Instance
{
get
{
return _instance;
}
}
}
}