Add externalprofile to TwAPI.
authorRoger Braun <roger@rogerbraun.net>
Wed, 10 May 2017 16:44:57 +0000 (18:44 +0200)
committerRoger Braun <roger@rogerbraun.net>
Wed, 10 May 2017 16:44:57 +0000 (18:44 +0200)
lib/pleroma/web/router.ex
lib/pleroma/web/twitter_api/twitter_api.ex
lib/pleroma/web/twitter_api/twitter_api_controller.ex
test/web/twitter_api/twitter_api_controller_test.exs
test/web/twitter_api/twitter_api_test.exs

index 50a3934d6a8f8380daa6c233366add4e415bad05..15f66b24f95ae2edf9abb7e786b384ba7856af59 100644 (file)
@@ -38,6 +38,8 @@ defmodule Pleroma.Web.Router do
     get "/statusnet/conversation/:id", TwitterAPI.Controller, :fetch_conversation
 
     post "/account/register", TwitterAPI.Controller, :register
+
+    get "/externalprofile/show", TwitterAPI.Controller, :external_profile
   end
 
   scope "/api", Pleroma.Web do
index d73ef3c7701d7355d62541e88283241f66b6d21a..d048d07c32aef0dadaf3ac992ca8afa410c45041 100644 (file)
@@ -350,4 +350,12 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
       {:error, "No such conversation"}
     end
   end
+
+  def get_external_profile(for_user, uri) do
+    with %User{} = user <- User.get_cached_by_ap_id(uri) do
+      {:ok, UserRepresenter.to_map(user, %{for: for_user})}
+    else _e ->
+      {:error, "Couldn't find user"}
+    end
+  end
 end
index 3fb60da6c3e9e17838f62089389d78c527761f84..4a1622cc80b540601520f1b32350941e492f6d36 100644 (file)
@@ -207,6 +207,14 @@ defmodule Pleroma.Web.TwitterAPI.Controller do
     |> json_reply(200, response)
   end
 
+  def external_profile(%{assigns: %{user: current_user}} = conn, %{"profileurl" => uri}) do
+    with {:ok, user_map} <- TwitterAPI.get_external_profile(current_user, uri),
+         response <- Poison.encode!(user_map) do
+      conn
+      |> json_reply(200, response)
+    end
+  end
+
   defp bad_request_reply(conn, error_message) do
     json = error_json(conn, error_message)
     json_reply(conn, 400, json)
index f8afbaee52b3d4a6995c8aeebb06bb0c6c6e76e9..0e9d29018cabd9c1aa34fc498e1938d69f5eecdd 100644 (file)
@@ -389,6 +389,17 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do
     end
   end
 
+  describe "GET /api/externalprofile/show" do
+    test "it returns the user", %{conn: conn} do
+      user = insert(:user)
+
+      conn = conn
+      |> get("/api/externalprofile/show", %{profileurl: user.ap_id})
+
+      assert json_response(conn, 200) == UserRepresenter.to_map(user)
+    end
+  end
+
   defp valid_user(_context) do
     user = insert(:user)
     [user: user]
index fd309e5ed2356c0f7ea915c1e016d557e1e60c1f..ebc9e362f47de6b13257e177ba5a5eb8bc434ad1 100644 (file)
@@ -358,4 +358,13 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do
       assert conversation_id == object.id
     end
   end
+
+  describe "fetching a user by uri" do
+    test "fetches a user by uri" do
+      user = insert(:user)
+
+      {:ok, represented} = TwitterAPI.get_external_profile(user, user.ap_id)
+      assert represented = UserRepresenter.to_map(user, %{for: user})
+    end
+  end
 end