aboutsummaryrefslogtreecommitdiff
path: root/priv
diff options
context:
space:
mode:
Diffstat (limited to 'priv')
-rw-r--r--priv/repo/migrations/20191108161911_create_user_blocks.exs14
-rw-r--r--priv/repo/migrations/20191108173911_data_migration_populate_user_blocks.exs49
-rw-r--r--priv/repo/migrations/20191112151559_create_user_mutes.exs14
-rw-r--r--priv/repo/migrations/20191112151614_data_migration_populate_user_mutes.exs48
-rw-r--r--priv/repo/migrations/20191118084425_create_user_relationships.exs17
-rw-r--r--priv/repo/migrations/20191118084500_data_migration_populate_user_relationships.exs64
6 files changed, 81 insertions, 125 deletions
diff --git a/priv/repo/migrations/20191108161911_create_user_blocks.exs b/priv/repo/migrations/20191108161911_create_user_blocks.exs
deleted file mode 100644
index c882d2bd6..000000000
--- a/priv/repo/migrations/20191108161911_create_user_blocks.exs
+++ /dev/null
@@ -1,14 +0,0 @@
-defmodule Pleroma.Repo.Migrations.CreateUserBlocks do
- use Ecto.Migration
-
- def change do
- create_if_not_exists table(:user_blocks) do
- add(:blocker_id, references(:users, type: :uuid, on_delete: :delete_all))
- add(:blockee_id, references(:users, type: :uuid, on_delete: :delete_all))
-
- timestamps(updated_at: false)
- end
-
- create_if_not_exists(unique_index(:user_blocks, [:blocker_id, :blockee_id]))
- end
-end
diff --git a/priv/repo/migrations/20191108173911_data_migration_populate_user_blocks.exs b/priv/repo/migrations/20191108173911_data_migration_populate_user_blocks.exs
deleted file mode 100644
index fe537679d..000000000
--- a/priv/repo/migrations/20191108173911_data_migration_populate_user_blocks.exs
+++ /dev/null
@@ -1,49 +0,0 @@
-defmodule Pleroma.Repo.Migrations.DataMigrationPopulateUserBlocks do
- use Ecto.Migration
-
- alias Ecto.Adapters.SQL
- alias Pleroma.Repo
-
- require Logger
-
- def up do
- {:ok, %{rows: block_rows}} =
- SQL.query(Repo, "SELECT id, blocks FROM users WHERE blocks != '{}'")
-
- blockee_ap_ids =
- Enum.flat_map(
- block_rows,
- fn [_, ap_ids] -> ap_ids end
- )
- |> Enum.uniq()
-
- # Selecting ids of all blockees at once in order to reduce the number of SELECT queries
- {:ok, %{rows: blockee_ap_id_id}} =
- SQL.query(Repo, "SELECT ap_id, id FROM users WHERE ap_id = ANY($1)", [blockee_ap_ids])
-
- blockee_id_by_ap_id = Enum.into(blockee_ap_id_id, %{}, fn [k, v] -> {k, v} end)
-
- Enum.each(
- block_rows,
- fn [blocker_id, blockee_ap_ids] ->
- blocker_uuid = Ecto.UUID.cast!(blocker_id)
-
- for blockee_ap_id <- blockee_ap_ids do
- blockee_id = blockee_id_by_ap_id[blockee_ap_id]
-
- with {:ok, blockee_uuid} <- blockee_id && Ecto.UUID.cast(blockee_id) do
- execute(
- "INSERT INTO user_blocks(blocker_id, blockee_id, inserted_at) " <>
- "VALUES('#{blocker_uuid}'::uuid, '#{blockee_uuid}'::uuid, now()) " <>
- "ON CONFLICT (blocker_id, blockee_id) DO NOTHING"
- )
- else
- _ -> Logger.warn("Missing reference: (#{blocker_uuid}, #{blockee_id})")
- end
- end
- end
- )
- end
-
- def down, do: :noop
-end
diff --git a/priv/repo/migrations/20191112151559_create_user_mutes.exs b/priv/repo/migrations/20191112151559_create_user_mutes.exs
deleted file mode 100644
index eaa285de2..000000000
--- a/priv/repo/migrations/20191112151559_create_user_mutes.exs
+++ /dev/null
@@ -1,14 +0,0 @@
-defmodule Pleroma.Repo.Migrations.CreateUserMutes do
- use Ecto.Migration
-
- def change do
- create_if_not_exists table(:user_mutes) do
- add(:muter_id, references(:users, type: :uuid, on_delete: :delete_all))
- add(:mutee_id, references(:users, type: :uuid, on_delete: :delete_all))
-
- timestamps(updated_at: false)
- end
-
- create_if_not_exists(unique_index(:user_mutes, [:muter_id, :mutee_id]))
- end
-end
diff --git a/priv/repo/migrations/20191112151614_data_migration_populate_user_mutes.exs b/priv/repo/migrations/20191112151614_data_migration_populate_user_mutes.exs
deleted file mode 100644
index a8bdd072e..000000000
--- a/priv/repo/migrations/20191112151614_data_migration_populate_user_mutes.exs
+++ /dev/null
@@ -1,48 +0,0 @@
-defmodule Pleroma.Repo.Migrations.DataMigrationPopulateUserMutes do
- use Ecto.Migration
-
- alias Ecto.Adapters.SQL
- alias Pleroma.Repo
-
- require Logger
-
- def up do
- {:ok, %{rows: mute_rows}} = SQL.query(Repo, "SELECT id, mutes FROM users WHERE mutes != '{}'")
-
- mutee_ap_ids =
- Enum.flat_map(
- mute_rows,
- fn [_, ap_ids] -> ap_ids end
- )
- |> Enum.uniq()
-
- # Selecting ids of all mutees at once in order to reduce the number of SELECT queries
- {:ok, %{rows: mutee_ap_id_id}} =
- SQL.query(Repo, "SELECT ap_id, id FROM users WHERE ap_id = ANY($1)", [mutee_ap_ids])
-
- mutee_id_by_ap_id = Enum.into(mutee_ap_id_id, %{}, fn [k, v] -> {k, v} end)
-
- Enum.each(
- mute_rows,
- fn [muter_id, mutee_ap_ids] ->
- muter_uuid = Ecto.UUID.cast!(muter_id)
-
- for mutee_ap_id <- mutee_ap_ids do
- mutee_id = mutee_id_by_ap_id[mutee_ap_id]
-
- with {:ok, mutee_uuid} <- mutee_id && Ecto.UUID.cast(mutee_id) do
- execute(
- "INSERT INTO user_mutes(muter_id, mutee_id, inserted_at) " <>
- "VALUES('#{muter_uuid}'::uuid, '#{mutee_uuid}'::uuid, now()) " <>
- "ON CONFLICT (muter_id, mutee_id) DO NOTHING"
- )
- else
- _ -> Logger.warn("Missing reference: (#{muter_uuid}, #{mutee_id})")
- end
- end
- end
- )
- end
-
- def down, do: :noop
-end
diff --git a/priv/repo/migrations/20191118084425_create_user_relationships.exs b/priv/repo/migrations/20191118084425_create_user_relationships.exs
new file mode 100644
index 000000000..c281f887d
--- /dev/null
+++ b/priv/repo/migrations/20191118084425_create_user_relationships.exs
@@ -0,0 +1,17 @@
+defmodule Pleroma.Repo.Migrations.CreateUserRelationships do
+ use Ecto.Migration
+
+ def change do
+ create_if_not_exists table(:user_relationships) do
+ add(:source_id, references(:users, type: :uuid, on_delete: :delete_all))
+ add(:target_id, references(:users, type: :uuid, on_delete: :delete_all))
+ add(:relationship_type, :integer, null: false)
+
+ timestamps(updated_at: false)
+ end
+
+ create_if_not_exists(
+ unique_index(:user_relationships, [:source_id, :relationship_type, :target_id])
+ )
+ end
+end
diff --git a/priv/repo/migrations/20191118084500_data_migration_populate_user_relationships.exs b/priv/repo/migrations/20191118084500_data_migration_populate_user_relationships.exs
new file mode 100644
index 000000000..f8dde7626
--- /dev/null
+++ b/priv/repo/migrations/20191118084500_data_migration_populate_user_relationships.exs
@@ -0,0 +1,64 @@
+defmodule Pleroma.Repo.Migrations.DataMigrationPopulateUserRelationships do
+ use Ecto.Migration
+
+ alias Ecto.Adapters.SQL
+ alias Pleroma.Repo
+
+ require Logger
+
+ def up do
+ Enum.each(
+ [blocks: 1, mutes: 2, muted_reblogs: 3, muted_notifications: 4],
+ fn {field, relationship_type_code} ->
+ migrate(field, relationship_type_code)
+ end
+ )
+ end
+
+ def down, do: :noop
+
+ defp migrate(field, relationship_type_code) do
+ Logger.info("Processing users.#{field}...")
+
+ {:ok, %{rows: field_rows}} =
+ SQL.query(Repo, "SELECT id, #{field} FROM users WHERE #{field} != '{}'")
+
+ target_ap_ids =
+ Enum.flat_map(
+ field_rows,
+ fn [_, ap_ids] -> ap_ids end
+ )
+ |> Enum.uniq()
+
+ # Selecting ids of all targets at once in order to reduce the number of SELECT queries
+ {:ok, %{rows: target_ap_id_id}} =
+ SQL.query(Repo, "SELECT ap_id, id FROM users WHERE ap_id = ANY($1)", [target_ap_ids])
+
+ target_id_by_ap_id = Enum.into(target_ap_id_id, %{}, fn [k, v] -> {k, v} end)
+
+ Enum.each(
+ field_rows,
+ fn [source_id, target_ap_ids] ->
+ source_uuid = Ecto.UUID.cast!(source_id)
+
+ for target_ap_id <- target_ap_ids do
+ target_id = target_id_by_ap_id[target_ap_id]
+
+ with {:ok, target_uuid} <- target_id && Ecto.UUID.cast(target_id) do
+ execute("""
+ INSERT INTO user_relationships(
+ source_id, target_id, relationship_type, inserted_at
+ )
+ VALUES(
+ '#{source_uuid}'::uuid, '#{target_uuid}'::uuid, #{relationship_type_code}, now()
+ )
+ ON CONFLICT (source_id, relationship_type, target_id) DO NOTHING
+ """)
+ else
+ _ -> Logger.warn("Unresolved #{field} reference: (#{source_uuid}, #{target_id})")
+ end
+ end
+ end
+ )
+ end
+end