module Shrine::Plugins::Backup

  1. lib/shrine/plugins/backup.rb

The backup plugin allows you to automatically back up stored files to an additional storage.

storages[:backup_store] =
plugin :backup, storage: :backup_store

After a file is stored, it will be reuploaded from store to the provided backup storage.

user.update(avatar: file) # uploaded both to :store and :backup_store

By default whenever stored files are deleted backed up files are deleted as well, but you can keep files on the “backup” storage by passing delete: false:

plugin :backup, storage: :backup_store, delete: false

Note that when adding this plugin with already existing stored files, Shrine won't know whether a stored file is backed up or not, so attempting to delete the backup could result in an error. To avoid that you can set delete: false until you manually back up the existing stored files.


Public Class

  1. configure

Public Class methods

configure (uploader, opts = {})
[show source]
# File lib/shrine/plugins/backup.rb, line 28
def self.configure(uploader, opts = {})
  uploader.opts[:backup_storage] = opts.fetch(:storage, uploader.opts[:backup_storage])
  uploader.opts[:backup_delete] = opts.fetch(:delete, uploader.opts.fetch(:backup_delete, true))

  raise Error, "The :storage option is required for backup plugin" if uploader.opts[:backup_storage].nil?