/* * 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 acm-pca-2017-08-22.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.ACMPCA.Model; using Amazon.Runtime; using Amazon.Runtime.Internal; using Amazon.Runtime.Internal.Transform; using Amazon.Runtime.Internal.Util; using ThirdParty.Json.LitJson; namespace Amazon.ACMPCA.Model.Internal.MarshallTransformations { /// /// CreateCertificateAuthority Request Marshaller /// public class CreateCertificateAuthorityRequestMarshaller : IMarshaller , IMarshaller { /// /// Marshaller the request object to the HTTP request. /// /// /// public IRequest Marshall(AmazonWebServiceRequest input) { return this.Marshall((CreateCertificateAuthorityRequest)input); } /// /// Marshaller the request object to the HTTP request. /// /// /// public IRequest Marshall(CreateCertificateAuthorityRequest publicRequest) { IRequest request = new DefaultRequest(publicRequest, "Amazon.ACMPCA"); string target = "ACMPrivateCA.CreateCertificateAuthority"; request.Headers["X-Amz-Target"] = target; request.Headers["Content-Type"] = "application/x-amz-json-1.1"; request.Headers[Amazon.Util.HeaderKeys.XAmzApiVersion] = "2017-08-22"; request.HttpMethod = "POST"; request.ResourcePath = "/"; using (StringWriter stringWriter = new StringWriter(CultureInfo.InvariantCulture)) { JsonWriter writer = new JsonWriter(stringWriter); writer.WriteObjectStart(); var context = new JsonMarshallerContext(request, writer); if(publicRequest.IsSetCertificateAuthorityConfiguration()) { context.Writer.WritePropertyName("CertificateAuthorityConfiguration"); context.Writer.WriteObjectStart(); var marshaller = CertificateAuthorityConfigurationMarshaller.Instance; marshaller.Marshall(publicRequest.CertificateAuthorityConfiguration, context); context.Writer.WriteObjectEnd(); } if(publicRequest.IsSetCertificateAuthorityType()) { context.Writer.WritePropertyName("CertificateAuthorityType"); context.Writer.Write(publicRequest.CertificateAuthorityType); } if(publicRequest.IsSetIdempotencyToken()) { context.Writer.WritePropertyName("IdempotencyToken"); context.Writer.Write(publicRequest.IdempotencyToken); } if(publicRequest.IsSetKeyStorageSecurityStandard()) { context.Writer.WritePropertyName("KeyStorageSecurityStandard"); context.Writer.Write(publicRequest.KeyStorageSecurityStandard); } if(publicRequest.IsSetRevocationConfiguration()) { context.Writer.WritePropertyName("RevocationConfiguration"); context.Writer.WriteObjectStart(); var marshaller = RevocationConfigurationMarshaller.Instance; marshaller.Marshall(publicRequest.RevocationConfiguration, context); context.Writer.WriteObjectEnd(); } if(publicRequest.IsSetTags()) { context.Writer.WritePropertyName("Tags"); context.Writer.WriteArrayStart(); foreach(var publicRequestTagsListValue in publicRequest.Tags) { context.Writer.WriteObjectStart(); var marshaller = TagMarshaller.Instance; marshaller.Marshall(publicRequestTagsListValue, context); context.Writer.WriteObjectEnd(); } context.Writer.WriteArrayEnd(); } if(publicRequest.IsSetUsageMode()) { context.Writer.WritePropertyName("UsageMode"); context.Writer.Write(publicRequest.UsageMode); } writer.WriteObjectEnd(); string snippet = stringWriter.ToString(); request.Content = System.Text.Encoding.UTF8.GetBytes(snippet); } return request; } private static CreateCertificateAuthorityRequestMarshaller _instance = new CreateCertificateAuthorityRequestMarshaller(); internal static CreateCertificateAuthorityRequestMarshaller GetInstance() { return _instance; } /// /// Gets the singleton. /// public static CreateCertificateAuthorityRequestMarshaller Instance { get { return _instance; } } } }