Merge pull request #3030 from evazion/feat-backups
Backup posts to S3 on creation/replacement
This commit is contained in:
@@ -23,6 +23,7 @@ class Post < ActiveRecord::Base
|
||||
before_save :set_tag_counts
|
||||
before_save :set_pool_category_pseudo_tags
|
||||
before_create :autoban
|
||||
after_save :queue_backup, if: :md5_changed?
|
||||
after_save :create_version
|
||||
after_save :update_parent_on_save
|
||||
after_save :apply_post_metatags
|
||||
@@ -229,6 +230,23 @@ class Post < ActiveRecord::Base
|
||||
end
|
||||
end
|
||||
|
||||
module BackupMethods
|
||||
extend ActiveSupport::Concern
|
||||
|
||||
def queue_backup
|
||||
Post.delay(queue: "default", priority: -1).backup_file(file_path, id: id, type: :original)
|
||||
Post.delay(queue: "default", priority: -1).backup_file(large_file_path, id: id, type: :large) if has_large?
|
||||
Post.delay(queue: "default", priority: -1).backup_file(preview_file_path, id: id, type: :preview) if has_preview?
|
||||
end
|
||||
|
||||
module ClassMethods
|
||||
def backup_file(file_path, options = {})
|
||||
backup_service = Danbooru.config.backup_service
|
||||
backup_service.backup(file_path, options)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
module ImageMethods
|
||||
def device_scale
|
||||
if large_image_width > 320
|
||||
@@ -1695,6 +1713,7 @@ class Post < ActiveRecord::Base
|
||||
end
|
||||
|
||||
include FileMethods
|
||||
include BackupMethods
|
||||
include ImageMethods
|
||||
include ApprovalMethods
|
||||
include PresenterMethods
|
||||
|
||||
Reference in New Issue
Block a user