-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
6 changed files
with
8,706 additions
and
3,057 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
#!/usr/bin/env sh | ||
. "$(dirname -- "$0")/_/husky.sh" | ||
|
||
npx --no -- commitlint --edit |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
#!/usr/bin/env sh | ||
. "$(dirname -- "$0")/_/husky.sh" | ||
|
||
pnpm exec lint-staged |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,224 @@ | ||
# strapi-v4-provider-cos | ||
Tencent Cloud COS storage provider designed specifically for Strapi v4. Simplifies the integration of Tencent Cloud COS as a file storage solution within Strapi v4. | ||
# strapi-provider-upload-tencent-cloud-storage | ||
|
||
## Resources | ||
|
||
- [LICENSE](LICENSE) | ||
|
||
## Links | ||
|
||
- [Strapi website](https://strapi.io/) | ||
- [Strapi documentation](https://docs.strapi.io) | ||
- [Strapi community on Discord](https://discord.strapi.io) | ||
- [Strapi news on Twitter](https://twitter.com/strapijs) | ||
|
||
## Installation | ||
|
||
```bash | ||
# using yarn | ||
yarn add strapi-provider-upload-tencent-cloud-storage | ||
|
||
# using npm | ||
npm install strapi-provider-upload-tencent-cloud-storage --save | ||
``` | ||
|
||
## Configuration | ||
|
||
- `provider` defines the name of the provider | ||
- `providerOptions` is passed down during the construction of the provider. It contains the following properties: | ||
|
||
- SecretId: Tencent Cloud API SecretId | ||
- SecretKey: Tencent Cloud API SecretKey | ||
- Region: Tencent Cloud API Region | ||
- Bucket: Tencent Cloud API Bucket | ||
- ACL: (optional) ACL applied to the uploaded files. If you set it to `private` you will need to configure the [security middleware](#security-middleware-configuration) to properly see thumbnail previews in the Media Library. | ||
- Expires: (optional) Expiration time of the signed URL. Default value is 360 seconds (6 minutes). | ||
- initOptions: (optional) Options passed to the constructor of the provider. You can find the complete list of [options here](https://cloud.tencent.com/document/product/436/8629#:~:text=%E5%8F%82%E8%A7%81%20demo%20%E7%A4%BA%E4%BE%8B%E3%80%82-,%E9%85%8D%E7%BD%AE%E9%A1%B9,-%E6%9E%84%E9%80%A0%E5%87%BD%E6%95%B0%E5%8F%82%E6%95%B0) | ||
- uploadOptions: (optional) Options passed to the `upload` method. You can find the complete list of [options here](https://cloud.tencent.com/document/product/436/64980#.E7.AE.80.E5.8D.95.E4.B8.8A.E4.BC.A0.E5.AF.B9.E8.B1.A1) | ||
|
||
See the [documentation about using a provider](https://docs.strapi.io/developer-docs/latest/plugins/upload.html#using-a-provider) for information on installing and using a provider. To understand how environment variables are used in Strapi, please refer to the [documentation about environment variables](https://docs.strapi.io/developer-docs/latest/setup-deployment-guides/configurations/optional/environment.html#environment-variables). | ||
|
||
### Provider Configuration | ||
|
||
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = ({ env }) => ({ | ||
// ... | ||
upload: { | ||
config: { | ||
provider: 'strapi-provider-upload-tencent-cloud-storage', | ||
providerOptions: { | ||
SecretId: env('COS_SecretId'), | ||
SecretKey: env('COS_SecretKey'), | ||
Region: env('COS_Region'), | ||
Bucket: env('COS_Bucket'), | ||
}, | ||
}, | ||
}, | ||
// ... | ||
}); | ||
``` | ||
|
||
### Configuration for a private COS bucket and signed URLs | ||
|
||
If your bucket is configured to be private, you will need to set the `ACL` option to `private` in the `params` object. This will ensure file URLs are signed. | ||
|
||
You can also define the expiration time of the signed URL by setting the `Expires` option in the `providerOptions` object. The default value is 360 seconds (6 minutes). | ||
|
||
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = ({ env }) => ({ | ||
// ... | ||
upload: { | ||
config: { | ||
provider: 'strapi-provider-upload-tencent-cloud-storage', | ||
providerOptions: { | ||
SecretId: env('COS_SecretId'), | ||
SecretKey: env('COS_SecretKey'), | ||
Region: env('COS_Region'), | ||
Bucket: env('COS_Bucket'), | ||
ACL: 'private', // <= set ACL to private | ||
}, | ||
}, | ||
}, | ||
// ... | ||
}); | ||
``` | ||
|
||
### 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 bellow instead as explained in the [middleware configuration](https://docs.strapi.io/developer-docs/latest/setup-deployment-guides/configurations/required/middlewares.html#loading-order) documentation. | ||
|
||
`./config/middlewares.js` or `./config/middlewares.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = [ | ||
// ... | ||
{ | ||
name: 'strapi::security', | ||
config: { | ||
contentSecurityPolicy: { | ||
useDefaults: true, | ||
directives: { | ||
'connect-src': ["'self'", 'https:'], | ||
'img-src': [ | ||
"'self'", | ||
'data:', | ||
'blob:', | ||
'market-assets.strapi.io', | ||
'yourBucketName.cos.yourRegion.myqcloud.com', | ||
], | ||
'media-src': [ | ||
"'self'", | ||
'data:', | ||
'blob:', | ||
'market-assets.strapi.io', | ||
'yourBucketName.cos.yourRegion.myqcloud.com' | ||
], | ||
upgradeInsecureRequests: null, | ||
}, | ||
}, | ||
}, | ||
}, | ||
// ... | ||
]; | ||
``` | ||
|
||
### Configure the access domain (CDN/global acceleration) | ||
|
||
#### Default CDN Acceleration Domain | ||
|
||
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = ({ env }) => ({ | ||
// ... | ||
upload: { | ||
config: { | ||
provider: 'strapi-provider-upload-tencent-cloud-storage', | ||
providerOptions: { | ||
Domain: '{Bucket}.file.myqcloud.com', // <= Custom acceleration domain name, the Domain parameter supports templates. In this example, {Bucket} will be automatically replaced with the provided Bucket during the request. | ||
SecretId: env('COS_SecretId'), | ||
SecretKey: env('COS_SecretKey'), | ||
Region: env('COS_Region'), | ||
Bucket: env('COS_Bucket'), | ||
}, | ||
}, | ||
}, | ||
// ... | ||
}); | ||
``` | ||
|
||
#### Custom CDN Acceleration Domain | ||
|
||
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = ({ env }) => ({ | ||
// ... | ||
upload: { | ||
config: { | ||
provider: 'strapi-provider-upload-tencent-cloud-storage', | ||
providerOptions: { | ||
Domain: 'example-cdn-domain.com', // <= Custom Accelerated Domain | ||
SecretId: env('COS_SecretId'), | ||
SecretKey: env('COS_SecretKey'), | ||
Region: env('COS_Region'), | ||
Bucket: env('COS_Bucket'), | ||
}, | ||
}, | ||
}, | ||
// ... | ||
}); | ||
``` | ||
|
||
#### Custom Source Site Domain | ||
|
||
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = ({ env }) => ({ | ||
// ... | ||
upload: { | ||
config: { | ||
provider: 'strapi-provider-upload-tencent-cloud-storage', | ||
providerOptions: { | ||
Domain: 'example-cos-domain.com', // <= Custom Source Site Domain | ||
SecretId: env('COS_SecretId'), | ||
SecretKey: env('COS_SecretKey'), | ||
Region: env('COS_Region'), | ||
Bucket: env('COS_Bucket'), | ||
}, | ||
}, | ||
}, | ||
// ... | ||
}); | ||
``` | ||
|
||
#### Global Accelerated Domain | ||
|
||
`./config/plugins.js` or `./config/plugins.ts` for TypeScript projects: | ||
|
||
```js | ||
module.exports = ({ env }) => ({ | ||
// ... | ||
upload: { | ||
config: { | ||
provider: 'strapi-provider-upload-tencent-cloud-storage', | ||
providerOptions: { | ||
UseAccelerate: true, | ||
SecretId: env('COS_SecretId'), | ||
SecretKey: env('COS_SecretKey'), | ||
Region: env('COS_Region'), | ||
Bucket: env('COS_Bucket'), | ||
}, | ||
}, | ||
}, | ||
// ... | ||
}); | ||
``` | ||
|
||
### Contribution | ||
|
||
Feel free to fork and make a Pull Request to this plugin project. All the input is warmly welcome! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.