alert = $alert; $this->keyCreationService = $keyCreationService; $this->repository = $repository; } /** * Render view showing all of a user's application API keys. * * @param \Illuminate\Http\Request $request * @return \Illuminate\View\View */ public function index(Request $request): View { return view('admin.api.index', [ 'keys' => $this->repository->getApplicationKeys($request->user()), ]); } /** * Render view allowing an admin to create a new application API key. * * @return \Illuminate\View\View * @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. * * @param \Pterodactyl\Http\Requests\Admin\Api\StoreApplicationApiKeyRequest $request * @return \Illuminate\Http\RedirectResponse * * @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. * * @param \Illuminate\Http\Request $request * @param string $identifier * @return \Illuminate\Http\Response */ public function delete(Request $request, string $identifier): Response { $this->repository->deleteApplicationKey($request->user(), $identifier); return new JsonResponse([], JsonResponse::HTTP_NO_CONTENT); } }