675e804a256a38b9fc9e3d141c1325956c9237eb
[akkoma] / federator.ex
1 defmodule Pleroma.Web.Federator do
2 alias Pleroma.User
3 alias Pleroma.Web.WebFinger
4 require Logger
5
6 @websub Application.get_env(:pleroma, :websub)
7
8 def handle(:publish, activity) do
9 Logger.debug("Running publish for #{activity.data["id"]}")
10 with actor when not is_nil(actor) <- User.get_cached_by_ap_id(activity.data["actor"]) do
11 Logger.debug("Sending #{activity.data["id"]} out via websub")
12 Pleroma.Web.Websub.publish(Pleroma.Web.OStatus.feed_path(actor), actor, activity)
13
14 {:ok, actor} = WebFinger.ensure_keys_present(actor)
15 Logger.debug("Sending #{activity.data["id"]} out via salmon")
16 Pleroma.Web.Salmon.publish(actor, activity)
17 end
18 end
19
20 def handle(:verify_websub, websub) do
21 Logger.debug("Running websub verification for #{websub.id} (#{websub.topic}, #{websub.callback})")
22 @websub.verify(websub)
23 end
24
25 def handle(type, payload) do
26 Logger.debug("Unknown task: #{type}")
27 {:error, "Don't know what do do with this"}
28 end
29
30 def enqueue(type, payload) do
31 # for now, just run immediately in a new process.
32 if Mix.env == :test do
33 handle(type, payload)
34 else
35 spawn(fn -> handle(type, payload) end)
36 end
37 end
38 end