/*
* 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 securityhub-2018-10-26.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.SecurityHub.Model;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
using Amazon.Runtime.Internal.Transform;
using Amazon.Runtime.Internal.Util;
using ThirdParty.Json.LitJson;
namespace Amazon.SecurityHub.Model.Internal.MarshallTransformations
{
///
/// AwsIamRoleDetails Marshaller
///
public class AwsIamRoleDetailsMarshaller : IRequestMarshaller
{
///
/// Unmarshaller the response from the service to the response class.
///
///
///
///
public void Marshall(AwsIamRoleDetails requestObject, JsonMarshallerContext context)
{
if(requestObject.IsSetAssumeRolePolicyDocument())
{
context.Writer.WritePropertyName("AssumeRolePolicyDocument");
context.Writer.Write(requestObject.AssumeRolePolicyDocument);
}
if(requestObject.IsSetAttachedManagedPolicies())
{
context.Writer.WritePropertyName("AttachedManagedPolicies");
context.Writer.WriteArrayStart();
foreach(var requestObjectAttachedManagedPoliciesListValue in requestObject.AttachedManagedPolicies)
{
context.Writer.WriteObjectStart();
var marshaller = AwsIamAttachedManagedPolicyMarshaller.Instance;
marshaller.Marshall(requestObjectAttachedManagedPoliciesListValue, context);
context.Writer.WriteObjectEnd();
}
context.Writer.WriteArrayEnd();
}
if(requestObject.IsSetCreateDate())
{
context.Writer.WritePropertyName("CreateDate");
context.Writer.Write(requestObject.CreateDate);
}
if(requestObject.IsSetInstanceProfileList())
{
context.Writer.WritePropertyName("InstanceProfileList");
context.Writer.WriteArrayStart();
foreach(var requestObjectInstanceProfileListListValue in requestObject.InstanceProfileList)
{
context.Writer.WriteObjectStart();
var marshaller = AwsIamInstanceProfileMarshaller.Instance;
marshaller.Marshall(requestObjectInstanceProfileListListValue, context);
context.Writer.WriteObjectEnd();
}
context.Writer.WriteArrayEnd();
}
if(requestObject.IsSetMaxSessionDuration())
{
context.Writer.WritePropertyName("MaxSessionDuration");
context.Writer.Write(requestObject.MaxSessionDuration);
}
if(requestObject.IsSetPath())
{
context.Writer.WritePropertyName("Path");
context.Writer.Write(requestObject.Path);
}
if(requestObject.IsSetPermissionsBoundary())
{
context.Writer.WritePropertyName("PermissionsBoundary");
context.Writer.WriteObjectStart();
var marshaller = AwsIamPermissionsBoundaryMarshaller.Instance;
marshaller.Marshall(requestObject.PermissionsBoundary, context);
context.Writer.WriteObjectEnd();
}
if(requestObject.IsSetRoleId())
{
context.Writer.WritePropertyName("RoleId");
context.Writer.Write(requestObject.RoleId);
}
if(requestObject.IsSetRoleName())
{
context.Writer.WritePropertyName("RoleName");
context.Writer.Write(requestObject.RoleName);
}
if(requestObject.IsSetRolePolicyList())
{
context.Writer.WritePropertyName("RolePolicyList");
context.Writer.WriteArrayStart();
foreach(var requestObjectRolePolicyListListValue in requestObject.RolePolicyList)
{
context.Writer.WriteObjectStart();
var marshaller = AwsIamRolePolicyMarshaller.Instance;
marshaller.Marshall(requestObjectRolePolicyListListValue, context);
context.Writer.WriteObjectEnd();
}
context.Writer.WriteArrayEnd();
}
}
///
/// Singleton Marshaller.
///
public readonly static AwsIamRoleDetailsMarshaller Instance = new AwsIamRoleDetailsMarshaller();
}
}