Fix tootctl upgrade storage-schema misbehaving (#13761)

- Fix not moving original files of custom emojis
- Fix command failing to move any files with S3 storage
- Fix command marking records as upgraded when move failed

Fix #13594
This commit is contained in:
Eugen Rochko 2020-05-15 17:15:24 +02:00 committed by GitHub
parent a319c1e60f
commit 2b91a3dac0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -41,10 +41,16 @@ module Mastodon
klass.find_each do |record| klass.find_each do |record|
attachment_names.each do |attachment_name| attachment_names.each do |attachment_name|
attachment = record.public_send(attachment_name) attachment = record.public_send(attachment_name)
upgraded = false
next if attachment.blank? || attachment.storage_schema_version >= CURRENT_STORAGE_SCHEMA_VERSION next if attachment.blank? || attachment.storage_schema_version >= CURRENT_STORAGE_SCHEMA_VERSION
attachment.styles.each_key do |style| styles = attachment.styles.keys
styles << :original unless styles.include?(:original)
styles.each do |style|
success = begin
case Paperclip::Attachment.default_options[:storage] case Paperclip::Attachment.default_options[:storage]
when :s3 when :s3
upgrade_storage_s3(progress, attachment, style) upgrade_storage_s3(progress, attachment, style)
@ -53,11 +59,14 @@ module Mastodon
when :filesystem when :filesystem
upgrade_storage_filesystem(progress, attachment, style) upgrade_storage_filesystem(progress, attachment, style)
end end
end
upgraded = true if style == :original && success
progress.increment progress.increment
end end
attachment.instance_write(:storage_schema_version, CURRENT_STORAGE_SCHEMA_VERSION) attachment.instance_write(:storage_schema_version, CURRENT_STORAGE_SCHEMA_VERSION) if upgraded
end end
if record.changed? if record.changed?
@ -78,18 +87,20 @@ module Mastodon
def upgrade_storage_s3(progress, attachment, style) def upgrade_storage_s3(progress, attachment, style)
previous_storage_schema_version = attachment.storage_schema_version previous_storage_schema_version = attachment.storage_schema_version
object = attachment.s3_object(style) object = attachment.s3_object(style)
success = true
attachment.instance_write(:storage_schema_version, CURRENT_STORAGE_SCHEMA_VERSION) attachment.instance_write(:storage_schema_version, CURRENT_STORAGE_SCHEMA_VERSION)
upgraded_path = attachment.path(style) new_object = attachment.s3_object(style)
if upgraded_path != object.key && object.exists? if new_object.key != object.key && object.exists?
progress.log("Moving #{object.key} to #{upgraded_path}") if options[:verbose] progress.log("Moving #{object.key} to #{new_object.key}") if options[:verbose]
begin begin
object.move_to(upgraded_path) unless dry_run? object.move_to(new_object) unless dry_run?
rescue => e rescue => e
progress.log(pastel.red("Error processing #{object.key}: #{e}")) progress.log(pastel.red("Error processing #{object.key}: #{e}"))
success = false
end end
end end
@ -97,6 +108,7 @@ module Mastodon
# previous version at the end. The upgrade will be recorded after # previous version at the end. The upgrade will be recorded after
# all styles are updated # all styles are updated
attachment.instance_write(:storage_schema_version, previous_storage_schema_version) attachment.instance_write(:storage_schema_version, previous_storage_schema_version)
success
end end
def upgrade_storage_fog(_progress, _attachment, _style) def upgrade_storage_fog(_progress, _attachment, _style)
@ -107,6 +119,7 @@ module Mastodon
def upgrade_storage_filesystem(progress, attachment, style) def upgrade_storage_filesystem(progress, attachment, style)
previous_storage_schema_version = attachment.storage_schema_version previous_storage_schema_version = attachment.storage_schema_version
previous_path = attachment.path(style) previous_path = attachment.path(style)
success = true
attachment.instance_write(:storage_schema_version, CURRENT_STORAGE_SCHEMA_VERSION) attachment.instance_write(:storage_schema_version, CURRENT_STORAGE_SCHEMA_VERSION)
@ -128,6 +141,7 @@ module Mastodon
end end
rescue => e rescue => e
progress.log(pastel.red("Error processing #{previous_path}: #{e}")) progress.log(pastel.red("Error processing #{previous_path}: #{e}"))
success = false
unless dry_run? unless dry_run?
begin begin
@ -143,6 +157,7 @@ module Mastodon
# previous version at the end. The upgrade will be recorded after # previous version at the end. The upgrade will be recorded after
# all styles are updated # all styles are updated
attachment.instance_write(:storage_schema_version, previous_storage_schema_version) attachment.instance_write(:storage_schema_version, previous_storage_schema_version)
success
end end
end end
end end