77 lines
2.2 KiB
PHP
77 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Auth;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\System\Verification;
|
|
use App\Models\User;
|
|
use App\Rules\PhoneCodeVerification;
|
|
use Illuminate\Contracts\View\View;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
|
|
class ResetPasswordController extends Controller
|
|
{
|
|
/**
|
|
* Reset password page
|
|
*/
|
|
public function index(): View
|
|
{
|
|
return view('vendor.nova.pages.reset-password');
|
|
}
|
|
|
|
/**
|
|
* Store new password
|
|
*/
|
|
public function store(Request $request)
|
|
{
|
|
$request->validate([
|
|
'username' => ['required', 'string', 'max:250', 'exists:users,username'],
|
|
'verification' => ['nullable', 'integer', 'digits:5'],
|
|
'password' => ['bail', 'nullable', 'string', 'min:8', 'confirmed'],
|
|
]);
|
|
|
|
if ($request->filled('verification')) {
|
|
return $this->verify();
|
|
}
|
|
|
|
$user = User::where('username', $request->username)->first();
|
|
|
|
// sendSMSVerification($user->phone);
|
|
$phone_code = rand(10000, 99999);
|
|
$verification = Verification::where(['username' => $user->phone])->first();
|
|
$verification ? $verification->update(['code' => $phone_code]) : Verification::create(['username' => $user->phone, 'code' => $phone_code]);
|
|
|
|
return response()->json([
|
|
'step' => 1,
|
|
'message' => __('We send you a verification code to ') . '****' .substr($user->phone, 4)
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Verify phone number
|
|
*/
|
|
public function verify(): JsonResponse
|
|
{
|
|
$verification = Verification::where('username', $request->username)
|
|
->where('code', $request->verification)
|
|
->first();
|
|
|
|
if (! $verification) {
|
|
return response()->json([
|
|
'errors' => [
|
|
'verification' => [
|
|
__('Incorrect verification code'),
|
|
]
|
|
],
|
|
'message' => __('Incorrect verification code')
|
|
]);
|
|
}
|
|
|
|
return response()->json([
|
|
'step' => 2,
|
|
'message' => __("Now you can set your password, but please make sure that you dont forget it")
|
|
]);
|
|
}
|
|
}
|