diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/activity_pub/activity_pub.ex | 20 | 
1 files changed, 13 insertions, 7 deletions
| diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 4aade6e40..421fd5cd7 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -10,6 +10,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do           :ok <- insert_full_object(map) do        {:ok, activity} = Repo.insert(%Activity{data: map, local: local, actor: map["actor"]})        Notification.create_notifications(activity) +      stream_out(activity)        {:ok, activity}      else        %Activity{} = activity -> {:ok, activity} @@ -17,17 +18,22 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do      end    end -  def create(to, actor, context, object, additional \\ %{}, published \\ nil, local \\ true) do -    with create_data <- make_create_data(%{to: to, actor: actor, published: published, context: context, object: object}, additional), -         {:ok, activity} <- insert(create_data, local), -         :ok <- maybe_federate(activity) do -      if activity.data["type"] == "Create" and Enum.member?(activity.data["to"], "https://www.w3.org/ns/activitystreams#Public") do +  def stream_out(activity) do +    if activity.data["type"] in ["Create", "Announce"] do +      Pleroma.Web.Streamer.stream("user", activity) +      if Enum.member?(activity.data["to"], "https://www.w3.org/ns/activitystreams#Public") do          Pleroma.Web.Streamer.stream("public", activity) -        Pleroma.Web.Streamer.stream("user", activity) -        if local do +        if activity.local do            Pleroma.Web.Streamer.stream("public:local", activity)          end        end +    end +  end + +  def create(to, actor, context, object, additional \\ %{}, published \\ nil, local \\ true) do +    with create_data <- make_create_data(%{to: to, actor: actor, published: published, context: context, object: object}, additional), +         {:ok, activity} <- insert(create_data, local), +         :ok <- maybe_federate(activity) do        {:ok, activity}      end    end | 
