
com.amazonaws.services.elastictranscoder.model.transform.CreatePipelineRequestMarshaller Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws-java-sdk-elastictranscoder Show documentation
Show all versions of aws-java-sdk-elastictranscoder Show documentation
The AWS Java SDK for Amazon Elastic Transcoder module holds the client classes that are used for communicating with Amazon Elastic Transcoder 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.elastictranscoder.model.transform;
import static com.amazonaws.util.StringUtils.UTF8;
import static com.amazonaws.util.StringUtils.COMMA_SEPARATOR;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.OutputStreamWriter;
import java.io.StringWriter;
import java.io.Writer;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.List;
import java.util.regex.Pattern;
import com.amazonaws.AmazonClientException;
import com.amazonaws.Request;
import com.amazonaws.DefaultRequest;
import com.amazonaws.http.HttpMethodName;
import com.amazonaws.services.elastictranscoder.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.util.SdkHttpUtils;
import com.amazonaws.protocol.json.*;
/**
* CreatePipelineRequest Marshaller
*/
public class CreatePipelineRequestMarshaller implements Marshaller, CreatePipelineRequest> {
private final SdkJsonProtocolFactory protocolFactory;
public CreatePipelineRequestMarshaller(SdkJsonProtocolFactory protocolFactory) {
this.protocolFactory = protocolFactory;
}
public Request marshall(CreatePipelineRequest createPipelineRequest) {
if (createPipelineRequest == null) {
throw new AmazonClientException("Invalid argument passed to marshall(...)");
}
Request request = new DefaultRequest(createPipelineRequest, "AmazonElasticTranscoder");
request.setHttpMethod(HttpMethodName.POST);
String uriResourcePath = "/2012-09-25/pipelines";
request.setResourcePath(uriResourcePath);
try {
final StructuredJsonGenerator jsonGenerator = protocolFactory.createGenerator();
jsonGenerator.writeStartObject();
if (createPipelineRequest.getName() != null) {
jsonGenerator.writeFieldName("Name").writeValue(createPipelineRequest.getName());
}
if (createPipelineRequest.getInputBucket() != null) {
jsonGenerator.writeFieldName("InputBucket").writeValue(createPipelineRequest.getInputBucket());
}
if (createPipelineRequest.getOutputBucket() != null) {
jsonGenerator.writeFieldName("OutputBucket").writeValue(createPipelineRequest.getOutputBucket());
}
if (createPipelineRequest.getRole() != null) {
jsonGenerator.writeFieldName("Role").writeValue(createPipelineRequest.getRole());
}
if (createPipelineRequest.getAwsKmsKeyArn() != null) {
jsonGenerator.writeFieldName("AwsKmsKeyArn").writeValue(createPipelineRequest.getAwsKmsKeyArn());
}
if (createPipelineRequest.getNotifications() != null) {
jsonGenerator.writeFieldName("Notifications");
NotificationsJsonMarshaller.getInstance().marshall(createPipelineRequest.getNotifications(), jsonGenerator);
}
if (createPipelineRequest.getContentConfig() != null) {
jsonGenerator.writeFieldName("ContentConfig");
PipelineOutputConfigJsonMarshaller.getInstance().marshall(createPipelineRequest.getContentConfig(), jsonGenerator);
}
if (createPipelineRequest.getThumbnailConfig() != null) {
jsonGenerator.writeFieldName("ThumbnailConfig");
PipelineOutputConfigJsonMarshaller.getInstance().marshall(createPipelineRequest.getThumbnailConfig(), jsonGenerator);
}
jsonGenerator.writeEndObject();
byte[] content = jsonGenerator.getBytes();
request.setContent(new ByteArrayInputStream(content));
request.addHeader("Content-Length", Integer.toString(content.length));
if (!request.getHeaders().containsKey("Content-Type")) {
request.addHeader("Content-Type", protocolFactory.getContentType());
}
} catch (Throwable t) {
throw new AmazonClientException("Unable to marshall request to JSON: " + t.getMessage(), t);
}
return request;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy