aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorHaelwenn <contact+git.pleroma.social@hacktivis.me>2020-11-19 16:22:14 +0000
committerHaelwenn <contact+git.pleroma.social@hacktivis.me>2020-11-19 16:22:14 +0000
commitc8d11c306452ea36f5690ba1824434dc71bd9f95 (patch)
treef2d91a7bb673366a38ceeaac00fb5c81434ef7e9 /lib
parent6fc38aac8814fa63d6c43d004cb5280131106cb2 (diff)
parent21eaaf491c3cc3b76ac2ee49536491fdb2df79e7 (diff)
downloadpleroma-c8d11c306452ea36f5690ba1824434dc71bd9f95.tar.gz
Merge branch '2317-old-reset-tokens' into 'develop'
Resolve "Don't allow old password reset tokens" Closes #2317 See merge request pleroma/pleroma!3160
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/password_reset_token.ex11
-rw-r--r--lib/pleroma/web/twitter_api/controllers/password_controller.ex1
2 files changed, 12 insertions, 0 deletions
diff --git a/lib/pleroma/password_reset_token.ex b/lib/pleroma/password_reset_token.ex
index 787bd4781..fea5b1c22 100644
--- a/lib/pleroma/password_reset_token.ex
+++ b/lib/pleroma/password_reset_token.ex
@@ -40,6 +40,7 @@ defmodule Pleroma.PasswordResetToken do
@spec reset_password(binary(), map()) :: {:ok, User.t()} | {:error, binary()}
def reset_password(token, data) do
with %{used: false} = token <- Repo.get_by(PasswordResetToken, %{token: token}),
+ false <- expired?(token),
%User{} = user <- User.get_cached_by_id(token.user_id),
{:ok, _user} <- User.reset_password(user, data),
{:ok, token} <- Repo.update(used_changeset(token)) do
@@ -48,4 +49,14 @@ defmodule Pleroma.PasswordResetToken do
_e -> {:error, token}
end
end
+
+ def expired?(%__MODULE__{inserted_at: inserted_at}) do
+ validity = Pleroma.Config.get([:instance, :password_reset_token_validity], 0)
+
+ now = NaiveDateTime.utc_now()
+
+ difference = NaiveDateTime.diff(now, inserted_at)
+
+ difference > validity
+ end
end
diff --git a/lib/pleroma/web/twitter_api/controllers/password_controller.ex b/lib/pleroma/web/twitter_api/controllers/password_controller.ex
index 800ab8954..b1a9d810e 100644
--- a/lib/pleroma/web/twitter_api/controllers/password_controller.ex
+++ b/lib/pleroma/web/twitter_api/controllers/password_controller.ex
@@ -17,6 +17,7 @@ defmodule Pleroma.Web.TwitterAPI.PasswordController do
def reset(conn, %{"token" => token}) do
with %{used: false} = token <- Repo.get_by(PasswordResetToken, %{token: token}),
+ false <- PasswordResetToken.expired?(token),
%User{} = user <- User.get_cached_by_id(token.user_id) do
render(conn, "reset.html", %{
token: token,