Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ainsleydev/strapi-provider-upload-vercel
A provider for Strapi that uploads media to Vercel's Blob store.
https://github.com/ainsleydev/strapi-provider-upload-vercel
cms strapi typescript uploader vercel
Last synced: about 1 month ago
JSON representation
A provider for Strapi that uploads media to Vercel's Blob store.
- Host: GitHub
- URL: https://github.com/ainsleydev/strapi-provider-upload-vercel
- Owner: ainsleydev
- License: mit
- Created: 2023-10-02T19:17:10.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-21T19:49:32.000Z (8 months ago)
- Last Synced: 2024-09-29T09:41:09.938Z (about 2 months ago)
- Topics: cms, strapi, typescript, uploader, vercel
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/strapi-provider-upload-vercel
- Size: 296 KB
- Stars: 2
- Watchers: 0
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
[![npm](https://img.shields.io/npm/v/strapi-provider-upload-vercel.svg?style=flat-shiny&logo=npm&color=white)](https://www.npmjs.com/package/strapi-provider-upload-vercel)
![Made with TypeScript](https://img.shields.io/badge/Made%20with-TypeScript-blue.svg?style=flat&logo=typescript)
[![Lint](https://github.com/ainsleydev/audits.com/actions/workflows/lint.yaml/badge.svg?branch=main&query=main)](https://github.com/ainsleydev/audits.com/actions/workflows/lint.yaml?query=main)
[![ainsley.dev](https://img.shields.io/badge/-ainsley.dev-black?style=flat&logo=)](https://ainsley.dev)
[![Twitter Handle](https://img.shields.io/twitter/follow/ainsleydev)](https://twitter.com/ainsleydev)## Strapi Vercel Blob Provider
A provider for Strapi that uploads media to Vercel's Blob store.
## Install
`npm install strapi-provider-upload-vercel`
## Configuration
The plugin settings mimic the SDK parameters defined in
their [documentation](https://vercel.com/docs/storage/vercel-blob/using-blob-sdk)- `token` A string specifying the token to use when making requests. It defaults to `process.env.BLOB_READ_WRITE_TOKEN`
when deployed on Vercel as explained in Read-write token. You can also pass a client token created with
the `generateClientTokenFromReadWriteToken` method
- `addRandomSuffix` A boolean specifying whether to add a random suffix to the pathname. It defaults to `true`.
- `cacheControlMaxAge` A number in seconds to configure the edge and browser cache. Defaults to one year. See the
caching documentation for more details.### Provider Configuration
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects:
```typescript
module.exports = ({ env }) => ({
upload: {
config: {
provider: 'strapi-provider-upload-vercel',
providerOptions: {
token: env('VERCEL_BLOB_TOKEN'),
addRandomSuffix: true,
cacheControlMaxAge: 31536000, // Year in seconds
},
},
},
});
```## Security Middleware Configuration
Due to the default settings in the Strapi Security Middleware you will need to modify the `contentSecurityPolicy`
settings to properly see thumbnail previews in the Media Library. You should replace `strapi::security` string with the
object below instead as explained in the middleware configuration documentation.```typescript
export default [
// ...
{
name: 'strapi::security',
config: {
contentSecurityPolicy: {
useDefaults: true,
directives: {
'connect-src': ["'self'", 'https:'],
'img-src': [
"'self'",
'data:',
'blob:',
'https://yourbucketname.public.blob.vercel-storage.com',
],
'media-src': [
"'self'",
'data:',
'blob:',
'https://yourbucketname.public.blob.vercel-storage.com',
],
upgradeInsecureRequests: null,
},
},
},
},
];
```## Open Source
[ainsley.dev](https://ainsley.dev) permits the use of any code found within the repository for use with external
projects.## Trademark
ainsley.dev and the ainsley.dev logo are either registered trademarks or trademarks of ainsley.dev LTD in the United
Kingdom and/or other countries. All other trademarks are the property of their respective owners.