One of the core feature of Flysystem is its ability to interact easily with remote filesystems, including many cloud storage providers. This bundle provides the same level of support for these cloud providers by providing corresponding adapters in the configuration.
- Azure
- AsyncAws S3
- AWS S3
- DigitalOcean Spaces
- Scaleway Object Storage
- Google Cloud Storage
- Cloudflare R2
composer require league/flysystem-azure-blob-storage
# config/packages/flysystem.yaml
flysystem:
storages:
users.storage:
adapter: 'azure'
options:
client: 'azure_client_service' # The service ID of the MicrosoftAzure\Storage\Blob\BlobRestProxy instance
container: 'container_name'
prefix: 'optional/path/prefix'
composer require league/flysystem-async-aws-s3
# config/packages/flysystem.yaml
flysystem:
storages:
users.storage:
adapter: 'asyncaws'
options:
client: 'aws_client_service' # The service ID of the AsyncAws\S3\S3Client instance
bucket: 'bucket_name'
prefix: 'optional/path/prefix'
composer require league/flysystem-aws-s3-v3
# config/packages/flysystem.yaml
flysystem:
storages:
users.storage:
adapter: 'aws'
# visibility: public # Make the uploaded file publicly accessible in S3
options:
client: 'aws_client_service' # The service ID of the Aws\S3\S3Client instance
bucket: 'bucket_name'
prefix: 'optional/path/prefix'
streamReads: true
composer require league/flysystem-google-cloud-storage
# config/packages/flysystem.yaml
flysystem:
storages:
users.storage:
adapter: 'gcloud'
options:
client: 'gcloud_client_service' # The service ID of the Google\Cloud\Storage\StorageClient instance
bucket: 'bucket_name'
prefix: 'optional/path/prefix'
The DigitalOcean Spaces are compatible with the AWS S3 API, meaning that you can use the same configuration as for a AWS storage. For example:
# config/packages/flysystem.yaml
services:
digitalocean_spaces_client:
class: 'AsyncAws\S3\S3Client'
arguments:
-
endpoint: '%env(DIGITALOCEAN_SPACES_ENDPOINT)%'
accessKeyId: '%env(DIGITALOCEAN_SPACES_ID)%'
accessKeySecret: '%env(DIGITALOCEAN_SPACES_SECRET)%'
flysystem:
storages:
cdn.storage:
adapter: 'asyncaws'
options:
client: 'digitalocean_spaces_client'
bucket: '%env(DIGITALOCEAN_SPACES_BUCKET)%'
The Scaleway Object Storage is compatible with the AWS S3 API, meaning that you can use the same configuration as for a AWS storage. For example:
# config/packages/flysystem.yaml
services:
scaleway_spaces_client:
class: 'AsyncAws\S3\S3Client'
arguments:
-
endpoint: '%env(SCALEWAY_SPACES_ENDPOINT)%'
accessKeyId: '%env(SCALEWAY_SPACES_ID)%'
accessKeySecret: '%env(SCALEWAY_SPACES_SECRET)%'
flysystem:
storages:
cdn.storage:
adapter: 'asyncaws'
options:
client: 'scaleway_spaces_client'
bucket: '%env(SCALEWAY_SPACES_BUCKET)%'
The Cloudflare R2 is compatible with the AWS S3 API, meaning that you can use the same configuration as for a AWS storage. For example:
# config/packages/flysystem.yaml
services:
cloudflare_r2_client:
class: 'AsyncAws\S3\S3Client'
arguments:
-
endpoint: '%env(CLOUDFLARE_R2_ENDPOINT)%'
accessKeyId: '%env(CLOUDFLARE_R2_ID)%'
accessKeySecret: '%env(CLOUDFLARE_R2_SECRET)%'
flysystem:
storages:
cdn.storage:
adapter: 'asyncaws'
options:
client: 'cloudflare_r2_client'
bucket: '%env(CLOUDFLARE_R2_BUCKET)%'