Integrating S3-Compatible Asset Storage
This guide demonstrates how to integrate S3-compatible asset storage into your Vendure application using multiple cloud storage platforms. You'll learn to configure a single, platform-agnostic storage solution that works seamlessly with AWS S3, DigitalOcean Spaces, MinIO, CloudFlare R2, and Supabase Storage.
Working Example Repository
This guide is based on the s3-file-storage example. Refer to the complete working code for full implementation details.
Prerequisites
- Node.js 20+ with npm package manager
- An existing Vendure project created with the Vendure create command
- An account with one of the supported S3-compatible storage providers
S3-Compatible Storage Provider Setup
Configure your chosen storage provider by following the setup instructions for your preferred platform:
Setting up AWS S3
-
Create an S3 Bucket
- Navigate to AWS S3 Console
- Click "Create bucket"
- Enter a unique bucket name (e.g.,
my-vendure-assets) - Choose your preferred AWS region
- Configure permissions as needed for public asset access
-
Create IAM User with S3 Permissions
- Go to AWS IAM Console
- Navigate to "Users" and click "Create user"
- Enter username and proceeed to
Set Permissions - Select the
Attach existing policies directlyoption - Attach the
AmazonS3FullAccesspolicy (or create a custom policy with minimal permissions)
-
Generate Access Keys
- After creating the user, click on the user name
- Go to "Security credentials" tab
- Click "Create access key" and select "Application running on AWS service"
- Copy the Access Key ID and Secret Access Key (Download the CSV file if needed)
-
Environment Variables
Vendure Configuration
Configure your Vendure application to use S3-compatible asset storage by modifying your vendure-config.ts:
IMPORTANT: The configuration uses a conditional approach - when S3_BUCKET is set, it activates S3 storage; otherwise, it falls back to local file storage. This enables seamless development-to-production transitions.
Environment Configuration
Create a .env file in your project root with your chosen storage provider configuration:
Preconfigured environment examples for each storage provider are available in the s3-file-storage example repository.
Testing Your Configuration
Verify your S3 storage configuration works correctly:
-
Start your Vendure server:
-
Access the Dashboard:
- Open http://localhost:3000/dashboard
- Log in with your superadmin credentials
-
Test asset upload:
- Navigate to "Catalog" → "Assets"
- Click "Upload assets"
- Select a test image and upload
- Verify the image appears in the asset gallery
-
Verify storage backend:
- Check your S3 bucket/storage service for the uploaded file
- Confirm the asset URL is accessible
Advanced Configuration
Custom Asset URL Prefix
For production deployments with CDN or custom domains:
Environment-Specific Configuration
Use different buckets for different environments:
Migration Between Platforms
Switching between storage providers requires updating only the environment variables:
Troubleshooting
Common Issues
-
"Access Denied" Errors:
- Verify your access key has proper permissions
- Check bucket policies allow the required operations
- Ensure credentials are correctly set in environment variables
-
"Bucket Not Found" Errors:
- Verify bucket name matches exactly (case-sensitive)
- Check that
S3_REGIONmatches your bucket's region - For MinIO/R2, ensure
S3_FORCE_PATH_STYLE=true
-
Assets Not Loading:
- Verify bucket has public read access (if needed)
- Check CORS configuration for browser-based access
- Ensure
assetUrlPrefixmatches your actual domain
-
Connection Timeout Issues:
- Verify
S3_ENDPOINTURL is correct and accessible - Check firewall settings for outbound connections
- For self-hosted MinIO, ensure server is running and accessible
- Verify
Conclusion
You now have a robust, platform-agnostic S3-compatible asset storage solution integrated with your Vendure application. This configuration provides:
- Seamless switching between storage providers via environment variables
- Development-to-production workflow with local storage fallback
- Built-in compatibility with major S3-compatible services
- Production-ready configuration patterns
The unified approach eliminates the need for custom storage plugins while maintaining flexibility across different cloud storage platforms. Your assets will be reliably stored and served regardless of which S3-compatible provider you choose.
Next Steps
- Set up CDN integration for improved global asset delivery
- Implement backup strategies for critical assets
- Configure monitoring and alerting for storage operations
- Consider implementing asset optimization and transformation workflows
