-
-
Notifications
You must be signed in to change notification settings - Fork 315
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
13 changed files
with
273 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
13 changes: 13 additions & 0 deletions
13
db/migrate/20240123080918_rename_alchemy_attachment_file.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
class RenameAlchemyAttachmentFile < ActiveRecord::Migration[7.0] | ||
COLUMNS = %i[ | ||
file_name | ||
file_size | ||
file_uid | ||
] | ||
|
||
def change | ||
COLUMNS.each do |column| | ||
rename_column :alchemy_attachments, column, :"legacy_#{column}" | ||
end | ||
end | ||
end |
16 changes: 16 additions & 0 deletions
16
db/migrate/20240123080918_rename_alchemy_picture_image_file.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
class RenameAlchemyPictureImageFile < ActiveRecord::Migration[7.0] | ||
COLUMNS = %i[ | ||
image_file_format | ||
image_file_height | ||
image_file_name | ||
image_file_size | ||
image_file_uid | ||
image_file_width | ||
] | ||
|
||
def change | ||
COLUMNS.each do |column| | ||
rename_column :alchemy_pictures, column, :"legacy_#{column}" | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,128 @@ | ||
# frozen_string_literal: true | ||
|
||
require "alchemy/shell" | ||
require "benchmark" | ||
require "active_storage/service/disk_service" | ||
|
||
module Alchemy | ||
class Upgrader::SevenPointOne < Upgrader | ||
extend Alchemy::Shell | ||
DEFAULT_CONTENT_TYPE = "application/octet-stream" | ||
DISK_SERVICE = ActiveStorage::Service::DiskService | ||
SERVICE_NAME = :alchemy_cms | ||
|
||
# Prevents (down)loading the original file | ||
METADATA = { | ||
identified: true, # Skip identifying file type | ||
analyzed: true, # Skip analyze job | ||
composed: true # Skip checksum check | ||
} | ||
|
||
class << self | ||
def migrate_pictures_to_active_storage | ||
pictures_without_as_attachment = Alchemy::Picture.where.missing(:image_file_attachment) | ||
count = pictures_without_as_attachment.count | ||
if count > 0 | ||
log "Migrating #{count} Dragonfly image file(s) to ActiveStorage." | ||
realtime = Benchmark.realtime do | ||
pictures_without_as_attachment.find_each do |picture| | ||
Alchemy::Deprecation.silence do | ||
uid = picture.legacy_image_file_uid | ||
key = key_for_uid(uid) | ||
content_type = Mime::Type.lookup_by_extension(picture.legacy_image_file_format) || DEFAULT_CONTENT_TYPE | ||
Alchemy::Picture.transaction do | ||
blob = ActiveStorage::Blob.create!( | ||
key: key, | ||
filename: picture.legacy_image_file_name, | ||
byte_size: picture.legacy_image_file_size, | ||
content_type: content_type, | ||
metadata: METADATA.merge( | ||
width: picture.legacy_image_file_width, | ||
height: picture.legacy_image_file_height | ||
), | ||
service_name: SERVICE_NAME | ||
) | ||
picture.create_image_file_attachment!( | ||
name: :image_file, | ||
record: picture, | ||
blob: blob | ||
) | ||
end | ||
move_file(Rails.root.join("uploads/pictures", uid), key) | ||
end | ||
print "." | ||
end | ||
end | ||
puts "\nDone in #{realtime.round(2)}s!" | ||
else | ||
log "No Dragonfly image files for migration found.", :skip | ||
end | ||
end | ||
|
||
def migrate_attachments_to_active_storage | ||
attachments_without_as_attachment = Alchemy::Attachment.where.missing(:file_attachment) | ||
count = attachments_without_as_attachment.count | ||
if count > 0 | ||
log "Migrating #{count} Dragonfly attachment file(s) to ActiveStorage." | ||
realtime = Benchmark.realtime do | ||
attachments_without_as_attachment.find_each do |attachment| | ||
Alchemy::Deprecation.silence do | ||
uid = attachment.legacy_file_uid | ||
key = key_for_uid(uid) | ||
Alchemy::Attachment.transaction do | ||
blob = ActiveStorage::Blob.create!( | ||
key: key, | ||
filename: attachment.legacy_file_name, | ||
byte_size: attachment.legacy_file_size, | ||
content_type: attachment.file_mime_type.presence || DEFAULT_CONTENT_TYPE, | ||
metadata: METADATA, | ||
service_name: SERVICE_NAME | ||
) | ||
attachment.create_file_attachment!( | ||
record: attachment, | ||
name: :file, | ||
blob: blob | ||
) | ||
end | ||
move_file(Rails.root.join("uploads/attachments", uid), key) | ||
end | ||
print "." | ||
end | ||
end | ||
puts "\nDone in #{realtime.round(2)}s!" | ||
else | ||
log "No Dragonfly attachment files for migration found.", :skip | ||
end | ||
end | ||
|
||
private | ||
|
||
# ActiveStorage::Service::DiskService stores files in a folder structure | ||
# based on the first two characters of the file uid. | ||
def key_for_uid(uid) | ||
case service | ||
when DISK_SERVICE | ||
uid.split("/").last | ||
else | ||
uid | ||
end | ||
end | ||
|
||
# ActiveStorage::Service::DiskService stores files in a folder structure | ||
# based on the first two characters of the file uid. | ||
def move_file(uid, key) | ||
case service | ||
when DISK_SERVICE | ||
if File.exist?(uid) | ||
service.send(:make_path_for, key) | ||
FileUtils.mv uid, service.send(:path_for, key) | ||
end | ||
end | ||
end | ||
|
||
def service | ||
ActiveStorage::Blob.services.fetch(SERVICE_NAME) | ||
end | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
14 changes: 14 additions & 0 deletions
14
spec/dummy/db/migrate/20240128195407_rename_alchemy_attachment_file.alchemy.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# This migration comes from alchemy (originally 20240123080918) | ||
class RenameAlchemyAttachmentFile < ActiveRecord::Migration[7.0] | ||
COLUMNS = %i[ | ||
file_name | ||
file_size | ||
file_uid | ||
] | ||
|
||
def change | ||
COLUMNS.each do |column| | ||
rename_column :alchemy_attachments, column, :"legacy_#{column}" | ||
end | ||
end | ||
end |
17 changes: 17 additions & 0 deletions
17
spec/dummy/db/migrate/20240128195408_rename_alchemy_picture_image_file.alchemy.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# This migration comes from alchemy (originally 20240123080918) | ||
class RenameAlchemyPictureImageFile < ActiveRecord::Migration[7.0] | ||
COLUMNS = %i[ | ||
image_file_format | ||
image_file_height | ||
image_file_name | ||
image_file_size | ||
image_file_uid | ||
image_file_width | ||
] | ||
|
||
def change | ||
COLUMNS.each do |column| | ||
rename_column :alchemy_pictures, column, :"legacy_#{column}" | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters