medusa-file-r2
Cloudflare R2 storage plugin for Medusa. This plugin also supports CSV exports and imports. R2 is S3-compatible object storage service by Cloudflare and has a 10GB/month forever-free tier.
This plugin is written in Typescript and uses ESBuild to create the bundle and files needed to be included in the medusa.config.js
file.
Getting Started
- Create a Cloudflare account: If you don't have one, you can create one here.
- Create a R2 bucket: Follow this guide to create a R2 bucket.
- Make the bucket public: Follow this guide to make the bucket public. While managed public access for your buckets through r2.dev cloudflare subdomain is relatively easy, it's preferred to use a custom domain as the managed r2.dev subdomain is rate-limited, custom domain also makes use of Cloudflare Cache to accelerate access to your R2 bucket.
- Obtain required credentials: You will need the following credentials to configure the plugin:
account_id
: Login to your Cloudflare account and go to theR2
section. Theaccount_id
is theAccount ID
in the top right corner.access_key
andsecret_key
- Follow this guide to generate Access Key ID and Secret Access Key for your R2 bucket.
bucket
: The name of the R2 bucket you created.public_url
: The public URL of the R2 bucket you created.
Install
medusa-file-r2
plugin: Run the following command in your terminal:yarn add medusa-file-r2Add the plugin to medusa.config.js: Add the following code to your medusa.config.js file:
const plugins = [// other plugin configurations{resolve: "medusa-file-r2",options: {account_id: "YOUR_ACCOUNT_ID",access_key: "YOUR_ACCESS_KEY",secret_key: "YOUR_SECRET_KEY",bucket: "YOUR_R2_BUCKET_NAME",public_url: "YOUR_R2_BUCKET_PUBLIC_URL",},},];

.png)
Build your own plugins
Take Medusa up another level, and develop your own plugins with our API to speed up your processes.
Focus on building plugins for tools you use in your daily workflow, and publish to the Medusa Plugin Store for others to install.
.png)