mirror of
https://github.com/discourse/discourse.git
synced 2025-02-05 19:11:13 +00: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
558 B
Ruby
19 lines
558 B
Ruby
# frozen_string_literal: true
|
|
|
|
class CopyUserUploadsToUploadReferences < ActiveRecord::Migration[6.1]
|
|
def up
|
|
execute <<~SQL
|
|
INSERT INTO upload_references(upload_id, target_type, target_id, created_at, updated_at)
|
|
SELECT users.uploaded_avatar_id, 'User', users.id, uploads.created_at, uploads.updated_at
|
|
FROM users
|
|
JOIN uploads ON uploads.id = users.uploaded_avatar_id
|
|
WHERE users.uploaded_avatar_id IS NOT NULL
|
|
ON CONFLICT DO NOTHING
|
|
SQL
|
|
end
|
|
|
|
def down
|
|
raise ActiveRecord::IrreversibleMigration
|
|
end
|
|
end
|