$this->repository->getApplicationKeys($request->user()), ]); } /** * Render view allowing an admin to create a new application API key. * * @throws \ReflectionException */ public function create(): View { $resources = AdminAcl::getResourceList(); sort($resources); return view('admin.api.new', [ 'resources' => $resources, 'permissions' => [ 'r' => AdminAcl::READ, 'rw' => AdminAcl::READ | AdminAcl::WRITE, 'n' => AdminAcl::NONE, ], ]); } /** * Store the new key and redirect the user back to the application key listing. * * @throws \Pterodactyl\Exceptions\Model\DataValidationException */ public function store(StoreApplicationApiKeyRequest $request): RedirectResponse { $this->keyCreationService->setKeyType(ApiKey::TYPE_APPLICATION)->handle([ 'memo' => $request->input('memo'), 'user_id' => $request->user()->id, ], $request->getKeyPermissions()); $this->alert->success('A new application API key has been generated for your account.')->flash(); return redirect()->route('admin.api.index'); } /** * Delete an application API key from the database. */ public function delete(Request $request, string $identifier): Response { $this->repository->deleteApplicationKey($request->user(), $identifier); return response('', 204); } }