summaryrefslogtreecommitdiff
path: root/priv/repo/migrations/20220308012601_create_announcements.exs
blob: 01c9ce041c71966bd2bcd1053ff57e433ce1ea67 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
defmodule Pleroma.Repo.Migrations.CreateAnnouncements do
  use Ecto.Migration

  def change do
    create_if_not_exists table(:announcements, primary_key: false) do
      add(:id, :uuid, primary_key: true)
      add(:data, :map)
      add(:starts_at, :naive_datetime)
      add(:ends_at, :naive_datetime)
      add(:rendered, :map)

      timestamps()
    end

    create_if_not_exists table(:announcement_read_relationships) do
      add(:user_id, references(:users, type: :uuid, on_delete: :delete_all))
      add(:announcement_id, references(:announcements, type: :uuid, on_delete: :delete_all))

      timestamps(updated_at: false)
    end

    create_if_not_exists(
      unique_index(:announcement_read_relationships, [:user_id, :announcement_id])
    )
  end
end