52 lines
929 B
Elixir
52 lines
929 B
Elixir
defmodule Pleroma.Repo.Migrations.AddStatusToNotificationsEnum do
|
|
use Ecto.Migration
|
|
|
|
@disable_ddl_transaction true
|
|
|
|
def up do
|
|
"""
|
|
alter type notification_type add value 'status'
|
|
"""
|
|
|> execute()
|
|
end
|
|
|
|
def down do
|
|
alter table(:notifications) do
|
|
modify(:type, :string)
|
|
end
|
|
|
|
"""
|
|
delete from notifications where type = 'status'
|
|
"""
|
|
|> execute()
|
|
|
|
"""
|
|
drop type if exists notification_type
|
|
"""
|
|
|> execute()
|
|
|
|
"""
|
|
create type notification_type as enum (
|
|
'follow',
|
|
'follow_request',
|
|
'mention',
|
|
'move',
|
|
'pleroma:emoji_reaction',
|
|
'pleroma:chat_mention',
|
|
'reblog',
|
|
'favourite',
|
|
'pleroma:report',
|
|
'poll',
|
|
'update'
|
|
)
|
|
"""
|
|
|> execute()
|
|
|
|
"""
|
|
alter table notifications
|
|
alter column type type notification_type using (type::notification_type)
|
|
"""
|
|
|> execute()
|
|
end
|
|
end
|