- Strapi
- AWS CloudFront SDK
Tested with Strapi v4 (current)
As a ✅ verified plugin by Strapi team we're available on the Strapi Marketplace as well as In-App Marketplace where you can follow the installation instructions.
It's recommended to use yarn to install this plugin within your Strapi project. You can install yarn with these docs.
yarn add strapi-plugin-aws-cloudfront@latest
After successful installation you've to re-build your Strapi instance. To archive that simply use:
yarn build
yarn develop
or just run Strapi in the development mode with --watch-admin
option:
yarn develop --watch-admin
./config/plugins.js
or ./config/plugins.ts
for TypeScript projects:
Option | Default | Description |
---|---|---|
client |
{} | |
client.distributionId |
The distribution id to connect to the CloudFront | |
bulk |
true | Activate or not bulk mode (recommended) |
bulkTimeout |
500 | Timeout for the bulk mode (in milliseconds) |
defaultConfig |
{} | |
defaultConfig.defaultLocale |
Set the default local | |
defaultConfig.prefixDefaultLocale |
Prefix the path with the default locale (only if prefixLocalization is set to true ) |
|
defaultConfig.prefixLocalization |
Prefix the path with the locale (except default locale) | |
defaultConfig.noTrailingSlash |
Remove the trailing slash at the end of the url | |
contentTypes |
{} | |
contentTypes.<my-content-type-name>.path |
[] | List of path to invalidate |
contentTypes.<my-content-type-name>.localizedPath |
{} | See below |
contentTypes.<my-content-type-name>.localizedPath.<locale> |
[] | List of path to invalidate |
module.exports = ({ env }) => ({
// ...
'aws-cloudfront': {
enabled: true,
config: {
client: {
distributionId: env('WEBSITE_CDN'),
},
bulk: true, // invalidate multiple urls in one call (default: true) (recommended)
bulkTimeout: 500, // milliseconds (default: 500)
defaultConfig: {
defaultLocale: 'fr', // default locale (default: empty)
prefixDefaultLocale: true, // prefix for the default locale (default: false)
prefixLocalization: true, // prefix url with /{locale}. Eg: /fr for french locale (default: false)
noTrailingSlash: true, // remove trailing slash at the end of url (default: false)
},
contentTypes: {
'my-content-type-name': {
prefixLocalization: false, // override defaultConfig.prefixLocalization
path: ['/*'], // invalidate all pages
},
'homepage': {
localizedPath: {
fr: ['/accueil'],
en: ['/home'],
},
},
'article': {
localizedPath: {
fr: ['/article/:slug'], // use the `slug` attribute value of `article` content type
en: ['/article/:slug'],
},
},
},
},
},
// ...
})
The cache will be invalidate when :
- For non-published content :
beforeUpdate
beforeUpdateMany
beforeDelete
beforeDeleteMany
afterUpdate
afterUpdateMany
- For published content :
- If old content was published :
beforeUpdate
beforeUpdateMany
beforeDelete
beforeDeleteMany
- If new content is published :
afterUpdate
afterUpdateMany
- If old content was published :
See more about lifecycle events.
In this example:
- Edit
my-content-type-name
invalidate/*
- Edit
homepage
infr
invalidate/fr/accueil
- Edit
homepage
inen
invalidate/en/home
- Edit the slug
article
inen
invalidate/en/article/old-slug
and/en/article/new-slug
You can invalidate some path with the service.
Example in src/api/my-api-name/content-types/my-content-type-name/lifecycles.js
:
module.exports = {
afterUpdate(event) {
strapi.plugin('aws-cloudfront').service('cloudfront').invalidateByEntry('my-content-type-name', event.result) // need to defined the content type in plugin configurations (see above)
strapi.plugin('aws-cloudfront').service('cloudfront').invalidate(`/some-url`)
},
}