This plugin allows you to create, download and manage backups from a dedicated View. Works together with kirby-janitor.
This plugin is completely free and published under the MIT license. However, if you are using it in a commercial project and want to help me keep up with maintenance, please consider making a donation of your choice or purchasing your license(s) through my affiliate link.
Prerequisite: you must install kirby-janitor (and the CLI per janitor's instructions) for this plugin to work. For a Kirby 3 website, install v.1.0.3. For a Kirby 4 website, install v.1.0.4+.
Download and copy this repository to /site/plugins/backups
Alternatively, you can install it with composer: composer require sylvainjule/backups
The plugin will work out of the box, no need for additionnal setup.
You can, however, change the prefix of the backups' filename (default is backup-{TIMESTAMP}.zip
)
// site/config.php
return [
'sylvainjule.backups.prefix' => 'backup-',
];
Any backup, created either with this plugin or with any of the janitor's options (CLI, CRON job, etc), will now show up in the Backups view.
Janitor stores the backups in a site/backups
folder. This folder isn't public and we should keep it that way. Therefore, anytime a user triggers a Download button, the plugin will create a copy of the given backup in a backups-temp
folder and expose an url from there.
When the user leaves the view, copies will be deleted.
This default public assets/backup-temp
folder can be changed to any name you'd like:
// site/config.php
return [
// backups will be copied in assets/my-secretly-public-backups
'sylvainjule.backups.publicFolder' => 'my-secretly-public-backups',
];
The backups list isn't paginated because it is not intended to keep hundreds of backups around. If included in a client website, you should include a note specifying an expected frequency of backup creation / deletion (or set up a CRON job).
You can enforce a maximum number of backups by setting the maximum
option to any integer (default is false
).
If this number is reached the oldest backup will be deleted automatically whenever a new backup is created.
// site/config.php
return [
'sylvainjule.backups.maximum' => 5,
];
If you want to create backups from a CRON job and still benefit from this maximum
option, the plugin exposes a tweaked janitor webhook:
https://your.domain/backups-webhook/{janitor.secret}/create-backup
There's also a way to disable the "Backups" menu-item for specific user roles:
# site/blueprints/users/{role}.yml
permissions:
access:
backups: false
MIT