2019-11-27 10:35:02 +00:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-02 05:08:45 +00:00
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2019-11-27 10:35:02 +00:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.Workers.Cron.PurgeExpiredActivitiesWorker do
|
|
|
|
@moduledoc """
|
|
|
|
The worker to purge expired activities.
|
|
|
|
"""
|
|
|
|
|
|
|
|
use Oban.Worker, queue: "activity_expiration"
|
|
|
|
|
|
|
|
alias Pleroma.Activity
|
|
|
|
alias Pleroma.ActivityExpiration
|
|
|
|
alias Pleroma.Config
|
|
|
|
alias Pleroma.User
|
|
|
|
alias Pleroma.Web.CommonAPI
|
|
|
|
|
|
|
|
require Logger
|
|
|
|
|
|
|
|
@interval :timer.minutes(1)
|
|
|
|
|
|
|
|
@impl Oban.Worker
|
2020-06-23 12:09:01 +00:00
|
|
|
def perform(_job) do
|
2020-08-13 18:01:54 +00:00
|
|
|
if Config.get([ActivityExpiration, :enabled]) do
|
|
|
|
Enum.each(ActivityExpiration.due_expirations(@interval), &delete_activity/1)
|
|
|
|
end
|
2020-08-13 18:01:21 +00:00
|
|
|
after
|
|
|
|
:ok
|
2019-11-27 10:35:02 +00:00
|
|
|
end
|
|
|
|
|
2020-01-23 08:05:08 +00:00
|
|
|
def delete_activity(%ActivityExpiration{activity_id: activity_id}) do
|
|
|
|
with {:activity, %Activity{} = activity} <-
|
|
|
|
{:activity, Activity.get_by_id_with_object(activity_id)},
|
|
|
|
{:user, %User{} = user} <- {:user, User.get_by_ap_id(activity.object.data["actor"])} do
|
2019-11-27 10:35:02 +00:00
|
|
|
CommonAPI.delete(activity.id, user)
|
2020-01-23 08:05:08 +00:00
|
|
|
else
|
|
|
|
{:activity, _} ->
|
|
|
|
Logger.error(
|
|
|
|
"#{__MODULE__} Couldn't delete expired activity: not found activity ##{activity_id}"
|
|
|
|
)
|
|
|
|
|
|
|
|
{:user, _} ->
|
|
|
|
Logger.error(
|
2020-08-13 18:01:21 +00:00
|
|
|
"#{__MODULE__} Couldn't delete expired activity: not found actor of ##{activity_id}"
|
2020-01-23 08:05:08 +00:00
|
|
|
)
|
2019-11-27 10:35:02 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|