MastodonAPI: Stream fixes.
authorRoger Braun <rbraun@Bobble.local>
Thu, 16 Nov 2017 12:48:58 +0000 (13:48 +0100)
committerRoger Braun <rbraun@Bobble.local>
Thu, 16 Nov 2017 12:48:58 +0000 (13:48 +0100)
lib/pleroma/web/activity_pub/activity_pub.ex
lib/pleroma/web/mastodon_api/mastodon_socket.ex
lib/pleroma/web/streamer.ex

index 9af0f553c47e4d9be266401bde835bff1264fd97..5cbf14868e2c39f71b386fc9fe35a8656f43753a 100644 (file)
@@ -24,6 +24,9 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do
          :ok <- maybe_federate(activity) do
       if activity.data["type"] == "Create" and Enum.member?(activity.data["to"], "https://www.w3.org/ns/activitystreams#Public") do
         Pleroma.Web.Streamer.stream("public", activity)
+        if local do
+          Pleroma.Web.Streamer.stream("public:local", activity)
+        end
       end
       {:ok, activity}
     end
index f9c8cec321e6e4def2ef35d04d19118346550f71..af76c87015cb687b5d5e8fc0684c60d9ca1e3c1b 100644 (file)
@@ -1,17 +1,24 @@
 defmodule Pleroma.Web.MastodonAPI.MastodonSocket do
   use Phoenix.Socket
 
+  alias Pleroma.Web.OAuth.Token
+  alias Pleroma.{User, Repo}
+
   transport :streaming, Phoenix.Transports.WebSocket.Raw,
     timeout: :infinity # We never receive data.
 
   def connect(params, socket) do
-    if params["stream"] == "public" do
+    with token when not is_nil(token) <- params["access_token"],
+         %Token{user_id: user_id} <- Repo.get_by(Token, token: token),
+         %User{} = user <- Repo.get(User, user_id),
+         stream when stream in ["public", "public:local"] <- params["stream"] do
       socket = socket
       |> assign(:topic, params["stream"])
+      |> assign(:user, user)
       Pleroma.Web.Streamer.add_socket(params["stream"], socket)
       {:ok, socket}
     else
-      :error
+      _e -> :error
     end
   end
 
index 3a7b9174322a72c8b68d720dd69830ac852e69ab..3b2938676721b9aba90e2b87df0d1e9762b91e62 100644 (file)
@@ -43,7 +43,7 @@ defmodule Pleroma.Web.Streamer do
     Enum.each(topics[topic] || [], fn (socket) ->
       json = %{
         event: "update",
-        payload: Pleroma.Web.MastodonAPI.StatusView.render("status.json", activity: item) |> Poison.encode!
+        payload: Pleroma.Web.MastodonAPI.StatusView.render("status.json", activity: item, for: socket.assigns[:user]) |> Poison.encode!
       } |> Poison.encode!
 
       send socket.transport_pid, {:text, json}