tomasvotruba / aws-sdk-php-symfony
A Symfony bundle for v3 of the AWS SDK for PHP
Installs: 7 992
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: ^8.1
- aws/aws-sdk-php: ^3.2.6
- symfony/config: ^6.0|^7.0
- symfony/dependency-injection: ^6.0|^7.0
- symfony/http-kernel: ^6.0|^7.0
Requires (Dev)
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^10.5
- rector/rector: ^0.18.13
- symfony/framework-bundle: ^6.0|^7.0
- symfony/yaml: ^6.0|^7.0
- symplify/easy-coding-standard: ^12.1
README
A Symfony bundle for including the AWS SDK for PHP.
Install
composer require tomasvotruba/aws-sdk-php-symfony
and add Aws\Symfony\AwsBundle
to the Kernel:
class AppKernel extends Kernel { public function registerBundles(): array { return [ ... new \Aws\Symfony\AwsBundle(), ]; } ... }
Configuration
By default, configuration is handled by the SDK rather than by the bundle, and no validation is performed at compile time. Full documentation of the configuration options available can be read in the SDK Guide.
If AWS_MERGE_CONFIG environment variable is set to true
, configuration
validation and merging are enabled. The bundle validates and merges known
configuration options, including for each service. Additional configuration
options can be included in a single configuration file, but merging will fail
if non-standard options are specified in more than once.
To use a service for any configuration value, use @
followed by the service
name, such as @a_service
. This syntax will be converted to a service during
container compilation. If you want to use a string literal that begins with @
,
you will need to escape it by adding another @
sign.
When using the SDK from an EC2 instance, you can write credentials: ~
to use
instance profile credentials.
This syntax means that temporary credentials will be automatically retrieved
from the EC2 instance's metadata server. It's also the preferred technique for
providing credentials to applications running on that specific context.
Sample configuration can be found in the tests/fixtures
folder for YAML, PHP, and XML.
Sample YML Configuration
The sample configuration which can be placed in app/config/config.yml
file.
framework: secret: "Rosebud was the name of his sled." aws: version: latest region: us-east-1 credentials: key: not-a-real-key secret: "@@not-a-real-secret" # this will be escaped as '@not-a-real-secret' DynamoDb: region: us-west-2 S3: version: '2006-03-01' Sqs: credentials: "@a_service" CloudSearchDomain: endpoint: https://search-with-some-subdomain.us-east-1.cloudsearch.amazonaws.com services: a_service: class: Aws\Credentials\Credentials arguments: - a-different-fake-key - a-different-fake-secret
Usage
This bundle exposes an instance of the Aws\Sdk
object as well as instances of
each AWS client object as services to your symfony application. They are name
aws.{$namespace}
, where $namespace
is the namespace of the service client.
For instance:
The services made available depends on which version of the SDK is installed. To view a full list, run the following command from your application's root directory:
php bin/console debug:container aws
Full documentation on each of the services listed can be found in the SDK API docs.