mirror of
https://github.com/discourse/discourse.git
synced 2024-11-25 10:20:58 -06:00
9db8f00b3d
This table holds associations between uploads and other models. This can be used to prevent removing uploads that are still in use. * DEV: Create upload_references * DEV: Use UploadReference instead of PostUpload * DEV: Use UploadReference for SiteSetting * DEV: Use UploadReference for Badge * DEV: Use UploadReference for Category * DEV: Use UploadReference for CustomEmoji * DEV: Use UploadReference for Group * DEV: Use UploadReference for ThemeField * DEV: Use UploadReference for ThemeSetting * DEV: Use UploadReference for User * DEV: Use UploadReference for UserAvatar * DEV: Use UploadReference for UserExport * DEV: Use UploadReference for UserProfile * DEV: Add method to extract uploads from raw text * DEV: Use UploadReference for Draft * DEV: Use UploadReference for ReviewableQueuedPost * DEV: Use UploadReference for UserProfile's bio_raw * DEV: Do not copy user uploads to upload references * DEV: Copy post uploads again after deploy * DEV: Use created_at and updated_at from uploads table * FIX: Check if upload site setting is empty * DEV: Copy user uploads to upload references * DEV: Make upload extraction less strict
19 lines
557 B
Ruby
19 lines
557 B
Ruby
# frozen_string_literal: true
|
|
|
|
class CopyBadgesUploadsToUploadReferences < ActiveRecord::Migration[6.1]
|
|
def up
|
|
execute <<~SQL
|
|
INSERT INTO upload_references(upload_id, target_type, target_id, created_at, updated_at)
|
|
SELECT badges.image_upload_id, 'Badge', badges.id, uploads.created_at, uploads.updated_at
|
|
FROM badges
|
|
JOIN uploads ON uploads.id = badges.image_upload_id
|
|
WHERE badges.image_upload_id IS NOT NULL
|
|
ON CONFLICT DO NOTHING
|
|
SQL
|
|
end
|
|
|
|
def down
|
|
raise ActiveRecord::IrreversibleMigration
|
|
end
|
|
end
|