- 在多个控制器中引入 ApiMessage,替换原有的 ApiResponse 错误处理逻辑,确保错误信息的一致性与可读性。 - 更新错误返回信息,使用更具语义的键值,提升 API 的可维护性与用户体验。 - 适配相关控制器的请求参数,确保在处理错误时能够正确返回相应的错误信息。
49 lines
1.8 KiB
PHP
49 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\V1\Admin\Player;
|
|
|
|
use App\Models\Player;
|
|
use App\Lottery\ErrorCode;
|
|
use App\Support\ApiMessage;
|
|
use App\Support\ApiResponse;
|
|
use Illuminate\Http\JsonResponse;
|
|
use App\Support\AdminSiteScope;
|
|
use App\Support\PlayerApiPresenter;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\Admin\AdminPlayerStoreRequest;
|
|
|
|
/** POST /api/v1/admin/players */
|
|
final class AdminPlayerStoreController extends Controller
|
|
{
|
|
public function __invoke(AdminPlayerStoreRequest $request): JsonResponse
|
|
{
|
|
$admin = $request->lotteryAdmin();
|
|
abort_if($admin === null, 401);
|
|
|
|
$siteCode = (string) $request->validated('site_code');
|
|
if (! AdminSiteScope::siteCodeAllowed($admin, $siteCode)) {
|
|
return ApiMessage::errorResponse($request, 'admin.player_create_site_forbidden', ErrorCode::AdminForbidden->value, null, 403);
|
|
}
|
|
|
|
$exists = Player::query()
|
|
->where('site_code', $request->validated('site_code'))
|
|
->where('site_player_id', $request->validated('site_player_id'))
|
|
->exists();
|
|
|
|
if ($exists) {
|
|
return ApiMessage::errorResponse($request, 'admin.player_already_registered', ErrorCode::ValidationFailed->value, null, 422);
|
|
}
|
|
|
|
$player = Player::query()->create([
|
|
'site_code' => $request->validated('site_code'),
|
|
'site_player_id' => $request->validated('site_player_id'),
|
|
'username' => $request->validated('username'),
|
|
'nickname' => $request->validated('nickname'),
|
|
'default_currency' => $request->validated('default_currency', 'NPR'),
|
|
'status' => $request->validated('status', 0),
|
|
]);
|
|
|
|
return ApiResponse::success(PlayerApiPresenter::listItem($player))->setStatusCode(201);
|
|
}
|
|
}
|