Lae/app/Http/Controllers/Module/UserController.php

156 lines
4.4 KiB
PHP
Raw Normal View History

2022-08-29 16:04:50 +00:00
<?php
2023-01-19 16:11:50 +00:00
namespace App\Http\Controllers\Module;
2022-08-29 16:04:50 +00:00
2022-11-06 11:28:22 +00:00
use App\Http\Controllers\Controller;
use App\Models\Host;
2023-01-18 15:38:31 +00:00
use App\Models\PersonalAccessToken;
2022-11-06 11:28:22 +00:00
use App\Models\User;
2023-01-10 13:42:27 +00:00
use Illuminate\Http\JsonResponse;
2022-10-29 03:25:02 +00:00
use Illuminate\Http\Request;
2023-01-18 15:38:31 +00:00
use Illuminate\Support\Arr;
2022-08-29 16:04:50 +00:00
class UserController extends Controller
{
2023-01-10 13:42:27 +00:00
public function index(Request $request): JsonResponse
2022-10-29 03:55:09 +00:00
{
2023-02-13 07:32:26 +00:00
$request->validate([
2022-10-29 03:55:09 +00:00
'user_id' => 'sometimes|integer',
'email' => 'sometimes|email',
'name' => 'sometimes|string',
]);
2022-12-18 09:39:59 +00:00
$users = User::query();
2022-10-29 03:55:09 +00:00
2022-12-18 09:39:59 +00:00
// 搜索 name, email, balance
if ($request->has('name')) {
2023-02-20 15:07:37 +00:00
$users->where('name', 'like', '%'.$request->input('name').'%');
2022-12-18 09:39:59 +00:00
}
2022-10-29 03:55:09 +00:00
if ($request->has('email')) {
2023-02-20 15:07:37 +00:00
$users->where('email', 'like', '%'.$request->input('email').'%');
2022-10-29 03:55:09 +00:00
}
2022-12-18 09:39:59 +00:00
if ($request->has('balance')) {
2023-02-20 15:07:37 +00:00
$users->where('balance', 'like', '%'.$request->input('balance').'%');
2022-10-29 03:55:09 +00:00
}
2022-12-18 09:39:59 +00:00
$users = $users->simplePaginate(100);
return $this->success($users);
2022-10-29 03:55:09 +00:00
}
2022-08-29 16:04:50 +00:00
2023-02-11 08:10:18 +00:00
public function store(Request $request): JsonResponse
{
2023-02-13 07:32:26 +00:00
$request->validate([
2023-02-11 08:10:18 +00:00
'name' => 'required|string',
'email' => 'required|email|unique:users',
'password' => 'required|string|min:6',
]);
2023-02-12 19:06:27 +00:00
$user = (new User)->create([
2023-02-11 08:10:18 +00:00
'name' => $request->input('name'),
'email' => $request->input('email'),
'password' => bcrypt($request->input('password')),
]);
return $this->created($user);
}
2023-01-10 13:42:27 +00:00
public function show(User $user): JsonResponse
{
2022-08-29 16:04:50 +00:00
return $this->success($user);
}
2023-01-10 13:42:27 +00:00
public function hosts(User $user): JsonResponse
{
2022-09-19 13:39:12 +00:00
$hosts = (new Host())->getUserHosts($user->id);
return $this->success($hosts);
}
2022-10-29 03:25:02 +00:00
2023-01-17 16:13:19 +00:00
public function update(Request $request, User $user): JsonResponse
2022-10-29 03:25:02 +00:00
{
2023-02-13 07:32:26 +00:00
$request->validate([
2023-01-17 16:13:19 +00:00
'balance' => 'required|numeric|min:-10000|max:10000',
2022-10-29 03:25:02 +00:00
'description' => 'required|string',
]);
2023-01-17 16:13:19 +00:00
$module = $request->user('module');
2022-10-29 03:25:02 +00:00
2023-01-17 16:13:19 +00:00
$balance = $request->input('balance');
if ($balance < 0) {
// 使用 bc取 balance 绝对值
$balance = bcsub(0, $balance, 4);
2023-02-13 07:32:26 +00:00
if ($user->hasBalance($balance) === false) {
2023-01-17 16:13:19 +00:00
return $this->error('用户余额不足。');
}
2023-02-20 15:07:28 +00:00
$trans = $user->reduce($balance, $request->description, true, [
2023-02-20 15:07:37 +00:00
'module_id' => $module->id,
2023-02-20 15:07:28 +00:00
]);
2023-01-17 16:13:19 +00:00
$module->charge($balance, 'balance', $request->description, [
'user_id' => $user->id,
]);
} else {
2023-02-13 07:32:26 +00:00
if ($module->hasBalance($balance) === false) {
2023-01-17 16:13:19 +00:00
return $this->error('模块余额不足。');
}
$module->reduce($balance, $request->description, true, [
'user_id' => $user->id,
2023-01-30 16:14:07 +00:00
'payment' => 'module_balance',
2023-01-17 16:13:19 +00:00
]);
2023-02-20 14:43:46 +00:00
$trans = $user->charge($balance, 'module_balance', $request->description, [
2023-02-20 15:07:37 +00:00
'module_id' => $module->id,
2023-02-20 14:43:46 +00:00
]);
2022-10-29 03:25:02 +00:00
}
2022-10-29 03:33:01 +00:00
2023-02-20 14:43:46 +00:00
return $this->success($trans);
2022-10-29 03:25:02 +00:00
}
2023-01-17 16:13:19 +00:00
2023-01-18 15:38:31 +00:00
public function auth($token): JsonResponse
{
$token = PersonalAccessToken::findToken($token);
// 画饼: 验证 Token 能力,比如是否可以访问这个模块
return $token ? $this->success(Arr::only(
$token->tokenable
->makeVisible('real_name')
2023-01-30 16:14:07 +00:00
->toArray(),
2023-01-18 15:38:31 +00:00
[
2023-01-30 16:14:07 +00:00
'id', 'name', 'email', 'real_name',
2023-01-18 15:38:31 +00:00
]
)) : $this->notFound();
}
public function attempt(Request $request)
{
$request->validate([
'email' => 'required|email',
'password' => 'required|string',
'require_token' => 'nullable|boolean',
'abilities' => 'nullable|array',
]);
// 验证
$user = User::where('email', $request->input('email'))->first();
if ($user === null) {
return $this->error('用户不存在。');
}
if (password_verify($request->input('password'), $user->password) === false) {
return $this->error('密码错误。');
}
if ($request->input('require_token')) {
$user['token'] = $user->createToken('模块创建', $request->input('abilities', ['*']))->plainTextToken;
}
return $this->success($user);
}
2022-08-29 16:04:50 +00:00
}