fileRepository = $fileRepository; $this->responseFactory = $responseFactory; } /** * Returns a listing of files in a given directory. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\ListFilesRequest $request * @param \Pterodactyl\Models\Server $server * @return array * * @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException */ public function listDirectory(ListFilesRequest $request, Server $server): array { try { $contents = $this->fileRepository ->setServer($server) ->getDirectory($request->get('directory') ?? '/'); } catch (TransferException $exception) { throw new DaemonConnectionException($exception, true); } return $this->fractal->collection($contents) ->transformWith($this->getTransformer(FileObjectTransformer::class)) ->toArray(); } /** * Return the contents of a specified file for the user. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\GetFileContentsRequest $request * @param \Pterodactyl\Models\Server $server * @return \Illuminate\Http\Response * @throws \Pterodactyl\Exceptions\Http\Server\FileSizeTooLargeException */ public function getFileContents(GetFileContentsRequest $request, Server $server): Response { return Response::create( $this->fileRepository->setServer($server)->getContent( $request->get('file'), config('pterodactyl.files.max_edit_size') ), Response::HTTP_OK, ['Content-Type' => 'text/plain'] ); } /** * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\GetFileContentsRequest $request * @param \Pterodactyl\Models\Server $server * @return \Symfony\Component\HttpFoundation\StreamedResponse * * @throws \Exception */ public function download(GetFileContentsRequest $request, Server $server) { set_time_limit(0); $request = $this->fileRepository->setServer($server)->streamContent( $request->get('file') ); $body = $request->getBody(); preg_match('/filename=(?.*)$/', $request->getHeaderLine('Content-Disposition'), $matches); return $this->responseFactory->streamDownload( function () use ($body) { while (! $body->eof()) { echo $body->read(128); } }, $matches['name'] ?? 'download', [ 'Content-Type' => $request->getHeaderLine('Content-Type'), 'Content-Length' => $request->getHeaderLine('Content-Length'), ] ); } /** * Writes the contents of the specified file to the server. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\WriteFileContentRequest $request * @param \Pterodactyl\Models\Server $server * @return \Illuminate\Http\Response */ public function writeFileContents(WriteFileContentRequest $request, Server $server): Response { $this->fileRepository->setServer($server)->putContent( $request->get('file'), $request->getContent() ); return Response::create('', Response::HTTP_NO_CONTENT); } /** * Creates a new folder on the server. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CreateFolderRequest $request * @param \Pterodactyl\Models\Server $server * @return \Illuminate\Http\Response */ public function createFolder(CreateFolderRequest $request, Server $server): Response { $this->fileRepository ->setServer($server) ->createDirectory($request->input('name'), $request->input('directory', '/')); return Response::create('', Response::HTTP_NO_CONTENT); } /** * Renames a file on the remote machine. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\RenameFileRequest $request * @param \Pterodactyl\Models\Server $server * @return \Illuminate\Http\Response */ public function renameFile(RenameFileRequest $request, Server $server): Response { $this->fileRepository ->setServer($server) ->renameFile($request->input('rename_from'), $request->input('rename_to')); return Response::create('', Response::HTTP_NO_CONTENT); } /** * Copies a file on the server. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CopyFileRequest $request * @param \Pterodactyl\Models\Server $server * @return \Illuminate\Http\Response */ public function copyFile(CopyFileRequest $request, Server $server): Response { $this->fileRepository ->setServer($server) ->copyFile($request->input('location')); return Response::create('', Response::HTTP_NO_CONTENT); } /** * Deletes a file or folder from the server. * * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\DeleteFileRequest $request * @param \Pterodactyl\Models\Server $server * @return \Illuminate\Http\Response */ public function delete(DeleteFileRequest $request, Server $server): Response { $this->fileRepository ->setServer($server) ->deleteFile($request->input('location')); return Response::create('', Response::HTTP_NO_CONTENT); } }