spc-pleroma/lib/pleroma/workers/scheduled_activity_worker.ex

47 lines
1.5 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
2019-12-03 18:30:10 +00:00
defmodule Pleroma.Workers.ScheduledActivityWorker do
@moduledoc """
2019-12-03 18:30:10 +00:00
The worker to post scheduled activity.
"""
2019-12-03 18:30:10 +00:00
use Pleroma.Workers.WorkerHelper, queue: "scheduled_activities"
alias Pleroma.Config
alias Pleroma.ScheduledActivity
alias Pleroma.User
alias Pleroma.Web.CommonAPI
require Logger
@impl Oban.Worker
2020-06-23 12:09:01 +00:00
def perform(%Job{args: %{"activity_id" => activity_id}}) do
if Config.get([ScheduledActivity, :enabled]) do
2019-12-03 18:30:10 +00:00
case Pleroma.Repo.get(ScheduledActivity, activity_id) do
%ScheduledActivity{} = scheduled_activity ->
post_activity(scheduled_activity)
_ ->
Logger.error("#{__MODULE__} Couldn't find scheduled activity: #{activity_id}")
end
end
end
2020-01-23 08:05:08 +00:00
defp post_activity(%ScheduledActivity{user_id: user_id, params: params} = scheduled_activity) do
2020-05-12 19:59:26 +00:00
params = Map.new(params, fn {key, value} -> {String.to_existing_atom(key), value} end)
2020-01-23 08:05:08 +00:00
with {:delete, {:ok, _}} <- {:delete, ScheduledActivity.delete(scheduled_activity)},
{:user, %User{} = user} <- {:user, User.get_cached_by_id(user_id)},
{:post, {:ok, _}} <- {:post, CommonAPI.post(user, params)} do
:ok
else
error ->
Logger.error(
"#{__MODULE__} Couldn't create a status from the scheduled activity: #{inspect(error)}"
)
end
end
end