forked from aws/aws-sdk-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathStandardErrorUnmarshaller.java
More file actions
103 lines (91 loc) · 3.56 KB
/
StandardErrorUnmarshaller.java
File metadata and controls
103 lines (91 loc) · 3.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
* Copyright 2010-2013 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.transform;
import org.w3c.dom.Node;
import com.amazonaws.AmazonServiceException;
import com.amazonaws.AmazonServiceException.ErrorType;
import com.amazonaws.util.XpathUtils;
/**
* Error unmarshaller that knows how to interpret a standard AWS error message
* (i.e. where to find the AWS error code, the error message, etc.) and turn it
* into an AmazonServiceException.
*
* @see LegacyErrorUnmarshaller
*/
public class StandardErrorUnmarshaller extends AbstractErrorUnmarshaller<Node> {
/**
* Constructs a new unmarshaller that will unmarshall a standard AWS error
* message as a generic AmazonServiceException object.
*/
public StandardErrorUnmarshaller() {}
/**
* Constructor allowing subclasses to specify a specific type of
* AmazonServiceException to instantiating when populating the exception
* object with data from the error message.
*
* @param exceptionClass
* The class of AmazonServiceException to create and populate
* when unmarshalling the error message.
*/
protected StandardErrorUnmarshaller(Class<? extends AmazonServiceException> exceptionClass) {
super(exceptionClass);
}
/**
* @see com.amazonaws.transform.Unmarshaller#unmarshall(java.lang.Object)
*/
public AmazonServiceException unmarshall(Node in) throws Exception {
String errorCode = parseErrorCode(in);
String errorType = XpathUtils.asString("ErrorResponse/Error/Type", in);
String requestId = XpathUtils.asString("ErrorResponse/RequestId", in);
String message = XpathUtils.asString("ErrorResponse/Error/Message", in);
AmazonServiceException ase = newException(message);
ase.setErrorCode(errorCode);
ase.setRequestId(requestId);
if (errorType == null) {
ase.setErrorType(ErrorType.Unknown);
} else if (errorType.equalsIgnoreCase("Receiver")) {
ase.setErrorType(ErrorType.Service);
} else if (errorType.equalsIgnoreCase("Sender")) {
ase.setErrorType(ErrorType.Client);
}
return ase;
}
/**
* Returns the AWS error code for the specified error response.
*
* @param in
* The DOM tree node containing the error response.
*
* @return The AWS error code contained in the specified error response.
*
* @throws Exception
* If any problems were encountered pulling out the AWS error
* code.
*/
public String parseErrorCode(Node in) throws Exception {
return XpathUtils.asString("ErrorResponse/Error/Code", in);
}
/**
* 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 "ErrorResponse/Error/" + property;
}
}