Comments (6)
Hello @millems ,
Can you please provide more details around this ?
from aws-sdk-java-v2.
@sakky11 We haven't started the design of this quite yet but we have some early impressions of what we think we want to do. Firstly, we want to restructure the exception hierarchy a bit. Right now we have the following structure
AmazonClientException <------ AmazonServiceException <---- DynamoDBException <--- ProvisionedThroughputException
We'd like to break that apart a bit to have separate hierarchies for client vs service exceptions as well as have a common exception for both to simplify catch all scenarios. We also want to revisit the naming so it's not branded with Amazon everywhere (this is important for our API Gateway generated SDKs which we want to be more generic, less AWS specific). So the new hierarchy would look something like this
SdkException
/ \
/ \
SdkClientException SdkServiceException
| |
| |
SpecificClientException DynamoDBException
|
|
ProvisionedThroughputException
We've also had problems with name clashes with fields defined in the base AmazonServiceException class and modeled service exception fields so we want to clean that class up a bit and move some of the state/metadata into other objects to limit the number of field names we reserve.
A bit of a stretch goal is to give service teams the ability to annotate which of their exceptions are retryable, which indicate throttling, etc. We currently keep track of a giant list of those in the core module but that's not very scalable and what may be retryable for one service might not for another so it's not very flexible.
Another stretch goal is to revisit our unmarshalling implementation of exceptions. For JSON we use Jackson databind which is pretty limiting and cannot handle exception fields bound to HTTP headers for example.
from aws-sdk-java-v2.
Thanks @shorea
I was thinking to start on this.How can I get started ?
from aws-sdk-java-v2.
@sakky11 That sounds great! I think a good first step would be getting rid of AmazonClientException. In most cases it should be replaced with SdkBaseException but may need to be replaced by SdkClientException in certain situations. Don't know exactly what those situations are but in general, anywhere we accept an AmazonClientException we should probably accept an SdkBaseException instead (retry policy is good example). Anywhere we throw an AmazonClientException we should thrown an SdkClientException instead.
from aws-sdk-java-v2.
Also https://github.com/aws/aws-sdk-java-v2/blob/master/core/src/main/java/software/amazon/awssdk/AmazonServiceException.java#L34 should extend SdkBaseException, anything else that extends AmazonClientException should extend SdkClientException instead.
from aws-sdk-java-v2.
from aws-sdk-java-v2.
Related Issues (20)
- PUT requests do not support setReadLimit option HOT 3
- Inconsistent methods for UpdateSecurityGroupRuleDescriptionsIngressRequest.Builder and AuthorizeSecurityGroupIngressRequest.Builder HOT 4
- Cognito: support for partial UpdateUserPoolClient calls HOT 1
- finalizeMultipartUpload is throwing 404 error HOT 3
- SDK Clients are `Closeable` and documented as thread safe but don't provide an `isClosed()` method HOT 1
- S3Async client fail to upload files (Service: S3, Status Code: 400, Request ID: null) HOT 1
- Getting occasional Crc32MismatchException using DynamoDbClient HOT 5
- Thread locals are lost after the control is returned from SDK methods to the client code HOT 1
- Parse QueryParams when building S3Uri from AWS CLI Style format HOT 3
- InstanceProfileCredentialsProvider unable to refresh/recover from network problems at time of credential cache refresh HOT 2
- Stuck on `java.util.concurrent.Future#get(long, java.util.concurrent.TimeUnit)` when using `java.util.concurrent.Executors#newVirtualThreadPerTaskExecutor` HOT 2
- Equivalent of `com.amazonaws.util.json.Jackson` in sdk v2 HOT 5
- Regression between SDK v1 and v2 around client side encryption HOT 2
- Version 2.25.26 Could not parse POM HOT 1
- S3 Transfer Manager created using S3Aysnc Client with CRT Builder holding significant memory even after downloads are completed
- Setting metadata and retention with UploadDirectoryRequest
- Don't download 200MB of JS for a JavaDoc search feature that most people don't use HOT 1
- Unshaded dependencies in AWS SDK HOT 9
- S3 Presign Head method HOT 2
- S3 CRT Client GetObject Request with Invalid Range crashes JVM with SIGSEGV HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from aws-sdk-java-v2.