TwitterAPI: Add network hiding.
authorlain <lain@soykaf.club>
Wed, 5 Dec 2018 18:22:40 +0000 (19:22 +0100)
committerlain <lain@soykaf.club>
Wed, 5 Dec 2018 18:22:40 +0000 (19:22 +0100)
lib/pleroma/user/info.ex
lib/pleroma/web/twitter_api/twitter_api_controller.ex
test/web/twitter_api/twitter_api_controller_test.exs

index 83fab7e3d6946b84d90a8e379068ef80233d6ab5..cefe33577f9e646e656f18d01d215a8f641d46ef 100644 (file)
@@ -135,7 +135,8 @@ defmodule Pleroma.User.Info do
       :locked,
       :no_rich_text,
       :default_scope,
-      :banner
+      :banner,
+      :hide_network
     ])
   end
 
index a59badfdb38fbb9a1b9abb78b241fc2085b0968e..95931268313e1671c893a21ca953487461e3b02c 100644 (file)
@@ -431,7 +431,7 @@ defmodule Pleroma.Web.TwitterAPI.Controller do
 
   defp build_info_cng(user, params) do
     info_params =
-      ["no_rich_text", "locked"]
+      ["no_rich_text", "locked", "hide_network"]
       |> Enum.reduce(%{}, fn key, res ->
         if value = params[key] do
           Map.put(res, key, value == "true")
index 8655105f33c585d7d1fee0458a92763a45b7f381..6836019a59156844dfe2171d7fa03332cf4c0e88 100644 (file)
@@ -1024,6 +1024,30 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do
       assert json_response(conn, 200) == UserView.render("user.json", %{user: user, for: user})
     end
 
+    test "it sets and un-sets hide_network", %{conn: conn} do
+      user = insert(:user)
+
+      conn
+      |> assign(:user, user)
+      |> post("/api/account/update_profile.json", %{
+        "hide_network" => "true"
+      })
+
+      user = Repo.get!(User, user.id)
+      assert user.info.hide_network == true
+
+      conn =
+        conn
+        |> assign(:user, user)
+        |> post("/api/account/update_profile.json", %{
+          "hide_network" => "false"
+        })
+
+      user = Repo.get!(User, user.id)
+      assert user.info.hide_network == false
+      assert json_response(conn, 200) == UserView.render("user.json", %{user: user, for: user})
+    end
+
     test "it locks an account", %{conn: conn} do
       user = insert(:user)