80 lines
2.1 KiB
PHP
80 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace App\Endpoint\Api\Http\Controllers\Account;
|
|
|
|
use App\Endpoint\Api\Http\Controllers\Controller;
|
|
use App\Exceptions\BizException;
|
|
use App\Models\SmsCode;
|
|
use App\Models\Wallet;
|
|
use App\Services\SmsCodeService;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Arr;
|
|
|
|
class WalletPasswordController extends Controller
|
|
{
|
|
/**
|
|
* 设置钱包密码
|
|
*
|
|
* @param Request $request
|
|
* @param SmsCodeService $smsCodeService
|
|
* @return void
|
|
*/
|
|
public function update(Request $request, SmsCodeService $smsCodeService)
|
|
{
|
|
$input = $request->validate([
|
|
'verify_code' => ['bail', 'required'],
|
|
'password' => ['bail', 'required', 'regex:/^\d{6}$/i'],
|
|
], [
|
|
'password.regex' => '安全密码 是6位数字',
|
|
], [
|
|
'verify_code' => '验证码',
|
|
'password' => '安全密码',
|
|
]);
|
|
|
|
$user = $request->user();
|
|
|
|
$smsCodeService->validate(
|
|
$user->phone,
|
|
SmsCode::TYPE_SET_WALLET_PASSWORD,
|
|
$input['verify_code']
|
|
);
|
|
|
|
Wallet::updateOrCreate([
|
|
'user_id'=> $user->id,
|
|
], [
|
|
'password' => $input['password'],
|
|
]);
|
|
|
|
return response()->noContent();
|
|
}
|
|
|
|
/**
|
|
* 设置安全密码
|
|
*
|
|
*/
|
|
public function reset(Request $request)
|
|
{
|
|
$input = $request->validate([
|
|
'old_password' => ['bail', 'filled', 'string', 'size:6'],
|
|
'new_password' => ['bail', 'required', 'string', 'size:6'],
|
|
], [], [
|
|
'old_password' => '旧密码',
|
|
'new_password' => '新密码',
|
|
]);
|
|
|
|
$wallet = $request->user()->wallet;
|
|
|
|
//如果已经设置安全密码则比对
|
|
if ($wallet && $wallet->password && (!$wallet->verifyPassword(Arr::get($input, 'old_password', '')))) {
|
|
throw new BizException('安全密码不正确');
|
|
}
|
|
|
|
Wallet::updateOrCreate(
|
|
['user_id'=> $request->user()->id],
|
|
['password' => $input['new_password']],
|
|
);
|
|
|
|
return response()->noContent();
|
|
}
|
|
}
|