summaryrefslogtreecommitdiff
path: root/priv
diff options
context:
space:
mode:
authorHélène <pleroma-dev@helene.moe>2022-09-05 03:51:35 +0200
committerHélène <pleroma-dev@helene.moe>2022-09-05 03:51:35 +0200
commitcfb1bc967f857569d8d0088a40e1d16e5cbbeca2 (patch)
treea6a7aaae425c8eb8c6e086dcd4b7a954de9cb3c6 /priv
parentcd237d22f165edb84202154e4c6f6725f63df635 (diff)
Migrations: generate unset user keys
User keys are now generated on user creation instead of "when needed", to prevent race conditions in federation and a few other issues. This migration will generate keys missing for local users.
Diffstat (limited to 'priv')
-rw-r--r--priv/repo/migrations/20220905011454_generate_unset_user_keys.exs28
1 files changed, 28 insertions, 0 deletions
diff --git a/priv/repo/migrations/20220905011454_generate_unset_user_keys.exs b/priv/repo/migrations/20220905011454_generate_unset_user_keys.exs
new file mode 100644
index 000000000..43bc7100b
--- /dev/null
+++ b/priv/repo/migrations/20220905011454_generate_unset_user_keys.exs
@@ -0,0 +1,28 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Repo.Migrations.GenerateUnsetUserKeys do
+ use Ecto.Migration
+ import Ecto.Query
+ alias Pleroma.Keys
+ alias Pleroma.Repo
+ alias Pleroma.User
+
+ def change do
+ query =
+ from(u in User,
+ where: u.local == true,
+ where: is_nil(u.keys),
+ select: u
+ )
+
+ Repo.stream(query)
+ |> Enum.each(fn user ->
+ with {:ok, pem} <- Keys.generate_rsa_pem() do
+ Ecto.Changeset.cast(user, %{keys: pem}, [:keys])
+ |> Repo.update()
+ end
+ end)
+ end
+end