Sha256: a1cd987bc6bb4fd7553e27ac6a2c260b0426385d5949e77bb696bef6fa3314e5
Contents?: true
Size: 1.25 KB
Versions: 3
Compression:
Stored size: 1.25 KB
Contents
class PasswordResetsController < ApplicationController skip_before_action :authenticate before_action :set_<%= singular_table_name %>, only: %i[ edit update ] def edit render json: { error: "Open this link in your device" }, status: :not_found end def create if @<%= singular_table_name %> = <%= class_name %>.find_by_email(params[:email]) PasswordMailer.with(<%= singular_table_name %>: @<%= singular_table_name %>).reset.deliver_later else render json: { error: "The email address doesn't exist in our database" }, status: :not_found end end def update if @<%= singular_table_name %>.update(<%= "#{singular_table_name}_params" %>) render json: @<%= singular_table_name %> else render json: @<%= singular_table_name %>.errors, status: :unprocessable_entity end end private def set_<%= singular_table_name %> @<%= singular_table_name %> = <%= class_name %>.find_signed!(params[:token], purpose: :password_reset) rescue ActiveSupport::MessageVerifier::InvalidSignature render json: { error: "Your token has expired, please request a new one" }, status: :bad_request end def <%= "#{singular_table_name}_params" %> params.permit(:password, :password_confirmation) end end
Version data entries
3 entries across 3 versions & 1 rubygems