don't expire pinned posts
This commit is contained in:
parent
9bf1065a06
commit
de4c935071
3 changed files with 45 additions and 3 deletions
|
@ -301,14 +301,14 @@ defmodule Pleroma.Activity do
|
|||
|> Repo.all()
|
||||
end
|
||||
|
||||
def follow_requests_for_actor(%Pleroma.User{ap_id: ap_id}) do
|
||||
def follow_requests_for_actor(%User{ap_id: ap_id}) do
|
||||
ap_id
|
||||
|> Queries.by_object_id()
|
||||
|> Queries.by_type("Follow")
|
||||
|> where([a], fragment("? ->> 'state' = 'pending'", a.data))
|
||||
end
|
||||
|
||||
def following_requests_for_actor(%Pleroma.User{ap_id: ap_id}) do
|
||||
def following_requests_for_actor(%User{ap_id: ap_id}) do
|
||||
Queries.by_type("Follow")
|
||||
|> where([a], fragment("?->>'state' = 'pending'", a.data))
|
||||
|> where([a], a.actor == ^ap_id)
|
||||
|
@ -343,4 +343,9 @@ defmodule Pleroma.Activity do
|
|||
actor = user_actor(activity)
|
||||
activity.id in actor.pinned_activities
|
||||
end
|
||||
|
||||
@spec pinned_by_actor?(Activity.t(), User.t()) :: boolean()
|
||||
def pinned_by_actor?(%Activity{id: id}, %User{} = user) do
|
||||
id in user.pinned_activities
|
||||
end
|
||||
end
|
||||
|
|
|
@ -21,8 +21,18 @@ defmodule Pleroma.Workers.PurgeExpiredActivity do
|
|||
@impl true
|
||||
def perform(%Oban.Job{args: %{"activity_id" => id}}) do
|
||||
with %Pleroma.Activity{} = activity <- find_activity(id),
|
||||
%Pleroma.User{} = user <- find_user(activity.object.data["actor"]) do
|
||||
%Pleroma.User{} = user <- find_user(activity.object.data["actor"]),
|
||||
false <- pinned_by_actor?(activity, user) do
|
||||
Pleroma.Web.CommonAPI.delete(activity.id, user)
|
||||
else
|
||||
:pinned_by_actor ->
|
||||
# if activity is pinned, schedule deletion on next day
|
||||
enqueue(%{activity_id: id, expires_at: DateTime.add(DateTime.utc_now(), 24 * 3600)})
|
||||
|
||||
:ok
|
||||
|
||||
error ->
|
||||
error
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -54,6 +64,12 @@ defmodule Pleroma.Workers.PurgeExpiredActivity do
|
|||
end
|
||||
end
|
||||
|
||||
defp pinned_by_actor?(activity, user) do
|
||||
with true <- Pleroma.Activity.pinned_by_actor?(activity, user) do
|
||||
:pinned_by_actor
|
||||
end
|
||||
end
|
||||
|
||||
def get_expiration(id) do
|
||||
from(j in Oban.Job,
|
||||
where: j.state == "scheduled",
|
||||
|
|
|
@ -44,4 +44,25 @@ defmodule Pleroma.Workers.PurgeExpiredActivityTest do
|
|||
|
||||
assert %Oban.Job{} = Pleroma.Workers.PurgeExpiredActivity.get_expiration(activity.id)
|
||||
end
|
||||
|
||||
test "don't delete pinned posts, schedule deletion on next day" do
|
||||
activity = insert(:note_activity)
|
||||
|
||||
assert {:ok, _} =
|
||||
PurgeExpiredActivity.enqueue(%{
|
||||
activity_id: activity.id,
|
||||
expires_at: DateTime.utc_now(),
|
||||
validate: false
|
||||
})
|
||||
|
||||
user = Pleroma.User.get_by_ap_id(activity.actor)
|
||||
{:ok, activity} = Pleroma.Web.CommonAPI.pin(activity.id, user)
|
||||
|
||||
assert %{success: 1, failure: 0} ==
|
||||
Oban.drain_queue(queue: :activity_expiration, with_scheduled: true)
|
||||
|
||||
job = Pleroma.Workers.PurgeExpiredActivity.get_expiration(activity.id)
|
||||
|
||||
assert DateTime.diff(job.scheduled_at, DateTime.add(DateTime.utc_now(), 24 * 3600)) in [0, 1]
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue