X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2FPasswordResetToken.ex;h=750ddd3c04645e3714face400e0cbbc42bb6ebe8;hb=833161b5d21f85e2276cd0cee3e148ecbe6e1f05;hp=79e60bf6969b5ff847fe2c7d4cc978dc168fafdd;hpb=6af164f27b5a285fb1b1c8790a86db061c8fc28a;p=akkoma diff --git a/lib/pleroma/PasswordResetToken.ex b/lib/pleroma/PasswordResetToken.ex index 79e60bf69..750ddd3c0 100644 --- a/lib/pleroma/PasswordResetToken.ex +++ b/lib/pleroma/PasswordResetToken.ex @@ -1,20 +1,26 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + defmodule Pleroma.PasswordResetToken do use Ecto.Schema - import Ecto.{Changeset, Query} + import Ecto.Changeset - alias Pleroma.{User, PasswordResetToken, Repo} + alias Pleroma.User + alias Pleroma.Repo + alias Pleroma.PasswordResetToken schema "password_reset_tokens" do - belongs_to :user, User - field :token, :string - field :used, :boolean, default: false + belongs_to(:user, User, type: Pleroma.FlakeId) + field(:token, :string) + field(:used, :boolean, default: false) timestamps() end def create_token(%User{} = user) do - token = :crypto.strong_rand_bytes(32) |> Base.url_encode64 + token = :crypto.strong_rand_bytes(32) |> Base.url_encode64() token = %PasswordResetToken{ user_id: user.id, @@ -26,7 +32,7 @@ defmodule Pleroma.PasswordResetToken do end def used_changeset(struct) do - changeset = struct + struct |> cast(%{}, []) |> put_change(:used, true) end @@ -34,7 +40,7 @@ defmodule Pleroma.PasswordResetToken do def reset_password(token, data) do with %{used: false} = token <- Repo.get_by(PasswordResetToken, %{token: token}), %User{} = user <- Repo.get(User, token.user_id), - {:ok, user} <- User.reset_password(user, data), + {:ok, _user} <- User.reset_password(user, data), {:ok, token} <- Repo.update(used_changeset(token)) do {:ok, token} else