重置密码
parent
a6b0bb31f6
commit
3d218bf7ee
|
|
@ -0,0 +1,45 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Endpoint\Api\Http\Controllers\Auth;
|
||||||
|
|
||||||
|
use App\Endpoint\Api\Http\Controllers\Controller;
|
||||||
|
use App\Endpoint\Api\Http\Requests\ResetPasswordRequest;
|
||||||
|
use App\Exceptions\BizException;
|
||||||
|
use App\Models\SmsCode;
|
||||||
|
use App\Models\User;
|
||||||
|
use App\Services\SmsCodeService;
|
||||||
|
|
||||||
|
class ResetPasswordController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 重置密码
|
||||||
|
*
|
||||||
|
* @param \App\Endpoint\Api\Http\Requests\LoginRequest $request
|
||||||
|
* @param \App\Services\SmsCodeService $smsCodeService
|
||||||
|
* @return \Illuminate\Http\JsonResponse
|
||||||
|
*/
|
||||||
|
public function __invoke(ResetPasswordRequest $request, SmsCodeService $smsCodeService)
|
||||||
|
{
|
||||||
|
$input = $request->validated();
|
||||||
|
|
||||||
|
$smsCodeService->validate(
|
||||||
|
$input['phone'],
|
||||||
|
SmsCode::TYPE_RESET_PASSWORD,
|
||||||
|
$input['verify_code']
|
||||||
|
);
|
||||||
|
|
||||||
|
$user = User::where('phone', $input['phone'])->first();
|
||||||
|
|
||||||
|
if ($user === null) {
|
||||||
|
throw new BizException(__('The phone number is not registered'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$user->update([
|
||||||
|
'password' => $input['password'],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$user->tokens()->delete();
|
||||||
|
|
||||||
|
return response()->noContent();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,33 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Endpoint\Api\Http\Requests;
|
||||||
|
|
||||||
|
use App\Rules\PhoneNumber;
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class ResetPasswordRequest extends FormRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'phone' => ['bail', 'required', new PhoneNumber()],
|
||||||
|
'password' => ['bail', 'required', 'string', 'min:6', 'max:32'],
|
||||||
|
'verify_code' => ['bail', 'required', 'string'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use App\Endpoint\Api\Http\Controllers\AdController;
|
use App\Endpoint\Api\Http\Controllers\AdController;
|
||||||
|
use App\Endpoint\Api\Http\Controllers\Auth\ResetPasswordController;
|
||||||
use App\Endpoint\Api\Http\Controllers\CaptchaController;
|
use App\Endpoint\Api\Http\Controllers\CaptchaController;
|
||||||
use App\Endpoint\Api\Http\Controllers\LoginController;
|
use App\Endpoint\Api\Http\Controllers\LoginController;
|
||||||
use App\Endpoint\Api\Http\Controllers\LogoutController;
|
use App\Endpoint\Api\Http\Controllers\LogoutController;
|
||||||
|
|
@ -27,6 +28,7 @@ Route::group([
|
||||||
Route::post('login', LoginController::class);
|
Route::post('login', LoginController::class);
|
||||||
Route::post('logout', LogoutController::class);
|
Route::post('logout', LogoutController::class);
|
||||||
Route::post('register', RegisterController::class);
|
Route::post('register', RegisterController::class);
|
||||||
|
Route::post('reset-password', ResetPasswordController::class);
|
||||||
|
|
||||||
Route::get('ads', [AdController::class, 'index']);
|
Route::get('ads', [AdController::class, 'index']);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,7 @@ class SmsCode extends Model
|
||||||
use Notifiable;
|
use Notifiable;
|
||||||
|
|
||||||
public const TYPE_REGISTER = 1;
|
public const TYPE_REGISTER = 1;
|
||||||
|
public const TYPE_RESET_PASSWORD = 2;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var array
|
* @var array
|
||||||
|
|
@ -49,6 +50,7 @@ class SmsCode extends Model
|
||||||
*/
|
*/
|
||||||
public static $allowedTypes = [
|
public static $allowedTypes = [
|
||||||
self::TYPE_REGISTER,
|
self::TYPE_REGISTER,
|
||||||
|
self::TYPE_RESET_PASSWORD,
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -7,5 +7,6 @@
|
||||||
"Invalid verification code type": "无效的验证码类型",
|
"Invalid verification code type": "无效的验证码类型",
|
||||||
"Registration failed, please try again": "注册失败,请重试",
|
"Registration failed, please try again": "注册失败,请重试",
|
||||||
"Sending too frequently, please try again later": "发送过于频繁,请稍后再试",
|
"Sending too frequently, please try again later": "发送过于频繁,请稍后再试",
|
||||||
"The phone number is already registered": "手机号码已被注册"
|
"The phone number is already registered": "手机号码已被注册",
|
||||||
|
"The phone number is not registered": "手机号码未注册"
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue