1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Repo.Migrations.MovePinnedActivitiesIntoPinnedObjects do
15 |> select([u], {u.id, fragment("?.pinned_activities", u)})
17 |> Stream.each(fn {user_id, pinned_activities_ids} ->
18 pinned_activities = Pleroma.Activity.all_by_ids_with_object(pinned_activities_ids)
21 Map.new(pinned_activities, fn %{object: %{data: %{"id" => object_id}}} ->
22 {object_id, NaiveDateTime.utc_now()}
25 from(u in User, where: u.id == ^user_id)
26 |> Repo.update_all(set: [pinned_objects: pins])