From 3a4773c3c2bd0bbef244eb519b07208da9108e49 Mon Sep 17 00:00:00 2001 From: dcc Date: Sat, 2 Sep 2023 00:52:52 -0700 Subject: First --- ...5158_add_following_address_from_source_data.exs | 32 ++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 priv/repo/migrations/20190710125158_add_following_address_from_source_data.exs (limited to 'priv/repo/migrations/20190710125158_add_following_address_from_source_data.exs') diff --git a/priv/repo/migrations/20190710125158_add_following_address_from_source_data.exs b/priv/repo/migrations/20190710125158_add_following_address_from_source_data.exs new file mode 100644 index 0000000..44a3d6d --- /dev/null +++ b/priv/repo/migrations/20190710125158_add_following_address_from_source_data.exs @@ -0,0 +1,32 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2022 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Repo.Migrations.AddFollowingAddressFromSourceData do + alias Pleroma.User + import Ecto.Query + require Logger + use Ecto.Migration + + def change do + query = + User.Query.build(%{ + external: true, + legacy_active: true, + order_by: :id + }) + |> select([u], struct(u, [:id, :ap_id, :info])) + + Pleroma.Repo.stream(query) + |> Enum.each(fn + %{info: %{source_data: source_data}} = user -> + Ecto.Changeset.cast(user, %{following_address: source_data["following"]}, [ + :following_address + ]) + |> Pleroma.Repo.update() + + user -> + Logger.warn("User #{user.id} / #{user.nickname} does not seem to have source_data") + end) + end +end -- cgit v1.2.3