2019-03-17 00:10:04 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Http\Controllers\Api\Client\Servers;
|
|
|
|
|
2019-05-02 05:45:39 +01:00
|
|
|
use Illuminate\Http\Response;
|
2019-03-17 00:10:04 +00:00
|
|
|
use Pterodactyl\Models\Server;
|
2019-07-28 04:23:51 +01:00
|
|
|
use GuzzleHttp\Exception\TransferException;
|
2019-10-26 22:36:37 +01:00
|
|
|
use Illuminate\Contracts\Routing\ResponseFactory;
|
2019-09-06 05:41:20 +01:00
|
|
|
use Pterodactyl\Repositories\Wings\DaemonFileRepository;
|
2019-07-28 04:23:51 +01:00
|
|
|
use Pterodactyl\Transformers\Daemon\FileObjectTransformer;
|
2019-03-17 00:10:04 +00:00
|
|
|
use Pterodactyl\Http\Controllers\Api\Client\ClientApiController;
|
2019-07-28 04:23:51 +01:00
|
|
|
use Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException;
|
2019-05-05 01:26:24 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\CopyFileRequest;
|
2019-05-02 04:54:40 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\ListFilesRequest;
|
2019-05-05 01:26:24 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\DeleteFileRequest;
|
2019-05-05 00:04:59 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\RenameFileRequest;
|
2019-05-02 05:45:39 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\CreateFolderRequest;
|
2019-05-26 00:24:13 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\GetFileContentsRequest;
|
2019-05-27 23:30:49 +01:00
|
|
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Files\WriteFileContentRequest;
|
2019-03-17 00:10:04 +00:00
|
|
|
|
|
|
|
class FileController extends ClientApiController
|
|
|
|
{
|
|
|
|
/**
|
2019-10-26 22:36:37 +01:00
|
|
|
* @var \Pterodactyl\Repositories\Wings\DaemonFileRepository
|
2019-03-17 00:10:04 +00:00
|
|
|
*/
|
2019-10-26 22:36:37 +01:00
|
|
|
private $fileRepository;
|
2019-03-17 00:10:04 +00:00
|
|
|
|
2019-05-26 00:24:13 +01:00
|
|
|
/**
|
2019-10-26 22:36:37 +01:00
|
|
|
* @var \Illuminate\Contracts\Routing\ResponseFactory
|
2019-05-02 04:54:40 +01:00
|
|
|
*/
|
2019-10-26 22:36:37 +01:00
|
|
|
private $responseFactory;
|
2019-05-02 04:54:40 +01:00
|
|
|
|
2019-03-17 00:10:04 +00:00
|
|
|
/**
|
|
|
|
* FileController constructor.
|
|
|
|
*
|
2019-10-26 22:36:37 +01:00
|
|
|
* @param \Illuminate\Contracts\Routing\ResponseFactory $responseFactory
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Repositories\Wings\DaemonFileRepository $fileRepository
|
2019-03-17 00:10:04 +00:00
|
|
|
*/
|
2019-10-26 22:36:37 +01:00
|
|
|
public function __construct(
|
|
|
|
ResponseFactory $responseFactory,
|
|
|
|
DaemonFileRepository $fileRepository
|
|
|
|
) {
|
2019-03-17 00:10:04 +00:00
|
|
|
parent::__construct();
|
|
|
|
|
2019-05-02 04:54:40 +01:00
|
|
|
$this->fileRepository = $fileRepository;
|
2019-10-26 22:36:37 +01:00
|
|
|
$this->responseFactory = $responseFactory;
|
2019-05-02 04:54:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a listing of files in a given directory.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\ListFilesRequest $request
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-07-28 04:23:51 +01:00
|
|
|
* @return array
|
|
|
|
*
|
|
|
|
* @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException
|
2019-05-02 04:54:40 +01:00
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function listDirectory(ListFilesRequest $request, Server $server): array
|
2019-05-02 04:54:40 +01:00
|
|
|
{
|
2019-07-28 04:23:51 +01:00
|
|
|
try {
|
|
|
|
$contents = $this->fileRepository
|
2019-09-06 05:41:20 +01:00
|
|
|
->setServer($server)
|
2019-07-28 04:23:51 +01:00
|
|
|
->getDirectory($request->get('directory') ?? '/');
|
|
|
|
} catch (TransferException $exception) {
|
|
|
|
throw new DaemonConnectionException($exception, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->fractal->collection($contents)
|
|
|
|
->transformWith($this->getTransformer(FileObjectTransformer::class))
|
|
|
|
->toArray();
|
2019-03-17 00:10:04 +00:00
|
|
|
}
|
|
|
|
|
2019-05-26 00:24:13 +01:00
|
|
|
/**
|
|
|
|
* Return the contents of a specified file for the user.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\GetFileContentsRequest $request
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-05-26 00:24:13 +01:00
|
|
|
* @return \Illuminate\Http\Response
|
2019-09-06 05:41:20 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\Http\Server\FileSizeTooLargeException
|
2019-05-26 00:24:13 +01:00
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function getFileContents(GetFileContentsRequest $request, Server $server): Response
|
2019-05-26 00:24:13 +01:00
|
|
|
{
|
|
|
|
return Response::create(
|
2019-09-06 05:41:20 +01:00
|
|
|
$this->fileRepository->setServer($server)->getContent(
|
|
|
|
$request->get('file'), config('pterodactyl.files.max_edit_size')
|
2019-09-29 23:32:22 +01:00
|
|
|
),
|
|
|
|
Response::HTTP_OK,
|
|
|
|
['Content-Type' => 'text/plain']
|
2019-05-26 00:24:13 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-10-26 22:36:37 +01:00
|
|
|
/**
|
|
|
|
* @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=(?<name>.*)$/', $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'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-05-27 23:30:49 +01:00
|
|
|
/**
|
|
|
|
* Writes the contents of the specified file to the server.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\WriteFileContentRequest $request
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-05-27 23:30:49 +01:00
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function writeFileContents(WriteFileContentRequest $request, Server $server): Response
|
2019-05-27 23:30:49 +01:00
|
|
|
{
|
2019-09-06 05:41:20 +01:00
|
|
|
$this->fileRepository->setServer($server)->putContent(
|
2019-05-27 23:30:49 +01:00
|
|
|
$request->get('file'),
|
|
|
|
$request->getContent()
|
|
|
|
);
|
|
|
|
|
|
|
|
return Response::create('', Response::HTTP_NO_CONTENT);
|
|
|
|
}
|
|
|
|
|
2019-05-02 05:45:39 +01:00
|
|
|
/**
|
|
|
|
* Creates a new folder on the server.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CreateFolderRequest $request
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-05-02 05:45:39 +01:00
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function createFolder(CreateFolderRequest $request, Server $server): Response
|
2019-05-02 05:45:39 +01:00
|
|
|
{
|
|
|
|
$this->fileRepository
|
2019-09-06 05:41:20 +01:00
|
|
|
->setServer($server)
|
2019-05-02 05:45:39 +01:00
|
|
|
->createDirectory($request->input('name'), $request->input('directory', '/'));
|
|
|
|
|
2019-05-05 00:04:59 +01:00
|
|
|
return Response::create('', Response::HTTP_NO_CONTENT);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renames a file on the remote machine.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\RenameFileRequest $request
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-05-05 00:04:59 +01:00
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function renameFile(RenameFileRequest $request, Server $server): Response
|
2019-05-05 00:04:59 +01:00
|
|
|
{
|
|
|
|
$this->fileRepository
|
2019-09-06 05:41:20 +01:00
|
|
|
->setServer($server)
|
2019-05-05 00:04:59 +01:00
|
|
|
->renameFile($request->input('rename_from'), $request->input('rename_to'));
|
2019-05-05 01:26:24 +01:00
|
|
|
|
|
|
|
return Response::create('', Response::HTTP_NO_CONTENT);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Copies a file on the server.
|
|
|
|
*
|
|
|
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CopyFileRequest $request
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-05-05 01:26:24 +01:00
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function copyFile(CopyFileRequest $request, Server $server): Response
|
2019-05-05 01:26:24 +01:00
|
|
|
{
|
|
|
|
$this->fileRepository
|
2019-09-06 05:41:20 +01:00
|
|
|
->setServer($server)
|
2019-05-05 01:26:24 +01:00
|
|
|
->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
|
2019-09-06 05:41:20 +01:00
|
|
|
* @param \Pterodactyl\Models\Server $server
|
2019-05-05 01:26:24 +01:00
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2019-09-06 05:41:20 +01:00
|
|
|
public function delete(DeleteFileRequest $request, Server $server): Response
|
2019-05-05 01:26:24 +01:00
|
|
|
{
|
|
|
|
$this->fileRepository
|
2019-09-06 05:41:20 +01:00
|
|
|
->setServer($server)
|
2019-05-05 01:26:24 +01:00
|
|
|
->deleteFile($request->input('location'));
|
2019-05-05 00:04:59 +01:00
|
|
|
|
|
|
|
return Response::create('', Response::HTTP_NO_CONTENT);
|
2019-05-02 05:45:39 +01:00
|
|
|
}
|
2019-03-17 00:10:04 +00:00
|
|
|
}
|