
com.amazonaws.codegen.AddInputShapes Maven / Gradle / Ivy
/*
* Copyright (c) 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.codegen;
import com.amazonaws.codegen.model.intermediate.OperationModel;
import com.amazonaws.codegen.model.intermediate.Protocol;
import com.amazonaws.codegen.model.intermediate.ShapeModel;
import com.amazonaws.codegen.model.intermediate.ShapeType;
import com.amazonaws.codegen.model.service.Input;
import com.amazonaws.codegen.model.service.Member;
import com.amazonaws.codegen.model.service.Operation;
import com.amazonaws.codegen.model.service.Shape;
import com.amazonaws.util.TimestampFormat;
import com.amazonaws.util.StringUtils;
import java.util.HashMap;
import java.util.Map;
import static com.amazonaws.codegen.internal.Utils.createInputShapeMarshaller;
/**
* Constructs the request shapes for the intermediate model. Analyzes the operations in the service
* model to identify the request shapes that are to be generated.
*/
final class AddInputShapes extends AddShapes implements IntermediateModelShapeProcessor {
AddInputShapes(IntermediateModelBuilder builder) {
super(builder);
}
@Override
public Map process(Map currentOperations,
Map currentShapes) {
return constructInputShapes();
}
private Map constructInputShapes() {
// Java input shape models, to be constructed
final Map javaShapes = new HashMap();
for (Map.Entry entry : getServiceModel().getOperations().entrySet()) {
String operationName = entry.getKey();
Operation operation = entry.getValue();
Input input = operation.getInput();
if (input != null) {
String javaRequestShapeName = getNamingStrategy()
.getRequestClassName(operationName);
ShapeModel inputShape = generateInputShapeModel(operation, javaRequestShapeName);
if (inputShape.getDocumentation() == null) {
inputShape.setDocumentation(input.getDocumentation());
}
javaShapes.put(javaRequestShapeName, inputShape);
}
}
return javaShapes;
}
/**
* Throw exception if timestamp format is provided for non-json protocol.
*/
@Override
protected String getDefaultTimeFormatIfNull(Member c2jMemberDefinition, Map allC2jShapes,
String protocolString, Shape parentShape) {
validateTimestampProtocol(protocolString, c2jMemberDefinition.getTimestampFormat(), c2jMemberDefinition.getShape());
String shapeName = c2jMemberDefinition.getShape();
Shape shape = allC2jShapes.get(shapeName);
validateTimestampProtocol(protocolString, shape.getTimestampFormat(), shapeName);
return super.getDefaultTimeFormatIfNull(c2jMemberDefinition, allC2jShapes, protocolString, parentShape);
}
/**
* Override the default header timestamp format for input type because we have always marshalled header value as ISO_8601, changing it to
* rfc822 might break existing customers who are relying on that behavior. If not configured, we set it to UNKNOWN and let HeaderMarshallers.DATE
* to set the default format.
*/
@Override
protected String defaultHeaderTimestamp() {
return TimestampFormat.UNKNOWN.getFormat();
}
private ShapeModel generateInputShapeModel(Operation operation,
String javaInputShapeNameOverride) {
Input input = operation.getInput();
String inputShapeName = input.getShape();
ShapeModel shapeModel = generateShapeModel(javaInputShapeNameOverride, inputShapeName);
shapeModel.setType(ShapeType.Request.getValue());
shapeModel.setMarshaller(
createInputShapeMarshaller(getServiceModel().getMetadata(), operation));
return shapeModel;
}
/**
* Throw exception if timestamp is provided for non-json protocol
*/
private void validateTimestampProtocol(String protocolString, String timestampFormat, String shape2) {
if (!StringUtils.isNullOrEmpty(timestampFormat) && isNonJsonProtocol(protocolString)) {
throw new IllegalArgumentException(String.format(
"Shape %s has timestamp format provided. Timestamp format for requests is not supported for xml, query or ec2 "
+ "protocol",
shape2));
}
}
private boolean isNonJsonProtocol(String protocolString) {
return Protocol.REST_XML.getValue().equals(protocolString)
|| Protocol.QUERY.getValue().equals(protocolString)
|| Protocol.EC2.getValue().equals(protocolString);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy