updateService = $updateService; $this->sessionGuard = $sessionGuard; } /** * @param Request $request * @return array */ public function index(Request $request): array { return $this->fractal->item($request->user()) ->transformWith($this->getTransformer(AccountTransformer::class)) ->toArray(); } /** * Update the authenticated user's email address. * * @param \Pterodactyl\Http\Requests\Api\Client\Account\UpdateEmailRequest $request * @return \Illuminate\Http\Response * * @throws \Pterodactyl\Exceptions\Model\DataValidationException * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException */ public function updateEmail(UpdateEmailRequest $request): Response { $this->updateService->handle($request->user(), $request->validated()); return response('', Response::HTTP_CREATED); } /** * Update the authenticated user's password. All existing sessions will be logged * out immediately. * * @param \Pterodactyl\Http\Requests\Api\Client\Account\UpdatePasswordRequest $request * @return \Illuminate\Http\JsonResponse * * @throws \Pterodactyl\Exceptions\Model\DataValidationException * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException */ public function updatePassword(UpdatePasswordRequest $request): \Illuminate\Http\JsonResponse { $this->updateService->handle($request->user(), $request->validated()); $this->sessionGuard->logoutOtherDevices($request->input('new_password')); return JsonResponse::create([], Response::HTTP_NO_CONTENT); } }