diff options
| author | Alexander Strizhakov <alex.strizhakov@gmail.com> | 2020-08-22 20:46:01 +0300 | 
|---|---|---|
| committer | rinpatch <rinpatch@sdf.org> | 2020-09-10 21:50:40 +0300 | 
| commit | 9bf1065a06837b4c753549d89afe23a636a20972 (patch) | |
| tree | 1637cfc658487fd95b89282b87212b9b7f354a83 /lib/mix | |
| parent | 0254696e30132f48e585154450aff87afb259e1d (diff) | |
| download | pleroma-9bf1065a06837b4c753549d89afe23a636a20972.tar.gz pleroma-9bf1065a06837b4c753549d89afe23a636a20972.zip | |
schedule activity expiration in Oban
Diffstat (limited to 'lib/mix')
| -rw-r--r-- | lib/mix/tasks/pleroma/database.ex | 18 | 
1 files changed, 12 insertions, 6 deletions
| diff --git a/lib/mix/tasks/pleroma/database.ex b/lib/mix/tasks/pleroma/database.ex index 7d8f00b08..aab4b5e9a 100644 --- a/lib/mix/tasks/pleroma/database.ex +++ b/lib/mix/tasks/pleroma/database.ex @@ -133,8 +133,7 @@ defmodule Mix.Tasks.Pleroma.Database do      days = Pleroma.Config.get([:mrf_activity_expiration, :days], 365)      Pleroma.Activity -    |> join(:left, [a], u in assoc(a, :expiration)) -    |> join(:inner, [a, _u], o in Object, +    |> join(:inner, [a], o in Object,        on:          fragment(            "(?->>'id') = COALESCE((?)->'object'->> 'id', (?)->>'object')", @@ -144,14 +143,21 @@ defmodule Mix.Tasks.Pleroma.Database do          )      )      |> 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)) +    |> where([_a, 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) +        expires_at = +          activity.inserted_at +          |> DateTime.from_naive!("Etc/UTC") +          |> Timex.shift(days: days) + +        Pleroma.Workers.PurgeExpiredActivity.enqueue(%{ +          activity_id: activity.id, +          expires_at: expires_at, +          validate: false +        })        end)      end)      |> Stream.run() | 
