diff options
author | feld <feld@feld.me> | 2020-08-13 17:38:19 +0000 |
---|---|---|
committer | feld <feld@feld.me> | 2020-08-13 17:38:19 +0000 |
commit | 14a06e63f661cc964a799a62c87103a00ba0c5e0 (patch) | |
tree | b35b19c925a40b273f63ac00e18f8fa8645c7ad8 /lib/mix/tasks | |
parent | fbc220d09c25057edfc1eae539fdb68d0cc7a933 (diff) | |
parent | 29a7bcd5bbb3a39fe1b31c9f5ffc0077f23fc101 (diff) | |
download | pleroma-14a06e63f661cc964a799a62c87103a00ba0c5e0.tar.gz |
Merge branch 'fix/activity-expirations-again' into 'develop'
Fix activity expirations again
See merge request pleroma/pleroma!2866
Diffstat (limited to 'lib/mix/tasks')
-rw-r--r-- | lib/mix/tasks/pleroma/database.ex | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/lib/mix/tasks/pleroma/database.ex b/lib/mix/tasks/pleroma/database.ex index d57e59b11..7d8f00b08 100644 --- a/lib/mix/tasks/pleroma/database.ex +++ b/lib/mix/tasks/pleroma/database.ex @@ -134,13 +134,23 @@ defmodule Mix.Tasks.Pleroma.Database do Pleroma.Activity |> join(:left, [a], u in assoc(a, :expiration)) + |> join(:inner, [a, _u], o in Object, + on: + fragment( + "(?->>'id') = COALESCE((?)->'object'->> 'id', (?)->>'object')", + o.data, + a.data, + a.data + ) + ) |> where(local: true) |> where([a, u], is_nil(u)) + |> where([a], fragment("(? ->> 'type'::text) = 'Create'", a.data)) + |> where([_a, _u, o], fragment("?->>'type' = 'Note'", o.data)) |> Pleroma.RepoStreamer.chunk_stream(100) |> Stream.each(fn activities -> Enum.each(activities, fn activity -> expires_at = Timex.shift(activity.inserted_at, days: days) - Pleroma.ActivityExpiration.create(activity, expires_at, false) end) end) |