sylvainjule / kirby-backups

Manage backups from the Kirby panel
MIT License
37 stars 2 forks source link

Kirby Backups

This plugin allows you to create, download and manage backups from a dedicated View. Works together with kirby-janitor.

screenshot-k4


Overview

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.


1. Installation

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


2. Usage

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


3. License

MIT


4. Credits