akkoma/lib/pleroma/web/federator/federator.ex

39 lines
1.2 KiB
Elixir
Raw Normal View History

defmodule Pleroma.Web.Federator do
alias Pleroma.User
2017-05-01 06:07:29 -06:00
alias Pleroma.Web.WebFinger
require Logger
2017-04-28 07:45:10 -06:00
@websub Application.get_env(:pleroma, :websub)
def handle(:publish, activity) do
Logger.debug("Running publish for #{activity.data["id"]}")
with actor when not is_nil(actor) <- User.get_cached_by_ap_id(activity.data["actor"]) do
2017-05-01 05:14:58 -06:00
Logger.debug("Sending #{activity.data["id"]} out via websub")
Pleroma.Web.Websub.publish(Pleroma.Web.OStatus.feed_path(actor), actor, activity)
2017-05-01 05:14:58 -06:00
2017-05-01 06:07:29 -06:00
{:ok, actor} = WebFinger.ensure_keys_present(actor)
2017-05-01 05:14:58 -06:00
Logger.debug("Sending #{activity.data["id"]} out via salmon")
Pleroma.Web.Salmon.publish(actor, activity)
end
end
def handle(:verify_websub, websub) do
Logger.debug("Running websub verification for #{websub.id} (#{websub.topic}, #{websub.callback})")
2017-04-28 07:45:10 -06:00
@websub.verify(websub)
end
def handle(type, payload) do
Logger.debug("Unknown task: #{type}")
{:error, "Don't know what do do with this"}
end
def enqueue(type, payload) do
# for now, just run immediately in a new process.
if Mix.env == :test do
handle(type, payload)
else
spawn(fn -> handle(type, payload) end)
end
end
end