2015-12-06 18:58:49 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Http\Controllers\Server;
|
|
|
|
|
|
|
|
use Auth;
|
|
|
|
use Pterodactyl\Models\Server;
|
|
|
|
use Pterodactyl\Models\Node;
|
|
|
|
use Pterodactyl\Models\Download;
|
2016-01-03 05:28:33 +00:00
|
|
|
use Pterodactyl\Models\Allocation;
|
2015-12-06 18:58:49 +00:00
|
|
|
use Debugbar;
|
|
|
|
use Uuid;
|
|
|
|
use Alert;
|
|
|
|
|
|
|
|
use Pterodactyl\Exceptions\DisplayException;
|
2016-01-01 23:08:15 +00:00
|
|
|
use Pterodactyl\Repositories;
|
2015-12-06 18:58:49 +00:00
|
|
|
use Pterodactyl\Http\Controllers\Controller;
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
|
|
|
class ServerController extends Controller
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Controller Constructor
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
|
|
|
|
// All routes in this controller are protected by the authentication middleware.
|
|
|
|
$this->middleware('auth');
|
|
|
|
|
|
|
|
// Routes in this file are also checked aganist the server middleware. If the user
|
|
|
|
// does not have permission to view the server it will not load.
|
|
|
|
$this->middleware('server');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders server index page for specified server.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Contracts\View\View
|
|
|
|
*/
|
|
|
|
public function getIndex(Request $request)
|
|
|
|
{
|
|
|
|
$server = Server::getByUUID($request->route()->server);
|
|
|
|
return view('server.index', [
|
|
|
|
'server' => $server,
|
2016-01-03 05:28:33 +00:00
|
|
|
'allocations' => Allocation::where('assigned_to', $server->id)->orderBy('ip', 'asc')->orderBy('port', 'asc')->get(),
|
2015-12-06 18:58:49 +00:00
|
|
|
'node' => Node::find($server->node)
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders file overview page.
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @return \Illuminate\Contracts\View\View
|
|
|
|
*/
|
|
|
|
public function getFiles(Request $request)
|
|
|
|
{
|
|
|
|
|
|
|
|
$server = Server::getByUUID($request->route()->server);
|
|
|
|
$this->authorize('list-files', $server);
|
|
|
|
|
|
|
|
return view('server.files.index', [
|
|
|
|
'server' => $server,
|
|
|
|
'node' => Node::find($server->node)
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders add file page.
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @return \Illuminate\Contracts\View\View
|
|
|
|
*/
|
|
|
|
public function getAddFile(Request $request)
|
|
|
|
{
|
|
|
|
|
|
|
|
$server = Server::getByUUID($request->route()->server);
|
|
|
|
$this->authorize('add-files', $server);
|
|
|
|
|
|
|
|
return view('server.files.add', [
|
|
|
|
'server' => $server,
|
|
|
|
'node' => Node::find($server->node),
|
|
|
|
'directory' => (in_array($request->get('dir'), [null, '/', ''])) ? '' : trim($request->get('dir'), '/') . '/'
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders edit file page for a given file.
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @param string $uuid
|
|
|
|
* @param string $file
|
|
|
|
* @return \Illuminate\Contracts\View\View
|
|
|
|
*/
|
|
|
|
public function getEditFile(Request $request, $uuid, $file)
|
|
|
|
{
|
|
|
|
|
|
|
|
$server = Server::getByUUID($uuid);
|
|
|
|
$this->authorize('edit-files', $server);
|
|
|
|
|
|
|
|
$fileInfo = (object) pathinfo($file);
|
2016-01-01 23:08:15 +00:00
|
|
|
$controller = new Repositories\Daemon\FileRepository($uuid);
|
2015-12-06 18:58:49 +00:00
|
|
|
|
|
|
|
try {
|
|
|
|
$fileContent = $controller->returnFileContents($file);
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
|
|
|
|
Debugbar::addException($e);
|
|
|
|
$exception = 'An error occured while attempting to load the requested file for editing, please try again.';
|
|
|
|
|
|
|
|
if ($e instanceof DisplayException) {
|
|
|
|
$exception = $e->getMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
Alert::danger($exception)->flash();
|
|
|
|
return redirect()->route('files.index', $uuid);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return view('server.files.edit', [
|
|
|
|
'server' => $server,
|
|
|
|
'node' => Node::find($server->node),
|
|
|
|
'file' => $file,
|
2016-01-01 23:08:15 +00:00
|
|
|
'contents' => $fileContent->content,
|
2015-12-06 18:58:49 +00:00
|
|
|
'directory' => (in_array($fileInfo->dirname, ['.', './', '/'])) ? '/' : trim($fileInfo->dirname, '/') . '/',
|
|
|
|
'extension' => $fileInfo->extension
|
|
|
|
]);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handles downloading a file for the user.
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @param string $uuid
|
|
|
|
* @param string $file
|
|
|
|
* @return \Illuminate\Contracts\View\View
|
|
|
|
*/
|
|
|
|
public function getDownloadFile(Request $request, $uuid, $file)
|
|
|
|
{
|
|
|
|
|
|
|
|
$server = Server::getByUUID($uuid);
|
|
|
|
$node = Node::find($server->node);
|
|
|
|
|
|
|
|
$this->authorize('download-files', $server);
|
|
|
|
|
|
|
|
$download = new Download;
|
|
|
|
|
|
|
|
$download->token = Uuid::generate(4);
|
2016-01-02 00:27:44 +00:00
|
|
|
$download->server = $server->uuid;
|
2015-12-06 18:58:49 +00:00
|
|
|
$download->path = str_replace('../', '', $file);
|
|
|
|
|
|
|
|
$download->save();
|
|
|
|
|
2016-01-01 23:08:15 +00:00
|
|
|
return redirect( $node->scheme . '://' . $node->fqdn . ':' . $node->daemonListen . '/server/download/' . $download->token);
|
2015-12-06 18:58:49 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|