abacaphiliac / aws-sdk-php-claim-check
Claim Check enterprise integration pattern, implemented via AWS PHP SDK.
Requires
Requires (Dev)
- behat/behat: ^3
- ircmaxell/random-lib: ^1
- jakub-onderka/php-parallel-lint: ^0.9.2
- phing/phing: ^2
- phpunit/phpunit: ^5|^4
- squizlabs/php_codesniffer: ^2.6
- vlucas/phpdotenv: ^2
This package is auto-updated.
Last update: 2024-12-25 12:26:02 UTC
README
abacaphiliac/aws-php-claim-check-sdk
An implementation of the Claim Check Enterprise Integration Pattern, utilizing Amazon Web Services. AWS recommends usage of the Claim Check pattern on the SQS Compliance FAQ.
This library provides extended SNS and SQS clients to "Check Luggage", uses S3 as the "Data Store", and uses the extended SQS client as the "Data Enricher".
This package aims to be a compatible port of Amazon's Extended Client Library. Messages stored via this PHP package should be able to be received by the Java package.
AWS Extended Client Library Compatibility
Similarities
- Claim Check structure is identical, i.e. keys are
s3BucketName
ands3Key
, meaning you can publish to SQS+S3 via this PHP lib and read via the AWS Extended Client Library java lib.
Differences
- Messages published from SNS to SQS contain a nested Claim Check message structure, so the Java SDK is not be able to natively consume messages published to SNS (citation needed).
- Usage of the pattern is not configurable by message size, nor can the pattern be disabled in this lib. Use the wrapped clients if you do not want to use Claim Check.
- The AWS Extended Client Library will always delete the message from S3 when the message is deleted from SQS. This is not acceptable when messages are published to SNS and fanned-out to multiple subscribers (e.g. multiple SQS queues). This package allows you to disable deletion from S3 in the SQS extended client configuration.
Installation
composer require abacaphiliac/aws-php-claim-check-sdk
Contributing
composer install && vendor/bin/phing
This library attempts to comply with PSR-1, PSR-2, and PSR-4. If you notice compliance oversights, please send a patch via pull request.
Tasks
- Add SQS check-in.
- Add SQS check-out.
- Add SNS check-in.
- Use WireMock to stub API responses and add feature tests to CI.
- Add async SQS check-in.
- Add async SQS check-out.
- Add async SNS check-in.