Add EnsureUserKeyPlug, smaller fixes
authorlain <lain@soykaf.club>
Wed, 5 Sep 2018 17:06:28 +0000 (19:06 +0200)
committerlain <lain@soykaf.club>
Wed, 5 Sep 2018 17:06:28 +0000 (19:06 +0200)
lib/pleroma/plugs/authentication_plug.ex
lib/pleroma/plugs/ensure_user_key_plug.ex [new file with mode: 0644]
test/plugs/basic_auth_decoder_plug_test.exs
test/plugs/ensure_user_key_plug_test.exs [new file with mode: 0644]

index 8706b32cd6b415a382234794b85b817fd3af8758..3ac301b9771decd0a5e165f42aa8a5e305d968f5 100644 (file)
@@ -37,4 +37,6 @@ defmodule Pleroma.Plugs.AuthenticationPlug do
     Pbkdf2.dummy_checkpw()
     conn
   end
+
+  def call(conn, _), do: conn
 end
diff --git a/lib/pleroma/plugs/ensure_user_key_plug.ex b/lib/pleroma/plugs/ensure_user_key_plug.ex
new file mode 100644 (file)
index 0000000..05a5677
--- /dev/null
@@ -0,0 +1,14 @@
+defmodule Pleroma.Plugs.EnsureUserKeyPlug do
+  import Plug.Conn
+
+  def init(opts) do
+    opts
+  end
+
+  def call(%{assigns: %{user: _}} = conn, _), do: conn
+
+  def call(conn, _) do
+    conn
+    |> assign(:user, nil)
+  end
+end
index 317f7d16726b546388361372a184a9d78bbb27b1..a4876fef7c1f9f282eb93f73a329f6b8a61896ed 100644 (file)
@@ -1,4 +1,4 @@
-defmodule Pleroma.Plugs.AuthenticationPlugTest do
+defmodule Pleroma.Plugs.BasicAuthDecoderPlugTest do
   use Pleroma.Web.ConnCase, async: true
 
   alias Pleroma.Plugs.BasicAuthDecoderPlug
diff --git a/test/plugs/ensure_user_key_plug_test.exs b/test/plugs/ensure_user_key_plug_test.exs
new file mode 100644 (file)
index 0000000..9beda83
--- /dev/null
@@ -0,0 +1,25 @@
+defmodule Pleroma.Plugs.EnsureUserKeyPlugTest do
+  use Pleroma.Web.ConnCase, async: true
+
+  alias Pleroma.Plugs.EnsureUserKeyPlug
+
+  test "if the conn has a user key set, it does nothing", %{conn: conn} do
+    conn =
+      conn
+      |> assign(:user, 1)
+
+    ret_conn =
+      conn
+      |> EnsureUserKeyPlug.call(%{})
+
+    assert conn == ret_conn
+  end
+
+  test "if the conn has no key set, it sets it to nil", %{conn: conn} do
+    conn =
+      conn
+      |> EnsureUserKeyPlug.call(%{})
+
+    assert Map.has_key?(conn.assigns, :user)
+  end
+end