com.ksc.transform.LegacyErrorUnmarshaller Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2010-2016 ksyun.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://ksyun.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.ksc.transform;
import static com.ksc.util.XpathUtils.asString;
import static com.ksc.util.XpathUtils.xpath;
import java.lang.reflect.Constructor;
import javax.xml.xpath.XPath;
import org.w3c.dom.Node;
import com.ksc.KscServiceException;
import com.ksc.KscServiceException.ErrorType;
import com.ksc.util.StringUtils;
/**
* Unmarshalls an KSC error response into an AmazonServiceException, or
* optionally, a subclass of AmazonServiceException if this class is extended.
*/
// TODOFIX 可能已经失效了。
public class LegacyErrorUnmarshaller implements Unmarshaller {
/**
* The type of AmazonServiceException that will be instantiated. Subclasses
* specialized for a specific type of exception can control this through the
* protected constructor.
*/
private final Class extends KscServiceException> exceptionClass;
/**
* Constructs a new unmarshaller that will unmarshall KSC error responses as
* a generic AmazonServiceException object.
*/
public LegacyErrorUnmarshaller() {
this(KscServiceException.class);
}
/**
* Constructor allowing subclasses to specify a specific type of
* AmazonServiceException to instantiating when populating the exception
* object with data from the KSC error response.
*
* @param exceptionClass
* The class of AmazonServiceException to create and populate
* when unmarshalling the KSC error response.
*/
protected LegacyErrorUnmarshaller(Class extends KscServiceException> exceptionClass) {
this.exceptionClass = exceptionClass;
}
@Override
public KscServiceException unmarshall(Node in) throws Exception {
XPath xpath = xpath();
String errorCode = parseErrorCode(in, xpath);
String message = asString("Response/Error/Message", in, xpath);
String requestId = asString("Response/RequestID", in, xpath);
String errorType = asString("Response/Error/Type", in, xpath);
if(StringUtils.isNullOrEmpty(errorCode)){
return null;
}
Constructor extends KscServiceException> constructor = exceptionClass.getConstructor(String.class);
KscServiceException ase = constructor.newInstance(message);
ase.setErrorCode(errorCode);
ase.setRequestId(requestId);
if (errorType == null) {
ase.setErrorType(ErrorType.Unknown);
} else if (errorType.equalsIgnoreCase("server")) {
ase.setErrorType(ErrorType.Service);
} else if (errorType.equalsIgnoreCase("client")) {
ase.setErrorType(ErrorType.Client);
}
return ase;
}
/**
* Returns the KSC error code for the specified error response.
*
* @param in
* The DOM tree node containing the error response.
*
* @return The KSC error code contained in the specified error response.
*
* @throws Exception
* If any problems were encountered pulling out the KSC error
* code.
*/
public String parseErrorCode(Node in) throws Exception {
return asString("Response/Error/Code", in);
}
public String parseErrorCode(Node in, XPath xpath) throws Exception {
return asString("Response/Error/Code", in, xpath);
}
/**
* Returns the path to the specified property within an error response.
*
* @param property
* The name of the desired property.
*
* @return The path to the specified property within an error message.
*/
public String getErrorPropertyPath(String property) {
return "Response/Error/" + property;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy