/* * 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 iot-2015-05-28.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.IoT.Model; using Amazon.Runtime; using Amazon.Runtime.Internal; using Amazon.Runtime.Internal.Transform; using Amazon.Runtime.Internal.Util; using ThirdParty.Json.LitJson; namespace Amazon.IoT.Model.Internal.MarshallTransformations { /// /// TestInvokeAuthorizer Request Marshaller /// public class TestInvokeAuthorizerRequestMarshaller : IMarshaller , IMarshaller { /// /// Marshaller the request object to the HTTP request. /// /// /// public IRequest Marshall(AmazonWebServiceRequest input) { return this.Marshall((TestInvokeAuthorizerRequest)input); } /// /// Marshaller the request object to the HTTP request. /// /// /// public IRequest Marshall(TestInvokeAuthorizerRequest publicRequest) { IRequest request = new DefaultRequest(publicRequest, "Amazon.IoT"); request.Headers["Content-Type"] = "application/json"; request.Headers[Amazon.Util.HeaderKeys.XAmzApiVersion] = "2015-05-28"; request.HttpMethod = "POST"; if (!publicRequest.IsSetAuthorizerName()) throw new AmazonIoTException("Request object does not have required field AuthorizerName set"); request.AddPathResource("{authorizerName}", StringUtils.FromString(publicRequest.AuthorizerName)); request.ResourcePath = "/authorizer/{authorizerName}/test"; using (StringWriter stringWriter = new StringWriter(CultureInfo.InvariantCulture)) { JsonWriter writer = new JsonWriter(stringWriter); writer.WriteObjectStart(); var context = new JsonMarshallerContext(request, writer); if(publicRequest.IsSetHttpContext()) { context.Writer.WritePropertyName("httpContext"); context.Writer.WriteObjectStart(); var marshaller = HttpContextMarshaller.Instance; marshaller.Marshall(publicRequest.HttpContext, context); context.Writer.WriteObjectEnd(); } if(publicRequest.IsSetMqttContext()) { context.Writer.WritePropertyName("mqttContext"); context.Writer.WriteObjectStart(); var marshaller = MqttContextMarshaller.Instance; marshaller.Marshall(publicRequest.MqttContext, context); context.Writer.WriteObjectEnd(); } if(publicRequest.IsSetTlsContext()) { context.Writer.WritePropertyName("tlsContext"); context.Writer.WriteObjectStart(); var marshaller = TlsContextMarshaller.Instance; marshaller.Marshall(publicRequest.TlsContext, context); context.Writer.WriteObjectEnd(); } if(publicRequest.IsSetToken()) { context.Writer.WritePropertyName("token"); context.Writer.Write(publicRequest.Token); } if(publicRequest.IsSetTokenSignature()) { context.Writer.WritePropertyName("tokenSignature"); context.Writer.Write(publicRequest.TokenSignature); } writer.WriteObjectEnd(); string snippet = stringWriter.ToString(); request.Content = System.Text.Encoding.UTF8.GetBytes(snippet); } return request; } private static TestInvokeAuthorizerRequestMarshaller _instance = new TestInvokeAuthorizerRequestMarshaller(); internal static TestInvokeAuthorizerRequestMarshaller GetInstance() { return _instance; } /// /// Gets the singleton. /// public static TestInvokeAuthorizerRequestMarshaller Instance { get { return _instance; } } } }