我正在尝试使用以下逻辑重构控制器。 :
def recover_password
if params[:login].present?
if User.exists?(id: params[:login])
render plain: "Recover by id" status: :ok
elsif Utils.is_email?(params[:login])
render plain: "Recover by email" status: :ok
else
render plain: "Email not found" status: :unauthorized
end
else
render plain: "Login not found" status: :unauthorized
end
end
我尝试向User Moel发送业务逻辑,但我不知道它是否是一个不错的选择:
def recover_password
result = User.recover_password(params)
render plain: result status: :status
end
重构此代码的最佳替代方法是什么?发送到模型并返回消息?但是如何返回消息和状态代码?
P.S:我无法在控制器中创建另一个方法/操作来分离恢复密码的方法。
答案 0 :(得分:3)
不确定将此逻辑添加到User模型是否是个好主意。您可以将其移动到控制器私有方法。
def recover_password
result = check_params(params[:login])
render plain: result[:message], status: result[:status]
end
private
def check_params(login)
return { message: "Login not found", status: :unauthorized } if login.blank?
return { message: "Recover by id", status: :ok } if User.exists?(id: login)
return { message: "Recover by email", status: :ok} if Utils.is_email?(login)
{ message: "Email not found", status: :unauthorized }
end