42 lines
1.1 KiB
PHP
42 lines
1.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\Wallet;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Arr;
|
|
|
|
class WalletPasswordController extends Controller
|
|
{
|
|
/**
|
|
* 设置安全密码
|
|
*
|
|
*/
|
|
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();
|
|
}
|
|
}
|