Low
Showing all detectors for the Java language with low severity.
The AWS Labs Transactions Library is a client-side solution and less efficient compared to DynamoDB native transactions.
Encryption can be improved by using Additional authenticated data (AAD).
Manually creating text-based IAM policies is error-prone.
Use S3Objects.withPrefix()
instead of manually paginating results.
Misconfigured CompletableFuture.get or Future.get.
Custom polling can be inefficient and prone to error. Consider using AWS waiters instead.
Insecure cookies can lead to unencrypted transmission of sensitive data.
Maintain your code's backward compatibility by checking the status code instead of parsing the error message.
Iterating on Map
entries is more efficient than iterating on the keys and asking for their respective values.
Not setting the S3 bucket owner condition might introduce a risk of accidentally using a wrong bucket.
Provide the full URL for the Amazon SQS queue.
Missing check on the value returned by ResultSet.next can cause your application to crash.
To minimize the risk of error, use an enum instead of a string to specify an AWS Region.
Check if errors are returned by DynamoDBMapper
's BatchWrite
operations.
Atomicity violations caused by improper usage of ConcurrentHashMap
or ConcurrentLinkedQueue
can result in crashses or incorrect program results.
Catching generic exceptions might hide issues when specific exceptions are thrown.
Your application can crash if the check for an application that can receive the implicit intent is missing from code.
Simplifiable code might be harder to read or maintain.
Oversynchronization with ConcurrentHashMap
or ConcurrentLinkedQueue
can reduce program performance.
Log the ARN identifying the state machine execution for better debuggability.