
com.amazonaws.services.elasticmapreduce.model.transform.JobFlowInstancesDetailJsonMarshaller Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws-java-sdk-emr Show documentation
Show all versions of aws-java-sdk-emr Show documentation
The AWS Java SDK for Amazon EMR module holds the client classes that are used for communicating with Amazon Elastic MapReduce Service
/*
* Copyright 2011-2016 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.
*/
package com.amazonaws.services.elasticmapreduce.model.transform;
import java.util.Map;
import java.util.List;
import com.amazonaws.AmazonClientException;
import com.amazonaws.services.elasticmapreduce.model.*;
import com.amazonaws.transform.Marshaller;
import com.amazonaws.util.BinaryUtils;
import com.amazonaws.util.StringUtils;
import com.amazonaws.util.IdempotentUtils;
import com.amazonaws.util.StringInputStream;
import com.amazonaws.protocol.json.*;
/**
* JobFlowInstancesDetailMarshaller
*/
public class JobFlowInstancesDetailJsonMarshaller {
/**
* Marshall the given parameter object, and output to a SdkJsonGenerator
*/
public void marshall(JobFlowInstancesDetail jobFlowInstancesDetail,
StructuredJsonGenerator jsonGenerator) {
if (jobFlowInstancesDetail == null) {
throw new AmazonClientException(
"Invalid argument passed to marshall(...)");
}
try {
jsonGenerator.writeStartObject();
if (jobFlowInstancesDetail.getMasterInstanceType() != null) {
jsonGenerator.writeFieldName("MasterInstanceType").writeValue(
jobFlowInstancesDetail.getMasterInstanceType());
}
if (jobFlowInstancesDetail.getMasterPublicDnsName() != null) {
jsonGenerator.writeFieldName("MasterPublicDnsName").writeValue(
jobFlowInstancesDetail.getMasterPublicDnsName());
}
if (jobFlowInstancesDetail.getMasterInstanceId() != null) {
jsonGenerator.writeFieldName("MasterInstanceId").writeValue(
jobFlowInstancesDetail.getMasterInstanceId());
}
if (jobFlowInstancesDetail.getSlaveInstanceType() != null) {
jsonGenerator.writeFieldName("SlaveInstanceType").writeValue(
jobFlowInstancesDetail.getSlaveInstanceType());
}
if (jobFlowInstancesDetail.getInstanceCount() != null) {
jsonGenerator.writeFieldName("InstanceCount").writeValue(
jobFlowInstancesDetail.getInstanceCount());
}
com.amazonaws.internal.SdkInternalList instanceGroupsList = (com.amazonaws.internal.SdkInternalList) jobFlowInstancesDetail
.getInstanceGroups();
if (!instanceGroupsList.isEmpty()
|| !instanceGroupsList.isAutoConstruct()) {
jsonGenerator.writeFieldName("InstanceGroups");
jsonGenerator.writeStartArray();
for (InstanceGroupDetail instanceGroupsListValue : instanceGroupsList) {
if (instanceGroupsListValue != null) {
InstanceGroupDetailJsonMarshaller.getInstance()
.marshall(instanceGroupsListValue,
jsonGenerator);
}
}
jsonGenerator.writeEndArray();
}
if (jobFlowInstancesDetail.getNormalizedInstanceHours() != null) {
jsonGenerator.writeFieldName("NormalizedInstanceHours")
.writeValue(
jobFlowInstancesDetail
.getNormalizedInstanceHours());
}
if (jobFlowInstancesDetail.getEc2KeyName() != null) {
jsonGenerator.writeFieldName("Ec2KeyName").writeValue(
jobFlowInstancesDetail.getEc2KeyName());
}
if (jobFlowInstancesDetail.getEc2SubnetId() != null) {
jsonGenerator.writeFieldName("Ec2SubnetId").writeValue(
jobFlowInstancesDetail.getEc2SubnetId());
}
if (jobFlowInstancesDetail.getPlacement() != null) {
jsonGenerator.writeFieldName("Placement");
PlacementTypeJsonMarshaller.getInstance().marshall(
jobFlowInstancesDetail.getPlacement(), jsonGenerator);
}
if (jobFlowInstancesDetail.getKeepJobFlowAliveWhenNoSteps() != null) {
jsonGenerator.writeFieldName("KeepJobFlowAliveWhenNoSteps")
.writeValue(
jobFlowInstancesDetail
.getKeepJobFlowAliveWhenNoSteps());
}
if (jobFlowInstancesDetail.getTerminationProtected() != null) {
jsonGenerator.writeFieldName("TerminationProtected")
.writeValue(
jobFlowInstancesDetail
.getTerminationProtected());
}
if (jobFlowInstancesDetail.getHadoopVersion() != null) {
jsonGenerator.writeFieldName("HadoopVersion").writeValue(
jobFlowInstancesDetail.getHadoopVersion());
}
jsonGenerator.writeEndObject();
} catch (Throwable t) {
throw new AmazonClientException(
"Unable to marshall request to JSON: " + t.getMessage(), t);
}
}
private static JobFlowInstancesDetailJsonMarshaller instance;
public static JobFlowInstancesDetailJsonMarshaller getInstance() {
if (instance == null)
instance = new JobFlowInstancesDetailJsonMarshaller();
return instance;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy