diff options
| -rw-r--r-- | lib/pleroma/plugs/user_enabled_plug.ex | 10 | ||||
| -rw-r--r-- | test/plugs/user_enabled_plug_test.exs | 17 | 
2 files changed, 24 insertions, 3 deletions
| diff --git a/lib/pleroma/plugs/user_enabled_plug.ex b/lib/pleroma/plugs/user_enabled_plug.ex index da892c28b..8d102ee5b 100644 --- a/lib/pleroma/plugs/user_enabled_plug.ex +++ b/lib/pleroma/plugs/user_enabled_plug.ex @@ -10,9 +10,13 @@ defmodule Pleroma.Plugs.UserEnabledPlug do      options    end -  def call(%{assigns: %{user: %User{info: %{deactivated: true}}}} = conn, _) do -    conn -    |> assign(:user, nil) +  def call(%{assigns: %{user: %User{} = user}} = conn, _) do +    if User.auth_active?(user) do +      conn +    else +      conn +      |> assign(:user, nil) +    end    end    def call(conn, _) do diff --git a/test/plugs/user_enabled_plug_test.exs b/test/plugs/user_enabled_plug_test.exs index c0fafcab1..3fb7c5316 100644 --- a/test/plugs/user_enabled_plug_test.exs +++ b/test/plugs/user_enabled_plug_test.exs @@ -16,6 +16,23 @@ defmodule Pleroma.Plugs.UserEnabledPlugTest do      assert ret_conn == conn    end +  test "with a user that's not confirmed and a config requiring confirmation, it removes that user", +       %{conn: conn} do +    old = Pleroma.Config.get([:instance, :account_activation_required]) +    Pleroma.Config.put([:instance, :account_activation_required], true) + +    user = insert(:user, confirmation_pending: true) + +    conn = +      conn +      |> assign(:user, user) +      |> UserEnabledPlug.call(%{}) + +    assert conn.assigns.user == nil + +    Pleroma.Config.put([:instance, :account_activation_required], old) +  end +    test "with a user that is deactivated, it removes that user", %{conn: conn} do      user = insert(:user, info: %{deactivated: true}) | 
