defmodule Core.Repo.Migrations.AddBlueskyTables do use Ecto.Migration def change do create table(:bluesky_accounts, primary_key: false) do add :id, :uuid, primary_key: true add :user_id, references(:users, type: :uuid, on_delete: :delete_all), null: false add :handle, :text, null: false add :did, :text, null: false add :access_jwt, :text, null: false add :access_jwt_iat, :utc_datetime, null: false add :access_jwt_exp, :utc_datetime, null: false add :refresh_jwt, :text, null: false add :refresh_jwt_iat, :utc_datetime, null: false add :refresh_jwt_exp, :utc_datetime, null: false timestamps(type: :utc_datetime_usec) end create unique_index(:bluesky_accounts, [:user_id]) create table(:bluesky_posts, primary_key: false) do add :id, :uuid, primary_key: true add :post_id, references(:posts, type: :uuid, on_delete: :delete_all), null: false add :cid, :text, null: false add :uri, :text, null: false add :commit, :jsonb, null: false timestamps(type: :utc_datetime_usec) end create unique_index(:bluesky_posts, [:post_id]) alter table(:posts) do add :syndicate_to_bluesky, :boolean, default: false, null: false end end end