Authentication Plug: Update bcrypt password on login.

This commit is contained in:
lain 2020-05-17 10:31:01 +02:00
parent 64b3d81e50
commit baef35bcc8
2 changed files with 25 additions and 6 deletions

View file

@ -30,6 +30,17 @@ def checkpw(_password, _password_hash) do
false false
end end
def maybe_update_password(%User{password_hash: "$2" <> _} = user, password) do
user
|> User.password_update_changeset(%{
"password" => password,
"password_confirmation" => password
})
|> Pleroma.Repo.update()
end
def maybe_update_password(user, _), do: {:ok, user}
def call(%{assigns: %{user: %User{}}} = conn, _), do: conn def call(%{assigns: %{user: %User{}}} = conn, _), do: conn
def call( def call(
@ -42,6 +53,8 @@ def call(
_ _
) do ) do
if checkpw(password, password_hash) do if checkpw(password, password_hash) do
{:ok, auth_user} = maybe_update_password(auth_user, password)
conn conn
|> assign(:user, auth_user) |> assign(:user, auth_user)
|> OAuthScopesPlug.skip_plug() |> OAuthScopesPlug.skip_plug()

View file

@ -11,6 +11,7 @@ defmodule Pleroma.Plugs.AuthenticationPlugTest do
alias Pleroma.User alias Pleroma.User
import ExUnit.CaptureLog import ExUnit.CaptureLog
import Pleroma.Factory
setup %{conn: conn} do setup %{conn: conn} do
user = %User{ user = %User{
@ -50,16 +51,21 @@ test "with a correct password in the credentials, " <>
assert PlugHelper.plug_skipped?(conn, OAuthScopesPlug) assert PlugHelper.plug_skipped?(conn, OAuthScopesPlug)
end end
test "with a wrong password in the credentials, it does nothing", %{conn: conn} do test "with a bcrypt hash, it updates to a pkbdf2 hash", %{conn: conn} do
user = insert(:user, password_hash: Bcrypt.hash_pwd_salt("123"))
assert "$2" <> _ = user.password_hash
conn = conn =
conn conn
|> assign(:auth_credentials, %{password: "wrong"}) |> assign(:auth_user, user)
|> assign(:auth_credentials, %{password: "123"})
ret_conn =
conn
|> AuthenticationPlug.call(%{}) |> AuthenticationPlug.call(%{})
assert conn == ret_conn assert conn.assigns.user.id == conn.assigns.auth_user.id
assert PlugHelper.plug_skipped?(conn, OAuthScopesPlug)
user = User.get_by_id(user.id)
assert "$pbkdf2" <> _ = user.password_hash
end end
describe "checkpw/2" do describe "checkpw/2" do