Non-Official Vercel Blob Provider for Strapi Upload
# using yarn
yarn add @femtozer/strapi-provider-upload-vercel-blob
# using npm
npm install @strapi/strapi-provider-upload-vercel-blob --save
Create a new Blob store on Vercel:
You will need to copy the BLOB_READ_WRITE_TOKEN
that can be found under .env.local
tab, on your store's dashboard.
Configure the upload provider in plugins.js
file:
module.exports = {
upload: {
config: {
provider: "@femtozer/strapi-provider-upload-vercel-blob",
providerOptions: {
vercelBlobReadWriteToken: "<BLOB_READ_WRITE_TOKEN>",
},
},
},
//...
};
First, copy the id of your store.
It can be found on the url of your stores's dashboard:
https://vercel.com/dashboard/stores/blob/store_<STORE_ID>
Then update middlewares.js
with the following CSP configuration:
module.exports = [
"strapi::errors",
{
name: "strapi::security",
config: {
contentSecurityPolicy: {
useDefaults: true,
directives: {
"connect-src": ["'self'", "https:"],
"img-src": [
"'self'",
"data:",
"blob:",
"https://<STORE_ID>.public.blob.vercel-storage.com",
"dl.airtable.com",
"market-assets.strapi.io",
],
"media-src": [
"'self'",
"data:",
"blob:",
"https:/<STORE_ID>.public.blob.vercel-storage.com",
"dl.airtable.com",
"market-assets.strapi.io",
],
upgradeInsecureRequests: null,
},
},
},
},
"strapi::cors",
"strapi::poweredBy",
"strapi::logger",
"strapi::query",
"strapi::body",
"strapi::session",
"strapi::favicon",
"strapi::public",
];