From 93d9efb7d0b4302e6b9a95c0cdbe565556c9ef7f Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Mon, 28 Nov 2016 17:32:40 -0500 Subject: [PATCH 01/24] Update ISSUE_TEMPLATE.md --- .github/ISSUE_TEMPLATE.md | 63 +++------------------------------------ 1 file changed, 4 insertions(+), 59 deletions(-) diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md index 1674b0b9e..346d32290 100644 --- a/.github/ISSUE_TEMPLATE.md +++ b/.github/ISSUE_TEMPLATE.md @@ -1,61 +1,6 @@ - - -## Product -Please check the corresponding boxes below for which products this is about. +Please describe your issue in full below. Include what products are affected, as well as what version(s) you are running. Please also include information about your system, such as `uname -a` and `php -v` and `docker info` if applicable. -- [ ] Panel -- [ ] Daemon -- [ ] Dockerfile(s) [Please list if so: __ ] +If you're just making a suggestion, be descriptive, and link to any issues that might be releated as well. -## Type -- [ ] Bug or Issue -- [ ] Feature Request -- [ ] Enhancement -- [ ] Other - - - - -## What Happens - - -## How to Reproduce - - -1. Step 1 -2. Step 2 -3. etc. - -## Error Logs - - - - -``` -error logs -``` - -## System Information -#### Output of `uname -a`: - -``` -paste here -``` - -#### Output of `php -v` (if Panel): - -``` -paste here -``` - -#### Output of `node -v` (if Daemon): - -``` -paste here -``` - -#### Output of `docker info` and `docker -v` (if Daemon or Dockerfiles): - -``` -paste here -``` +You can delete from this line up. +--------------------- From 03c6f986d2464885366fb48a2407406635324e62 Mon Sep 17 00:00:00 2001 From: Jakob Date: Wed, 30 Nov 2016 12:26:23 +0100 Subject: [PATCH 02/24] fix api /servers/{id}/build remove unrelated error thrown every time --- app/Http/Controllers/API/ServerController.php | 2 -- 1 file changed, 2 deletions(-) diff --git a/app/Http/Controllers/API/ServerController.php b/app/Http/Controllers/API/ServerController.php index 2b9f0986c..3e6063ee0 100755 --- a/app/Http/Controllers/API/ServerController.php +++ b/app/Http/Controllers/API/ServerController.php @@ -221,8 +221,6 @@ class ServerController extends BaseController public function build(Request $request, $id) { try { - throw new BadRequestHttpException('There was an error while attempting to add this node to the system.'); - $server = new ServerRepository; $server->changeBuild($id, $request->all()); return Models\Server::findOrFail($id); From a03add7e4f355e33439f082c28b611792a2e10da Mon Sep 17 00:00:00 2001 From: Emmet Young Date: Thu, 1 Dec 2016 03:01:22 +1100 Subject: [PATCH 03/24] Allow API to set a custom ID for server creation. (#187) * Allow API to set a custom ID for server creation. Useful when dealing with billing systems such as WHMCS * Correct API code changes based on feedback. --- app/Repositories/ServerRepository.php | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/app/Repositories/ServerRepository.php b/app/Repositories/ServerRepository.php index 47b1a4a97..19b4abd05 100644 --- a/app/Repositories/ServerRepository.php +++ b/app/Repositories/ServerRepository.php @@ -88,7 +88,8 @@ class ServerRepository 'option' => 'bail|required|numeric|min:1|exists:service_options,id', 'startup' => 'string', 'custom_image_name' => 'required_if:use_custom_image,on', - 'auto_deploy' => 'sometimes|boolean' + 'auto_deploy' => 'sometimes|boolean', + 'custom_id' => 'sometimes|required|numeric|unique:servers,id', ]); $validator->sometimes('node', 'bail|required|numeric|min:1|exists:nodes,id', function ($input) { @@ -232,6 +233,11 @@ class ServerRepository $server = new Models\Server; $genUuid = $uuid->generate('servers', 'uuid'); $genShortUuid = $uuid->generateShort('servers', 'uuidShort', $genUuid); + + if (isset($data['custom_id'])) { + $server->id = $data['custom_id']; + } + $server->fill([ 'uuid' => $genUuid, 'uuidShort' => $genShortUuid, @@ -994,4 +1000,4 @@ class ServerRepository } -} +} \ No newline at end of file From 72ad6d5c879b28b3a9092ec7818f83339cdfd7d0 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Thu, 1 Dec 2016 18:32:05 -0500 Subject: [PATCH 04/24] Show file upload size limit when uploading files Also handle errors better. --- CHANGELOG.md | 5 +++ ...1_173018_add_configurable_upload_limit.php | 32 +++++++++++++++++ resources/views/admin/nodes/view.blade.php | 15 +++++++- resources/views/server/files/add.blade.php | 36 ++++++++++++++----- resources/views/server/files/index.blade.php | 9 +++-- 5 files changed, 83 insertions(+), 14 deletions(-) create mode 100644 database/migrations/2016_12_01_173018_add_configurable_upload_limit.php diff --git a/CHANGELOG.md b/CHANGELOG.md index 41e834a2f..622528589 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,11 @@ This file is a running track of new features and fixes to each version of the pa This project follows [Semantic Versioning](http://semver.org) guidelines. +## v0.5.4 (Bodacious Boreopterus) +### Changed +* File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. +* File upload limit can now be controlled from the panel. + ## v0.5.3 (Bodacious Boreopterus) ### Fixed * Fixed an error that occurred when viewing a node listing when no nodes were created yet due to a mis-declared variable. Also fixes a bug that would have all nodes trying to connect to the daemon using the same secret token on the node listing, causing only the last node to display properly. diff --git a/database/migrations/2016_12_01_173018_add_configurable_upload_limit.php b/database/migrations/2016_12_01_173018_add_configurable_upload_limit.php new file mode 100644 index 000000000..91ef1fbbd --- /dev/null +++ b/database/migrations/2016_12_01_173018_add_configurable_upload_limit.php @@ -0,0 +1,32 @@ +unsignedInteger('upload_size')->after('disk_overallocate')->default(100); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::table('nodes', function (Blueprint $table) { + $table->dropColumn('upload_size'); + }); + } +} diff --git a/resources/views/admin/nodes/view.blade.php b/resources/views/admin/nodes/view.blade.php index 79203f153..df81a56ed 100644 --- a/resources/views/admin/nodes/view.blade.php +++ b/resources/views/admin/nodes/view.blade.php @@ -216,6 +216,19 @@
+
+
+
+ +
+ + MB +
+

Enter the maximum size of files that can be uploaded through the web-based file manager.

+
+
+
+
@@ -310,7 +323,7 @@ "installed": "{{ route('remote.install') }}" }, "uploads": { - "maximumSize": 100000000 + "size_limit": {{ $node->upload_size }} }, "keys": [ "{{ $node->daemonSecret }}" diff --git a/resources/views/server/files/add.blade.php b/resources/views/server/files/add.blade.php index 7019c0cdc..62cff9719 100644 --- a/resources/views/server/files/add.blade.php +++ b/resources/views/server/files/add.blade.php @@ -105,8 +105,11 @@
Edit the path location above before you upload files. They will automatically be placed in the directory you specify above. You can change this each time you upload a new file without having to press anything else. The directory must exist before performing an upload.
-
-

Drag and Drop File Here

+
+
+

Drag and Drop File(s) Here

+

The maximum size for web-based file uploads is currently {{ $node->upload_size }} MB.

+
@@ -154,16 +157,33 @@ $(window).load(function () { } }); + var dropCounter = 0; + $('#upload_box').bind({ + dragenter: function (event) { + event.preventDefault(); + dropCounter++; + $(this).addClass('hasFileHover'); + }, + dragleave: function (event) { + dropCounter--; + if (dropCounter === 0) { + $(this).removeClass('hasFileHover'); + } + }, + drop: function (event) { + dropCounter = 0; + $(this).removeClass('hasFileHover'); + } + }); + socket.on('error', function (err) { console.error('There was an error while attemping to connect to the websocket: ' + err + '\n\nPlease try loading this page again.'); }); - var siofu = new SocketIOFileUpload(uploadSocket); - siofu.chunkDelay = 25; - document.getElementById("uploader_box").addEventListener("click", siofu.prompt, false); - siofu.listenOnDrop(document.getElementById("uploader_box")); + document.getElementById("upload_box").addEventListener("click", siofu.prompt, false); + siofu.listenOnDrop(document.getElementById("upload_box")); siofu.addEventListener('start', function (event) { event.file.meta.path = $("#u_file_name").val(); @@ -197,13 +217,13 @@ $(window).load(function () { // Do something when a file is uploaded: siofu.addEventListener('complete', function(event){ if (!event.success) { - $("#upload_error").html('An error was encountered while attempting to upload this file. Does the target directory exist?').show(); + $("#upload_error").html('An error was encountered while attempting to upload this file: ' + event.message + '.').show(); $("#file-upload-" + event.file.meta.identifier).hide(); } }); siofu.addEventListener('error', function(event){ - $("#upload_error").html('An error was encountered while attempting to upload this file. Does the target directory exist?').show(); + $("#upload_error").html('An error was encountered while attempting to upload this file: ' + event.message + '.').show(); $("#file-upload-" + event.file.meta.identifier).hide(); }); diff --git a/resources/views/server/files/index.blade.php b/resources/views/server/files/index.blade.php index c284faf60..c664414ba 100644 --- a/resources/views/server/files/index.blade.php +++ b/resources/views/server/files/index.blade.php @@ -52,7 +52,7 @@

File Path Information

- When configuring any file paths in your server plugins or settings you should use /home/container as your base path. + When configuring any file paths in your server plugins or settings you should use /home/container as your base path. The maximum size for web-based file uploads is currently {{ $node->upload_size }} MB.
@@ -101,8 +101,6 @@ $(window).load(function () { var siofu = new SocketIOFileUpload(uploadSocket); - siofu.chunkDelay = 25; - siofu.listenOnDrop(document.getElementById("upload_box")); window.addEventListener('dragover', function (event) { @@ -173,12 +171,13 @@ $(window).load(function () { }); siofu.addEventListener('error', function(event){ + console.error(event); $('.prog-bar-' + event.file.meta.identifier).css('width', '100%').removeClass('progress-bar-info').addClass('progress-bar-danger'); $.notify({ - message: 'An error was encountered while attempting to upload this file.' + message: 'An error was encountered while attempting to upload this file: ' + event.message + '.', }, { type: 'danger', - delay: 5000 + delay: 8000 }); }); @endcan From 1eb1f96e719a6e4f8f8db1789e791b1f13c950d5 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Thu, 1 Dec 2016 18:33:32 -0500 Subject: [PATCH 05/24] Add support for updating the daemon's configuration file automatically. --- CHANGELOG.md | 3 ++ app/Repositories/NodeRepository.php | 40 ++++++++++++++++++++-- resources/views/admin/nodes/view.blade.php | 2 +- 3 files changed, 42 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 622528589..6efd4f0e4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,9 @@ This file is a running track of new features and fixes to each version of the pa This project follows [Semantic Versioning](http://semver.org) guidelines. ## v0.5.4 (Bodacious Boreopterus) +### Added +* Changing node configuration values now automatically makes a call to the daemon and updates the configuration there. Changing daemon tokens now does not require any intervention, and takes effect immediately. SSL & Port configurations will still require a daemon reboot. + ### Changed * File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. * File upload limit can now be controlled from the panel. diff --git a/app/Repositories/NodeRepository.php b/app/Repositories/NodeRepository.php index 2d579f274..ace645de4 100644 --- a/app/Repositories/NodeRepository.php +++ b/app/Repositories/NodeRepository.php @@ -106,6 +106,7 @@ class NodeRepository { 'memory_overallocate' => 'numeric|min:-1', 'disk' => 'numeric|min:1', 'disk_overallocate' => 'numeric|min:-1', + 'upload_size' => 'numeric|min:0', 'daemonBase' => 'regex:/^([\/][\d\w.\-\/]+)$/', 'daemonSFTP' => 'numeric|between:1,65535', 'daemonListen' => 'numeric|between:1,65535', @@ -151,8 +152,43 @@ class NodeRepository { unset($data['reset_secret']); } - // Store the Data - return $node->update($data); + $oldDaemonKey = $node->daemonSecret; + $node->update($data); + try { + $client = Models\Node::guzzleRequest($node->id); + $client->request('PATCH', '/config', [ + 'headers' => [ + 'X-Access-Token' => $oldDaemonKey, + ], + 'json' => [ + 'web' => [ + 'listen' => $node->daemonListen, + 'ssl' => [ + 'enabled' => ($node->scheme === 'https'), + 'certificate' => '/etc/letsencrypt/live/' . $node->fqdn .'/fullchain.pem', + 'key' => '/etc/letsencrypt/live/' . $node->fqdn . '/privkey.pem', + ], + ], + 'sftp' => [ + 'path' => $node->daemonBase, + 'port' => $node->daemonSFTP, + ], + 'remote' => [ + 'base' => config('app.url'), + 'download' => route('remote.download'), + 'installed' => route('remote.install'), + ], + 'uploads' => [ + 'size_limit' => $node->upload_size, + ], + 'keys' => [ + $node->daemonSecret, + ] + ], + ]); + } catch (\Exception $ex) { + throw new DisplayException('Failed to update the node configuration, however your changes have been saved to the database. You will need to manually update the configuration file for the node to apply these changes.'); + } } diff --git a/resources/views/admin/nodes/view.blade.php b/resources/views/admin/nodes/view.blade.php index df81a56ed..734e8e4a2 100644 --- a/resources/views/admin/nodes/view.blade.php +++ b/resources/views/admin/nodes/view.blade.php @@ -255,7 +255,7 @@
- +
Reset Daemon Master Key
From 90460bef435005095107839a4e037281097c07e2 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Thu, 1 Dec 2016 19:11:48 -0500 Subject: [PATCH 06/24] New button in file manager that triggers the right click menu MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Enable’s support on mobile devices and those who cannot right click (blessed be them) closes #182 --- CHANGELOG.md | 1 + resources/views/server/files/list.blade.php | 9 +- .../js/filemanager/contextmenu.blade.php | 173 +++++++++--------- 3 files changed, 98 insertions(+), 85 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6efd4f0e4..32a436a48 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,7 @@ This project follows [Semantic Versioning](http://semver.org) guidelines. ## v0.5.4 (Bodacious Boreopterus) ### Added * Changing node configuration values now automatically makes a call to the daemon and updates the configuration there. Changing daemon tokens now does not require any intervention, and takes effect immediately. SSL & Port configurations will still require a daemon reboot. +* New button in file manager that triggers the right click menu to enable support on mobile devices and those who cannot right click (blessed be them). ### Changed * File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. diff --git a/resources/views/server/files/list.blade.php b/resources/views/server/files/list.blade.php index 74f539efb..ff6a28551 100644 --- a/resources/views/server/files/list.blade.php +++ b/resources/views/server/files/list.blade.php @@ -21,13 +21,14 @@ - File Name + File Name Size Last Modified + - + /home/container{{ $directory['header'] }} @@ -44,6 +45,7 @@ + @endif @if (isset($directory['show']) && $directory['show'] === true) @@ -54,6 +56,7 @@ + @endif @foreach ($folders as $folder) @@ -73,6 +76,7 @@ {{ $carbon->diffForHumans() }} @endif + @endforeach @foreach ($files as $file) @@ -149,6 +153,7 @@ {{ $carbon->diffForHumans() }} @endif + @endforeach diff --git a/resources/views/server/js/filemanager/contextmenu.blade.php b/resources/views/server/js/filemanager/contextmenu.blade.php index a4111415c..e396b50aa 100644 --- a/resources/views/server/js/filemanager/contextmenu.blade.php +++ b/resources/views/server/js/filemanager/contextmenu.blade.php @@ -56,102 +56,109 @@ class ContextMenuClass { } rightClick() { - $('#file_listing > tbody td').on('contextmenu', event => { - - const parent = $(event.target).closest('tr'); - const menu = $(this.makeMenu(parent)); - - if (parent.data('type') === 'disabled') return; + $('[data-action="toggleMenu"]').on('mousedown', () => { event.preventDefault(); + this.showMenu(event); + }); + $('#file_listing > tbody td').on('contextmenu', event => { + this.showMenu(event); + }); + } - $(menu).appendTo('body'); - $(menu).data('invokedOn', $(event.target)).show().css({ - position: 'absolute', - left: event.pageX, - top: event.pageY, - }); + showMenu(event) { + const parent = $(event.target).closest('tr'); + const menu = $(this.makeMenu(parent)); - this.activeLine = parent; - this.activeLine.addClass('active'); + if (parent.data('type') === 'disabled') return; + event.preventDefault(); - @can('download-files', $server) - if (parent.data('type') === 'file') { - $(menu).find('li[data-action="download"]').removeClass('hidden'); - } - @endcan + $(menu).appendTo('body'); + $(menu).data('invokedOn', $(event.target)).show().css({ + position: 'absolute', + left: event.pageX - 150, + top: event.pageY, + }); - @can('compress-files', $server) - if (parent.data('type') === 'folder') { - $(menu).find('li[data-action="compress"]').removeClass('hidden'); - } - @endcan + this.activeLine = parent; + this.activeLine.addClass('active'); - @can('decompress-files', $server) - if (_.without(['application/zip', 'application/gzip', 'application/x-gzip'], parent.data('mime')).length < 3) { - $(menu).find('li[data-action="decompress"]').removeClass('hidden'); - } - @endcan + @can('download-files', $server) + if (parent.data('type') === 'file') { + $(menu).find('li[data-action="download"]').removeClass('hidden'); + } + @endcan - // Handle Events - const Actions = new ActionsClass(parent, menu); - @can('move-files', $server) - $(menu).find('li[data-action="move"]').unbind().on('click', e => { - e.preventDefault(); - Actions.move(); - }); - @endcan + @can('compress-files', $server) + if (parent.data('type') === 'folder') { + $(menu).find('li[data-action="compress"]').removeClass('hidden'); + } + @endcan - @can('copy-files', $server) - $(menu).find('li[data-action="copy"]').unbind().on('click', e => { - e.preventDefault(); - Actions.copy(); - }); - @endcan + @can('decompress-files', $server) + if (_.without(['application/zip', 'application/gzip', 'application/x-gzip'], parent.data('mime')).length < 3) { + $(menu).find('li[data-action="decompress"]').removeClass('hidden'); + } + @endcan - @can('move-files', $server) - $(menu).find('li[data-action="rename"]').unbind().on('click', e => { - e.preventDefault(); - Actions.rename(); - }); - @endcan - - @can('compress-files', $server) - $(menu).find('li[data-action="compress"]').unbind().on('click', e => { - e.preventDefault(); - Actions.compress(); - }); - @endcan - - @can('decompress-files', $server) - $(menu).find('li[data-action="decompress"]').unbind().on('click', e => { - e.preventDefault(); - Actions.decompress(); - }); - @endcan - - @can('create-files', $server) - $(menu).find('li[data-action="folder"]').unbind().on('click', e => { - e.preventDefault(); - Actions.folder(); - }); - @endcan - - @can('download-files', $server) - $(menu).find('li[data-action="download"]').unbind().on('click', e => { - e.preventDefault(); - Actions.download(); - }); - @endcan - - $(menu).find('li[data-action="delete"]').unbind().on('click', e => { + // Handle Events + const Actions = new ActionsClass(parent, menu); + @can('move-files', $server) + $(menu).find('li[data-action="move"]').unbind().on('click', e => { e.preventDefault(); - Actions.delete(); + Actions.move(); }); + @endcan - $(window).on('click', () => { - $(menu).remove(); - if(!_.isNull(this.activeLine)) this.activeLine.removeClass('active'); + @can('copy-files', $server) + $(menu).find('li[data-action="copy"]').unbind().on('click', e => { + e.preventDefault(); + Actions.copy(); }); + @endcan + + @can('move-files', $server) + $(menu).find('li[data-action="rename"]').unbind().on('click', e => { + e.preventDefault(); + Actions.rename(); + }); + @endcan + + @can('compress-files', $server) + $(menu).find('li[data-action="compress"]').unbind().on('click', e => { + e.preventDefault(); + Actions.compress(); + }); + @endcan + + @can('decompress-files', $server) + $(menu).find('li[data-action="decompress"]').unbind().on('click', e => { + e.preventDefault(); + Actions.decompress(); + }); + @endcan + + @can('create-files', $server) + $(menu).find('li[data-action="folder"]').unbind().on('click', e => { + e.preventDefault(); + Actions.folder(); + }); + @endcan + + @can('download-files', $server) + $(menu).find('li[data-action="download"]').unbind().on('click', e => { + e.preventDefault(); + Actions.download(); + }); + @endcan + + $(menu).find('li[data-action="delete"]').unbind().on('click', e => { + e.preventDefault(); + Actions.delete(); + }); + + $(window).on('click', () => { + $(menu).remove(); + if(!_.isNull(this.activeLine)) this.activeLine.removeClass('active'); }); } From ed5b7559ec36db3d2346f7d96e2bf6c90bf07cfc Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Thu, 1 Dec 2016 19:16:40 -0500 Subject: [PATCH 07/24] Fixes potential for generated password to not meet own validation requirements --- CHANGELOG.md | 3 +++ app/Http/Controllers/Base/IndexController.php | 11 ++++++++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 32a436a48..43bce8284 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,6 +12,9 @@ This project follows [Semantic Versioning](http://semver.org) guidelines. * File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. * File upload limit can now be controlled from the panel. +### Fixed +* Fixes potential for generated password to not meet own validation requirements. + ## v0.5.3 (Bodacious Boreopterus) ### Fixed * Fixed an error that occurred when viewing a node listing when no nodes were created yet due to a mis-declared variable. Also fixes a bug that would have all nodes trying to connect to the daemon using the same secret token on the node listing, causing only the last node to display properly. diff --git a/app/Http/Controllers/Base/IndexController.php b/app/Http/Controllers/Base/IndexController.php index bed1cb988..5631dc137 100644 --- a/app/Http/Controllers/Base/IndexController.php +++ b/app/Http/Controllers/Base/IndexController.php @@ -62,7 +62,16 @@ class IndexController extends Controller public function getPassword(Request $request, $length = 16) { $length = ($length < 8) ? 8 : $length; - return str_random($length); + + $returnable = false; + while (!$returnable) { + $generated = str_random($length); + if (preg_match('/[A-Z]+[a-z]+[0-9]+/', $generated)) { + $returnable = true; + } + } + + return $generated; } } From 3cd0a8337fb76d6d3744cf807938284205e408be Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 18:41:52 -0500 Subject: [PATCH 08/24] Add ability to filter user list --- CHANGELOG.md | 1 + app/Http/Controllers/Admin/UserController.php | 27 ++++++++++++++++++- resources/views/admin/users/index.blade.php | 8 ++++++ 3 files changed, 35 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 43bce8284..126b69c4d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,7 @@ This project follows [Semantic Versioning](http://semver.org) guidelines. ### Added * Changing node configuration values now automatically makes a call to the daemon and updates the configuration there. Changing daemon tokens now does not require any intervention, and takes effect immediately. SSL & Port configurations will still require a daemon reboot. * New button in file manager that triggers the right click menu to enable support on mobile devices and those who cannot right click (blessed be them). +* Support for filtering users when listing all users on the system. ### Changed * File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. diff --git a/app/Http/Controllers/Admin/UserController.php b/app/Http/Controllers/Admin/UserController.php index 18ec6f1a1..8fc403ecd 100644 --- a/app/Http/Controllers/Admin/UserController.php +++ b/app/Http/Controllers/Admin/UserController.php @@ -51,8 +51,33 @@ class UserController extends Controller public function getIndex(Request $request) { + $query = User::select('users.*'); + if ($request->input('filter') && !is_null($request->input('filter'))) { + preg_match_all('/[^\s"\']+|"([^"]*)"|\'([^\']*)\'/', urldecode($request->input('filter')), $matches); + foreach($matches[0] as $match) { + $match = str_replace('"', '', $match); + if (strpos($match, ':')) { + list($field, $term) = explode(':', $match); + $query->orWhere($field, 'LIKE', '%' . $term . '%'); + } else { + $query->where('email', 'LIKE', '%' . $match . '%'); + $query->orWhere([ + ['uuid', 'LIKE', '%' . $match . '%'], + ['root_admin', 'LIKE', '%' . $match . '%'] + ]); + } + } + } + + try { + $users = $query->paginate(20); + } catch (\Exception $ex) { + Alert::warning('There was an error with the search parameters provided.'); + $users = User::all()->paginate(20); + } + return view('admin.users.index', [ - 'users' => User::paginate(20) + 'users' => $users ]); } diff --git a/resources/views/admin/users/index.blade.php b/resources/views/admin/users/index.blade.php index 4092caa6c..04eaaf207 100644 --- a/resources/views/admin/users/index.blade.php +++ b/resources/views/admin/users/index.blade.php @@ -31,6 +31,14 @@
  • Accounts
  • All Registered Users


    +
    +
    + +
    + +
    +
    +
    From 259b220dfcbaa1448230f8565cf44044958533cf Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 18:45:08 -0500 Subject: [PATCH 09/24] misc file cleanup --- app/Models/Server.php | 2 +- app/Repositories/Daemon/FileRepository.php | 4 ++-- resources/views/admin/servers/new.blade.php | 2 +- resources/views/layouts/master.blade.php | 2 +- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/app/Models/Server.php b/app/Models/Server.php index 9948c7a10..93f6d9641 100644 --- a/app/Models/Server.php +++ b/app/Models/Server.php @@ -199,7 +199,7 @@ class Server extends Model } /** - * Returns non-administrative headers for accessing a server on Scales + * Returns non-administrative headers for accessing a server on the daemon * * @param string $uuid * @return array diff --git a/app/Repositories/Daemon/FileRepository.php b/app/Repositories/Daemon/FileRepository.php index 1d6bf7aac..c77baba11 100644 --- a/app/Repositories/Daemon/FileRepository.php +++ b/app/Repositories/Daemon/FileRepository.php @@ -132,7 +132,7 @@ class FileRepository } /** - * Save the contents of a requested file on the Scales instance. + * Save the contents of a requested file on the daemon. * * @param string $file * @param string $content @@ -166,7 +166,7 @@ class FileRepository } /** - * Returns a listing of all files and folders within a specified Scales directory. + * Returns a listing of all files and folders within a specified directory on the daemon. * * @param string $directory * @return object diff --git a/resources/views/admin/servers/new.blade.php b/resources/views/admin/servers/new.blade.php index 8db93ffcd..bb0a46f0e 100644 --- a/resources/views/admin/servers/new.blade.php +++ b/resources/views/admin/servers/new.blade.php @@ -50,7 +50,7 @@
    {{-- Hacky workaround to prevent Safari and Chrome from trying to suggest emails here --}} - +
    diff --git a/resources/views/layouts/master.blade.php b/resources/views/layouts/master.blade.php index f66a9a857..f7c7d383d 100644 --- a/resources/views/layouts/master.blade.php +++ b/resources/views/layouts/master.blade.php @@ -106,7 +106,7 @@ $('#applyUpdate').removeClass('fa-circle-o-notch fa-spinner fa-spin fa-check-circle fa-times-circle').addClass(selector).css({ color: color }); }); - // Socket Recieves New Status from Scales + // Socket Recieves New Status from Daemon socket.on('status', function(data) { var newStatus, selector = 'fa-times-circle'; var color = '#E33200'; From e39c750563f84c4f5aca83b2a4b4c945a2a349b8 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 18:47:22 -0500 Subject: [PATCH 10/24] Remove link that shouldn't exist in the first place. --- resources/views/admin/databases/index.blade.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/resources/views/admin/databases/index.blade.php b/resources/views/admin/databases/index.blade.php index 0549f1d60..5417473ab 100644 --- a/resources/views/admin/databases/index.blade.php +++ b/resources/views/admin/databases/index.blade.php @@ -88,7 +88,7 @@
    @foreach($dbh as $db) - + From 777e7138e6789460d5f82c392af653a45e871191 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 19:06:14 -0500 Subject: [PATCH 11/24] Update regex checking for minecraft services closes #193 --- CHANGELOG.md | 2 + ...12_02_185206_correct_service_variables.php | 79 +++++++++++++++++++ .../seeds/MinecraftServiceTableSeeder.php | 14 ++-- 3 files changed, 88 insertions(+), 7 deletions(-) create mode 100644 database/migrations/2016_12_02_185206_correct_service_variables.php diff --git a/CHANGELOG.md b/CHANGELOG.md index 126b69c4d..40c7aa6cf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,9 +12,11 @@ This project follows [Semantic Versioning](http://semver.org) guidelines. ### Changed * File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. * File upload limit can now be controlled from the panel. +* Updates regex and default values for some Minecraft services to reflect current technology. ### Fixed * Fixes potential for generated password to not meet own validation requirements. +* Fixes some regex checking issues with newer versions of Minecraft. ## v0.5.3 (Bodacious Boreopterus) ### Fixed diff --git a/database/migrations/2016_12_02_185206_correct_service_variables.php b/database/migrations/2016_12_02_185206_correct_service_variables.php new file mode 100644 index 000000000..f3da07e0a --- /dev/null +++ b/database/migrations/2016_12_02_185206_correct_service_variables.php @@ -0,0 +1,79 @@ +where([ + ['name', 'Spigot'], + ['tag', 'spigot'], + ['startup', '-Xms128M -Xmx{{SERVER_MEMORY}}M -Djline.terminal=jline.UnsupportedTerminal -jar {{SERVER_JARFILE}}'], + ])->update([ + 'startup' => null, + ]); + + // Correct Spigot Version Checking + DB::table('service_variables')->where([ + ['name', 'Spigot Version'], + ['env_variable', 'DL_VERSION'], + ['default_value', 'latest'], + ['regex', '/^(latest|[a-zA-Z0-9_\.-]{5,6})$/'], + ])->update([ + 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/', + ]); + + // Correct Vanilla Version Checking (as well as naming) + DB::table('service_variables')->where([ + ['name', 'Server Jar File'], + ['env_variable', 'VANILLA_VERSION'], + ['default_value', 'latest'], + ['regex', '/^(latest|[a-zA-Z0-9_\.-]{5,6})$/'] + ])->update([ + 'name' => 'Server Version', + 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/', + ]); + + // Update Sponge Version Checking and Update Default Version + DB::table('service_variables')->where([ + ['name', 'Sponge Version'], + ['env_variable', 'SPONGE_VERSION'], + ['default_value', '1.8.9-4.2.0-BETA-351'], + ['regex', '/^(.*)$/'], + ])->update([ + 'default_value' => '1.10.2-5.1.0-BETA-359', + 'regex' => '/^([a-zA-Z0-9.\-_]+)$/', + ]); + + // Update Bungeecord Version Checking + DB::table('service_variables')->where([ + ['name', 'Bungeecord Version'], + ['env_variable', 'BUNGEE_VERSION'], + ['default_value', 'latest'], + ['regex', '/^(latest|[\d]{3,5})$/'], + ])->update([ + 'regex' => '/^(latest|[\d]{1,6})$/', + ]); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + // do nothing + } +} diff --git a/database/seeds/MinecraftServiceTableSeeder.php b/database/seeds/MinecraftServiceTableSeeder.php index ff141abdb..9f55abb80 100644 --- a/database/seeds/MinecraftServiceTableSeeder.php +++ b/database/seeds/MinecraftServiceTableSeeder.php @@ -84,7 +84,7 @@ class MinecraftServiceTableSeeder extends Seeder 'tag' => 'spigot', 'docker_image' => 'quay.io/pterodactyl/minecraft:spigot', 'executable' => null, - 'startup' => '-Xms128M -Xmx{{SERVER_MEMORY}}M -Djline.terminal=jline.UnsupportedTerminal -jar {{SERVER_JARFILE}}' + 'startup' => '-Xms128M -Xmx{{SERVER_MEMORY}}M -jar {{SERVER_JARFILE}}' ]); $this->option['sponge'] = Models\ServiceOptions::create([ @@ -132,14 +132,14 @@ class MinecraftServiceTableSeeder extends Seeder Models\ServiceVariables::create([ 'option_id' => $this->option['vanilla']->id, - 'name' => 'Server Jar File', + 'name' => 'Server Version', 'description' => 'The version of Minecraft Vanilla to install. Use "latest" to install the latest version.', 'env_variable' => 'VANILLA_VERSION', 'default_value' => 'latest', 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{5,6})$/' + 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/' ]); } @@ -166,7 +166,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{5,6})$/' + 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/' ]); Models\ServiceVariables::create([ @@ -189,11 +189,11 @@ class MinecraftServiceTableSeeder extends Seeder 'name' => 'Sponge Version', 'description' => 'The version of SpongeVanilla to download and use.', 'env_variable' => 'SPONGE_VERSION', - 'default_value' => '1.8.9-4.2.0-BETA-351', + 'default_value' => '1.10.2-5.1.0-BETA-359', 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(.*)$/' + 'regex' => '/^([a-zA-Z0-9.\-_]+)$/' ]); Models\ServiceVariables::create([ @@ -220,7 +220,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(latest|[\d]{3,5})$/' + 'regex' => '/^(latest|[\d]{1,6})$/' ]); Models\ServiceVariables::create([ From 2ac734d5952751131e115bf32c9c84412fe44c67 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 19:12:29 -0500 Subject: [PATCH 12/24] Update node config sent over API --- app/Http/Controllers/API/NodeController.php | 14 ++++++++------ resources/views/admin/nodes/view.blade.php | 2 +- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/app/Http/Controllers/API/NodeController.php b/app/Http/Controllers/API/NodeController.php index a0da14af5..6a60427b4 100755 --- a/app/Http/Controllers/API/NodeController.php +++ b/app/Http/Controllers/API/NodeController.php @@ -170,6 +170,7 @@ class NodeController extends BaseController return [ 'web' => [ 'listen' => $node->daemonListen, + 'host' => '0.0.0.0', 'ssl' => [ 'enabled' => ($node->scheme === 'https'), 'certificate' => '/etc/certs/' . $node->fqdn . '/fullchain.pem', @@ -183,7 +184,11 @@ class NodeController extends BaseController 'sftp' => [ 'path' => $node->daemonBase, 'port' => (int) $node->daemonSFTP, - 'container' => '0x0000' + 'container' => 'ptdl-sftp' + ], + 'query' => [ + 'kill_on_fail' => true, + 'fail_limit' => 5 ], 'logger' => [ 'path' => 'logs/', @@ -193,19 +198,16 @@ class NodeController extends BaseController 'count' => 3 ], 'remote' => [ + 'base' => config('app.url'), 'download' => route('remote.download'), 'installed' => route('remote.install') ], 'uploads' => [ - 'maximumSize' => 100000000 + 'size_limit' => $node->upload_size ], 'keys' => [ $node->daemonSecret ], - 'query' => [ - 'kill_on_fail' => true, - 'fail_limit' => 3 - ] ]; } diff --git a/resources/views/admin/nodes/view.blade.php b/resources/views/admin/nodes/view.blade.php index 734e8e4a2..3d5d9c7d7 100644 --- a/resources/views/admin/nodes/view.blade.php +++ b/resources/views/admin/nodes/view.blade.php @@ -307,7 +307,7 @@ "container": "ptdl-sftp" }, "query": { - "kill_on_fail": false, + "kill_on_fail": true, "fail_limit": 5 }, "logger": { From 9ae716ee429cb8d3a186f0553544f1e4c548a5fd Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 19:35:08 -0500 Subject: [PATCH 13/24] show container ID for server in panel Also shows the UID of the user to ease permissions setting closes #160 --- .../Controllers/Admin/ServersController.php | 9 +++-- resources/views/admin/servers/view.blade.php | 33 +++++++++++++++++-- 2 files changed, 37 insertions(+), 5 deletions(-) diff --git a/app/Http/Controllers/Admin/ServersController.php b/app/Http/Controllers/Admin/ServersController.php index 5ec7d9a2b..be598f241 100644 --- a/app/Http/Controllers/Admin/ServersController.php +++ b/app/Http/Controllers/Admin/ServersController.php @@ -123,9 +123,7 @@ class ServersController extends Controller { $server = Models\Server::withTrashed()->select( 'servers.*', - 'nodes.name as a_nodeName', 'users.email as a_ownerEmail', - 'locations.long as a_locationName', 'services.name as a_serviceName', DB::raw('IFNULL(service_options.executable, services.executable) as a_serviceExecutable'), 'service_options.docker_image', @@ -135,7 +133,6 @@ class ServersController extends Controller 'allocations.ip_alias' )->join('nodes', 'servers.node', '=', 'nodes.id') ->join('users', 'servers.owner', '=', 'users.id') - ->join('locations', 'nodes.location', '=', 'locations.id') ->join('services', 'servers.service', '=', 'services.id') ->join('service_options', 'servers.option', '=', 'service_options.id') ->join('allocations', 'servers.allocation', '=', 'allocations.id') @@ -148,6 +145,12 @@ class ServersController extends Controller return view('admin.servers.view', [ 'server' => $server, + 'node' => Models\Node::select( + 'nodes.*', + 'locations.long as a_locationName' + )->join('locations', 'nodes.location', '=', 'locations.id') + ->where('nodes.id', $server->node) + ->first(), 'assigned' => Models\Allocation::where('assigned_to', $id)->orderBy('ip', 'asc')->orderBy('port', 'asc')->get(), 'unassigned' => Models\Allocation::where('node', $server->node)->whereNull('assigned_to')->orderBy('ip', 'asc')->orderBy('port', 'asc')->get(), 'startup' => Models\ServiceVariables::select('service_variables.*', 'server_variables.variable_value as a_serverValue') diff --git a/resources/views/admin/servers/view.blade.php b/resources/views/admin/servers/view.blade.php index a3ec84e1f..a3cc399e1 100644 --- a/resources/views/admin/servers/view.blade.php +++ b/resources/views/admin/servers/view.blade.php @@ -79,17 +79,25 @@ + + + + + + + + - + - + @@ -553,6 +561,27 @@ $(document).ready(function () { $('[data-toggle="tooltip"]').tooltip(); $('#sidebar_links').find("a[href='/admin/servers']").addClass('active'); + (function checkServerInfo() { + $.ajax({ + type: 'GET', + headers: { + 'X-Access-Token': '{{ $server->daemonSecret }}', + 'X-Access-Server': '{{ $server->uuid }}' + }, + url: '{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}/server', + dataType: 'json', + timeout: 5000, + }).done(function (data) { + $('td[data-attr="container-id"]').html('' + data.container.id + ''); + $('td[data-attr="container-user"]').html('' + data.user + ''); + }).fail(function (jqXHR) { + $('td[data-attr="container-id"]').html('error'); + $('td[data-attr="container-user"]').html('error'); + console.error(jqXHR); + }).always(function () { + setTimeout(checkServerInfo, 60000); + }) + })(); $('input[name="default"]').on('change', function (event) { $('select[name="remove_additional[]"]').find('option:disabled').prop('disabled', false); $('select[name="remove_additional[]"]').find('option[value="' + $(this).val() + '"]').prop('disabled', true).prop('selected', false); From e3587966e2a7f8fbd9ac53cbd81b0beed203a9a6 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Fri, 2 Dec 2016 19:46:27 -0500 Subject: [PATCH 14/24] Update changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 40c7aa6cf..5282fdbe2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ This project follows [Semantic Versioning](http://semver.org) guidelines. * Changing node configuration values now automatically makes a call to the daemon and updates the configuration there. Changing daemon tokens now does not require any intervention, and takes effect immediately. SSL & Port configurations will still require a daemon reboot. * New button in file manager that triggers the right click menu to enable support on mobile devices and those who cannot right click (blessed be them). * Support for filtering users when listing all users on the system. +* Container ID and User ID on the daemon are now shown when viewing a server in the panel. ### Changed * File uploads now account for a maximum file size that is assigned for the daemon, and gives cleaner errors when that limit is reached. From f687fab9a2024ab58f78b6fe2a6bfa3390e1fac2 Mon Sep 17 00:00:00 2001 From: Emmet Young Date: Mon, 5 Dec 2016 14:17:35 +1100 Subject: [PATCH 15/24] API: ability to search for an allocation based on the assigned server id (#194) --- app/Http/Controllers/API/NodeController.php | 26 +++++++++++++++++++++ app/Http/Routes/APIRoutes.php | 5 ++++ 2 files changed, 31 insertions(+) diff --git a/app/Http/Controllers/API/NodeController.php b/app/Http/Controllers/API/NodeController.php index 6a60427b4..50c16ad0d 100755 --- a/app/Http/Controllers/API/NodeController.php +++ b/app/Http/Controllers/API/NodeController.php @@ -228,6 +228,32 @@ class NodeController extends BaseController } return $allocations; } + + /** + * List Node Allocation based on assigned to ID + * + * Returns a listing of the allocation for the specified server id. + * + * @Get("/nodes/allocations/{id}") + * @Versions({"v1"}) + * @Response(200) + */ + public function allocationsView(Request $request, $id) + { + $query = Models\Allocation::where('assigned_to', $id)->get(); + try { + + if (empty($query)) { + throw new NotFoundHttpException('No allocations for that server were found.'); + } + + return $query; + } catch (NotFoundHttpException $ex) { + throw $ex; + } catch (\Exception $ex) { + throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); + } + } /** * Delete Node diff --git a/app/Http/Routes/APIRoutes.php b/app/Http/Routes/APIRoutes.php index 33d3d7177..b08da5a61 100755 --- a/app/Http/Routes/APIRoutes.php +++ b/app/Http/Routes/APIRoutes.php @@ -140,6 +140,11 @@ class APIRoutes 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@allocations' ]); + $api->get('nodes/allocations/{id}', [ + 'as' => 'api.admin.nodes.allocations', + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@allocationsView' + ]); + $api->get('nodes/{id}', [ 'as' => 'api.admin.nodes.view', 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@view' From 88837f8ac0a48dbab12fa8f75b3685e7f20e5e0e Mon Sep 17 00:00:00 2001 From: Emmet Young Date: Wed, 7 Dec 2016 14:31:44 +1100 Subject: [PATCH 16/24] Fix the subuser edit view, large amount of checkboxes were not properly formatted causing the first half of the edit screen to be broken. Correct the value used for the create files permission. --- resources/views/server/users/new.blade.php | 2 +- resources/views/server/users/view.blade.php | 49 +++++++++++---------- 2 files changed, 26 insertions(+), 25 deletions(-) diff --git a/resources/views/server/users/new.blade.php b/resources/views/server/users/new.blade.php index c954bcd4b..1f1bca4e1 100644 --- a/resources/views/server/users/new.blade.php +++ b/resources/views/server/users/new.blade.php @@ -120,7 +120,7 @@
    diff --git a/resources/views/server/users/view.blade.php b/resources/views/server/users/view.blade.php index 6ac4dc9a8..9d76060b5 100644 --- a/resources/views/server/users/view.blade.php +++ b/resources/views/server/users/view.blade.php @@ -83,32 +83,33 @@

    Allows user to save modified file contents.

    -

    Allows user to move and rename files and folders on the filesystem.

    - - -

    -
    -
    -
    -
    -
    +
    +
    +
    +
    +
    +
    +
    +
    From c1fb0a665f3ebfe3dc17c59603089e541a63dd47 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Wed, 7 Dec 2016 22:46:38 +0000 Subject: [PATCH 17/24] Apply fixes from StyleCI --- app/Console/Commands/ClearServices.php | 7 +- app/Console/Commands/ClearTasks.php | 7 +- app/Console/Commands/Inspire.php | 2 +- app/Console/Commands/MakeUser.php | 6 +- app/Console/Commands/RunTasks.php | 8 +- app/Console/Commands/ShowVersion.php | 5 +- app/Console/Commands/UpdateEmailSettings.php | 21 +- app/Console/Commands/UpdateEnvironment.php | 18 +- app/Events/ServerDeleted.php | 4 +- app/Exceptions/AccountNotFoundException.php | 4 +- app/Exceptions/DisplayException.php | 5 +- app/Exceptions/DisplayValidationException.php | 3 +- app/Exceptions/Handler.php | 8 +- app/Facades/Version.php | 4 +- app/Http/Controllers/API/BaseController.php | 3 +- .../Controllers/API/LocationController.php | 9 +- app/Http/Controllers/API/NodeController.php | 131 +++++----- app/Http/Controllers/API/ServerController.php | 66 ++--- .../Controllers/API/ServiceController.php | 17 +- .../Controllers/API/User/InfoController.php | 12 +- .../Controllers/API/User/ServerController.php | 32 +-- app/Http/Controllers/API/UserController.php | 44 ++-- app/Http/Controllers/Admin/BaseController.php | 14 +- .../Controllers/Admin/DatabaseController.php | 35 +-- .../Controllers/Admin/LocationsController.php | 32 +-- .../Controllers/Admin/NodesController.php | 75 +++--- .../Controllers/Admin/ServersController.php | 147 ++++++----- .../Controllers/Admin/ServiceController.php | 62 +++-- app/Http/Controllers/Admin/UserController.php | 43 ++-- app/Http/Controllers/Auth/LoginController.php | 41 ++- .../Controllers/Auth/RegisterController.php | 2 +- .../Auth/ResetPasswordController.php | 4 +- app/Http/Controllers/Base/APIController.php | 21 +- .../Controllers/Base/AccountController.php | 22 +- app/Http/Controllers/Base/IndexController.php | 12 +- .../Controllers/Base/LanguageController.php | 11 +- .../Controllers/Base/SecurityController.php | 32 +-- .../Controllers/Remote/RemoteController.php | 37 ++- .../Controllers/Server/AjaxController.php | 59 ++--- .../Controllers/Server/ServerController.php | 54 ++-- .../Controllers/Server/SubuserController.php | 53 ++-- .../Controllers/Server/TaskController.php | 46 ++-- app/Http/Middleware/APISecretToken.php | 41 ++- app/Http/Middleware/AdminAuthenticate.php | 5 +- app/Http/Middleware/CheckServer.php | 12 +- app/Http/Middleware/LanguageMiddleware.php | 8 +- app/Http/Middleware/VerifyCsrfToken.php | 2 +- app/Http/Routes/APIRoutes.php | 75 +++--- app/Http/Routes/AdminRoutes.php | 175 +++++++------ app/Http/Routes/AuthRoutes.php | 37 ++- app/Http/Routes/BaseRoutes.php | 52 ++-- app/Http/Routes/LanguageRoutes.php | 10 +- app/Http/Routes/RemoteRoutes.php | 18 +- app/Http/Routes/ServerRoutes.php | 69 +++-- app/Jobs/DeleteServer.php | 10 +- app/Jobs/SendScheduledTask.php | 22 +- app/Jobs/SuspendServer.php | 8 +- app/Listeners/DeleteServerListener.php | 10 +- app/Models/APIKey.php | 5 +- app/Models/APILog.php | 17 +- app/Models/APIPermission.php | 17 +- app/Models/Allocation.php | 15 +- app/Models/Database.php | 15 +- app/Models/DatabaseServer.php | 17 +- app/Models/Download.php | 6 +- app/Models/Location.php | 5 +- app/Models/Node.php | 20 +- app/Models/Permission.php | 15 +- app/Models/Server.php | 35 +-- app/Models/ServerVariables.php | 15 +- app/Models/Service.php | 5 +- app/Models/ServiceOptions.php | 15 +- app/Models/ServiceVariables.php | 15 +- app/Models/Session.php | 15 +- app/Models/Subuser.php | 23 +- app/Models/Task.php | 17 +- app/Models/TaskLog.php | 19 +- app/Models/User.php | 50 ++-- app/Notifications/AccountCreated.php | 4 +- app/Notifications/SendPasswordReset.php | 3 +- app/Notifications/ServerCreated.php | 1 - app/Policies/ServerPolicy.php | 81 +++--- app/Providers/AuthServiceProvider.php | 2 +- app/Repositories/APIRepository.php | 38 +-- app/Repositories/Daemon/CommandRepository.php | 23 +- app/Repositories/Daemon/FileRepository.php | 70 ++--- app/Repositories/Daemon/PowerRepository.php | 18 +- app/Repositories/DatabaseRepository.php | 40 ++- app/Repositories/HelperRepository.php | 15 +- app/Repositories/LocationRepository.php | 17 +- app/Repositories/NodeRepository.php | 47 ++-- app/Repositories/ServerRepository.php | 242 +++++++++--------- app/Repositories/ServiceRepository/Option.php | 12 +- .../ServiceRepository/Service.php | 14 +- .../ServiceRepository/Variable.php | 19 +- app/Repositories/SubuserRepository.php | 72 +++--- app/Repositories/TaskRepository.php | 19 +- app/Repositories/UserRepository.php | 45 ++-- app/Services/APILogService.php | 9 +- app/Services/DeploymentService.php | 24 +- app/Services/NotificationService.php | 12 +- app/Services/UuidService.php | 27 +- app/Services/VersionService.php | 11 +- app/Transformers/AllocationTransformer.php | 7 +- app/Transformers/NodeTransformer.php | 7 +- app/Transformers/ServerTransformer.php | 7 +- app/Transformers/UserTransformer.php | 7 +- bootstrap/app.php | 2 +- bootstrap/autoload.php | 4 +- config/debugbar.php | 52 ++-- ...3_18_155649_add_nullable_field_lastrun.php | 5 +- .../2016_08_30_212718_add_ip_alias.php | 4 +- ..._08_30_213301_modify_ip_storage_method.php | 14 +- ...6_09_17_194246_add_docker_image_column.php | 2 - ..._09_29_213518_rename_double_insurgency.php | 2 - .../2016_10_07_152117_build_api_log_table.php | 1 - ...16_10_23_181719_update_misnamed_bungee.php | 5 +- ...6_10_23_201624_add_foreign_allocations.php | 14 +- ...6_10_23_203522_add_foreign_permissions.php | 1 - ...23_203857_add_foreign_server_variables.php | 1 - ...3_204321_add_foreign_service_variables.php | 2 +- ...04_000949_add_ark_service_option_fixed.php | 13 +- ...12_02_185206_correct_service_variables.php | 4 +- .../seeds/MinecraftServiceTableSeeder.php | 35 ++- database/seeds/SourceServiceTableSeeder.php | 39 ++- database/seeds/TerrariaServiceTableSeeder.php | 15 +- database/seeds/VoiceServiceTableSeeder.php | 19 +- public/index.php | 7 +- resources/lang/de/auth.php | 4 +- resources/lang/de/base.php | 6 +- resources/lang/de/pagination.php | 2 +- resources/lang/de/passwords.php | 2 +- resources/lang/de/server.php | 2 +- resources/lang/de/strings.php | 2 +- resources/lang/en/auth.php | 4 +- resources/lang/en/base.php | 6 +- resources/lang/en/pagination.php | 2 +- resources/lang/en/passwords.php | 2 +- resources/lang/en/server.php | 2 +- resources/lang/en/strings.php | 2 +- resources/lang/pt/auth.php | 4 +- resources/lang/pt/base.php | 6 +- resources/lang/pt/pagination.php | 2 +- resources/lang/pt/passwords.php | 4 +- resources/lang/pt/server.php | 2 +- resources/lang/pt/strings.php | 2 +- resources/lang/pt/validation.php | 2 +- server.php | 8 +- tests/ExampleTest.php | 3 - tests/TestCase.php | 2 +- 150 files changed, 1558 insertions(+), 1760 deletions(-) diff --git a/app/Console/Commands/ClearServices.php b/app/Console/Commands/ClearServices.php index 626d7720f..803425185 100644 --- a/app/Console/Commands/ClearServices.php +++ b/app/Console/Commands/ClearServices.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,10 +21,10 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; use DB; - use Illuminate\Console\Command; class ClearServices extends Command @@ -60,8 +60,7 @@ class ClearServices extends Command */ public function handle() { - - if (!$this->confirm('This is a destructive operation, are you sure you wish to continue?')) { + if (! $this->confirm('This is a destructive operation, are you sure you wish to continue?')) { $this->error('Canceling.'); exit(); } diff --git a/app/Console/Commands/ClearTasks.php b/app/Console/Commands/ClearTasks.php index 4f2181ca0..dde631f29 100644 --- a/app/Console/Commands/ClearTasks.php +++ b/app/Console/Commands/ClearTasks.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,16 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; -use DB; use Carbon; use Pterodactyl\Models; use Illuminate\Console\Command; use Illuminate\Foundation\Bus\DispatchesJobs; -use Pterodactyl\Jobs\SendScheduledTask; - class ClearTasks extends Command { - use DispatchesJobs; /** diff --git a/app/Console/Commands/Inspire.php b/app/Console/Commands/Inspire.php index 6efa5aa73..b579f2c86 100644 --- a/app/Console/Commands/Inspire.php +++ b/app/Console/Commands/Inspire.php @@ -28,6 +28,6 @@ class Inspire extends Command */ public function handle() { - $this->comment(PHP_EOL.Inspiring::quote().PHP_EOL); + $this->comment(PHP_EOL . Inspiring::quote() . PHP_EOL); } } diff --git a/app/Console/Commands/MakeUser.php b/app/Console/Commands/MakeUser.php index a1d507b79..f1992836b 100644 --- a/app/Console/Commands/MakeUser.php +++ b/app/Console/Commands/MakeUser.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,11 +21,10 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; -use Hash; use Illuminate\Console\Command; - use Pterodactyl\Repositories\UserRepository; class MakeUser extends Command @@ -77,6 +76,7 @@ class MakeUser extends Command try { $user = new UserRepository; $user->create($email, $password, $admin); + return $this->info('User successfully created.'); } catch (\Exception $ex) { return $this->error($ex->getMessage()); diff --git a/app/Console/Commands/RunTasks.php b/app/Console/Commands/RunTasks.php index 3047dc54e..d9e610973 100644 --- a/app/Console/Commands/RunTasks.php +++ b/app/Console/Commands/RunTasks.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; -use DB; use Carbon; use Pterodactyl\Models; use Illuminate\Console\Command; -use Illuminate\Foundation\Bus\DispatchesJobs; - use Pterodactyl\Jobs\SendScheduledTask; +use Illuminate\Foundation\Bus\DispatchesJobs; class RunTasks extends Command { - use DispatchesJobs; /** diff --git a/app/Console/Commands/ShowVersion.php b/app/Console/Commands/ShowVersion.php index 2033f9b0f..357cdc1fe 100644 --- a/app/Console/Commands/ShowVersion.php +++ b/app/Console/Commands/ShowVersion.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,10 +21,11 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; -use Illuminate\Console\Command; use Version; +use Illuminate\Console\Command; class ShowVersion extends Command { diff --git a/app/Console/Commands/UpdateEmailSettings.php b/app/Console/Commands/UpdateEmailSettings.php index f6dd5a304..54655ebc9 100644 --- a/app/Console/Commands/UpdateEmailSettings.php +++ b/app/Console/Commands/UpdateEmailSettings.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; use Illuminate\Console\Command; @@ -66,7 +67,7 @@ class UpdateEmailSettings extends Command { $variables = []; $file = base_path() . '/.env'; - if (!file_exists($file)) { + if (! file_exists($file)) { $this->error('Missing environment file! It appears that you have not installed this panel correctly.'); exit(); } @@ -75,35 +76,35 @@ class UpdateEmailSettings extends Command $this->table([ 'Option', - 'Description' + 'Description', ], [ [ 'smtp', - 'SMTP Server Email' + 'SMTP Server Email', ], [ 'mail', - 'PHP\'s Internal Mail Server' + 'PHP\'s Internal Mail Server', ], [ 'mailgun', - 'Mailgun Email Service' + 'Mailgun Email Service', ], [ 'mandrill', - 'Mandrill Transactional Email Service' + 'Mandrill Transactional Email Service', ], [ 'postmark', - 'Postmark Transactional Email Service' - ] + 'Postmark Transactional Email Service', + ], ]); $variables['MAIL_DRIVER'] = is_null($this->option('driver')) ? $this->choice('Which email driver would you like to use?', [ 'smtp', 'mail', 'mailgun', 'mandrill', - 'postmark' + 'postmark', ]) : $this->option('driver'); switch ($variables['MAIL_DRIVER']) { diff --git a/app/Console/Commands/UpdateEnvironment.php b/app/Console/Commands/UpdateEnvironment.php index 7afa3e7e2..df1631d7d 100644 --- a/app/Console/Commands/UpdateEnvironment.php +++ b/app/Console/Commands/UpdateEnvironment.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Console\Commands; use Uuid; @@ -66,10 +67,9 @@ class UpdateEnvironment extends Command */ public function handle() { - $variables = []; $file = base_path() . '/.env'; - if (!file_exists($file)) { + if (! file_exists($file)) { $this->error('Missing environment file! It appears that you have not installed this panel correctly.'); exit(); } @@ -77,12 +77,12 @@ class UpdateEnvironment extends Command $envContents = file_get_contents($file); $this->info('Simply leave blank and press enter to fields that you do not wish to update.'); - if (!env('SERVICE_AUTHOR', false)) { + if (! env('SERVICE_AUTHOR', false)) { $this->info('No service author set, setting one now.'); $variables['SERVICE_AUTHOR'] = env('SERVICE_AUTHOR', (string) Uuid::generate(4)); } - if (!env('QUEUE_STANDARD', false) || !env('QUEUE_DRIVER', false)) { + if (! env('QUEUE_STANDARD', false) || ! env('QUEUE_DRIVER', false)) { $this->info('Setting default queue settings.'); $variables['QUEUE_DRIVER'] = env('QUEUE_DRIVER', 'database'); $variables['QUEUE_HIGH'] = env('QUEUE_HIGH', 'high'); @@ -91,25 +91,25 @@ class UpdateEnvironment extends Command } if (is_null($this->option('dbhost'))) { - $variables['DB_HOST'] = $this->anticipate('Database Host', [ 'localhost', '127.0.0.1', env('DB_HOST') ], env('DB_HOST')); + $variables['DB_HOST'] = $this->anticipate('Database Host', ['localhost', '127.0.0.1', env('DB_HOST')], env('DB_HOST')); } else { $variables['DB_HOST'] = $this->option('dbhost'); } if (is_null($this->option('dbport'))) { - $variables['DB_PORT'] = $this->anticipate('Database Port', [ 3306, env('DB_PORT') ], env('DB_PORT')); + $variables['DB_PORT'] = $this->anticipate('Database Port', [3306, env('DB_PORT')], env('DB_PORT')); } else { $variables['DB_PORT'] = $this->option('dbport'); } if (is_null($this->option('dbname'))) { - $variables['DB_DATABASE'] = $this->anticipate('Database Name', [ 'pterodactyl', 'homestead', ENV('DB_DATABASE') ], env('DB_DATABASE')); + $variables['DB_DATABASE'] = $this->anticipate('Database Name', ['pterodactyl', 'homestead', ENV('DB_DATABASE')], env('DB_DATABASE')); } else { $variables['DB_DATABASE'] = $this->option('dbname'); } if (is_null($this->option('dbuser'))) { - $variables['DB_USERNAME'] = $this->anticipate('Database Username', [ ENV('DB_DATABASE') ], env('DB_USERNAME')); + $variables['DB_USERNAME'] = $this->anticipate('Database Username', [ENV('DB_DATABASE')], env('DB_USERNAME')); } else { $variables['DB_USERNAME'] = $this->option('dbuser'); } diff --git a/app/Events/ServerDeleted.php b/app/Events/ServerDeleted.php index 4451b01bc..86770e9eb 100644 --- a/app/Events/ServerDeleted.php +++ b/app/Events/ServerDeleted.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Events; use Illuminate\Queue\SerializesModels; @@ -40,5 +41,4 @@ class ServerDeleted { $this->server = $id; } - } diff --git a/app/Exceptions/AccountNotFoundException.php b/app/Exceptions/AccountNotFoundException.php index 166031644..160427b27 100644 --- a/app/Exceptions/AccountNotFoundException.php +++ b/app/Exceptions/AccountNotFoundException.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,9 +21,9 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Exceptions; class AccountNotFoundException extends \Exception { - } diff --git a/app/Exceptions/DisplayException.php b/app/Exceptions/DisplayException.php index ae06f983a..1c9869079 100644 --- a/app/Exceptions/DisplayException.php +++ b/app/Exceptions/DisplayException.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Exceptions; use Log; class DisplayException extends \Exception { - private $_logging = null; public function __construct($message, $log = null) @@ -44,5 +44,4 @@ class DisplayException extends \Exception { return $this->_logging; } - } diff --git a/app/Exceptions/DisplayValidationException.php b/app/Exceptions/DisplayValidationException.php index e8d319f4c..a172bfce4 100644 --- a/app/Exceptions/DisplayValidationException.php +++ b/app/Exceptions/DisplayValidationException.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Exceptions; class DisplayValidationException extends \Exception diff --git a/app/Exceptions/Handler.php b/app/Exceptions/Handler.php index 2230c771d..2b89cacbf 100644 --- a/app/Exceptions/Handler.php +++ b/app/Exceptions/Handler.php @@ -3,12 +3,8 @@ namespace Pterodactyl\Exceptions; use Log; - use Exception; use DisplayException; -use DisplayValidationException; -use AccountNotFoundException; - use Illuminate\Auth\AuthenticationException; use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler; @@ -52,7 +48,7 @@ class Handler extends ExceptionHandler { if ($request->isXmlHttpRequest() || $request->ajax() || $request->is('remote/*')) { $response = response()->json([ - 'error' => ($exception instanceof DisplayException) ? $exception->getMessage() : 'An unhandled error occured while attempting to process this request.' + 'error' => ($exception instanceof DisplayException) ? $exception->getMessage() : 'An unhandled error occured while attempting to process this request.', ], 500); // parent::render() will log it, we are bypassing it in this case. @@ -74,7 +70,7 @@ class Handler extends ExceptionHandler if ($request->expectsJson()) { return response()->json(['error' => 'Unauthenticated.'], 401); } + return redirect()->guest('/auth/login'); } - } diff --git a/app/Facades/Version.php b/app/Facades/Version.php index 840862600..f4aa8b116 100644 --- a/app/Facades/Version.php +++ b/app/Facades/Version.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Facades; use Illuminate\Support\Facades\Facade; class Version extends Facade { - protected static function getFacadeAccessor() { return '\Pterodactyl\Services\VersionService'; diff --git a/app/Http/Controllers/API/BaseController.php b/app/Http/Controllers/API/BaseController.php index 7d897fe55..6a3822bad 100755 --- a/app/Http/Controllers/API/BaseController.php +++ b/app/Http/Controllers/API/BaseController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API; use Dingo\Api\Routing\Helpers; diff --git a/app/Http/Controllers/API/LocationController.php b/app/Http/Controllers/API/LocationController.php index 27f192679..a2c510c35 100755 --- a/app/Http/Controllers/API/LocationController.php +++ b/app/Http/Controllers/API/LocationController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API; use DB; @@ -32,14 +33,13 @@ use Pterodactyl\Models\Location; */ class LocationController extends BaseController { - public function __construct() { // } /** - * List All Locations + * List All Locations. * * Lists all locations currently on the system. * @@ -54,11 +54,10 @@ class LocationController extends BaseController ->groupBy('locations.id') ->get(); - foreach($locations as &$location) { + foreach ($locations as &$location) { $location->nodes = explode(',', $location->nodes); } return $locations->toArray(); } - } diff --git a/app/Http/Controllers/API/NodeController.php b/app/Http/Controllers/API/NodeController.php index 50c16ad0d..4c16fcb14 100755 --- a/app/Http/Controllers/API/NodeController.php +++ b/app/Http/Controllers/API/NodeController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API; -use Illuminate\Http\Request; - use Pterodactyl\Models; -use Pterodactyl\Transformers\NodeTransformer; -use Pterodactyl\Transformers\AllocationTransformer; -use Pterodactyl\Repositories\NodeRepository; - -use Pterodactyl\Exceptions\DisplayValidationException; -use Pterodactyl\Exceptions\DisplayException; +use Illuminate\Http\Request; use Dingo\Api\Exception\ResourceException; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Repositories\NodeRepository; +use Pterodactyl\Exceptions\DisplayValidationException; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; @@ -42,14 +39,13 @@ use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; */ class NodeController extends BaseController { - public function __construct() { // } /** - * List All Nodes + * List All Nodes. * * Lists all nodes currently on the system. * @@ -66,7 +62,7 @@ class NodeController extends BaseController } /** - * Create a New Node + * Create a New Node. * * @Post("/nodes") * @Versions({"v1"}) @@ -102,7 +98,8 @@ class NodeController extends BaseController try { $node = new NodeRepository; $new = $node->create($request->all()); - return [ 'id' => $new ]; + + return ['id' => $new]; } catch (DisplayValidationException $ex) { throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); } catch (DisplayException $ex) { @@ -113,7 +110,7 @@ class NodeController extends BaseController } /** - * List Specific Node + * List Specific Node. * * Lists specific fields about a server or all fields pertaining to that node. * @@ -129,16 +126,16 @@ class NodeController extends BaseController { $node = Models\Node::where('id', $id); - if (!is_null($request->input('fields'))) { - foreach(explode(',', $request->input('fields')) as $field) { - if (!empty($field)) { + if (! is_null($request->input('fields'))) { + foreach (explode(',', $request->input('fields')) as $field) { + if (! empty($field)) { $node->addSelect($field); } } } try { - if (!$node->first()) { + if (! $node->first()) { throw new NotFoundHttpException('No node by that ID was found.'); } @@ -146,8 +143,8 @@ class NodeController extends BaseController 'node' => $node->first(), 'allocations' => [ 'assigned' => Models\Allocation::where('node', $id)->whereNotNull('assigned_to')->get(), - 'unassigned' => Models\Allocation::where('node', $id)->whereNull('assigned_to')->get() - ] + 'unassigned' => Models\Allocation::where('node', $id)->whereNull('assigned_to')->get(), + ], ]; } catch (NotFoundHttpException $ex) { throw $ex; @@ -158,12 +155,12 @@ class NodeController extends BaseController public function config(Request $request, $id) { - if (!$request->secure()) { + if (! $request->secure()) { throw new BadRequestHttpException('This API route can only be accessed using a secure connection.'); } $node = Models\Node::where('id', $id)->first(); - if (!$node) { + if (! $node) { throw new NotFoundHttpException('No node by that ID was found.'); } @@ -174,89 +171,89 @@ class NodeController extends BaseController 'ssl' => [ 'enabled' => ($node->scheme === 'https'), 'certificate' => '/etc/certs/' . $node->fqdn . '/fullchain.pem', - 'key' => '/etc/certs/' . $node->fqdn . '/privkey.pem' - ] + 'key' => '/etc/certs/' . $node->fqdn . '/privkey.pem', + ], ], 'docker' => [ 'socket' => '/var/run/docker.sock', - 'autoupdate_images' => true + 'autoupdate_images' => true, ], 'sftp' => [ 'path' => $node->daemonBase, 'port' => (int) $node->daemonSFTP, - 'container' => 'ptdl-sftp' + 'container' => 'ptdl-sftp', ], 'query' => [ 'kill_on_fail' => true, - 'fail_limit' => 5 + 'fail_limit' => 5, ], 'logger' => [ 'path' => 'logs/', 'src' => false, 'level' => 'info', 'period' => '1d', - 'count' => 3 + 'count' => 3, ], 'remote' => [ 'base' => config('app.url'), 'download' => route('remote.download'), - 'installed' => route('remote.install') + 'installed' => route('remote.install'), ], 'uploads' => [ - 'size_limit' => $node->upload_size + 'size_limit' => $node->upload_size, ], 'keys' => [ - $node->daemonSecret + $node->daemonSecret, ], ]; } - /** - * List all Node Allocations - * - * Returns a listing of all allocations for every node. - * - * @Get("/nodes/allocations") - * @Versions({"v1"}) - * @Response(200) - */ + /** + * List all Node Allocations. + * + * Returns a listing of all allocations for every node. + * + * @Get("/nodes/allocations") + * @Versions({"v1"}) + * @Response(200) + */ public function allocations(Request $request) { $allocations = Models\Allocation::all(); if ($allocations->count() < 1) { throw new NotFoundHttpException('No allocations have been created.'); } + return $allocations; } - - /** - * List Node Allocation based on assigned to ID - * - * Returns a listing of the allocation for the specified server id. - * - * @Get("/nodes/allocations/{id}") - * @Versions({"v1"}) - * @Response(200) - */ + + /** + * List Node Allocation based on assigned to ID. + * + * Returns a listing of the allocation for the specified server id. + * + * @Get("/nodes/allocations/{id}") + * @Versions({"v1"}) + * @Response(200) + */ public function allocationsView(Request $request, $id) { - $query = Models\Allocation::where('assigned_to', $id)->get(); - try { - - if (empty($query)) { - throw new NotFoundHttpException('No allocations for that server were found.'); - } - - return $query; - } catch (NotFoundHttpException $ex) { - throw $ex; - } catch (\Exception $ex) { - throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); - } - } + $query = Models\Allocation::where('assigned_to', $id)->get(); + try { + if (empty($query)) { + throw new NotFoundHttpException('No allocations for that server were found.'); + } + + return $query; + } catch (NotFoundHttpException $ex) { + throw $ex; + } catch (\Exception $ex) { + throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); + } + } /** - * Delete Node + * Delete Node. * * @Delete("/nodes/{id}") * @Versions({"v1"}) @@ -270,12 +267,12 @@ class NodeController extends BaseController try { $node = new NodeRepository; $node->delete($id); + return $this->response->noContent(); } catch (DisplayException $ex) { throw new ResourceException($ex->getMessage()); - } catch(\Exception $e) { + } catch (\Exception $e) { throw new ServiceUnavailableHttpException('An error occured while attempting to delete this node.'); } } - } diff --git a/app/Http/Controllers/API/ServerController.php b/app/Http/Controllers/API/ServerController.php index 3e6063ee0..909353dd4 100755 --- a/app/Http/Controllers/API/ServerController.php +++ b/app/Http/Controllers/API/ServerController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,16 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -namespace Pterodactyl\Http\Controllers\API; -use Illuminate\Http\Request; +namespace Pterodactyl\Http\Controllers\API; use Log; use Pterodactyl\Models; -use Pterodactyl\Transformers\ServerTransformer; -use Pterodactyl\Repositories\ServerRepository; - -use Pterodactyl\Exceptions\DisplayValidationException; -use Pterodactyl\Exceptions\DisplayException; +use Illuminate\Http\Request; use Dingo\Api\Exception\ResourceException; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Repositories\ServerRepository; +use Pterodactyl\Exceptions\DisplayValidationException; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; @@ -42,14 +40,13 @@ use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; */ class ServerController extends BaseController { - public function __construct() { // } /** - * List All Servers + * List All Servers. * * Lists all servers currently on the system. * @@ -66,18 +63,19 @@ class ServerController extends BaseController } /** - * Create Server - * - * @Post("/servers") - * @Versions({"v1"}) - * @Response(201) + * Create Server. + * + * @Post("/servers") + * @Versions({"v1"}) + * @Response(201) */ public function create(Request $request) { try { $server = new ServerRepository; $new = $server->create($request->all()); - return [ 'id' => $new ]; + + return ['id' => $new]; } catch (DisplayValidationException $ex) { throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); } catch (DisplayException $ex) { @@ -89,7 +87,7 @@ class ServerController extends BaseController } /** - * List Specific Server + * List Specific Server. * * Lists specific fields about a server or all fields pertaining to that server. * @@ -105,16 +103,16 @@ class ServerController extends BaseController { $query = Models\Server::where('id', $id); - if (!is_null($request->input('fields'))) { - foreach(explode(',', $request->input('fields')) as $field) { - if (!empty($field)) { + if (! is_null($request->input('fields'))) { + foreach (explode(',', $request->input('fields')) as $field) { + if (! empty($field)) { $query->addSelect($field); } } } try { - if (!$query->first()) { + if (! $query->first()) { throw new NotFoundHttpException('No server by that ID was found.'); } @@ -126,8 +124,8 @@ class ServerController extends BaseController $response = $client->request('GET', '/servers', [ 'headers' => [ - 'X-Access-Token' => $node->daemonSecret - ] + 'X-Access-Token' => $node->daemonSecret, + ], ]); // Only return the daemon token if the request is using HTTPS @@ -140,14 +138,14 @@ class ServerController extends BaseController } return $server->toArray(); - } catch (NotFoundHttpException $ex) { throw $ex; } catch (\GuzzleHttp\Exception\TransferException $ex) { // Couldn't hit the daemon, return what we have though. $server->daemon = [ - 'error' => 'There was an error encountered while attempting to connect to the remote daemon.' + 'error' => 'There was an error encountered while attempting to connect to the remote daemon.', ]; + return $server->toArray(); } catch (\Exception $ex) { throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); @@ -155,7 +153,7 @@ class ServerController extends BaseController } /** - * Update Server configuration + * Update Server configuration. * * Updates display information on panel. * @@ -179,6 +177,7 @@ class ServerController extends BaseController try { $server = new ServerRepository; $server->updateDetails($id, $request->all()); + return Models\Server::findOrFail($id); } catch (DisplayValidationException $ex) { throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); @@ -190,7 +189,7 @@ class ServerController extends BaseController } /** - * Update Server Build Configuration + * Update Server Build Configuration. * * Updates server build information on panel and on node. * @@ -223,6 +222,7 @@ class ServerController extends BaseController try { $server = new ServerRepository; $server->changeBuild($id, $request->all()); + return Models\Server::findOrFail($id); } catch (DisplayValidationException $ex) { throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); @@ -234,7 +234,7 @@ class ServerController extends BaseController } /** - * Suspend Server + * Suspend Server. * * @Post("/servers/{id}/suspend") * @Versions({"v1"}) @@ -248,6 +248,7 @@ class ServerController extends BaseController try { $server = new ServerRepository; $server->suspend($id); + return $this->response->noContent(); } catch (DisplayException $ex) { throw new ResourceException($ex->getMessage()); @@ -257,7 +258,7 @@ class ServerController extends BaseController } /** - * Unsuspend Server + * Unsuspend Server. * * @Post("/servers/{id}/unsuspend") * @Versions({"v1"}) @@ -271,6 +272,7 @@ class ServerController extends BaseController try { $server = new ServerRepository; $server->unsuspend($id); + return $this->response->noContent(); } catch (DisplayException $ex) { throw new ResourceException($ex->getMessage()); @@ -280,7 +282,7 @@ class ServerController extends BaseController } /** - * Delete Server + * Delete Server. * * @Delete("/servers/{id}/{force}") * @Versions({"v1"}) @@ -295,12 +297,12 @@ class ServerController extends BaseController try { $server = new ServerRepository; $server->deleteServer($id, $force); + return $this->response->noContent(); } catch (DisplayException $ex) { throw new ResourceException($ex->getMessage()); - } catch(\Exception $e) { + } catch (\Exception $e) { throw new ServiceUnavailableHttpException('An error occured while attempting to delete this server.'); } } - } diff --git a/app/Http/Controllers/API/ServiceController.php b/app/Http/Controllers/API/ServiceController.php index 5a60990e6..06df710d1 100755 --- a/app/Http/Controllers/API/ServiceController.php +++ b/app/Http/Controllers/API/ServiceController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,11 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API; -use Illuminate\Http\Request; - use Pterodactyl\Models; -use Pterodactyl\Transformers\ServiceTransformer; - +use Illuminate\Http\Request; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; /** @@ -35,7 +33,6 @@ use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; */ class ServiceController extends BaseController { - public function __construct() { // @@ -49,20 +46,18 @@ class ServiceController extends BaseController public function view(Request $request, $id) { $service = Models\Service::find($id); - if (!$service) { + if (! $service) { throw new NotFoundHttpException('No service by that ID was found.'); } $options = Models\ServiceOptions::select('id', 'name', 'description', 'tag', 'docker_image')->where('parent_service', $service->id)->get(); - foreach($options as &$opt) { + foreach ($options as &$opt) { $opt->variables = Models\ServiceVariables::where('option_id', $opt->id)->get(); } return [ 'service' => $service, - 'options' => $options + 'options' => $options, ]; - } - } diff --git a/app/Http/Controllers/API/User/InfoController.php b/app/Http/Controllers/API/User/InfoController.php index 2e2e3a03b..c71498a7a 100644 --- a/app/Http/Controllers/API/User/InfoController.php +++ b/app/Http/Controllers/API/User/InfoController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,11 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API\User; -use Auth; -use Dingo; use Pterodactyl\Models; use Illuminate\Http\Request; - use Pterodactyl\Http\Controllers\API\BaseController; class InfoController extends BaseController @@ -37,7 +35,7 @@ class InfoController extends BaseController $servers = Models\Server::getUserServers(); $response = []; - foreach($servers as &$server) { + foreach ($servers as &$server) { $response = array_merge($response, [[ 'id' => $server->uuidShort, 'uuid' => $server->uuid, @@ -45,11 +43,11 @@ class InfoController extends BaseController 'node' => $server->nodeName, 'ip' => [ 'set' => $server->ip, - 'alias' => $server->ip_alias + 'alias' => $server->ip_alias, ], 'port' => $server->port, 'service' => $server->a_serviceName, - 'option' => $server->a_serviceOptionName + 'option' => $server->a_serviceOptionName, ]]); } diff --git a/app/Http/Controllers/API/User/ServerController.php b/app/Http/Controllers/API/User/ServerController.php index 613f90582..7399bf8b8 100644 --- a/app/Http/Controllers/API/User/ServerController.php +++ b/app/Http/Controllers/API/User/ServerController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API\User; -use Auth; use Log; +use Auth; use Pterodactyl\Models; use Illuminate\Http\Request; - use Pterodactyl\Http\Controllers\API\BaseController; class ServerController extends BaseController { - public function info(Request $request, $uuid) { $server = Models\Server::getByUUID($uuid); @@ -43,28 +42,29 @@ class ServerController extends BaseController $response = $client->request('GET', '/server', [ 'headers' => [ 'X-Access-Token' => $server->daemonSecret, - 'X-Access-Server' => $server->uuid - ] + 'X-Access-Server' => $server->uuid, + ], ]); $json = json_decode($response->getBody()); $daemon = [ 'status' => $json->status, 'stats' => $json->proc, - 'query' => $json->query + 'query' => $json->query, ]; } catch (\Exception $ex) { $daemon = [ - 'error' => 'An error was encountered while trying to connect to the daemon to collece information. It might be offline.' + 'error' => 'An error was encountered while trying to connect to the daemon to collece information. It might be offline.', ]; Log::error($ex); } $allocations = Models\Allocation::select('id', 'ip', 'port', 'ip_alias as alias')->where('assigned_to', $server->id)->get(); - foreach($allocations as &$allocation) { + foreach ($allocations as &$allocation) { $allocation->default = ($allocation->id === $server->allocation); unset($allocation->id); } + return [ 'uuidShort' => $server->uuidShort, 'uuid' => $server->uuid, @@ -76,16 +76,16 @@ class ServerController extends BaseController 'disk' => $server->disk, 'io' => $server->io, 'cpu' => $server->cpu, - 'oom_disabled' => (bool) $server->oom_disabled + 'oom_disabled' => (bool) $server->oom_disabled, ], 'allocations' => $allocations, 'sftp' => [ - 'username' => (Auth::user()->can('view-sftp', $server)) ? $server->username : null + 'username' => (Auth::user()->can('view-sftp', $server)) ? $server->username : null, ], 'daemon' => [ 'token' => ($request->secure()) ? $server->daemonSecret : false, - 'response' => $daemon - ] + 'response' => $daemon, + ], ]; } @@ -100,12 +100,12 @@ class ServerController extends BaseController $res = $client->request('PUT', '/server/power', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $server->daemonSecret + 'X-Access-Token' => $server->daemonSecret, ], 'exceptions' => false, 'json' => [ - 'action' => $request->input('action') - ] + 'action' => $request->input('action'), + ], ]); if ($res->getStatusCode() !== 204) { diff --git a/app/Http/Controllers/API/UserController.php b/app/Http/Controllers/API/UserController.php index 564f69215..3b657bf02 100755 --- a/app/Http/Controllers/API/UserController.php +++ b/app/Http/Controllers/API/UserController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\API; -use Illuminate\Http\Request; - -use Dingo\Api\Exception\ResourceException; - use Pterodactyl\Models; -use Pterodactyl\Transformers\UserTransformer; -use Pterodactyl\Repositories\UserRepository; - -use Pterodactyl\Exceptions\DisplayValidationException; +use Illuminate\Http\Request; +use Dingo\Api\Exception\ResourceException; use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Repositories\UserRepository; +use Pterodactyl\Exceptions\DisplayValidationException; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; @@ -42,14 +39,12 @@ use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; */ class UserController extends BaseController { - public function __construct() { - } /** - * List All Users + * List All Users. * * Lists all users currently on the system. * @@ -66,7 +61,7 @@ class UserController extends BaseController } /** - * List Specific User + * List Specific User. * * Lists specific fields about a user or all fields pertaining to that user. * @@ -82,22 +77,22 @@ class UserController extends BaseController { $query = Models\User::where('id', $id); - if (!is_null($request->input('fields'))) { - foreach(explode(',', $request->input('fields')) as $field) { - if (!empty($field)) { + if (! is_null($request->input('fields'))) { + foreach (explode(',', $request->input('fields')) as $field) { + if (! empty($field)) { $query->addSelect($field); } } } try { - if (!$query->first()) { + if (! $query->first()) { throw new NotFoundHttpException('No user by that ID was found.'); } $user = $query->first(); $userArray = $user->toArray(); - $userArray['servers'] = Models\Server::select('id', 'uuid', 'node', 'suspended')->where('owner', $user->id)->get(); + $userArray['servers'] = Models\Server::select('id', 'uuid', 'node', 'suspended')->where('owner', $user->id)->get(); return $userArray; } catch (NotFoundHttpException $ex) { @@ -105,11 +100,10 @@ class UserController extends BaseController } catch (\Exception $ex) { throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); } - } /** - * Create a New User + * Create a New User. * * @Post("/users") * @Versions({"v1"}) @@ -129,7 +123,8 @@ class UserController extends BaseController try { $user = new UserRepository; $create = $user->create($request->input('email'), $request->input('password'), $request->input('admin'), $request->input('custom_id')); - return [ 'id' => $create ]; + + return ['id' => $create]; } catch (DisplayValidationException $ex) { throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); } catch (DisplayException $ex) { @@ -140,7 +135,7 @@ class UserController extends BaseController } /** - * Update an Existing User + * Update an Existing User. * * The data sent in the request will be used to update the existing user on the system. * @@ -162,6 +157,7 @@ class UserController extends BaseController try { $user = new UserRepository; $user->update($id, $request->all()); + return Models\User::findOrFail($id); } catch (DisplayValidationException $ex) { throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); @@ -173,7 +169,7 @@ class UserController extends BaseController } /** - * Delete a User + * Delete a User. * * @Delete("/users/{id}") * @Versions({"v1"}) @@ -191,6 +187,7 @@ class UserController extends BaseController try { $user = new UserRepository; $user->delete($id); + return $this->response->noContent(); } catch (DisplayException $ex) { throw new ResourceException($ex->getMessage()); @@ -198,5 +195,4 @@ class UserController extends BaseController throw new ServiceUnavailableHttpException('Unable to delete this user due to an error.'); } } - } diff --git a/app/Http/Controllers/Admin/BaseController.php b/app/Http/Controllers/Admin/BaseController.php index f44ac06f4..9eb273013 100644 --- a/app/Http/Controllers/Admin/BaseController.php +++ b/app/Http/Controllers/Admin/BaseController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,20 +21,19 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; use Alert; use Settings; use Validator; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; +use Pterodactyl\Http\Controllers\Controller; class BaseController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -57,7 +56,7 @@ class BaseController extends Controller 'company' => 'required|between:1,256', 'default_language' => 'required|alpha_dash|min:2|max:5', 'email_from' => 'required|email', - 'email_sender_name' => 'required|between:1,256' + 'email_sender_name' => 'required|between:1,256', ]); if ($validator->fails()) { @@ -70,8 +69,7 @@ class BaseController extends Controller Settings::set('email_sender_name', $request->input('email_sender_name')); Alert::success('Settings have been successfully updated.')->flash(); + return redirect()->route('admin.settings'); - } - } diff --git a/app/Http/Controllers/Admin/DatabaseController.php b/app/Http/Controllers/Admin/DatabaseController.php index e30278f81..33b4ff263 100644 --- a/app/Http/Controllers/Admin/DatabaseController.php +++ b/app/Http/Controllers/Admin/DatabaseController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,25 +21,23 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; -use Alert; use DB; use Log; - +use Alert; use Pterodactyl\Models; -use Pterodactyl\Repositories\DatabaseRepository; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\DatabaseRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class DatabaseController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -63,7 +61,7 @@ class DatabaseController extends Controller 'nodes.name as a_linkedNode', DB::raw('(SELECT COUNT(*) FROM `databases` WHERE `databases`.`db_server` = database_servers.id) as c_databases') )->leftJoin('nodes', 'nodes.id', '=', 'database_servers.linked_node') - ->paginate(20) + ->paginate(20), ]); } @@ -72,7 +70,7 @@ class DatabaseController extends Controller return view('admin.databases.new', [ 'nodes' => Models\Node::select('nodes.id', 'nodes.name', 'locations.long as a_location') ->join('locations', 'locations.id', '=', 'nodes.location') - ->get() + ->get(), ]); } @@ -81,12 +79,13 @@ class DatabaseController extends Controller try { $repo = new DatabaseRepository; $repo->add($request->except([ - '_token' + '_token', ])); Alert::success('Successfully added a new database server to the system.')->flash(); + return redirect()->route('admin.databases', [ - 'tab' => 'tab_dbservers' + 'tab' => 'tab_dbservers', ]); } catch (DisplayValidationException $ex) { return redirect()->route('admin.databases.new')->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -97,6 +96,7 @@ class DatabaseController extends Controller Log::error($ex); Alert::danger('An error occurred while attempting to delete this database server from the system.')->flash(); } + return redirect()->route('admin.databases.new')->withInput(); } } @@ -108,8 +108,9 @@ class DatabaseController extends Controller $repo->drop($id); } catch (\Exception $ex) { Log::error($ex); + return response()->json([ - 'error' => ($ex instanceof DisplayException) ? $ex->getMessage() : 'An error occurred while attempting to delete this database from the system.' + 'error' => ($ex instanceof DisplayException) ? $ex->getMessage() : 'An error occurred while attempting to delete this database from the system.', ], 500); } } @@ -121,10 +122,10 @@ class DatabaseController extends Controller $repo->delete($id); } catch (\Exception $ex) { Log::error($ex); + return response()->json([ - 'error' => ($ex instanceof DisplayException) ? $ex->getMessage() : 'An error occurred while attempting to delete this database server from the system.' + 'error' => ($ex instanceof DisplayException) ? $ex->getMessage() : 'An error occurred while attempting to delete this database server from the system.', ], 500); } } - } diff --git a/app/Http/Controllers/Admin/LocationsController.php b/app/Http/Controllers/Admin/LocationsController.php index 86f32c8e6..46544ebb6 100644 --- a/app/Http/Controllers/Admin/LocationsController.php +++ b/app/Http/Controllers/Admin/LocationsController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,23 +21,20 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; use DB; use Alert; - use Pterodactyl\Models; -use Pterodactyl\Repositories\LocationRepository; -use Pterodactyl\Http\Controllers\Controller; - -use Pterodactyl\Exceptions\DisplayValidationException; -use Pterodactyl\Exceptions\DisplayException; - use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\LocationRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class LocationsController extends Controller { - public function __construct() { // @@ -50,7 +47,7 @@ class LocationsController extends Controller 'locations.*', DB::raw('(SELECT COUNT(*) FROM nodes WHERE nodes.location = locations.id) as a_nodeCount'), DB::raw('(SELECT COUNT(*) FROM servers WHERE servers.node IN (SELECT nodes.id FROM nodes WHERE nodes.location = locations.id)) as a_serverCount') - )->paginate(20) + )->paginate(20), ]); } @@ -62,19 +59,20 @@ class LocationsController extends Controller DB::raw('(SELECT COUNT(*) FROM servers WHERE servers.node IN (SELECT nodes.id FROM nodes WHERE nodes.location = locations.id)) as a_serverCount') )->where('id', $id)->first(); - if (!$model) { + if (! $model) { return response()->json([ - 'error' => 'No location with that ID exists on the system.' + 'error' => 'No location with that ID exists on the system.', ], 404); } if ($model->a_nodeCount > 0 || $model->a_serverCount > 0) { return response()->json([ - 'error' => 'You cannot remove a location that is currently assigned to a node or server.' + 'error' => 'You cannot remove a location that is currently assigned to a node or server.', ], 422); } $model->delete(); + return response('', 204); } @@ -83,10 +81,11 @@ class LocationsController extends Controller try { $location = new LocationRepository; $location->edit($id, $request->all()); + return response('', 204); } catch (DisplayValidationException $ex) { return response()->json([ - 'error' => 'There was a validation error while processing this request. Location descriptions must be between 1 and 255 characters, and the location code must be between 1 and 10 characters with no spaces or special characters.' + 'error' => 'There was a validation error while processing this request. Location descriptions must be between 1 and 255 characters, and the location code must be between 1 and 10 characters with no spaces or special characters.', ], 422); } catch (\Exception $ex) { // This gets caught and processed into JSON anyways. @@ -99,9 +98,10 @@ class LocationsController extends Controller try { $location = new LocationRepository; $id = $location->create($request->except([ - '_token' + '_token', ])); Alert::success('New location successfully added.')->flash(); + return redirect()->route('admin.locations'); } catch (DisplayValidationException $ex) { return redirect()->route('admin.locations')->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -111,7 +111,7 @@ class LocationsController extends Controller Log::error($ex); Alert::danger('An unhandled exception occured while attempting to add this location. Please try again.')->flash(); } + return redirect()->route('admin.locations')->withInput(); } - } diff --git a/app/Http/Controllers/Admin/NodesController.php b/app/Http/Controllers/Admin/NodesController.php index ef77da4e0..e2b617b63 100644 --- a/app/Http/Controllers/Admin/NodesController.php +++ b/app/Http/Controllers/Admin/NodesController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,27 +21,24 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; -use Alert; -use Debugbar; -use Log; use DB; +use Log; +use Alert; use Validator; - use Pterodactyl\Models; -use Pterodactyl\Repositories\NodeRepository; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\NodeRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class NodesController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -50,7 +47,7 @@ class NodesController extends Controller public function getScript(Request $request, $id) { - return response()->view('admin.nodes.remote.deploy', [ 'node' => Models\Node::findOrFail($id) ])->header('Content-Type', 'text/plain'); + return response()->view('admin.nodes.remote.deploy', ['node' => Models\Node::findOrFail($id)])->header('Content-Type', 'text/plain'); } public function getIndex(Request $request) @@ -66,13 +63,14 @@ class NodesController extends Controller public function getNew(Request $request) { - if (!Models\Location::all()->count()) { + if (! Models\Location::all()->count()) { Alert::warning('You must add a location before you can add a new node.')->flash(); + return redirect()->route('admin.locations'); } return view('admin.nodes.new', [ - 'locations' => Models\Location::all() + 'locations' => Models\Location::all(), ]); } @@ -81,12 +79,13 @@ class NodesController extends Controller try { $node = new NodeRepository; $new = $node->create($request->except([ - '_token' + '_token', ])); Alert::success('Successfully created new node. Before you can add any servers you need to first assign some IP addresses and ports.')->flash(); + return redirect()->route('admin.nodes.view', [ 'id' => $new, - 'tab' => 'tab_allocation' + 'tab' => 'tab_allocation', ]); } catch (DisplayValidationException $e) { return redirect()->route('admin.nodes.new')->withErrors(json_decode($e->getMessage()))->withInput(); @@ -96,6 +95,7 @@ class NodesController extends Controller Log::error($e); Alert::danger('An unhandled exception occured while attempting to add this node. Please try again.')->flash(); } + return redirect()->route('admin.nodes.new')->withInput(); } @@ -129,12 +129,13 @@ class NodesController extends Controller try { $node = new NodeRepository; $node->update($id, $request->except([ - '_token' + '_token', ])); Alert::success('Successfully update this node\'s information. If you changed any daemon settings you will need to restart it now.')->flash(); + return redirect()->route('admin.nodes.view', [ 'id' => $id, - 'tab' => 'tab_settings' + 'tab' => 'tab_settings', ]); } catch (DisplayValidationException $e) { return redirect()->route('admin.nodes.view', $id)->withErrors(json_decode($e->getMessage()))->withInput(); @@ -144,9 +145,10 @@ class NodesController extends Controller Log::error($e); Alert::danger('An unhandled exception occured while attempting to edit this node. Please try again.')->flash(); } + return redirect()->route('admin.nodes.view', [ 'id' => $id, - 'tab' => 'tab_settings' + 'tab' => 'tab_settings', ])->withInput(); } @@ -155,9 +157,10 @@ class NodesController extends Controller $query = Models\Allocation::where('node', $node)->whereNull('assigned_to')->where('id', $allocation)->delete(); if ((int) $query === 0) { return response()->json([ - 'error' => 'Unable to find an allocation matching those details to delete.' + 'error' => 'Unable to find an allocation matching those details to delete.', ], 400); } + return response('', 204); } @@ -166,21 +169,23 @@ class NodesController extends Controller $query = Models\Allocation::where('node', $node)->whereNull('assigned_to')->where('ip', $request->input('ip'))->delete(); if ((int) $query === 0) { Alert::danger('There was an error while attempting to delete allocations on that IP.')->flash(); + return redirect()->route('admin.nodes.view', [ 'id' => $node, - 'tab' => 'tab_allocations' + 'tab' => 'tab_allocations', ]); } Alert::success('Deleted all unallocated ports for ' . $request->input('ip') . '.')->flash(); + return redirect()->route('admin.nodes.view', [ 'id' => $node, - 'tab' => 'tab_allocation' + 'tab' => 'tab_allocation', ]); } public function setAlias(Request $request, $node) { - if (!$request->input('allocation')) { + if (! $request->input('allocation')) { return response('Missing required parameters.', 422); } @@ -198,36 +203,36 @@ class NodesController extends Controller public function getAllocationsJson(Request $request, $id) { $allocations = Models\Allocation::select('ip')->where('node', $id)->groupBy('ip')->get(); + return response()->json($allocations); } public function postAllocations(Request $request, $id) { - $validator = Validator::make($request->all(), [ 'allocate_ip.*' => 'required|string', - 'allocate_port.*' => 'required' + 'allocate_port.*' => 'required', ]); if ($validator->fails()) { return redirect()->route('admin.nodes.view', [ 'id' => $id, - 'tab' => 'tab_allocation' + 'tab' => 'tab_allocation', ])->withErrors($validator->errors())->withInput(); } $processedData = []; - foreach($request->input('allocate_ip') as $ip) { - if (!array_key_exists($ip, $processedData)) { + foreach ($request->input('allocate_ip') as $ip) { + if (! array_key_exists($ip, $processedData)) { $processedData[$ip] = []; } } - foreach($request->input('allocate_port') as $portid => $ports) { + foreach ($request->input('allocate_port') as $portid => $ports) { if (array_key_exists($portid, $request->input('allocate_ip'))) { $json = json_decode($ports); - if (json_last_error() === 0 && !empty($json)) { - foreach($json as &$parsed) { + if (json_last_error() === 0 && ! empty($json)) { + foreach ($json as &$parsed) { array_push($processedData[$request->input('allocate_ip')[$portid]], $parsed->value); } } @@ -246,7 +251,7 @@ class NodesController extends Controller } finally { return redirect()->route('admin.nodes.view', [ 'id' => $id, - 'tab' => 'tab_allocation' + 'tab' => 'tab_allocation', ]); } } @@ -257,6 +262,7 @@ class NodesController extends Controller $repo = new NodeRepository; $repo->delete($id); Alert::success('Successfully deleted the requested node from the panel.')->flash(); + return redirect()->route('admin.nodes'); } catch (DisplayException $e) { Alert::danger($e->getMessage())->flash(); @@ -267,8 +273,7 @@ class NodesController extends Controller return redirect()->route('admin.nodes.view', [ 'id' => $id, - 'tab' => 'tab_delete' + 'tab' => 'tab_delete', ]); } - } diff --git a/app/Http/Controllers/Admin/ServersController.php b/app/Http/Controllers/Admin/ServersController.php index be598f241..dd007881c 100644 --- a/app/Http/Controllers/Admin/ServersController.php +++ b/app/Http/Controllers/Admin/ServersController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,28 +21,24 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; -use Alert; -use Debugbar; use DB; use Log; - +use Alert; use Pterodactyl\Models; +use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; use Pterodactyl\Repositories\ServerRepository; use Pterodactyl\Repositories\DatabaseRepository; - -use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Exceptions\DisplayValidationException; -use Pterodactyl\Http\Controllers\Controller; -use Illuminate\Http\Request; - class ServersController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -62,17 +58,17 @@ class ServersController extends Controller ->join('users', 'servers.owner', '=', 'users.id') ->join('allocations', 'servers.allocation', '=', 'allocations.id'); - if ($request->input('filter') && !is_null($request->input('filter'))) { + if ($request->input('filter') && ! is_null($request->input('filter'))) { preg_match_all('/[^\s"\']+|"([^"]*)"|\'([^\']*)\'/', urldecode($request->input('filter')), $matches); - foreach($matches[0] as $match) { + foreach ($matches[0] as $match) { $match = str_replace('"', '', $match); if (strpos($match, ':')) { list($field, $term) = explode(':', $match); if ($field === 'node') { $field = 'nodes.name'; - } else if ($field === 'owner') { + } elseif ($field === 'owner') { $field = 'users.email'; - } else if (!strpos($field, '.')) { + } elseif (! strpos($field, '.')) { $field = 'servers.' . $field; } @@ -107,7 +103,7 @@ class ServersController extends Controller } return view('admin.servers.index', [ - 'servers' => $servers + 'servers' => $servers, ]); } @@ -115,7 +111,7 @@ class ServersController extends Controller { return view('admin.servers.new', [ 'locations' => Models\Location::all(), - 'services' => Models\Service::all() + 'services' => Models\Service::all(), ]); } @@ -139,7 +135,7 @@ class ServersController extends Controller ->where('servers.id', $id) ->first(); - if (!$server) { + if (! $server) { return abort(404); } @@ -162,28 +158,29 @@ class ServersController extends Controller ->where('server_id', $server->id) ->join('database_servers', 'database_servers.id', '=', 'databases.db_server') ->get(), - 'db_servers' => Models\DatabaseServer::all() + 'db_servers' => Models\DatabaseServer::all(), ]); } public function postNewServer(Request $request) { - try { $server = new ServerRepository; $response = $server->create($request->all()); - return redirect()->route('admin.servers.view', [ 'id' => $response ]); + + return redirect()->route('admin.servers.view', ['id' => $response]); } catch (DisplayValidationException $ex) { return redirect()->route('admin.servers.new')->withErrors(json_decode($ex->getMessage()))->withInput(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); + return redirect()->route('admin.servers.new')->withInput(); } catch (\Exception $ex) { Log::error($ex); Alert::danger('An unhandled exception occured while attemping to add this server. Please try again.')->flash(); + return redirect()->route('admin.servers.new')->withInput(); } - } /** @@ -194,15 +191,13 @@ class ServersController extends Controller */ public function postNewServerGetNodes(Request $request) { - - if(!$request->input('location')) { + if (! $request->input('location')) { return response()->json([ - 'error' => 'Missing location in request.' + 'error' => 'Missing location in request.', ], 500); } return response()->json(Models\Node::select('id', 'name', 'public')->where('location', $request->input('location'))->get()); - } /** @@ -213,25 +208,24 @@ class ServersController extends Controller */ public function postNewServerGetIps(Request $request) { - - if(!$request->input('node')) { + if (! $request->input('node')) { return response()->json([ - 'error' => 'Missing node in request.' + 'error' => 'Missing node in request.', ], 500); } $ips = Models\Allocation::where('node', $request->input('node'))->whereNull('assigned_to')->get(); $listing = []; - foreach($ips as &$ip) { + foreach ($ips as &$ip) { if (array_key_exists($ip->ip, $listing)) { $listing[$ip->ip] = array_merge($listing[$ip->ip], [$ip->port]); } else { $listing[$ip->ip] = [$ip->port]; } } - return response()->json($listing); + return response()->json($listing); } /** @@ -242,16 +236,15 @@ class ServersController extends Controller */ public function postNewServerServiceOptions(Request $request) { - - if(!$request->input('service')) { + if (! $request->input('service')) { return response()->json([ - 'error' => 'Missing service in request.' + 'error' => 'Missing service in request.', ], 500); } $service = Models\Service::select('executable', 'startup')->where('id', $request->input('service'))->first(); - return response()->json(Models\ServiceOptions::select('id', 'name', 'docker_image')->where('parent_service', $request->input('service'))->orderBy('name', 'asc')->get()); + return response()->json(Models\ServiceOptions::select('id', 'name', 'docker_image')->where('parent_service', $request->input('service'))->orderBy('name', 'asc')->get()); } /** @@ -262,10 +255,9 @@ class ServersController extends Controller */ public function postNewServerServiceVariables(Request $request) { - - if(!$request->input('option')) { + if (! $request->input('option')) { return response()->json([ - 'error' => 'Missing option in request.' + 'error' => 'Missing option in request.', ], 500); } @@ -279,28 +271,25 @@ class ServersController extends Controller return response()->json([ 'variables' => Models\ServiceVariables::where('option_id', $request->input('option'))->get(), 'exec' => $option->executable, - 'startup' => $option->startup + 'startup' => $option->startup, ]); - } public function postUpdateServerDetails(Request $request, $id) { - try { - $server = new ServerRepository; $server->updateDetails($id, [ 'owner' => $request->input('owner'), 'name' => $request->input('name'), - 'reset_token' => ($request->input('reset_token', false) === 'on') ? true : false + 'reset_token' => ($request->input('reset_token', false) === 'on') ? true : false, ]); Alert::success('Server details were successfully updated.')->flash(); } catch (DisplayValidationException $ex) { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_details' + 'tab' => 'tab_details', ])->withErrors(json_decode($ex->getMessage()))->withInput(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); @@ -311,21 +300,22 @@ class ServersController extends Controller return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_details' + 'tab' => 'tab_details', ])->withInput(); } - public function postUpdateContainerDetails(Request $request, $id) { + public function postUpdateContainerDetails(Request $request, $id) + { try { $server = new ServerRepository; $server->updateContainer($id, [ - 'image' => $request->input('docker_image') + 'image' => $request->input('docker_image'), ]); Alert::success('Successfully updated this server\'s docker image.')->flash(); } catch (DisplayValidationException $ex) { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_details' + 'tab' => 'tab_details', ])->withErrors(json_decode($ex->getMessage()))->withInput(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); @@ -336,11 +326,12 @@ class ServersController extends Controller return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_details' + 'tab' => 'tab_details', ]); } - public function postUpdateServerToggleBuild(Request $request, $id) { + public function postUpdateServerToggleBuild(Request $request, $id) + { $server = Models\Server::findOrFail($id); $node = Models\Node::findOrFail($server->node); $client = Models\Node::guzzleRequest($server->node); @@ -349,8 +340,8 @@ class ServersController extends Controller $res = $client->request('POST', '/server/rebuild', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret - ] + 'X-Access-Token' => $node->daemonSecret, + ], ]); Alert::success('A rebuild has been queued successfully. It will run the next time this server is booted.')->flash(); } catch (\GuzzleHttp\Exception\TransferException $ex) { @@ -360,14 +351,13 @@ class ServersController extends Controller return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_manage' + 'tab' => 'tab_manage', ]); } public function postUpdateServerUpdateBuild(Request $request, $id) { try { - $server = new ServerRepository; $server->changeBuild($id, [ 'default' => $request->input('default'), @@ -382,13 +372,14 @@ class ServersController extends Controller } catch (DisplayValidationException $ex) { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_build' + 'tab' => 'tab_build', ])->withErrors(json_decode($ex->getMessage()))->withInput(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); + return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_build' + 'tab' => 'tab_build', ]); } catch (\Exception $ex) { Log::error($ex); @@ -397,7 +388,7 @@ class ServersController extends Controller return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_build' + 'tab' => 'tab_build', ]); } @@ -407,16 +398,18 @@ class ServersController extends Controller $server = new ServerRepository; $server->deleteServer($id, $force); Alert::success('Server has been marked for deletion on the system.')->flash(); + return redirect()->route('admin.servers'); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); - } catch(\Exception $ex) { + } catch (\Exception $ex) { Log::error($ex); Alert::danger('An unhandled exception occured while attemping to delete this server. Please try again.')->flash(); } + return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_delete' + 'tab' => 'tab_delete', ]); } @@ -428,13 +421,13 @@ class ServersController extends Controller Alert::success('Server status was successfully toggled.')->flash(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); - } catch(\Exception $ex) { + } catch (\Exception $ex) { Log::error($ex); Alert::danger('An unhandled exception occured while attemping to toggle this servers status.')->flash(); } finally { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_manage' + 'tab' => 'tab_manage', ]); } } @@ -444,18 +437,18 @@ class ServersController extends Controller try { $server = new ServerRepository; $server->updateStartup($id, $request->except([ - '_token' + '_token', ]), true); Alert::success('Server startup variables were successfully updated.')->flash(); } catch (\Pterodactyl\Exceptions\DisplayException $e) { Alert::danger($e->getMessage())->flash(); - } catch(\Exception $e) { + } catch (\Exception $e) { Log::error($e); Alert::danger('An unhandled exception occured while attemping to update startup variables for this server. Please try again.')->flash(); } finally { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_startup' + 'tab' => 'tab_startup', ])->withInput(); } } @@ -465,13 +458,13 @@ class ServersController extends Controller try { $repo = new DatabaseRepository; $repo->create($id, $request->except([ - '_token' + '_token', ])); Alert::success('Added new database to this server.')->flash(); } catch (DisplayValidationException $ex) { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_database' + 'tab' => 'tab_database', ])->withInput()->withErrors(json_decode($ex->getMessage()))->withInput(); } catch (\Exception $ex) { Log::error($ex); @@ -480,7 +473,7 @@ class ServersController extends Controller return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_database' + 'tab' => 'tab_database', ])->withInput(); } @@ -492,13 +485,13 @@ class ServersController extends Controller Alert::success('Server has been suspended on the system. All running processes have been stopped and will not be startable until it is un-suspended.'); } catch (DisplayException $e) { Alert::danger($e->getMessage())->flash(); - } catch(\Exception $e) { + } catch (\Exception $e) { Log::error($e); Alert::danger('An unhandled exception occured while attemping to suspend this server. Please try again.')->flash(); } finally { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_manage' + 'tab' => 'tab_manage', ]); } } @@ -511,13 +504,13 @@ class ServersController extends Controller Alert::success('Server has been unsuspended on the system. Access has been re-enabled.'); } catch (DisplayException $e) { Alert::danger($e->getMessage())->flash(); - } catch(\Exception $e) { + } catch (\Exception $e) { Log::error($e); Alert::danger('An unhandled exception occured while attemping to unsuspend this server. Please try again.')->flash(); } finally { return redirect()->route('admin.servers.view', [ 'id' => $id, - 'tab' => 'tab_manage' + 'tab' => 'tab_manage', ]); } } @@ -526,27 +519,31 @@ class ServersController extends Controller { try { $repo = new ServerRepository; - if (!is_null($request->input('cancel'))) { + if (! is_null($request->input('cancel'))) { $repo->cancelDeletion($id); Alert::success('Server deletion has been cancelled. This server will remain suspended until you unsuspend it.')->flash(); + return redirect()->route('admin.servers.view', $id); - } else if(!is_null($request->input('delete'))) { + } elseif (! is_null($request->input('delete'))) { $repo->deleteNow($id); Alert::success('Server was successfully deleted from the system.')->flash(); + return redirect()->route('admin.servers'); - } else if(!is_null($request->input('force_delete'))) { + } elseif (! is_null($request->input('force_delete'))) { $repo->deleteNow($id, true); Alert::success('Server was successfully force deleted from the system.')->flash(); + return redirect()->route('admin.servers'); } } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); + return redirect()->route('admin.servers.view', $id); } catch (\Exception $ex) { Log::error($ex); Alert::danger('An unhandled error occured while attempting to perform this action.')->flash(); + return redirect()->route('admin.servers.view', $id); } } - } diff --git a/app/Http/Controllers/Admin/ServiceController.php b/app/Http/Controllers/Admin/ServiceController.php index dc5977470..848b41962 100644 --- a/app/Http/Controllers/Admin/ServiceController.php +++ b/app/Http/Controllers/Admin/ServiceController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,24 +21,21 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; -use Alert; use DB; use Log; -use Validator; - +use Alert; use Pterodactyl\Models; -use Pterodactyl\Repositories\ServiceRepository; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\ServiceRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class ServiceController extends Controller { - public function __construct() { // @@ -50,7 +47,7 @@ class ServiceController extends Controller 'services' => Models\Service::select( 'services.*', DB::raw('(SELECT COUNT(*) FROM servers WHERE servers.service = services.id) as c_servers') - )->get() + )->get(), ]); } @@ -64,9 +61,10 @@ class ServiceController extends Controller try { $repo = new ServiceRepository\Service; $id = $repo->create($request->except([ - '_token' + '_token', ])); Alert::success('Successfully created new service!')->flash(); + return redirect()->route('admin.services.service', $id); } catch (DisplayValidationException $ex) { return redirect()->route('admin.services.new')->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -76,6 +74,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occured while attempting to add a new service.')->flash(); } + return redirect()->route('admin.services.new')->withInput(); } @@ -86,7 +85,7 @@ class ServiceController extends Controller 'options' => Models\ServiceOptions::select( 'service_options.*', DB::raw('(SELECT COUNT(*) FROM servers WHERE servers.option = service_options.id) as c_servers') - )->where('parent_service', $service)->get() + )->where('parent_service', $service)->get(), ]); } @@ -95,7 +94,7 @@ class ServiceController extends Controller try { $repo = new ServiceRepository\Service; $repo->update($service, $request->except([ - '_token' + '_token', ])); Alert::success('Successfully updated this service.')->flash(); } catch (DisplayValidationException $ex) { @@ -106,6 +105,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occurred while attempting to update this service.')->flash(); } + return redirect()->route('admin.services.service', $service)->withInput(); } @@ -115,6 +115,7 @@ class ServiceController extends Controller $repo = new ServiceRepository\Service; $repo->delete($service); Alert::success('Successfully deleted that service.')->flash(); + return redirect()->route('admin.services'); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); @@ -122,12 +123,14 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error was encountered while attempting to delete that service.')->flash(); } + return redirect()->route('admin.services.service', $service); } public function getOption(Request $request, $service, $option) { $opt = Models\ServiceOptions::findOrFail($option); + return view('admin.services.options.view', [ 'service' => Models\Service::findOrFail($opt->parent_service), 'option' => $opt, @@ -135,7 +138,7 @@ class ServiceController extends Controller 'servers' => Models\Server::select('servers.*', 'users.email as a_ownerEmail') ->join('users', 'users.id', '=', 'servers.owner') ->where('option', $option) - ->paginate(10) + ->paginate(10), ]); } @@ -144,7 +147,7 @@ class ServiceController extends Controller try { $repo = new ServiceRepository\Option; $repo->update($option, $request->except([ - '_token' + '_token', ])); Alert::success('Option settings successfully updated.')->flash(); } catch (DisplayValidationException $ex) { @@ -153,6 +156,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occured while attempting to modify this option.')->flash(); } + return redirect()->route('admin.services.option', [$service, $option])->withInput(); } @@ -164,6 +168,7 @@ class ServiceController extends Controller $repo->delete($option); Alert::success('Successfully deleted that option.')->flash(); + return redirect()->route('admin.services.service', $service->parent_service); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); @@ -171,6 +176,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error was encountered while attempting to delete this option.')->flash(); } + return redirect()->route('admin.services.option', [$service, $option]); } @@ -184,18 +190,19 @@ class ServiceController extends Controller $data = [ 'user_viewable' => '0', 'user_editable' => '0', - 'required' => '0' + 'required' => '0', ]; - foreach($request->except(['_token']) as $id => $val) { - $data[str_replace($variable.'_', '', $id)] = $val; + foreach ($request->except(['_token']) as $id => $val) { + $data[str_replace($variable . '_', '', $id)] = $val; } $repo->update($variable, $data); Alert::success('Successfully updated variable.')->flash(); } catch (DisplayValidationException $ex) { $data = []; - foreach(json_decode($ex->getMessage(), true) as $id => $val) { - $data[$variable.'_'.$id] = $val; + foreach (json_decode($ex->getMessage(), true) as $id => $val) { + $data[$variable . '_' . $id] = $val; } + return redirect()->route('admin.services.option', [$service, $option])->withErrors((object) $data)->withInput(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); @@ -203,6 +210,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occurred while attempting to update this service.')->flash(); } + return redirect()->route('admin.services.option', [$service, $option])->withInput(); } @@ -210,7 +218,7 @@ class ServiceController extends Controller { return view('admin.services.options.variable', [ 'service' => Models\Service::findOrFail($service), - 'option' => Models\ServiceOptions::where('parent_service', $service)->where('id', $option)->firstOrFail() + 'option' => Models\ServiceOptions::where('parent_service', $service)->where('id', $option)->firstOrFail(), ]); } @@ -219,9 +227,10 @@ class ServiceController extends Controller try { $repo = new ServiceRepository\Variable; $repo->create($option, $request->except([ - '_token' + '_token', ])); Alert::success('Successfully added new variable to this option.')->flash(); + return redirect()->route('admin.services.option', [$service, $option])->withInput(); } catch (DisplayValidationException $ex) { return redirect()->route('admin.services.option.variable.new', [$service, $option])->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -231,6 +240,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occurred while attempting to add this variable.')->flash(); } + return redirect()->route('admin.services.option.variable.new', [$service, $option])->withInput(); } @@ -246,9 +256,10 @@ class ServiceController extends Controller try { $repo = new ServiceRepository\Option; $id = $repo->create($service, $request->except([ - '_token' + '_token', ])); Alert::success('Successfully created new service option.')->flash(); + return redirect()->route('admin.services.option', [$service, $id]); } catch (DisplayValidationException $ex) { return redirect()->route('admin.services.option.new', $service)->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -256,6 +267,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occured while attempting to add this service option.')->flash(); } + return redirect()->route('admin.services.option.new', $service)->withInput(); } @@ -271,7 +283,7 @@ class ServiceController extends Controller Log::error($ex); Alert::danger('An error occured while attempting to delete that variable.')->flash(); } + return redirect()->route('admin.services.option', [$service, $option]); } - } diff --git a/app/Http/Controllers/Admin/UserController.php b/app/Http/Controllers/Admin/UserController.php index 8fc403ecd..36e2590ba 100644 --- a/app/Http/Controllers/Admin/UserController.php +++ b/app/Http/Controllers/Admin/UserController.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,27 +22,23 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Admin; -use Alert; -use Settings; -use Mail; use Log; -use Pterodactyl\Models\User; -use Pterodactyl\Repositories\UserRepository; -use Pterodactyl\Models\Server; - -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - -use Pterodactyl\Http\Controllers\Controller; +use Alert; use Illuminate\Http\Request; +use Pterodactyl\Models\User; +use Pterodactyl\Models\Server; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\UserRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class UserController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -52,9 +48,9 @@ class UserController extends Controller public function getIndex(Request $request) { $query = User::select('users.*'); - if ($request->input('filter') && !is_null($request->input('filter'))) { + if ($request->input('filter') && ! is_null($request->input('filter'))) { preg_match_all('/[^\s"\']+|"([^"]*)"|\'([^\']*)\'/', urldecode($request->input('filter')), $matches); - foreach($matches[0] as $match) { + foreach ($matches[0] as $match) { $match = str_replace('"', '', $match); if (strpos($match, ':')) { list($field, $term) = explode(':', $match); @@ -63,7 +59,7 @@ class UserController extends Controller $query->where('email', 'LIKE', '%' . $match . '%'); $query->orWhere([ ['uuid', 'LIKE', '%' . $match . '%'], - ['root_admin', 'LIKE', '%' . $match . '%'] + ['root_admin', 'LIKE', '%' . $match . '%'], ]); } } @@ -77,7 +73,7 @@ class UserController extends Controller } return view('admin.users.index', [ - 'users' => $users + 'users' => $users, ]); } @@ -104,13 +100,15 @@ class UserController extends Controller $repo = new UserRepository; $repo->delete($id); Alert::success('Successfully deleted user from system.')->flash(); + return redirect()->route('admin.users'); - } catch(DisplayException $ex) { + } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); } catch (\Exception $ex) { Log::error($ex); Alert::danger('An exception was encountered while attempting to delete this user.')->flash(); } + return redirect()->route('admin.users.view', $id); } @@ -120,12 +118,14 @@ class UserController extends Controller $user = new UserRepository; $userid = $user->create($request->input('email'), $request->input('password')); Alert::success('Account has been successfully created.')->flash(); + return redirect()->route('admin.users.view', $userid); } catch (DisplayValidationException $ex) { return redirect()->route('admin.users.new')->withErrors(json_decode($ex->getMessage()))->withInput(); } catch (\Exception $ex) { Log::error($ex); Alert::danger('An error occured while attempting to add a new user.')->flash(); + return redirect()->route('admin.users.new'); } } @@ -152,15 +152,16 @@ class UserController extends Controller Log::error($e); Alert::danger('An error occured while attempting to update this user.')->flash(); } + return redirect()->route('admin.users.view', $user); } public function getJson(Request $request) { - foreach(User::select('email')->get() as $user) { + foreach (User::select('email')->get() as $user) { $resp[] = $user->email; } + return $resp; } - } diff --git a/app/Http/Controllers/Auth/LoginController.php b/app/Http/Controllers/Auth/LoginController.php index 2a6903144..d381fcdd4 100644 --- a/app/Http/Controllers/Auth/LoginController.php +++ b/app/Http/Controllers/Auth/LoginController.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,20 +22,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -namespace Pterodactyl\Http\Controllers\Auth; -use Pterodactyl\Models\User; +namespace Pterodactyl\Http\Controllers\Auth; use Auth; use Alert; -use Validator; - -use Pterodactyl\Http\Controllers\Controller; -use PragmaRX\Google2FA\Google2FA; use Illuminate\Http\Request; -use Illuminate\Foundation\Auth\ThrottlesLogins; -use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers; - +use Pterodactyl\Models\User; +use PragmaRX\Google2FA\Google2FA; +use Pterodactyl\Http\Controllers\Controller; use Illuminate\Foundation\Auth\AuthenticatesUsers; class LoginController extends Controller @@ -62,14 +57,14 @@ class LoginController extends Controller /** * Lockout time for failed login requests. * - * @var integer + * @var int */ protected $lockoutTime = 120; /** * After how many attempts should logins be throttled and locked. * - * @var integer + * @var int */ protected $maxLoginAttempts = 3; @@ -91,7 +86,6 @@ class LoginController extends Controller */ public function login(Request $request) { - $this->validate($request, [ 'email' => 'required|email', 'password' => 'required', @@ -99,42 +93,40 @@ class LoginController extends Controller if ($lockedOut = $this->hasTooManyLoginAttempts($request)) { $this->fireLockoutEvent($request); + return $this->sendLockoutResponse($request); } // Is the email & password valid? - if (!Auth::once([ + if (! Auth::once([ 'email' => $request->input('email'), - 'password' => $request->input('password') + 'password' => $request->input('password'), ], $request->has('remember'))) { - - if (!$lockedOut) { + if (! $lockedOut) { $this->incrementLoginAttempts($request); } return $this->sendFailedLoginResponse($request); - } // Verify TOTP Token was Valid - if(Auth::user()->use_totp === 1) { + if (Auth::user()->use_totp === 1) { $G2FA = new Google2FA(); - if(is_null($request->input('totp_token')) || !$G2FA->verifyKey(Auth::user()->totp_secret, $request->input('totp_token'))) { - - if (!$lockedOut) { + if (is_null($request->input('totp_token')) || ! $G2FA->verifyKey(Auth::user()->totp_secret, $request->input('totp_token'))) { + if (! $lockedOut) { $this->incrementLoginAttempts($request); } Alert::danger(trans('auth.totp_failed'))->flash(); - return $this->sendFailedLoginResponse($request); + return $this->sendFailedLoginResponse($request); } } // Successfully Authenticated. Auth::login(Auth::user(), $request->has('remember')); - return $this->sendLoginResponse($request); + return $this->sendLoginResponse($request); } /** @@ -147,5 +139,4 @@ class LoginController extends Controller { return response()->json(User::select('id')->where('email', $request->input('email'))->where('use_totp', 1)->first()); } - } diff --git a/app/Http/Controllers/Auth/RegisterController.php b/app/Http/Controllers/Auth/RegisterController.php index e2663825a..d28692293 100644 --- a/app/Http/Controllers/Auth/RegisterController.php +++ b/app/Http/Controllers/Auth/RegisterController.php @@ -2,8 +2,8 @@ namespace Pterodactyl\Http\Controllers\Auth; -use Pterodactyl\User; use Validator; +use Pterodactyl\User; use Pterodactyl\Http\Controllers\Controller; use Illuminate\Foundation\Auth\RegistersUsers; diff --git a/app/Http/Controllers/Auth/ResetPasswordController.php b/app/Http/Controllers/Auth/ResetPasswordController.php index e9989ec83..fca008051 100644 --- a/app/Http/Controllers/Auth/ResetPasswordController.php +++ b/app/Http/Controllers/Auth/ResetPasswordController.php @@ -33,8 +33,8 @@ class ResetPasswordController extends Controller $this->middleware('guest'); } - - protected function rules() { + protected function rules() + { return [ 'token' => 'required', 'email' => 'required|email', 'password' => 'required|confirmed|' . User::PASSWORD_RULES, diff --git a/app/Http/Controllers/Base/APIController.php b/app/Http/Controllers/Base/APIController.php index da9a20d78..c041cfa98 100644 --- a/app/Http/Controllers/Base/APIController.php +++ b/app/Http/Controllers/Base/APIController.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,31 +22,29 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Base; -use Alert; use Log; - +use Alert; use Pterodactyl\Models; - +use Illuminate\Http\Request; use Pterodactyl\Repositories\APIRepository; -use Pterodactyl\Exceptions\DisplayValidationException; use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Http\Controllers\Controller; - -use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayValidationException; class APIController extends Controller { public function index(Request $request) { $keys = Models\APIKey::where('user', $request->user()->id)->get(); - foreach($keys as &$key) { + foreach ($keys as &$key) { $key->permissions = Models\APIPermission::where('key_id', $key->id)->get(); } return view('base.api.index', [ - 'keys' => $keys + 'keys' => $keys, ]); } @@ -61,6 +59,7 @@ class APIController extends Controller $repo = new APIRepository($request->user()); $secret = $repo->new($request->except(['_token'])); Alert::success('An API Keypair has successfully been generated. The API secret for this public key is shown below and will not be shown again.

    ' . $secret . '')->flash(); + return redirect()->route('account.api'); } catch (DisplayValidationException $ex) { return redirect()->route('account.api.new')->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -70,6 +69,7 @@ class APIController extends Controller Log::error($ex); Alert::danger('An unhandled exception occured while attempting to add this API key.')->flash(); } + return redirect()->route('account.api.new')->withInput(); } @@ -78,10 +78,11 @@ class APIController extends Controller try { $repo = new APIRepository($request->user()); $repo->revoke($key); + return response('', 204); } catch (\Exception $ex) { return response()->json([ - 'error' => 'An error occured while attempting to remove this key.' + 'error' => 'An error occured while attempting to remove this key.', ], 503); } } diff --git a/app/Http/Controllers/Base/AccountController.php b/app/Http/Controllers/Base/AccountController.php index a58c691a8..2bfe9bd9f 100644 --- a/app/Http/Controllers/Base/AccountController.php +++ b/app/Http/Controllers/Base/AccountController.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,16 +22,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Base; use Alert; - +use Illuminate\Http\Request; use Pterodactyl\Models\User; use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Http\Controllers\Controller; -use Illuminate\Http\Request; - class AccountController extends Controller { /** @@ -53,16 +52,16 @@ class AccountController extends Controller */ public function email(Request $request) { - $this->validate($request, [ 'new_email' => 'required|email', - 'password' => 'required' + 'password' => 'required', ]); $user = $request->user(); - if (!password_verify($request->input('password'), $user->password)) { + if (! password_verify($request->input('password'), $user->password)) { Alert::danger('The password provided was not valid for this account.')->flash(); + return redirect()->route('account'); } @@ -70,8 +69,8 @@ class AccountController extends Controller $user->save(); Alert::success('Your email address has successfully been updated.')->flash(); - return redirect()->route('account'); + return redirect()->route('account'); } /** @@ -82,17 +81,17 @@ class AccountController extends Controller */ public function password(Request $request) { - $this->validate($request, [ 'current_password' => 'required', 'new_password' => 'required|confirmed|different:current_password|' . User::PASSWORD_RULES, - 'new_password_confirmation' => 'required' + 'new_password_confirmation' => 'required', ]); $user = $request->user(); - if (!password_verify($request->input('current_password'), $user->password)) { + if (! password_verify($request->input('current_password'), $user->password)) { Alert::danger('The password provided was not valid for this account.')->flash(); + return redirect()->route('account'); } @@ -104,6 +103,5 @@ class AccountController extends Controller } return redirect()->route('account'); - } } diff --git a/app/Http/Controllers/Base/IndexController.php b/app/Http/Controllers/Base/IndexController.php index 5631dc137..8bdaddf63 100644 --- a/app/Http/Controllers/Base/IndexController.php +++ b/app/Http/Controllers/Base/IndexController.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,18 +22,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Base; +use Illuminate\Http\Request; use Pterodactyl\Models\Server; use Pterodactyl\Http\Controllers\Controller; -use Illuminate\Http\Request; - class IndexController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -64,7 +63,7 @@ class IndexController extends Controller $length = ($length < 8) ? 8 : $length; $returnable = false; - while (!$returnable) { + while (! $returnable) { $generated = str_random($length); if (preg_match('/[A-Z]+[a-z]+[0-9]+/', $generated)) { $returnable = true; @@ -73,5 +72,4 @@ class IndexController extends Controller return $generated; } - } diff --git a/app/Http/Controllers/Base/LanguageController.php b/app/Http/Controllers/Base/LanguageController.php index c4afc1e50..a735c365c 100644 --- a/app/Http/Controllers/Base/LanguageController.php +++ b/app/Http/Controllers/Base/LanguageController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Base; use Auth; use Session; - -use Pterodactyl\Models\User; use Illuminate\Http\Request; +use Pterodactyl\Models\User; use Pterodactyl\Http\Controllers\Controller; class LanguageController extends Controller { - protected $languages = [ 'de' => 'Danish', 'en' => 'English', @@ -47,7 +46,7 @@ class LanguageController extends Controller ]; /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -64,7 +63,7 @@ class LanguageController extends Controller } Session::set('applocale', $language); } + return redirect()->back(); } - } diff --git a/app/Http/Controllers/Base/SecurityController.php b/app/Http/Controllers/Base/SecurityController.php index dec2f3fd1..1feaa0df3 100644 --- a/app/Http/Controllers/Base/SecurityController.php +++ b/app/Http/Controllers/Base/SecurityController.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,19 +22,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Base; -use Google2FA; use Alert; - +use Google2FA; +use Illuminate\Http\Request; use Pterodactyl\Models\Session; use Pterodactyl\Http\Controllers\Controller; -use Illuminate\Http\Request; - class SecurityController extends Controller { - /** * Returns Security Management Page. * @@ -44,7 +42,7 @@ class SecurityController extends Controller public function index(Request $request) { return view('base.security', [ - 'sessions' => Session::where('user_id', $request->user()->id)->get() + 'sessions' => Session::where('user_id', $request->user()->id)->get(), ]); } @@ -57,7 +55,6 @@ class SecurityController extends Controller */ public function generateTotp(Request $request) { - $user = $request->user(); $user->totp_secret = Google2FA::generateSecretKey(); @@ -69,9 +66,8 @@ class SecurityController extends Controller $user->email, $user->totp_secret ), - 'secret' => $user->totp_secret + 'secret' => $user->totp_secret, ]); - } /** @@ -82,18 +78,16 @@ class SecurityController extends Controller */ public function setTotp(Request $request) { - - if (!$request->has('token')) { + if (! $request->has('token')) { return response(null, 500); } $user = $request->user(); - if($user->toggleTotp($request->input('token'))) { + if ($user->toggleTotp($request->input('token'))) { return response('true'); } return response('false'); - } /** @@ -104,27 +98,27 @@ class SecurityController extends Controller */ public function disableTotp(Request $request) { - - if (!$request->has('token')) { + if (! $request->has('token')) { Alert::danger('Missing required `token` field in request.')->flash(); + return redirect()->route('account.totp'); } $user = $request->user(); - if($user->toggleTotp($request->input('token'))) { + if ($user->toggleTotp($request->input('token'))) { return redirect()->route('account.security'); } Alert::danger('The TOTP token provided was invalid.')->flash(); - return redirect()->route('account.security'); + return redirect()->route('account.security'); } public function revoke(Request $request, $id) { $session = Session::where('id', $id)->where('user_id', $request->user()->id)->firstOrFail(); $session->delete(); + return redirect()->route('account.security'); } - } diff --git a/app/Http/Controllers/Remote/RemoteController.php b/app/Http/Controllers/Remote/RemoteController.php index ee1b86b4c..e6dab6984 100644 --- a/app/Http/Controllers/Remote/RemoteController.php +++ b/app/Http/Controllers/Remote/RemoteController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,47 +21,47 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Remote; use Pterodactyl\Models; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Services\NotificationService; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Services\NotificationService; class RemoteController extends Controller { - /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { // No middleware for this route. } - public function postDownload(Request $request) { + public function postDownload(Request $request) + { $download = Models\Download::where('token', $request->input('token', '00'))->first(); - if (!$download) { + if (! $download) { return response()->json([ - 'error' => 'An invalid request token was recieved with this request.' + 'error' => 'An invalid request token was recieved with this request.', ], 403); } $download->delete(); + return response()->json([ 'path' => $download->path, - 'server' => $download->server + 'server' => $download->server, ]); } public function postInstall(Request $request) { $server = Models\Server::where('uuid', $request->input('server'))->first(); - if (!$server) { + if (! $server) { return response()->json([ - 'error' => 'No server by that ID was found on the system.' + 'error' => 'No server by that ID was found on the system.', ], 422); } @@ -71,7 +71,7 @@ class RemoteController extends Controller if (base64_decode($hmac) !== hash_hmac('sha256', $server->uuid, $node->daemonSecret, true)) { return response()->json([ - 'error' => 'Signed HMAC was invalid.' + 'error' => 'Signed HMAC was invalid.', ], 403); } @@ -79,16 +79,16 @@ class RemoteController extends Controller $server->save(); return response()->json([ - 'message' => 'Recieved!' + 'message' => 'Recieved!', ], 200); } public function event(Request $request) { $server = Models\Server::where('uuid', $request->input('server'))->first(); - if (!$server) { + if (! $server) { return response()->json([ - 'error' => 'No server by that ID was found on the system.' + 'error' => 'No server by that ID was found on the system.', ], 422); } @@ -97,7 +97,7 @@ class RemoteController extends Controller $hmac = $request->input('signed'); if (base64_decode($hmac) !== hash_hmac('sha256', $server->uuid, $node->daemonSecret, true)) { return response()->json([ - 'error' => 'Signed HMAC was invalid.' + 'error' => 'Signed HMAC was invalid.', ], 403); } @@ -107,5 +107,4 @@ class RemoteController extends Controller return response('', 201); } - } diff --git a/app/Http/Controllers/Server/AjaxController.php b/app/Http/Controllers/Server/AjaxController.php index f2db322ec..c1cf51635 100644 --- a/app/Http/Controllers/Server/AjaxController.php +++ b/app/Http/Controllers/Server/AjaxController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,24 +21,20 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Server; use Log; use Pterodactyl\Models; - -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - -use Pterodactyl\Repositories; -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; - -use GuzzleHttp\Client; +use Pterodactyl\Repositories; use GuzzleHttp\Exception\RequestException; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Exceptions\DisplayValidationException; class AjaxController extends Controller { - /** * @var array */ @@ -55,7 +51,7 @@ class AjaxController extends Controller protected $directory; /** - * Controller Constructor + * Controller Constructor. */ public function __construct() { @@ -73,7 +69,7 @@ class AjaxController extends Controller { $server = Models\Server::getByUUID($uuid); - if (!$server) { + if (! $server) { return response()->json([], 404); } @@ -81,14 +77,15 @@ class AjaxController extends Controller try { $res = $client->request('GET', '/server', [ - 'headers' => Models\Server::getGuzzleHeaders($uuid) + 'headers' => Models\Server::getGuzzleHeaders($uuid), ]); - if($res->getStatusCode() === 200) { + if ($res->getStatusCode() === 200) { return response()->json(json_decode($res->getBody())); } } catch (RequestException $e) { // } + return response()->json([]); } @@ -101,13 +98,12 @@ class AjaxController extends Controller */ public function postDirectoryList(Request $request, $uuid) { - $server = Models\Server::getByUUID($uuid); $this->directory = '/' . trim(urldecode($request->input('directory', '/')), '/'); $this->authorize('list-files', $server); $prevDir = [ - 'header' => ($this->directory !== '/') ? $this->directory : '' + 'header' => ($this->directory !== '/') ? $this->directory : '', ]; if ($this->directory !== '/') { $prevDir['first'] = true; @@ -116,7 +112,7 @@ class AjaxController extends Controller // Determine if we should show back links in the file browser. // This code is strange, and could probably be rewritten much better. $goBack = explode('/', trim($this->directory, '/')); - if (!empty(array_filter($goBack)) && count($goBack) >= 2) { + if (! empty(array_filter($goBack)) && count($goBack) >= 2) { $prevDir['show'] = true; array_pop($goBack); $prevDir['link'] = '/' . implode('/', $goBack); @@ -131,6 +127,7 @@ class AjaxController extends Controller return response($ex->getMessage(), 500); } catch (\Exception $ex) { Log::error($ex); + return response('An error occured while attempting to load the requested directory, please try again.', 500); } @@ -139,9 +136,8 @@ class AjaxController extends Controller 'files' => $directoryContents->files, 'folders' => $directoryContents->folders, 'editableMime' => Repositories\HelperRepository::editableFiles(), - 'directory' => $prevDir + 'directory' => $prevDir, ]); - } /** @@ -153,7 +149,6 @@ class AjaxController extends Controller */ public function postSaveFile(Request $request, $uuid) { - $server = Models\Server::getByUUID($uuid); $this->authorize('save-files', $server); @@ -161,39 +156,39 @@ class AjaxController extends Controller try { $controller->saveFileContents($request->input('file'), $request->input('contents')); + return response(null, 204); } catch (DisplayException $ex) { return response($ex->getMessage(), 500); } catch (\Exception $ex) { Log::error($ex); + return response('An error occured while attempting to save this file, please try again.', 500); } - } /** - * [postSetPrimary description] + * [postSetPrimary description]. * @param Request $request * @param string $uuid * @return \Illuminate\Http\Response */ public function postSetPrimary(Request $request, $uuid) { - $server = Models\Server::getByUUID($uuid); $this->authorize('set-connection', $server); if ((int) $request->input('allocation') === $server->allocation) { return response()->json([ - 'error' => 'You are already using this as your default connection.' + 'error' => 'You are already using this as your default connection.', ], 409); } try { $allocation = Models\Allocation::where('id', $request->input('allocation'))->where('assigned_to', $server->id)->first(); - if (!$allocation) { + if (! $allocation) { return response()->json([ - 'error' => 'No allocation matching your request was found in the system.' + 'error' => 'No allocation matching your request was found in the system.', ], 422); } @@ -201,6 +196,7 @@ class AjaxController extends Controller $repo->changeBuild($server->id, [ 'default' => $allocation->ip . ':' . $allocation->port, ]); + return response('The default connection for this server has been updated. Please be aware that you will need to restart your server for this change to go into effect.'); } catch (DisplayValidationException $ex) { return response()->json([ @@ -212,8 +208,9 @@ class AjaxController extends Controller ], 503); } catch (\Exception $ex) { Log::error($ex); + return response()->json([ - 'error' => 'An unhandled exception occured while attemping to modify the default connection for this server.' + 'error' => 'An unhandled exception occured while attemping to modify the default connection for this server.', ], 503); } } @@ -225,21 +222,21 @@ class AjaxController extends Controller $this->authorize('reset-db-password', $server); try { - $repo = new Repositories\DatabaseRepository; $password = str_random(16); $repo->modifyPassword($request->input('database'), $password); + return response($password); } catch (\Pterodactyl\Exceptions\DisplayException $ex) { return response()->json([ 'error' => $ex->getMessage(), ], 503); - } catch(\Exception $ex) { + } catch (\Exception $ex) { Log::error($ex); + return response()->json([ - 'error' => 'An unhandled error occured while attempting to modify this database\'s password.' + 'error' => 'An unhandled error occured while attempting to modify this database\'s password.', ], 503); } } - } diff --git a/app/Http/Controllers/Server/ServerController.php b/app/Http/Controllers/Server/ServerController.php index 810223303..ed051b8e9 100644 --- a/app/Http/Controllers/Server/ServerController.php +++ b/app/Http/Controllers/Server/ServerController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,30 +21,26 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Server; -use Auth; use DB; +use Log; use Uuid; use Alert; -use Log; - use Pterodactyl\Models; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; -use Pterodactyl\Repositories\Daemon\FileRepository; -use Pterodactyl\Repositories\ServerRepository; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; - use InvalidArgumentException; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\ServerRepository; +use Pterodactyl\Repositories\Daemon\FileRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class ServerController extends Controller { - /** - * Controller Constructor + * Controller Constructor. * * @return void */ @@ -62,7 +58,7 @@ class ServerController extends Controller try { return response()->view('server.js.' . $folder . '.' . $routeFile, [ 'server' => $server, - 'node' => Models\Node::find($server->node) + 'node' => Models\Node::find($server->node), ])->header('Content-Type', 'application/javascript'); } catch (InvalidArgumentException $ex) { return abort(404); @@ -80,10 +76,11 @@ class ServerController extends Controller public function getIndex(Request $request) { $server = Models\Server::getByUUID($request->route()->server); + return view('server.index', [ 'server' => $server, 'allocations' => Models\Allocation::where('assigned_to', $server->id)->orderBy('ip', 'asc')->orderBy('port', 'asc')->get(), - 'node' => Models\Node::find($server->node) + 'node' => Models\Node::find($server->node), ]); } @@ -95,13 +92,12 @@ class ServerController extends Controller */ public function getFiles(Request $request) { - $server = Models\Server::getByUUID($request->route()->server); $this->authorize('list-files', $server); return view('server.files.index', [ 'server' => $server, - 'node' => Models\Node::find($server->node) + 'node' => Models\Node::find($server->node), ]); } @@ -113,14 +109,13 @@ class ServerController extends Controller */ public function getAddFile(Request $request) { - $server = Models\Server::getByUUID($request->route()->server); $this->authorize('add-files', $server); return view('server.files.add', [ 'server' => $server, 'node' => Models\Node::find($server->node), - 'directory' => (in_array($request->get('dir'), [null, '/', ''])) ? '' : trim($request->get('dir'), '/') . '/' + 'directory' => (in_array($request->get('dir'), [null, '/', ''])) ? '' : trim($request->get('dir'), '/') . '/', ]); } @@ -134,7 +129,6 @@ class ServerController extends Controller */ public function getEditFile(Request $request, $uuid, $file) { - $server = Models\Server::getByUUID($uuid); $this->authorize('edit-files', $server); @@ -145,10 +139,12 @@ class ServerController extends Controller $fileContent = $controller->returnFileContents($file); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); + return redirect()->route('server.files.index', $uuid); } catch (\Exception $ex) { Log::error($ex); Alert::danger('An error occured while attempting to load the requested file for editing, please try again.')->flash(); + return redirect()->route('server.files.index', $uuid); } @@ -158,9 +154,8 @@ class ServerController extends Controller 'file' => $file, 'stat' => $fileContent['stat'], 'contents' => $fileContent['file']->content, - 'directory' => (in_array($fileInfo->dirname, ['.', './', '/'])) ? '/' : trim($fileInfo->dirname, '/') . '/' + 'directory' => (in_array($fileInfo->dirname, ['.', './', '/'])) ? '/' : trim($fileInfo->dirname, '/') . '/', ]); - } /** @@ -173,7 +168,6 @@ class ServerController extends Controller */ public function getDownloadFile(Request $request, $uuid, $file) { - $server = Models\Server::getByUUID($uuid); $node = Models\Node::find($server->node); @@ -187,8 +181,7 @@ class ServerController extends Controller $download->save(); - return redirect( $node->scheme . '://' . $node->fqdn . ':' . $node->daemonListen . '/server/file/download/' . $download->token); - + return redirect($node->scheme . '://' . $node->fqdn . ':' . $node->daemonListen . '/server/file/download/' . $download->token); } /** @@ -224,7 +217,7 @@ class ServerController extends Controller ]; $processed = str_replace(array_keys($serverVariables), array_values($serverVariables), $server->startup); - foreach($variables as &$variable) { + foreach ($variables as &$variable) { $replace = ($variable->user_viewable === 1) ? $variable->a_serverValue : '**'; $processed = str_replace('{{' . $variable->env_variable . '}}', $replace, $processed); } @@ -259,6 +252,7 @@ class ServerController extends Controller Log::error($ex); Alert::danger('An unknown error occured while attempting to update this server\'s SFTP settings.')->flash(); } + return redirect()->route('server.settings', $uuid); } @@ -270,19 +264,19 @@ class ServerController extends Controller try { $repo = new ServerRepository; $repo->updateStartup($server->id, $request->except([ - '_token' + '_token', ])); Alert::success('Server startup variables were successfully updated.')->flash(); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); - } catch(\Exception $ex) { + } catch (\Exception $ex) { Log::error($ex); Alert::danger('An unhandled exception occured while attemping to update startup variables for this server. Please try again.')->flash(); } + return redirect()->route('server.settings', [ 'uuid' => $uuid, - 'tab' => 'tab_startup' + 'tab' => 'tab_startup', ]); } - } diff --git a/app/Http/Controllers/Server/SubuserController.php b/app/Http/Controllers/Server/SubuserController.php index 963ea99a1..48de4621d 100644 --- a/app/Http/Controllers/Server/SubuserController.php +++ b/app/Http/Controllers/Server/SubuserController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,27 +21,24 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Server; use DB; +use Log; use Auth; use Alert; -use Log; - use Pterodactyl\Models; -use Pterodactyl\Repositories\SubuserRepository; - -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - use Illuminate\Http\Request; +use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Repositories\SubuserRepository; +use Pterodactyl\Exceptions\DisplayValidationException; class SubuserController extends Controller { - /** - * Controller Constructor + * Controller Constructor. * * @return void */ @@ -61,9 +58,8 @@ class SubuserController extends Controller 'subusers' => Models\Subuser::select('subusers.*', 'users.email as a_userEmail') ->join('users', 'users.id', '=', 'subusers.user_id') ->where('server_id', $server->id) - ->get() + ->get(), ]); - } public function getView(Request $request, $uuid, $id) @@ -76,7 +72,7 @@ class SubuserController extends Controller ->where(DB::raw('md5(subusers.id)'), $id)->where('subusers.server_id', $server->id) ->first(); - if (!$subuser) { + if (! $subuser) { abort(404); } @@ -85,7 +81,7 @@ class SubuserController extends Controller ->where('user_id', $subuser->user_id)->where('server_id', $server->id) ->get(); - foreach($modelPermissions as &$perm) { + foreach ($modelPermissions as &$perm) { $permissions[$perm->permission] = true; } @@ -99,17 +95,15 @@ class SubuserController extends Controller public function postView(Request $request, $uuid, $id) { - $server = Models\Server::getByUUID($uuid); $this->authorize('edit-subuser', $server); $subuser = Models\Subuser::where(DB::raw('md5(id)'), $id)->where('server_id', $server->id)->first(); try { - - if (!$subuser) { + if (! $subuser) { throw new DisplayException('Unable to locate a subuser by that ID.'); - } else if ($subuser->user_id === Auth::user()->id) { + } elseif ($subuser->user_id === Auth::user()->id) { throw new DisplayException('You are not authorized to edit you own account.'); } @@ -117,14 +111,14 @@ class SubuserController extends Controller $repo->update($subuser->id, [ 'permissions' => $request->input('permissions'), 'server' => $server->id, - 'user' => $subuser->user_id + 'user' => $subuser->user_id, ]); Alert::success('Subuser permissions have successfully been updated.')->flash(); } catch (DisplayValidationException $ex) { return redirect()->route('server.subusers.view', [ 'uuid' => $uuid, - 'id' => $id + 'id' => $id, ])->withErrors(json_decode($ex->getMessage())); } catch (DisplayException $ex) { Alert::danger($ex->getMessage())->flash(); @@ -132,9 +126,10 @@ class SubuserController extends Controller Log::error($ex); Alert::danger('An unknown error occured while attempting to update this subuser.')->flash(); } + return redirect()->route('server.subusers.view', [ 'uuid' => $uuid, - 'id' => $id + 'id' => $id, ]); } @@ -145,7 +140,7 @@ class SubuserController extends Controller return view('server.users.new', [ 'server' => $server, - 'node' => Models\Node::find($server->node) + 'node' => Models\Node::find($server->node), ]); } @@ -157,12 +152,13 @@ class SubuserController extends Controller try { $repo = new SubuserRepository; $id = $repo->create($server->id, $request->except([ - '_token' + '_token', ])); Alert::success('Successfully created new subuser.')->flash(); + return redirect()->route('server.subusers.view', [ 'uuid' => $uuid, - 'id' => md5($id) + 'id' => md5($id), ]); } catch (DisplayValidationException $ex) { return redirect()->route('server.subusers.new', $uuid)->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -172,6 +168,7 @@ class SubuserController extends Controller Log::error($ex); Alert::danger('An unknown error occured while attempting to add a new subuser.')->flash(); } + return redirect()->route('server.subusers.new', $uuid)->withInput(); } @@ -182,23 +179,23 @@ class SubuserController extends Controller try { $subuser = Models\Subuser::select('id')->where(DB::raw('md5(id)'), $id)->where('server_id', $server->id)->first(); - if (!$subuser) { + if (! $subuser) { throw new DisplayException('No subuser by that ID was found on the system.'); } $repo = new SubuserRepository; $repo->delete($subuser->id); + return response('', 204); } catch (DisplayException $ex) { response()->json([ - 'error' => $ex->getMessage() + 'error' => $ex->getMessage(), ], 422); } catch (\Exception $ex) { Log::error($ex); response()->json([ - 'error' => 'An unknown error occured while attempting to delete this subuser.' + 'error' => 'An unknown error occured while attempting to delete this subuser.', ], 503); } } - } diff --git a/app/Http/Controllers/Server/TaskController.php b/app/Http/Controllers/Server/TaskController.php index 0ef5e7bc5..7c6140379 100644 --- a/app/Http/Controllers/Server/TaskController.php +++ b/app/Http/Controllers/Server/TaskController.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Controllers\Server; -use Alert; use Log; -use Cron; - -use Pterodactyl\Repositories; +use Alert; use Pterodactyl\Models; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\DisplayValidationException; - -use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; +use Pterodactyl\Repositories; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Http\Controllers\Controller; +use Pterodactyl\Exceptions\DisplayValidationException; class TaskController extends Controller { @@ -53,8 +51,8 @@ class TaskController extends Controller 'tasks' => Models\Task::where('server', $server->id)->get(), 'actions' => [ 'command' => 'Send Command', - 'power' => 'Set Power Status' - ] + 'power' => 'Set Power Status', + ], ]); } @@ -65,7 +63,7 @@ class TaskController extends Controller return view('server.tasks.new', [ 'server' => $server, - 'node' => Models\Node::findOrFail($server->node) + 'node' => Models\Node::findOrFail($server->node), ]); } @@ -77,7 +75,7 @@ class TaskController extends Controller try { $repo = new Repositories\TaskRepository; $repo->create($server->id, $request->except([ - '_token' + '_token', ])); } catch (DisplayValidationException $ex) { return redirect()->route('server.tasks', $uuid)->withErrors(json_decode($ex->getMessage()))->withInput(); @@ -87,8 +85,8 @@ class TaskController extends Controller Log::error($ex); Alert::danger('An unknown error occured while attempting to create this task.')->flash(); } - return redirect()->route('server.tasks', $uuid); + return redirect()->route('server.tasks', $uuid); } public function getView(Request $request, $uuid, $id) @@ -99,7 +97,7 @@ class TaskController extends Controller return view('server.tasks.view', [ 'server' => $server, 'node' => Models\Node::findOrFail($server->node), - 'task' => Models\Task::where('id', $id)->where('server', $server->id)->firstOrFail() + 'task' => Models\Task::where('id', $id)->where('server', $server->id)->firstOrFail(), ]); } @@ -110,20 +108,22 @@ class TaskController extends Controller $task = Models\Task::findOrFail($id); - if (!$task || $server->id !== $task->server) { + if (! $task || $server->id !== $task->server) { return response()->json([ - 'error' => 'No task by that ID was found associated with this server.' + 'error' => 'No task by that ID was found associated with this server.', ], 404); } try { $repo = new Repositories\TaskRepository; $repo->delete($id); + return response()->json([], 204); } catch (\Exception $ex) { Log::error($ex); + return response()->json([ - 'error' => 'A server error occured while attempting to delete this task.' + 'error' => 'A server error occured while attempting to delete this task.', ], 503); } } @@ -135,22 +135,24 @@ class TaskController extends Controller $task = Models\Task::findOrFail($id); - if (!$task || $server->id !== $task->server) { + if (! $task || $server->id !== $task->server) { return response()->json([ - 'error' => 'No task by that ID was found associated with this server.' + 'error' => 'No task by that ID was found associated with this server.', ], 404); } try { $repo = new Repositories\TaskRepository; $resp = $repo->toggle($id); + return response()->json([ - 'status' => $resp + 'status' => $resp, ]); } catch (\Exception $ex) { Log::error($ex); + return response()->json([ - 'error' => 'A server error occured while attempting to toggle this task.' + 'error' => 'A server error occured while attempting to toggle this task.', ], 503); } } diff --git a/app/Http/Middleware/APISecretToken.php b/app/Http/Middleware/APISecretToken.php index fab4d177d..04e033a99 100755 --- a/app/Http/Middleware/APISecretToken.php +++ b/app/Http/Middleware/APISecretToken.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Middleware; use Auth; @@ -28,24 +29,20 @@ use Crypt; use Config; use IPTools\IP; use IPTools\Range; - +use Dingo\Api\Routing\Route; +use Illuminate\Http\Request; +use Pterodactyl\Models\User; use Pterodactyl\Models\APIKey; use Pterodactyl\Models\APIPermission; -use Pterodactyl\Models\User; use Pterodactyl\Services\APILogService; - -use Illuminate\Http\Request; -use Dingo\Api\Routing\Route; use Dingo\Api\Auth\Provider\Authorization; - -use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; // 400 -use Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException; // 401 +use Symfony\Component\HttpKernel\Exception\HttpException; // 400 +use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; // 401 use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException; // 403 -use Symfony\Component\HttpKernel\Exception\HttpException; //500 +use Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException; //500 class APISecretToken extends Authorization { - protected $algo = 'sha256'; protected $permissionAllowed = false; @@ -64,7 +61,7 @@ class APISecretToken extends Authorization public function authenticate(Request $request, Route $route) { - if (!$request->bearerToken() || empty($request->bearerToken())) { + if (! $request->bearerToken() || empty($request->bearerToken())) { APILogService::log($request, 'The authentication header was missing or malformed.'); throw new UnauthorizedHttpException('The authentication header was missing or malformed.'); } @@ -72,22 +69,22 @@ class APISecretToken extends Authorization list($public, $hashed) = explode('.', $request->bearerToken()); $key = APIKey::where('public', $public)->first(); - if (!$key) { + if (! $key) { APILogService::log($request, 'Invalid API Key.'); throw new AccessDeniedHttpException('Invalid API Key.'); } // Check for Resource Permissions - if (!empty($request->route()->getName())) { - if(!is_null($key->allowed_ips)) { + if (! empty($request->route()->getName())) { + if (! is_null($key->allowed_ips)) { $inRange = false; - foreach(json_decode($key->allowed_ips) as $ip) { + foreach (json_decode($key->allowed_ips) as $ip) { if (Range::parse($ip)->contains(new IP($request->ip()))) { $inRange = true; break; } } - if (!$inRange) { + if (! $inRange) { APILogService::log($request, 'This IP address <' . $request->ip() . '> does not have permission to use this API key.'); throw new AccessDeniedHttpException('This IP address <' . $request->ip() . '> does not have permission to use this API key.'); } @@ -98,11 +95,11 @@ class APISecretToken extends Authorization // Suport Wildcards if (starts_with($request->route()->getName(), 'api.user')) { $permission->orWhere('permission', 'api.user.*'); - } else if(starts_with($request->route()->getName(), 'api.admin')) { + } elseif (starts_with($request->route()->getName(), 'api.admin')) { $permission->orWhere('permission', 'api.admin.*'); } - if (!$permission->first()) { + if (! $permission->first()) { APILogService::log($request, 'You do not have permission to access this resource. This API Key requires the ' . $request->route()->getName() . ' permission node.'); throw new AccessDeniedHttpException('You do not have permission to access this resource. This API Key requires the ' . $request->route()->getName() . ' permission node.'); } @@ -116,21 +113,21 @@ class APISecretToken extends Authorization } $this->url = urldecode($request->fullUrl()); - if($this->_generateHMAC($request->getContent(), $decrypted) !== base64_decode($hashed)) { + if ($this->_generateHMAC($request->getContent(), $decrypted) !== base64_decode($hashed)) { APILogService::log($request, 'The hashed body was not valid. Potential modification of contents in route.'); throw new BadRequestHttpException('The hashed body was not valid. Potential modification of contents in route.'); } // Log the Route Access APILogService::log($request, null, true); - return Auth::loginUsingId($key->user); + return Auth::loginUsingId($key->user); } protected function _generateHMAC($body, $key) { $data = $this->url . $body; + return hash_hmac($this->algo, $data, $key, true); } - } diff --git a/app/Http/Middleware/AdminAuthenticate.php b/app/Http/Middleware/AdminAuthenticate.php index e4c3f91bb..78b73fb72 100644 --- a/app/Http/Middleware/AdminAuthenticate.php +++ b/app/Http/Middleware/AdminAuthenticate.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Middleware; use Closure; @@ -63,7 +64,7 @@ class AdminAuthenticate } } - if($this->auth->user()->root_admin !== 1) { + if ($this->auth->user()->root_admin !== 1) { return abort(403); } diff --git a/app/Http/Middleware/CheckServer.php b/app/Http/Middleware/CheckServer.php index 7ae0c115f..99ff35afd 100644 --- a/app/Http/Middleware/CheckServer.php +++ b/app/Http/Middleware/CheckServer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,12 +21,12 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Middleware; -use Closure; use Auth; +use Closure; use Pterodactyl\Models\Server; -use Debugbar; class CheckServer { @@ -39,13 +39,12 @@ class CheckServer */ public function handle($request, Closure $next) { - - if (!Auth::user()) { + if (! Auth::user()) { return redirect()->guest('auth/login'); } $server = Server::getByUUID($request->route()->server); - if (!$server) { + if (! $server) { return response()->view('errors.404', [], 404); } @@ -58,6 +57,5 @@ class CheckServer } return $next($request); - } } diff --git a/app/Http/Middleware/LanguageMiddleware.php b/app/Http/Middleware/LanguageMiddleware.php index 5b52705c6..1a4d6ff92 100644 --- a/app/Http/Middleware/LanguageMiddleware.php +++ b/app/Http/Middleware/LanguageMiddleware.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Middleware; use Auth; use Closure; use Session; use Settings; - use Illuminate\Support\Facades\App; class LanguageMiddleware { - public function __construct() { // @@ -49,12 +48,13 @@ class LanguageMiddleware { if (Session::has('applocale')) { App::setLocale(Session::get('applocale')); - } else if(Auth::check() && isset(Auth::user()->language)) { + } elseif (Auth::check() && isset(Auth::user()->language)) { Session::set('applocale', Auth::user()->language); App::setLocale(Auth::user()->language); } else { App::setLocale(Settings::get('default_language', 'en')); } + return $next($request); } } diff --git a/app/Http/Middleware/VerifyCsrfToken.php b/app/Http/Middleware/VerifyCsrfToken.php index be7b74e42..fe23f9e99 100644 --- a/app/Http/Middleware/VerifyCsrfToken.php +++ b/app/Http/Middleware/VerifyCsrfToken.php @@ -13,6 +13,6 @@ class VerifyCsrfToken extends BaseVerifier */ protected $except = [ 'remote/*', - 'api/*' + 'api/*', ]; } diff --git a/app/Http/Routes/APIRoutes.php b/app/Http/Routes/APIRoutes.php index b08da5a61..9417e0846 100755 --- a/app/Http/Routes/APIRoutes.php +++ b/app/Http/Routes/APIRoutes.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,167 +21,164 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; -use Pterodactyl\Models; use Illuminate\Routing\Router; class APIRoutes { - - public function map(Router $router) { - + public function map(Router $router) + { $api = app('Dingo\Api\Routing\Router'); $api->version('v1', ['prefix' => 'api/me', 'middleware' => 'api.auth'], function ($api) { $api->get('/', [ 'as' => 'api.user.me', - 'uses' => 'Pterodactyl\Http\Controllers\API\User\InfoController@me' + 'uses' => 'Pterodactyl\Http\Controllers\API\User\InfoController@me', ]); $api->get('/server/{uuid}', [ 'as' => 'api.user.server', - 'uses' => 'Pterodactyl\Http\Controllers\API\User\ServerController@info' + 'uses' => 'Pterodactyl\Http\Controllers\API\User\ServerController@info', ]); $api->put('/server/{uuid}', [ 'as' => 'api.user.server.power', - 'uses' => 'Pterodactyl\Http\Controllers\API\User\ServerController@power' + 'uses' => 'Pterodactyl\Http\Controllers\API\User\ServerController@power', ]); }); $api->version('v1', ['prefix' => 'api', 'middleware' => 'api.auth'], function ($api) { - /** + /* * User Routes */ $api->get('users', [ 'as' => 'api.admin.users.list', - 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@list' + 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@list', ]); $api->post('users', [ 'as' => 'api.admin.users.create', - 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@create' + 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@create', ]); $api->get('users/{id}', [ 'as' => 'api.admin.users.view', - 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@view' + 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@view', ]); $api->patch('users/{id}', [ 'as' => 'api.admin.users.update', - 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@update' + 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@update', ]); $api->delete('users/{id}', [ 'as' => 'api.admin.users.delete', - 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@delete' + 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@delete', ]); - /** + /* * Server Routes */ $api->get('servers', [ 'as' => 'api.admin.servers.list', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@list' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@list', ]); $api->post('servers', [ 'as' => 'api.admin.servers.create', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@create' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@create', ]); $api->get('servers/{id}', [ 'as' => 'api.admin.servers.view', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@view' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@view', ]); $api->patch('servers/{id}/config', [ 'as' => 'api.admin.servers.config', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@config' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@config', ]); $api->patch('servers/{id}/build', [ 'as' => 'api.admin.servers.build', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@build' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@build', ]); $api->post('servers/{id}/suspend', [ 'as' => 'api.admin.servers.suspend', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@suspend' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@suspend', ]); $api->post('servers/{id}/unsuspend', [ 'as' => 'api.admin.servers.unsuspend', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@unsuspend' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@unsuspend', ]); $api->delete('servers/{id}/{force?}', [ 'as' => 'api.admin.servers.delete', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@delete' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@delete', ]); - /** + /* * Node Routes */ $api->get('nodes', [ 'as' => 'api.admin.nodes.list', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@list' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@list', ]); $api->post('nodes', [ 'as' => 'api.admin.nodes.create', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@create' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@create', ]); $api->get('nodes/allocations', [ 'as' => 'api.admin.nodes.allocations', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@allocations' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@allocations', ]); $api->get('nodes/allocations/{id}', [ 'as' => 'api.admin.nodes.allocations', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@allocationsView' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@allocationsView', ]); - + $api->get('nodes/{id}', [ 'as' => 'api.admin.nodes.view', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@view' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@view', ]); $api->get('nodes/{id}/config', [ 'as' => 'api.admin.nodes.view', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@config' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@config', ]); $api->delete('nodes/{id}', [ 'as' => 'api.admin.nodes.delete', - 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@delete' + 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@delete', ]); - /** + /* * Location Routes */ $api->get('locations', [ 'as' => 'api.admin.locations.list', - 'uses' => 'Pterodactyl\Http\Controllers\API\LocationController@list' + 'uses' => 'Pterodactyl\Http\Controllers\API\LocationController@list', ]); - /** + /* * Service Routes */ $api->get('services', [ 'as' => 'api.admin.services.list', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServiceController@list' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServiceController@list', ]); $api->get('services/{id}', [ 'as' => 'api.admin.services.view', - 'uses' => 'Pterodactyl\Http\Controllers\API\ServiceController@view' + 'uses' => 'Pterodactyl\Http\Controllers\API\ServiceController@view', ]); - }); } - } diff --git a/app/Http/Routes/AdminRoutes.php b/app/Http/Routes/AdminRoutes.php index bfc07b725..916517171 100644 --- a/app/Http/Routes/AdminRoutes.php +++ b/app/Http/Routes/AdminRoutes.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,13 +22,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; use Illuminate\Routing\Router; -class AdminRoutes { - - public function map(Router $router) { +class AdminRoutes +{ + public function map(Router $router) + { // Admin Index $router->get('admin', [ @@ -36,9 +38,9 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' + 'csrf', ], - 'uses' => 'Admin\BaseController@getIndex' + 'uses' => 'Admin\BaseController@getIndex', ]); $router->group([ @@ -46,15 +48,15 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'admin.settings', - 'uses' => 'Admin\BaseController@getSettings' + 'uses' => 'Admin\BaseController@getSettings', ]); $router->post('/', [ - 'uses' => 'Admin\BaseController@postSettings' + 'uses' => 'Admin\BaseController@postSettings', ]); }); @@ -63,48 +65,47 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { // View All Accounts on System $router->get('/', [ 'as' => 'admin.users', - 'uses' => 'Admin\UserController@getIndex' + 'uses' => 'Admin\UserController@getIndex', ]); $router->get('/accounts.json', [ 'as' => 'admin.users.json', - 'uses' => 'Admin\UserController@getJson' + 'uses' => 'Admin\UserController@getJson', ]); // View Specific Account $router->get('/view/{id}', [ 'as' => 'admin.users.view', - 'uses' => 'Admin\UserController@getView' + 'uses' => 'Admin\UserController@getView', ]); // View Specific Account $router->post('/view/{id}', [ - 'uses' => 'Admin\UserController@updateUser' + 'uses' => 'Admin\UserController@updateUser', ]); // Delete an Account Matching an ID $router->delete('/view/{id}', [ - 'uses' => 'Admin\UserController@deleteUser' + 'uses' => 'Admin\UserController@deleteUser', ]); // Show Create Account Page $router->get('/new', [ 'as' => 'admin.users.new', - 'uses' => 'Admin\UserController@getNew' + 'uses' => 'Admin\UserController@getNew', ]); // Handle Creating New Account $router->post('/new', [ - 'uses' => 'Admin\UserController@postNew' + 'uses' => 'Admin\UserController@postNew', ]); - }); // Server Routes @@ -113,108 +114,107 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { // View All Servers $router->get('/', [ 'as' => 'admin.servers', - 'uses' => 'Admin\ServersController@getIndex' ]); + 'uses' => 'Admin\ServersController@getIndex', ]); // View Create Server Page $router->get('/new', [ 'as' => 'admin.servers.new', - 'uses' => 'Admin\ServersController@getNew' + 'uses' => 'Admin\ServersController@getNew', ]); // Handle POST Request for Creating Server $router->post('/new', [ - 'uses' => 'Admin\ServersController@postNewServer' + 'uses' => 'Admin\ServersController@postNewServer', ]); // Assorted Page Helpers $router->post('/new/get-nodes', [ - 'uses' => 'Admin\ServersController@postNewServerGetNodes' + 'uses' => 'Admin\ServersController@postNewServerGetNodes', ]); $router->post('/new/get-ips', [ - 'uses' => 'Admin\ServersController@postNewServerGetIps' + 'uses' => 'Admin\ServersController@postNewServerGetIps', ]); $router->post('/new/service-options', [ - 'uses' => 'Admin\ServersController@postNewServerServiceOptions' + 'uses' => 'Admin\ServersController@postNewServerServiceOptions', ]); $router->post('/new/service-variables', [ - 'uses' => 'Admin\ServersController@postNewServerServiceVariables' + 'uses' => 'Admin\ServersController@postNewServerServiceVariables', ]); // End Assorted Page Helpers // View Specific Server $router->get('/view/{id}', [ 'as' => 'admin.servers.view', - 'uses' => 'Admin\ServersController@getView' + 'uses' => 'Admin\ServersController@getView', ]); // Database Stuffs $router->post('/view/{id}/database', [ 'as' => 'admin.servers.database', - 'uses' => 'Admin\ServersController@postDatabase' + 'uses' => 'Admin\ServersController@postDatabase', ]); // Change Server Details $router->post('/view/{id}/details', [ - 'uses' => 'Admin\ServersController@postUpdateServerDetails' + 'uses' => 'Admin\ServersController@postUpdateServerDetails', ]); // Change Server Details $router->post('/view/{id}/container', [ 'as' => 'admin.servers.post.container', - 'uses' => 'Admin\ServersController@postUpdateContainerDetails' + 'uses' => 'Admin\ServersController@postUpdateContainerDetails', ]); // Change Server Details $router->post('/view/{id}/startup', [ 'as' => 'admin.servers.post.startup', - 'uses' => 'Admin\ServersController@postUpdateServerStartup' + 'uses' => 'Admin\ServersController@postUpdateServerStartup', ]); // Rebuild Server $router->post('/view/{id}/rebuild', [ - 'uses' => 'Admin\ServersController@postUpdateServerToggleBuild' + 'uses' => 'Admin\ServersController@postUpdateServerToggleBuild', ]); // Change Build Details $router->post('/view/{id}/build', [ - 'uses' => 'Admin\ServersController@postUpdateServerUpdateBuild' + 'uses' => 'Admin\ServersController@postUpdateServerUpdateBuild', ]); // Suspend Server $router->post('/view/{id}/suspend', [ - 'uses' => 'Admin\ServersController@postSuspendServer' + 'uses' => 'Admin\ServersController@postSuspendServer', ]); // Unsuspend Server $router->post('/view/{id}/unsuspend', [ - 'uses' => 'Admin\ServersController@postUnsuspendServer' + 'uses' => 'Admin\ServersController@postUnsuspendServer', ]); // Change Install Status $router->post('/view/{id}/installed', [ - 'uses' => 'Admin\ServersController@postToggleInstall' + 'uses' => 'Admin\ServersController@postToggleInstall', ]); // Delete [force delete] $router->delete('/view/{id}/{force?}', [ - 'uses' => 'Admin\ServersController@deleteServer' + 'uses' => 'Admin\ServersController@deleteServer', ]); $router->post('/view/{id}/queuedDeletion', [ 'uses' => 'Admin\ServersController@postQueuedDeletionHandler', - 'as' => 'admin.servers.post.queuedDeletion' + 'as' => 'admin.servers.post.queuedDeletion', ]); - }); // Node Routes @@ -223,70 +223,69 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { // View All Nodes $router->get('/', [ 'as' => 'admin.nodes', - 'uses' => 'Admin\NodesController@getIndex' + 'uses' => 'Admin\NodesController@getIndex', ]); // Add New Node $router->get('/new', [ 'as' => 'admin.nodes.new', - 'uses' => 'Admin\NodesController@getNew' + 'uses' => 'Admin\NodesController@getNew', ]); $router->post('/new', [ - 'uses' => 'Admin\NodesController@postNew' + 'uses' => 'Admin\NodesController@postNew', ]); // View Node $router->get('/view/{id}', [ 'as' => 'admin.nodes.view', - 'uses' => 'Admin\NodesController@getView' + 'uses' => 'Admin\NodesController@getView', ]); $router->post('/view/{id}', [ - 'uses' => 'Admin\NodesController@postView' + 'uses' => 'Admin\NodesController@postView', ]); $router->delete('/view/{id}/deallocate/single/{allocation}', [ - 'uses' => 'Admin\NodesController@deallocateSingle' + 'uses' => 'Admin\NodesController@deallocateSingle', ]); $router->post('/view/{id}/deallocate/block', [ - 'uses' => 'Admin\NodesController@deallocateBlock' + 'uses' => 'Admin\NodesController@deallocateBlock', ]); $router->post('/view/{id}/alias', [ 'as' => 'admin.nodes.alias', - 'uses' => 'Admin\NodesController@setAlias' + 'uses' => 'Admin\NodesController@setAlias', ]); $router->get('/view/{id}/allocations.json', [ 'as' => 'admin.nodes.view.allocations', - 'uses' => 'Admin\NodesController@getAllocationsJson' + 'uses' => 'Admin\NodesController@getAllocationsJson', ]); $router->post('/view/{id}/allocations', [ 'as' => 'admin.nodes.post.allocations', - 'uses' => 'Admin\NodesController@postAllocations' + 'uses' => 'Admin\NodesController@postAllocations', ]); // View Deploy $router->get('/view/{id}/deploy', [ 'as' => 'admin.nodes.deply', - 'uses' => 'Admin\NodesController@getScript' + 'uses' => 'Admin\NodesController@getScript', ]); $router->delete('/view/{id}', [ 'as' => 'admin.nodes.delete', - 'uses' => 'Admin\NodesController@deleteNode' + 'uses' => 'Admin\NodesController@deleteNode', ]); - }); // Location Routes @@ -295,21 +294,21 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'admin.locations', - 'uses' => 'Admin\LocationsController@getIndex' + 'uses' => 'Admin\LocationsController@getIndex', ]); $router->delete('/{id}', [ - 'uses' => 'Admin\LocationsController@deleteLocation' + 'uses' => 'Admin\LocationsController@deleteLocation', ]); $router->patch('/{id}', [ - 'uses' => 'Admin\LocationsController@patchLocation' + 'uses' => 'Admin\LocationsController@patchLocation', ]); $router->post('/', [ - 'uses' => 'Admin\LocationsController@postLocation' + 'uses' => 'Admin\LocationsController@postLocation', ]); }); @@ -319,27 +318,27 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'admin.databases', - 'uses' => 'Admin\DatabaseController@getIndex' + 'uses' => 'Admin\DatabaseController@getIndex', ]); $router->get('/new', [ 'as' => 'admin.databases.new', - 'uses' => 'Admin\DatabaseController@getNew' + 'uses' => 'Admin\DatabaseController@getNew', ]); $router->post('/new', [ - 'uses' => 'Admin\DatabaseController@postNew' + 'uses' => 'Admin\DatabaseController@postNew', ]); $router->delete('/delete/{id}', [ 'as' => 'admin.databases.delete', - 'uses' => 'Admin\DatabaseController@deleteDatabase' + 'uses' => 'Admin\DatabaseController@deleteDatabase', ]); $router->delete('/delete-server/{id}', [ 'as' => 'admin.databases.delete-server', - 'uses' => 'Admin\DatabaseController@deleteServer' + 'uses' => 'Admin\DatabaseController@deleteServer', ]); }); @@ -349,78 +348,76 @@ class AdminRoutes { 'middleware' => [ 'auth', 'admin', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'admin.services', - 'uses' => 'Admin\ServiceController@getIndex' + 'uses' => 'Admin\ServiceController@getIndex', ]); $router->get('/new', [ 'as' => 'admin.services.new', - 'uses' => 'Admin\ServiceController@getNew' + 'uses' => 'Admin\ServiceController@getNew', ]); $router->post('/new', [ - 'uses' => 'Admin\ServiceController@postNew' + 'uses' => 'Admin\ServiceController@postNew', ]); $router->get('/service/{id}', [ 'as' => 'admin.services.service', - 'uses' => 'Admin\ServiceController@getService' + 'uses' => 'Admin\ServiceController@getService', ]); $router->post('/service/{id}', [ - 'uses' => 'Admin\ServiceController@postService' + 'uses' => 'Admin\ServiceController@postService', ]); $router->delete('/service/{id}', [ - 'uses' => 'Admin\ServiceController@deleteService' + 'uses' => 'Admin\ServiceController@deleteService', ]); $router->get('/service/{service}/option/new', [ 'as' => 'admin.services.option.new', - 'uses' => 'Admin\ServiceController@newOption' + 'uses' => 'Admin\ServiceController@newOption', ]); $router->post('/service/{service}/option/new', [ - 'uses' => 'Admin\ServiceController@postNewOption' + 'uses' => 'Admin\ServiceController@postNewOption', ]); $router->get('/service/{service}/option/{option}', [ 'as' => 'admin.services.option', - 'uses' => 'Admin\ServiceController@getOption' + 'uses' => 'Admin\ServiceController@getOption', ]); $router->post('/service/{service}/option/{option}', [ - 'uses' => 'Admin\ServiceController@postOption' + 'uses' => 'Admin\ServiceController@postOption', ]); $router->delete('/service/{service}/option/{id}', [ - 'uses' => 'Admin\ServiceController@deleteOption' + 'uses' => 'Admin\ServiceController@deleteOption', ]); $router->get('/service/{service}/option/{option}/variable/new', [ 'as' => 'admin.services.option.variable.new', - 'uses' => 'Admin\ServiceController@getNewVariable' + 'uses' => 'Admin\ServiceController@getNewVariable', ]); $router->post('/service/{service}/option/{option}/variable/new', [ - 'uses' => 'Admin\ServiceController@postNewVariable' + 'uses' => 'Admin\ServiceController@postNewVariable', ]); $router->post('/service/{service}/option/{option}/variable/{variable}', [ 'as' => 'admin.services.option.variable', - 'uses' => 'Admin\ServiceController@postOptionVariable' + 'uses' => 'Admin\ServiceController@postOptionVariable', ]); $router->get('/service/{service}/option/{option}/variable/{variable}/delete', [ 'as' => 'admin.services.option.variable.delete', - 'uses' => 'Admin\ServiceController@deleteVariable' + 'uses' => 'Admin\ServiceController@deleteVariable', ]); }); - } - } diff --git a/app/Http/Routes/AuthRoutes.php b/app/Http/Routes/AuthRoutes.php index a447f3c5e..63887d9f4 100644 --- a/app/Http/Routes/AuthRoutes.php +++ b/app/Http/Routes/AuthRoutes.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,71 +22,68 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; -use Illuminate\Routing\Router; -use Request; -use Pterodactyl\Models\User as User; - use Auth; -class AuthRoutes { +use Illuminate\Routing\Router; - public function map(Router $router) { +class AuthRoutes +{ + public function map(Router $router) + { $router->group([ 'prefix' => 'auth', 'middleware' => [ 'guest', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { // Display Login Page $router->get('login', [ 'as' => 'auth.login', - 'uses' => 'Auth\LoginController@showLoginForm' + 'uses' => 'Auth\LoginController@showLoginForm', ]); // Handle Login $router->post('login', [ - 'uses' => 'Auth\LoginController@login' + 'uses' => 'Auth\LoginController@login', ]); // Determine if we need to ask for a TOTP Token $router->post('login/totp', [ - 'uses' => 'Auth\LoginController@checkTotp' + 'uses' => 'Auth\LoginController@checkTotp', ]); // Show Password Reset Form $router->get('password', [ 'as' => 'auth.password', - 'uses' => 'Auth\ForgotPasswordController@showLinkRequestForm' + 'uses' => 'Auth\ForgotPasswordController@showLinkRequestForm', ]); // Handle Password Reset $router->post('password', [ - 'uses' => 'Auth\ForgotPasswordController@sendResetLinkEmail' + 'uses' => 'Auth\ForgotPasswordController@sendResetLinkEmail', ]); // Show Verification Checkpoint $router->get('password/reset/{token}', [ 'as' => 'auth.reset', - 'uses' => 'Auth\ResetPasswordController@showResetForm' + 'uses' => 'Auth\ResetPasswordController@showResetForm', ]); // Handle Verification $router->post('password/reset', [ - 'uses' => 'Auth\ResetPasswordController@reset' + 'uses' => 'Auth\ResetPasswordController@reset', ]); - }); // Not included above because we don't want the guest middleware $router->get('auth/logout', [ 'as' => 'auth.logout', 'middleware' => 'auth', - 'uses' => 'Auth\LoginController@logout' + 'uses' => 'Auth\LoginController@logout', ]); - } - } diff --git a/app/Http/Routes/BaseRoutes.php b/app/Http/Routes/BaseRoutes.php index 6841ea1b6..a4cabe1b1 100644 --- a/app/Http/Routes/BaseRoutes.php +++ b/app/Http/Routes/BaseRoutes.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,19 +22,21 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; use Illuminate\Routing\Router; -class BaseRoutes { - - public function map(Router $router) { +class BaseRoutes +{ + public function map(Router $router) + { // Index of Panel $router->get('/', [ 'as' => 'index', 'middleware' => 'auth', - 'uses' => 'Base\IndexController@getIndex' + 'uses' => 'Base\IndexController@getIndex', ]); // Handle Index. Redirect /index to / @@ -46,7 +48,7 @@ class BaseRoutes { $router->get('/password-gen/{length}', [ 'as' => 'password-gen', 'middleware' => 'auth', - 'uses' => 'Base\IndexController@getPassword' + 'uses' => 'Base\IndexController@getPassword', ]); // Account Routes @@ -54,18 +56,18 @@ class BaseRoutes { 'prefix' => 'account', 'middleware' => [ 'auth', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'account', - 'uses' => 'Base\AccountController@index' + 'uses' => 'Base\AccountController@index', ]); $router->post('/password', [ - 'uses' => 'Base\AccountController@password' + 'uses' => 'Base\AccountController@password', ]); $router->post('/email', [ - 'uses' => 'Base\AccountController@email' + 'uses' => 'Base\AccountController@email', ]); }); @@ -74,23 +76,23 @@ class BaseRoutes { 'prefix' => 'account/api', 'middleware' => [ 'auth', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'account.api', - 'uses' => 'Base\APIController@index' + 'uses' => 'Base\APIController@index', ]); $router->get('/new', [ 'as' => 'account.api.new', - 'uses' => 'Base\APIController@new' + 'uses' => 'Base\APIController@new', ]); $router->post('/new', [ - 'uses' => 'Base\APIController@save' + 'uses' => 'Base\APIController@save', ]); $router->delete('/revoke/{key}', [ - 'uses' => 'Base\APIController@revoke' + 'uses' => 'Base\APIController@revoke', ]); }); @@ -99,28 +101,26 @@ class BaseRoutes { 'prefix' => 'account/security', 'middleware' => [ 'auth', - 'csrf' - ] + 'csrf', + ], ], function () use ($router) { $router->get('/', [ 'as' => 'account.security', - 'uses' => 'Base\SecurityController@index' + 'uses' => 'Base\SecurityController@index', ]); $router->get('/revoke/{id}', [ 'as' => 'account.security.revoke', - 'uses' => 'Base\SecurityController@revoke' + 'uses' => 'Base\SecurityController@revoke', ]); $router->put('/totp', [ - 'uses' => 'Base\SecurityController@generateTotp' + 'uses' => 'Base\SecurityController@generateTotp', ]); $router->post('/totp', [ - 'uses' => 'Base\SecurityController@setTotp' + 'uses' => 'Base\SecurityController@setTotp', ]); $router->delete('/totp', [ - 'uses' => 'Base\SecurityController@disableTotp' + 'uses' => 'Base\SecurityController@disableTotp', ]); }); - } - } diff --git a/app/Http/Routes/LanguageRoutes.php b/app/Http/Routes/LanguageRoutes.php index 4989f7ca6..17fefd1d8 100644 --- a/app/Http/Routes/LanguageRoutes.php +++ b/app/Http/Routes/LanguageRoutes.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,18 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; use Illuminate\Routing\Router; -class LanguageRoutes { - +class LanguageRoutes +{ public function map(Router $router) { $router->get('language/{lang}', [ 'as' => 'langauge.set', - 'uses' => 'Base\LanguageController@setLanguage' + 'uses' => 'Base\LanguageController@setLanguage', ]); } - } diff --git a/app/Http/Routes/RemoteRoutes.php b/app/Http/Routes/RemoteRoutes.php index 802f1d923..2e2201c45 100644 --- a/app/Http/Routes/RemoteRoutes.php +++ b/app/Http/Routes/RemoteRoutes.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,31 +21,31 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; use Illuminate\Routing\Router; -use Request; -class RemoteRoutes { - - public function map(Router $router) { +class RemoteRoutes +{ + public function map(Router $router) + { $router->group(['prefix' => 'remote'], function () use ($router) { // Handles Remote Download Authentication Requests $router->post('download', [ 'as' => 'remote.download', - 'uses' => 'Remote\RemoteController@postDownload' + 'uses' => 'Remote\RemoteController@postDownload', ]); $router->post('install', [ 'as' => 'remote.install', - 'uses' => 'Remote\RemoteController@postInstall' + 'uses' => 'Remote\RemoteController@postInstall', ]); $router->post('event', [ 'as' => 'remote.event', - 'uses' => 'Remote\RemoteController@event' + 'uses' => 'Remote\RemoteController@event', ]); }); } - } diff --git a/app/Http/Routes/ServerRoutes.php b/app/Http/Routes/ServerRoutes.php index 5916287e2..49c58754a 100644 --- a/app/Http/Routes/ServerRoutes.php +++ b/app/Http/Routes/ServerRoutes.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,148 +21,149 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Http\Routes; use Illuminate\Routing\Router; -class ServerRoutes { - - public function map(Router $router) { - +class ServerRoutes +{ + public function map(Router $router) + { $router->group([ 'prefix' => 'server/{server}', 'middleware' => [ 'auth', 'server', - 'csrf' - ] + 'csrf', + ], ], function ($server) use ($router) { // Index View for Server $router->get('/', [ 'as' => 'server.index', - 'uses' => 'Server\ServerController@getIndex' + 'uses' => 'Server\ServerController@getIndex', ]); // Settings $router->get('/settings', [ 'as' => 'server.settings', - 'uses' => 'Server\ServerController@getSettings' + 'uses' => 'Server\ServerController@getSettings', ]); $router->post('/settings/sftp', [ 'as' => 'server.settings.sftp', - 'uses' => 'Server\ServerController@postSettingsSFTP' + 'uses' => 'Server\ServerController@postSettingsSFTP', ]); $router->post('/settings/startup', [ 'as' => 'server.settings.startup', - 'uses' => 'Server\ServerController@postSettingsStartup' + 'uses' => 'Server\ServerController@postSettingsStartup', ]); // File Manager Routes $router->get('/files', [ 'as' => 'server.files.index', - 'uses' => 'Server\ServerController@getFiles' + 'uses' => 'Server\ServerController@getFiles', ]); $router->get('/files/edit/{file}', [ 'as' => 'server.files.edit', - 'uses' => 'Server\ServerController@getEditFile' + 'uses' => 'Server\ServerController@getEditFile', ])->where('file', '.*'); $router->get('/files/download/{file}', [ 'as' => 'server.files.download', - 'uses' => 'Server\ServerController@getDownloadFile' + 'uses' => 'Server\ServerController@getDownloadFile', ])->where('file', '.*'); $router->get('/files/add', [ 'as' => 'server.files.add', - 'uses' => 'Server\ServerController@getAddFile' + 'uses' => 'Server\ServerController@getAddFile', ]); $router->post('files/directory-list', [ 'as' => 'server.files.directory-list', - 'uses' => 'Server\AjaxController@postDirectoryList' + 'uses' => 'Server\AjaxController@postDirectoryList', ]); $router->post('files/save', [ 'as' => 'server.files.save', - 'uses' => 'Server\AjaxController@postSaveFile' + 'uses' => 'Server\AjaxController@postSaveFile', ]); // Sub-User Routes $router->get('users', [ 'as' => 'server.subusers', - 'uses' => 'Server\SubuserController@getIndex' + 'uses' => 'Server\SubuserController@getIndex', ]); $router->get('users/new', [ 'as' => 'server.subusers.new', - 'uses' => 'Server\SubuserController@getNew' + 'uses' => 'Server\SubuserController@getNew', ]); $router->post('users/new', [ - 'uses' => 'Server\SubuserController@postNew' + 'uses' => 'Server\SubuserController@postNew', ]); $router->get('users/view/{id}', [ 'as' => 'server.subusers.view', - 'uses' => 'Server\SubuserController@getView' + 'uses' => 'Server\SubuserController@getView', ]); $router->post('users/view/{id}', [ - 'uses' => 'Server\SubuserController@postView' + 'uses' => 'Server\SubuserController@postView', ]); $router->delete('users/delete/{id}', [ - 'uses' => 'Server\SubuserController@deleteSubuser' + 'uses' => 'Server\SubuserController@deleteSubuser', ]); $router->get('tasks/', [ 'as' => 'server.tasks', - 'uses' => 'Server\TaskController@getIndex' + 'uses' => 'Server\TaskController@getIndex', ]); $router->get('tasks/view/{id}', [ 'as' => 'server.tasks.view', - 'uses' => 'Server\TaskController@getView' + 'uses' => 'Server\TaskController@getView', ]); $router->get('tasks/new', [ 'as' => 'server.tasks.new', - 'uses' => 'Server\TaskController@getNew' + 'uses' => 'Server\TaskController@getNew', ]); $router->post('tasks/new', [ - 'uses' => 'Server\TaskController@postNew' + 'uses' => 'Server\TaskController@postNew', ]); $router->delete('tasks/delete/{id}', [ 'as' => 'server.tasks.delete', - 'uses' => 'Server\TaskController@deleteTask' + 'uses' => 'Server\TaskController@deleteTask', ]); $router->post('tasks/toggle/{id}', [ 'as' => 'server.tasks.toggle', - 'uses' => 'Server\TaskController@toggleTask' + 'uses' => 'Server\TaskController@toggleTask', ]); // Assorted AJAX Routes $router->group(['prefix' => 'ajax'], function ($server) use ($router) { // Returns Server Status $router->get('status', [ - 'uses' => 'Server\AjaxController@getStatus' + 'uses' => 'Server\AjaxController@getStatus', ]); // Sets the Default Connection for the Server $router->post('set-primary', [ - 'uses' => 'Server\AjaxController@postSetPrimary' + 'uses' => 'Server\AjaxController@postSetPrimary', ]); $router->post('settings/reset-database-password', [ 'as' => 'server.ajax.reset-database-password', - 'uses' => 'Server\AjaxController@postResetDatabasePassword' + 'uses' => 'Server\AjaxController@postResetDatabasePassword', ]); }); @@ -171,11 +172,9 @@ class ServerRoutes { // Returns Server Status $router->get('{folder}/{file}', [ 'as' => 'server.js', - 'uses' => 'Server\ServerController@getJavascript' + 'uses' => 'Server\ServerController@getJavascript', ])->where('file', '.*'); - }); }); } - } diff --git a/app/Jobs/DeleteServer.php b/app/Jobs/DeleteServer.php index 78e1e1f48..ea1688625 100644 --- a/app/Jobs/DeleteServer.php +++ b/app/Jobs/DeleteServer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,16 +21,12 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Jobs; -use DB; - -use Illuminate\Bus\Queueable; use Illuminate\Queue\SerializesModels; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; - -use Pterodactyl\Models; use Pterodactyl\Repositories\ServerRepository; class DeleteServer extends Job implements ShouldQueue @@ -46,7 +42,7 @@ class DeleteServer extends Job implements ShouldQueue /** * Create a new job instance. * - * @param integer $server + * @param int $server * @return void */ public function __construct($id) diff --git a/app/Jobs/SendScheduledTask.php b/app/Jobs/SendScheduledTask.php index 96d4a669a..fb155af19 100644 --- a/app/Jobs/SendScheduledTask.php +++ b/app/Jobs/SendScheduledTask.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Jobs; -use Pterodactyl\Jobs\Job; +use Cron; +use Carbon; +use Pterodactyl\Models; use Illuminate\Queue\SerializesModels; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; - -use DB; -use Carbon; -use Cron; -use Pterodactyl\Models; -use Pterodactyl\Repositories\Daemon\CommandRepository; use Pterodactyl\Repositories\Daemon\PowerRepository; +use Pterodactyl\Repositories\Daemon\CommandRepository; class SendScheduledTask extends Job implements ShouldQueue { @@ -76,7 +74,7 @@ class SendScheduledTask extends Job implements ShouldQueue if ($this->task->action === 'command') { $repo = new CommandRepository($this->server); $response = $repo->send($this->task->data); - } else if ($this->task->action === 'power') { + } elseif ($this->task->action === 'power') { $repo = new PowerRepository($this->server); $response = $repo->do($this->task->data); } @@ -84,14 +82,14 @@ class SendScheduledTask extends Job implements ShouldQueue 'task_id' => $this->task->id, 'run_time' => $time, 'run_status' => 0, - 'response' => $response + 'response' => $response, ]); } catch (\Exception $ex) { $log->fill([ 'task_id' => $this->task->id, 'run_time' => $time, 'run_status' => 1, - 'response' => $ex->getMessage() + 'response' => $ex->getMessage(), ]); } finally { $cron = Cron::factory(sprintf('%s %s %s %s %s %s', @@ -105,7 +103,7 @@ class SendScheduledTask extends Job implements ShouldQueue $this->task->fill([ 'last_run' => $time, 'next_run' => $cron->getNextRunDate(), - 'queued' => 0 + 'queued' => 0, ]); $this->task->save(); $log->save(); diff --git a/app/Jobs/SuspendServer.php b/app/Jobs/SuspendServer.php index 912f8a0a9..752325b67 100644 --- a/app/Jobs/SuspendServer.php +++ b/app/Jobs/SuspendServer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,14 +21,12 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Jobs; -use Debugbar; -use Illuminate\Bus\Queueable; use Illuminate\Queue\SerializesModels; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; - use Pterodactyl\Repositories\ServerRepository; class SuspendServer extends Job implements ShouldQueue @@ -44,7 +42,7 @@ class SuspendServer extends Job implements ShouldQueue /** * Create a new job instance. * - * @param integer $id + * @param int $id * @return void */ public function __construct($id) diff --git a/app/Listeners/DeleteServerListener.php b/app/Listeners/DeleteServerListener.php index 6a7833504..c6f5b0183 100644 --- a/app/Listeners/DeleteServerListener.php +++ b/app/Listeners/DeleteServerListener.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Listeners; use Carbon; - +use Pterodactyl\Jobs\DeleteServer; +use Pterodactyl\Jobs\SuspendServer; use Pterodactyl\Events\ServerDeleted; use Illuminate\Foundation\Bus\DispatchesJobs; -use Pterodactyl\Jobs\SuspendServer; -use Pterodactyl\Jobs\DeleteServer; - class DeleteServerListener { - use DispatchesJobs; /** diff --git a/app/Models/APIKey.php b/app/Models/APIKey.php index ae40b2036..3ba610a3f 100644 --- a/app/Models/APIKey.php +++ b/app/Models/APIKey.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class APIKey extends Model { - /** * The table associated with the model. * @@ -48,5 +48,4 @@ class APIKey extends Model * @var array */ protected $guarded = ['id', 'created_at', 'updated_at']; - } diff --git a/app/Models/APILog.php b/app/Models/APILog.php index 41a7f8e47..0e2a1a16d 100644 --- a/app/Models/APILog.php +++ b/app/Models/APILog.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class APILog extends Model { - /** * The table associated with the model. * @@ -49,13 +49,12 @@ class APILog extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ - 'authorized' => 'boolean' + 'authorized' => 'boolean', ]; - } diff --git a/app/Models/APIPermission.php b/app/Models/APIPermission.php index 99c564b2a..415c41c5e 100644 --- a/app/Models/APIPermission.php +++ b/app/Models/APIPermission.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class APIPermission extends Model { - /** * The table associated with the model. * @@ -42,11 +42,11 @@ class APIPermission extends Model */ protected $guarded = ['id']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'key_id' => 'integer', ]; @@ -54,8 +54,7 @@ class APIPermission extends Model /** * Disable timestamps for this table. * - * @var boolean + * @var bool */ public $timestamps = false; - } diff --git a/app/Models/Allocation.php b/app/Models/Allocation.php index 2eeff851d..ce08da5d9 100644 --- a/app/Models/Allocation.php +++ b/app/Models/Allocation.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Allocation extends Model { - /** * The table associated with the model. * @@ -42,15 +42,14 @@ class Allocation extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'node' => 'integer', 'port' => 'integer', 'assigned_to' => 'integer', ]; - } diff --git a/app/Models/Database.php b/app/Models/Database.php index c682b296e..ed8049b85 100644 --- a/app/Models/Database.php +++ b/app/Models/Database.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Database extends Model { - /** * The table associated with the model. * @@ -49,14 +49,13 @@ class Database extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'server' => 'integer', 'db_server' => 'integer', ]; - } diff --git a/app/Models/DatabaseServer.php b/app/Models/DatabaseServer.php index 78b45d953..38b8611d1 100644 --- a/app/Models/DatabaseServer.php +++ b/app/Models/DatabaseServer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class DatabaseServer extends Model { - /** * The table associated with the model. * @@ -49,15 +49,14 @@ class DatabaseServer extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'id' => 'integer', 'server_id' => 'integer', - 'db_server' => 'integer' + 'db_server' => 'integer', ]; - } diff --git a/app/Models/Download.php b/app/Models/Download.php index c3ee39d88..9adb8596c 100644 --- a/app/Models/Download.php +++ b/app/Models/Download.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; -use Debugbar; use Illuminate\Database\Eloquent\Model; class Download extends Model { - /** * The table associated with the model. * * @var string */ protected $table = 'downloads'; - } diff --git a/app/Models/Location.php b/app/Models/Location.php index 9778283f9..7b8a2d5cc 100644 --- a/app/Models/Location.php +++ b/app/Models/Location.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Location extends Model { - /** * The table associated with the model. * @@ -41,5 +41,4 @@ class Location extends Model * @var array */ protected $guarded = ['id', 'created_at', 'updated_at']; - } diff --git a/app/Models/Node.php b/app/Models/Node.php index 7bfc37cec..396f2849d 100644 --- a/app/Models/Node.php +++ b/app/Models/Node.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use GuzzleHttp\Client; @@ -28,7 +29,6 @@ use Illuminate\Database\Eloquent\Model; class Node extends Model { - /** * The table associated with the model. * @@ -43,11 +43,11 @@ class Node extends Model */ protected $hidden = ['daemonSecret']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'public' => 'integer', 'location' => 'integer', @@ -88,9 +88,9 @@ class Node extends Model return self::$nodes[$id]; } - self::$nodes[$id] = Node::where('id', $id)->first(); - return self::$nodes[$id]; + self::$nodes[$id] = self::where('id', $id)->first(); + return self::$nodes[$id]; } /** @@ -116,7 +116,5 @@ class Node extends Model ]); return self::$guzzle[$node]; - } - } diff --git a/app/Models/Permission.php b/app/Models/Permission.php index 5a59d579d..05c83fc9b 100644 --- a/app/Models/Permission.php +++ b/app/Models/Permission.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Permission extends Model { - /** * The table associated with the model. * @@ -42,11 +42,11 @@ class Permission extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'user_id' => 'integer', 'server_id' => 'integer', @@ -61,5 +61,4 @@ class Permission extends Model { return $query->where('server_id', $server->id); } - } diff --git a/app/Models/Server.php b/app/Models/Server.php index 93f6d9641..a2f7d7382 100644 --- a/app/Models/Server.php +++ b/app/Models/Server.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,18 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Auth; -use Pterodactyl\Models\Subuser; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes; -use Pterodactyl\Exceptions\DisplayException; - class Server extends Model { - use SoftDeletes; /** @@ -63,11 +60,11 @@ class Server extends Model */ protected $guarded = ['id', 'installed', 'created_at', 'updated_at', 'deleted_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'node' => 'integer', 'suspended' => 'integer', @@ -95,7 +92,7 @@ class Server extends Model protected static $user; /** - * Constructor + * Constructor. */ public function __construct() { @@ -112,7 +109,6 @@ class Server extends Model */ public static function getUserDaemonSecret(Server $server) { - if (self::$user->id === $server->owner || self::$user->root_admin === 1) { return $server->daemonSecret; } @@ -124,7 +120,6 @@ class Server extends Model } return $subuser->daemonSecret; - } /** @@ -135,7 +130,6 @@ class Server extends Model */ public static function getUserServers($paginate = null) { - $query = self::select( 'servers.*', 'nodes.name as nodeName', @@ -160,7 +154,6 @@ class Server extends Model } return $query->get(); - } /** @@ -173,7 +166,6 @@ class Server extends Model */ public static function getByUUID($uuid) { - if (array_key_exists($uuid, self::$serverUUIDInstance)) { return self::$serverUUIDInstance[$uuid]; } @@ -189,33 +181,30 @@ class Server extends Model $result = $query->first(); - if(!is_null($result)) { + if (! is_null($result)) { $result->daemonSecret = self::getUserDaemonSecret($result); } self::$serverUUIDInstance[$uuid] = $result; - return self::$serverUUIDInstance[$uuid]; + return self::$serverUUIDInstance[$uuid]; } /** - * Returns non-administrative headers for accessing a server on the daemon + * Returns non-administrative headers for accessing a server on the daemon. * * @param string $uuid * @return array */ public static function getGuzzleHeaders($uuid) { - if (array_key_exists($uuid, self::$serverUUIDInstance)) { return [ 'X-Access-Server' => self::$serverUUIDInstance[$uuid]->uuid, - 'X-Access-Token' => self::$serverUUIDInstance[$uuid]->daemonSecret + 'X-Access-Token' => self::$serverUUIDInstance[$uuid]->daemonSecret, ]; } return []; - } - } diff --git a/app/Models/ServerVariables.php b/app/Models/ServerVariables.php index d5d062489..8c11c8af5 100644 --- a/app/Models/ServerVariables.php +++ b/app/Models/ServerVariables.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class ServerVariables extends Model { - /** * The table associated with the model. * @@ -42,14 +42,13 @@ class ServerVariables extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'server_id' => 'integer', 'variable_id' => 'integer', ]; - } diff --git a/app/Models/Service.php b/app/Models/Service.php index e1d3e23e6..bd10ee884 100644 --- a/app/Models/Service.php +++ b/app/Models/Service.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Service extends Model { - /** * The table associated with the model. * @@ -41,5 +41,4 @@ class Service extends Model * @var array */ protected $guarded = ['id', 'created_at', 'updated_at']; - } diff --git a/app/Models/ServiceOptions.php b/app/Models/ServiceOptions.php index 393445a48..e74bae281 100644 --- a/app/Models/ServiceOptions.php +++ b/app/Models/ServiceOptions.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class ServiceOptions extends Model { - /** * The table associated with the model. * @@ -42,13 +42,12 @@ class ServiceOptions extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'parent_service' => 'integer', ]; - } diff --git a/app/Models/ServiceVariables.php b/app/Models/ServiceVariables.php index 8b7f203b3..b46690f54 100644 --- a/app/Models/ServiceVariables.php +++ b/app/Models/ServiceVariables.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class ServiceVariables extends Model { - /** * The table associated with the model. * @@ -42,16 +42,15 @@ class ServiceVariables extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'option_id' => 'integer', 'user_viewable' => 'integer', 'user_editable' => 'integer', 'required' => 'integer', ]; - } diff --git a/app/Models/Session.php b/app/Models/Session.php index 2b17bf6ce..9beef05ff 100644 --- a/app/Models/Session.php +++ b/app/Models/Session.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Session extends Model { - /** * The table associated with the model. * @@ -35,14 +35,13 @@ class Session extends Model */ protected $table = 'sessions'; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'id' => 'string', 'user_id' => 'integer', ]; - } diff --git a/app/Models/Subuser.php b/app/Models/Subuser.php index 5c22adfb7..3c2bfe9e0 100644 --- a/app/Models/Subuser.php +++ b/app/Models/Subuser.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Auth; @@ -28,7 +29,6 @@ use Illuminate\Database\Eloquent\Model; class Subuser extends Model { - /** * The table associated with the model. * @@ -50,11 +50,11 @@ class Subuser extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'user_id' => 'integer', 'server_id' => 'integer', @@ -66,7 +66,7 @@ class Subuser extends Model protected static $user; /** - * Constructor + * Constructor. */ public function __construct() { @@ -80,18 +80,15 @@ class Subuser extends Model */ public static function accessServers() { - $access = []; $union = self::select('server_id')->where('user_id', self::$user->id); $select = Server::select('id')->where('owner', self::$user->id)->union($union)->get(); - foreach($select as &$select) { - $access = array_merge($access, [ $select->id ]); + foreach ($select as &$select) { + $access = array_merge($access, [$select->id]); } return $access; - } - } diff --git a/app/Models/Task.php b/app/Models/Task.php index cfac1f5b7..63a326c4f 100644 --- a/app/Models/Task.php +++ b/app/Models/Task.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class Task extends Model { - /** * The table associated with the model. * @@ -42,22 +42,21 @@ class Task extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'id' => 'integer', 'server' => 'integer', 'queued' => 'integer', ]; - /** + /** * The attributes that should be mutated to dates. * * @var array */ protected $dates = ['last_run', 'next_run', 'created_at', 'updated_at']; - } diff --git a/app/Models/TaskLog.php b/app/Models/TaskLog.php index d2e2519d1..a07937373 100644 --- a/app/Models/TaskLog.php +++ b/app/Models/TaskLog.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,13 +21,13 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Illuminate\Database\Eloquent\Model; class TaskLog extends Model { - /** * The table associated with the model. * @@ -42,22 +42,21 @@ class TaskLog extends Model */ protected $guarded = ['id', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'id' => 'integer', 'task_id' => 'integer', - 'run_status' => 'integer' + 'run_status' => 'integer', ]; - /** + /** * The attributes that should be mutated to dates. * * @var array */ protected $dates = ['run_time', 'created_at', 'updated_at']; - } diff --git a/app/Models/User.php b/app/Models/User.php index 990511ecb..ef7bda0bd 100644 --- a/app/Models/User.php +++ b/app/Models/User.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,25 +21,24 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Models; use Hash; use Google2FA; -use Pterodactyl\Exceptions\AccountNotFoundException; -use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Models\Permission; -use Pterodactyl\Notifications\SendPasswordReset as ResetPasswordNotification; - use Illuminate\Auth\Authenticatable; -use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Model; +use Illuminate\Notifications\Notifiable; +use Pterodactyl\Exceptions\DisplayException; use Illuminate\Auth\Passwords\CanResetPassword; use Illuminate\Foundation\Auth\Access\Authorizable; use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract; use Illuminate\Contracts\Auth\Access\Authorizable as AuthorizableContract; use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract; +use Pterodactyl\Notifications\SendPasswordReset as ResetPasswordNotification; -class User extends Model implements AuthenticatableContract, +class User extends Model implements + AuthenticatableContract, AuthorizableContract, CanResetPasswordContract { @@ -59,11 +58,11 @@ class User extends Model implements AuthenticatableContract, */ protected $guarded = ['id', 'remeber_token', 'created_at', 'updated_at']; - /** - * Cast values to correct type. - * - * @var array - */ + /** + * Cast values to correct type. + * + * @var array + */ protected $casts = [ 'root_admin' => 'integer', 'use_totp' => 'integer', @@ -77,10 +76,10 @@ class User extends Model implements AuthenticatableContract, protected $hidden = ['password', 'remember_token', 'totp_secret']; /** - * The rules for user passwords - * - * @var string - */ + * The rules for user passwords. + * + * @var string + */ const PASSWORD_RULES = 'min:8|regex:((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})'; public function permissions() @@ -92,20 +91,18 @@ class User extends Model implements AuthenticatableContract, * Enables or disables TOTP on an account if the token is valid. * * @param int $token The token that we want to verify. - * @return boolean + * @return bool */ public function toggleTotp($token) { - - if (!Google2FA::verifyKey($this->totp_secret, $token)) { + if (! Google2FA::verifyKey($this->totp_secret, $token)) { return false; } - $this->use_totp = !$this->use_totp; + $this->use_totp = ! $this->use_totp; $this->save(); return true; - } /** @@ -113,7 +110,7 @@ class User extends Model implements AuthenticatableContract, * - 8 or more characters in length * - at least one uppercase character * - at least one lowercase character - * - at least one number + * - at least one number. * * @param string $password The raw password to set the account password to. * @param string $regex The regex to use when validating the password. Defaults to '((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})'. @@ -121,16 +118,12 @@ class User extends Model implements AuthenticatableContract, */ public function setPassword($password, $regex = '((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})') { - - if (!preg_match($regex, $password)) { + if (! preg_match($regex, $password)) { throw new DisplayException('The password passed did not meet the minimum password requirements.'); } $this->password = Hash::make($password); $this->save(); - - return; - } /** @@ -143,5 +136,4 @@ class User extends Model implements AuthenticatableContract, { $this->notify(new ResetPasswordNotification($token)); } - } diff --git a/app/Notifications/AccountCreated.php b/app/Notifications/AccountCreated.php index 806aa9408..8d0815b5e 100644 --- a/app/Notifications/AccountCreated.php +++ b/app/Notifications/AccountCreated.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Notifications; use Illuminate\Bus\Queueable; @@ -73,5 +74,4 @@ class AccountCreated extends Notification implements ShouldQueue ->line('Email: ' . $notifiable->email) ->action('Setup Your Account', url('/auth/password/reset/' . $this->token . '?email=' . $notifiable->email)); } - } diff --git a/app/Notifications/SendPasswordReset.php b/app/Notifications/SendPasswordReset.php index b7aa49ec0..5b4301688 100644 --- a/app/Notifications/SendPasswordReset.php +++ b/app/Notifications/SendPasswordReset.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Notifications; use Illuminate\Bus\Queueable; diff --git a/app/Notifications/ServerCreated.php b/app/Notifications/ServerCreated.php index 3d2b21344..a581a8fb2 100644 --- a/app/Notifications/ServerCreated.php +++ b/app/Notifications/ServerCreated.php @@ -52,5 +52,4 @@ class ServerCreated extends Notification implements ShouldQueue ->action('Peel Off the Protective Wrap', route('server.index', $this->server->uuidShort)) ->line('Please let us know if you have any additional questions or concerns!'); } - } diff --git a/app/Policies/ServerPolicy.php b/app/Policies/ServerPolicy.php index 2615149f0..56ae09df3 100644 --- a/app/Policies/ServerPolicy.php +++ b/app/Policies/ServerPolicy.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Policies; use Pterodactyl\Models\User; @@ -28,7 +29,6 @@ use Pterodactyl\Models\Server; class ServerPolicy { - /** * Create a new policy instance. * @@ -44,7 +44,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ protected function isOwner(User $user, Server $server) { @@ -56,7 +56,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param string $ability - * @return boolean + * @return bool */ public function before(User $user, $ability) { @@ -70,7 +70,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function power(User $user, Server $server) { @@ -86,7 +86,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function powerStart(User $user, Server $server) { @@ -102,7 +102,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function powerStop(User $user, Server $server) { @@ -118,7 +118,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function powerRestart(User $user, Server $server) { @@ -134,7 +134,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function powerKill(User $user, Server $server) { @@ -150,7 +150,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function sendCommand(User $user, Server $server) { @@ -166,7 +166,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function listFiles(User $user, Server $server) { @@ -182,7 +182,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function editFiles(User $user, Server $server) { @@ -198,7 +198,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function saveFiles(User $user, Server $server) { @@ -214,7 +214,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function moveFiles(User $user, Server $server) { @@ -230,7 +230,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function copyFiles(User $user, Server $server) { @@ -246,7 +246,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function compressFiles(User $user, Server $server) { @@ -262,7 +262,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function decompressFiles(User $user, Server $server) { @@ -278,7 +278,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function addFiles(User $user, Server $server) { @@ -295,7 +295,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function uploadFiles(User $user, Server $server) { @@ -311,7 +311,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function downloadFiles(User $user, Server $server) { @@ -327,7 +327,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function deleteFiles(User $user, Server $server) { @@ -343,7 +343,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function listSubusers(User $user, Server $server) { @@ -359,7 +359,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function viewSubuser(User $user, Server $server) { @@ -375,7 +375,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function editSubuser(User $user, Server $server) { @@ -391,7 +391,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function deleteSubuser(User $user, Server $server) { @@ -407,7 +407,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function createSubuser(User $user, Server $server) { @@ -423,7 +423,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function setConnection(User $user, Server $server) { @@ -439,7 +439,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function viewStartup(User $user, Server $server) { @@ -455,7 +455,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function editStartup(User $user, Server $server) { @@ -471,7 +471,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function viewSftp(User $user, Server $server) { @@ -487,7 +487,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function resetSftp(User $user, Server $server) { @@ -503,7 +503,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function viewSftpPassword(User $user, Server $server) { @@ -519,7 +519,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function viewDatabases(User $user, Server $server) { @@ -535,7 +535,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function resetDbPassword(User $user, Server $server) { @@ -551,7 +551,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function listTasks(User $user, Server $server) { @@ -567,7 +567,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function viewTask(User $user, Server $server) { @@ -583,7 +583,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function toggleTask(User $user, Server $server) { @@ -599,7 +599,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function queueTask(User $user, Server $server) { @@ -615,7 +615,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function deleteTask(User $user, Server $server) { @@ -631,7 +631,7 @@ class ServerPolicy * * @param Pterodactyl\Models\User $user * @param Pterodactyl\Models\Server $server - * @return boolean + * @return bool */ public function createTask(User $user, Server $server) { @@ -641,5 +641,4 @@ class ServerPolicy return $user->permissions()->server($server)->permission('create-task')->exists(); } - } diff --git a/app/Providers/AuthServiceProvider.php b/app/Providers/AuthServiceProvider.php index 757101e2d..86c94d99f 100644 --- a/app/Providers/AuthServiceProvider.php +++ b/app/Providers/AuthServiceProvider.php @@ -13,7 +13,7 @@ class AuthServiceProvider extends ServiceProvider * @var array */ protected $policies = [ - 'Pterodactyl\Models\Server' => 'Pterodactyl\Policies\ServerPolicy' + 'Pterodactyl\Models\Server' => 'Pterodactyl\Policies\ServerPolicy', ]; /** diff --git a/app/Repositories/APIRepository.php b/app/Repositories/APIRepository.php index c093c86ed..c9e2581b2 100644 --- a/app/Repositories/APIRepository.php +++ b/app/Repositories/APIRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,21 +21,20 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; -use Auth; use DB; +use Auth; use Crypt; use Validator; use IPTools\Network; - use Pterodactyl\Models; use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Exceptions\DisplayValidationException; class APIRepository { - /** * Valid API permissions. * @var array @@ -97,7 +96,7 @@ class APIRepository protected $user; /** - * Constructor + * Constructor. */ public function __construct(Models\User $user = null) { @@ -122,12 +121,12 @@ class APIRepository $validator = Validator::make($data, [ 'memo' => 'string|max:500', 'permissions' => 'sometimes|required|array', - 'adminPermissions' => 'sometimes|required|array' + 'adminPermissions' => 'sometimes|required|array', ]); - $validator->after(function($validator) use ($data) { - if (array_key_exists('allowed_ips', $data) && !empty($data['allowed_ips'])) { - foreach(explode("\n", $data['allowed_ips']) as $ip) { + $validator->after(function ($validator) use ($data) { + if (array_key_exists('allowed_ips', $data) && ! empty($data['allowed_ips'])) { + foreach (explode("\n", $data['allowed_ips']) as $ip) { $ip = trim($ip); try { Network::parse($ip); @@ -155,14 +154,16 @@ class APIRepository 'secret' => Crypt::encrypt($secretKey), 'allowed_ips' => empty($this->allowed) ? null : json_encode($this->allowed), 'memo' => $data['memo'], - 'expires_at' => null + 'expires_at' => null, ]); $key->save(); $totalPermissions = 0; if (isset($data['permissions'])) { - foreach($data['permissions'] as $permNode) { - if (!strpos($permNode, ':')) continue; + foreach ($data['permissions'] as $permNode) { + if (! strpos($permNode, ':')) { + continue; + } list($toss, $permission) = explode(':', $permNode); if (in_array($permission, $this->permissions['user'])) { @@ -170,7 +171,7 @@ class APIRepository $model = new Models\APIPermission; $model->fill([ 'key_id' => $key->id, - 'permission' => 'api.user.' . $permission + 'permission' => 'api.user.' . $permission, ]); $model->save(); } @@ -178,8 +179,10 @@ class APIRepository } if ($this->user->root_admin === 1 && isset($data['adminPermissions'])) { - foreach($data['adminPermissions'] as $permNode) { - if (!strpos($permNode, ':')) continue; + foreach ($data['adminPermissions'] as $permNode) { + if (! strpos($permNode, ':')) { + continue; + } list($toss, $permission) = explode(':', $permNode); if (in_array($permission, $this->permissions['admin'])) { @@ -187,7 +190,7 @@ class APIRepository $model = new Models\APIPermission; $model->fill([ 'key_id' => $key->id, - 'permission' => 'api.admin.' . $permission + 'permission' => 'api.admin.' . $permission, ]); $model->save(); } @@ -199,12 +202,12 @@ class APIRepository } DB::commit(); + return $secretKey; } catch (\Exception $ex) { DB::rollBack(); throw $ex; } - } /** @@ -231,5 +234,4 @@ class APIRepository throw $ex; } } - } diff --git a/app/Repositories/Daemon/CommandRepository.php b/app/Repositories/Daemon/CommandRepository.php index ebaf9dc61..23c3755bc 100644 --- a/app/Repositories/Daemon/CommandRepository.php +++ b/app/Repositories/Daemon/CommandRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,16 +21,16 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories\Daemon; +use GuzzleHttp\Client; use Pterodactyl\Models; +use GuzzleHttp\Exception\RequestException; use Pterodactyl\Exceptions\DisplayException; -use GuzzleHttp\Client; -use GuzzleHttp\Exception\RequestException; - -class CommandRepository { - +class CommandRepository +{ protected $server; protected $node; protected $client; @@ -43,9 +43,9 @@ class CommandRepository { } /** - * [send description] + * [send description]. * @param string $command - * @return boolean + * @return bool * @throws DisplayException * @throws RequestException */ @@ -59,11 +59,11 @@ class CommandRepository { $response = $this->client->request('POST', '/server/command', [ 'headers' => [ 'X-Access-Token' => $this->server->daemonSecret, - 'X-Access-Server' => $this->server->uuid + 'X-Access-Server' => $this->server->uuid, ], 'json' => [ - 'command' => $command - ] + 'command' => $command, + ], ]); if ($response->getStatusCode() < 200 || $response->getStatusCode() >= 300) { @@ -75,5 +75,4 @@ class CommandRepository { throw $ex; } } - } diff --git a/app/Repositories/Daemon/FileRepository.php b/app/Repositories/Daemon/FileRepository.php index c77baba11..716a8e387 100644 --- a/app/Repositories/Daemon/FileRepository.php +++ b/app/Repositories/Daemon/FileRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,22 +21,18 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories\Daemon; -use \Exception; -use Log; - -use Pterodactyl\Models\Server; -use Pterodactyl\Models\Node; -use Pterodactyl\Repositories\HelperRepository; -use Pterodactyl\Exceptions\DisplayException; - +use Exception; use GuzzleHttp\Client; -use GuzzleHttp\Exception\RequestException; +use Pterodactyl\Models\Node; +use Pterodactyl\Models\Server; +use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Repositories\HelperRepository; class FileRepository { - /** * The Eloquent Model associated with the requested server. * @@ -60,25 +56,23 @@ class FileRepository /** * The Guzzle Client headers associated with the requested server and node. - * (non-administrative headers) + * (non-administrative headers). * * @var array */ protected $headers; /** - * Constructor + * Constructor. * * @param string $server The server Short UUID */ public function __construct($uuid) { - $this->server = Server::getByUUID($uuid); $this->node = Node::getByID($this->server->node); $this->client = Node::guzzleRequest($this->server->node); $this->headers = Server::getGuzzleHeaders($uuid); - } /** @@ -89,7 +83,6 @@ class FileRepository */ public function returnFileContents($file) { - if (empty($file)) { throw new Exception('Not all parameters were properly passed to the function.'); } @@ -98,16 +91,16 @@ class FileRepository $file->dirname = (in_array($file->dirname, ['.', './', '/'])) ? null : trim($file->dirname, '/') . '/'; - $res = $this->client->request('GET', '/server/file/stat/' . rawurlencode($file->dirname.$file->basename) , [ - 'headers' => $this->headers + $res = $this->client->request('GET', '/server/file/stat/' . rawurlencode($file->dirname . $file->basename), [ + 'headers' => $this->headers, ]); $stat = json_decode($res->getBody()); - if($res->getStatusCode() !== 200 || !isset($stat->size)) { + if ($res->getStatusCode() !== 200 || ! isset($stat->size)) { throw new DisplayException('The daemon provided a non-200 error code on stat lookup: HTTP\\' . $res->getStatusCode()); } - if (!in_array($stat->mime, HelperRepository::editableFiles())) { + if (! in_array($stat->mime, HelperRepository::editableFiles())) { throw new DisplayException('You cannot edit that type of file (' . $stat->mime . ') through the panel.'); } @@ -115,20 +108,19 @@ class FileRepository throw new DisplayException('That file is too large to open in the browser, consider using a SFTP client.'); } - $res = $this->client->request('GET', '/server/file/f/' . rawurlencode($file->dirname.$file->basename) , [ - 'headers' => $this->headers + $res = $this->client->request('GET', '/server/file/f/' . rawurlencode($file->dirname . $file->basename), [ + 'headers' => $this->headers, ]); $json = json_decode($res->getBody()); - if($res->getStatusCode() !== 200 || !isset($json->content)) { + if ($res->getStatusCode() !== 200 || ! isset($json->content)) { throw new DisplayException('The daemon provided a non-200 error code: HTTP\\' . $res->getStatusCode()); } return [ 'file' => $json, - 'stat' => $stat + 'stat' => $stat, ]; - } /** @@ -140,7 +132,6 @@ class FileRepository */ public function saveFileContents($file, $content) { - if (empty($file)) { throw new Exception('A valid file and path must be specified to save a file.'); } @@ -152,9 +143,9 @@ class FileRepository $res = $this->client->request('POST', '/server/file/save', [ 'headers' => $this->headers, 'json' => [ - 'path' => rawurlencode($file->dirname.$file->basename), - 'content' => $content - ] + 'path' => rawurlencode($file->dirname . $file->basename), + 'content' => $content, + ], ]); if ($res->getStatusCode() !== 204) { @@ -162,7 +153,6 @@ class FileRepository } return true; - } /** @@ -173,25 +163,23 @@ class FileRepository */ public function returnDirectoryListing($directory) { - if (empty($directory)) { throw new Exception('A valid directory must be specified in order to list its contents.'); } $res = $this->client->request('GET', '/server/directory/' . rawurlencode($directory), [ - 'headers' => $this->headers + 'headers' => $this->headers, ]); $json = json_decode($res->getBody()); - if($res->getStatusCode() !== 200) { + if ($res->getStatusCode() !== 200) { throw new DisplayException('An error occured while attempting to save this file. ' . $res->getBody()); } // Iterate through results $files = []; $folders = []; - foreach($json as &$value) { - + foreach ($json as &$value) { if ($value->directory === true) { // @TODO Handle Symlinks @@ -200,29 +188,23 @@ class FileRepository 'directory' => trim($directory, '/'), 'size' => null, 'date' => strtotime($value->modified), - 'mime' => $value->mime + 'mime' => $value->mime, ]]); - - } else if ($value->file === true) { - + } elseif ($value->file === true) { $files = array_merge($files, [[ 'entry' => $value->name, 'directory' => trim($directory, '/'), 'extension' => pathinfo($value->name, PATHINFO_EXTENSION), 'size' => HelperRepository::bytesToHuman($value->size), 'date' => strtotime($value->modified), - 'mime' => $value->mime + 'mime' => $value->mime, ]]); - } - } return (object) [ 'files' => $files, 'folders' => $folders, ]; - } - } diff --git a/app/Repositories/Daemon/PowerRepository.php b/app/Repositories/Daemon/PowerRepository.php index 2fa56d5da..eb1b6a020 100644 --- a/app/Repositories/Daemon/PowerRepository.php +++ b/app/Repositories/Daemon/PowerRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,16 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories\Daemon; +use GuzzleHttp\Client; use Pterodactyl\Models; use Pterodactyl\Exceptions\DisplayException; -use GuzzleHttp\Client; -use GuzzleHttp\Exception\RequestException; - -class PowerRepository { - +class PowerRepository +{ protected $server; protected $node; protected $client; @@ -52,11 +51,11 @@ class PowerRepository { $response = $this->client->request('PUT', '/server/power', [ 'headers' => [ 'X-Access-Token' => $this->server->daemonSecret, - 'X-Access-Server' => $this->server->uuid + 'X-Access-Server' => $this->server->uuid, ], 'json' => [ - 'action' => $action - ] + 'action' => $action, + ], ]); if ($response->getStatusCode() < 200 || $response->getStatusCode() >= 300) { @@ -88,5 +87,4 @@ class PowerRepository { { $this->do('kill'); } - } diff --git a/app/Repositories/DatabaseRepository.php b/app/Repositories/DatabaseRepository.php index 1e9962a4e..075084281 100644 --- a/app/Repositories/DatabaseRepository.php +++ b/app/Repositories/DatabaseRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,21 +21,19 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; -use Crypt; -use Log; use DB; +use Crypt; use Validator; - use Pterodactyl\Models; use Pterodactyl\Exceptions\DisplayException; +use Illuminate\Database\Capsule\Manager as Capsule; use Pterodactyl\Exceptions\DisplayValidationException; -use Illuminate\Database\Capsule\Manager as Capsule; - -class DatabaseRepository { - +class DatabaseRepository +{ /** * Adds a new database to a given database server. * @param int $server Id of the server to add a database for. @@ -64,7 +62,7 @@ class DatabaseRepository { 'database' => "s{$server->id}_{$options['database']}", 'username' => $server->uuidShort . '_' . str_random(7), 'remote' => $options['remote'], - 'password' => Crypt::encrypt(str_random(20)) + 'password' => Crypt::encrypt(str_random(20)), ]); $db->save(); @@ -84,11 +82,10 @@ class DatabaseRepository { 'prefix' => '', 'options' => [ \PDO::ATTR_TIMEOUT => 3, - ] + ], ]); $capsule->setAsGlobal(); - } catch (\Exception $ex) { DB::rollBack(); throw new DisplayException('There was an error while connecting to the Database Host Server. Please check the error logs.', $ex); @@ -128,7 +125,6 @@ class DatabaseRepository { DB::beginTransaction(); try { - $db->password = Crypt::encrypt($password); $db->save(); @@ -145,7 +141,7 @@ class DatabaseRepository { 'prefix' => '', 'options' => [ \PDO::ATTR_TIMEOUT => 3, - ] + ], ]); $capsule->setAsGlobal(); @@ -157,16 +153,16 @@ class DatabaseRepository { )); DB::commit(); - } catch(\Exception $ex) { + } catch (\Exception $ex) { DB::rollback(); throw $ex; } } /** - * Drops a database from the associated MySQL Server + * Drops a database from the associated MySQL Server. * @param int $database The ID of the database to drop. - * @return boolean + * @return bool */ public function drop($database) { @@ -189,7 +185,7 @@ class DatabaseRepository { 'prefix' => '', 'options' => [ \PDO::ATTR_TIMEOUT => 3, - ] + ], ]); $capsule->setAsGlobal(); @@ -200,12 +196,12 @@ class DatabaseRepository { $db->delete(); DB::commit(); + return true; } catch (\Exception $ex) { DB::rollback(); throw $ex; } - } /** @@ -231,7 +227,6 @@ class DatabaseRepository { */ public function add(array $data) { - if (isset($data['host'])) { $data['host'] = gethostbyname($data['host']); } @@ -265,7 +260,7 @@ class DatabaseRepository { 'prefix' => '', 'options' => [ \PDO::ATTR_TIMEOUT => 3, - ] + ], ]); $capsule->setAsGlobal(); @@ -280,8 +275,8 @@ class DatabaseRepository { 'port' => $data['port'], 'username' => $data['username'], 'password' => Crypt::encrypt($data['password']), - 'max_databases' => NULL, - 'linked_node' => (!empty($data['linked_node']) && $data['linked_node'] > 0) ? $data['linked_node'] : NULL + 'max_databases' => null, + 'linked_node' => (! empty($data['linked_node']) && $data['linked_node'] > 0) ? $data['linked_node'] : null, ]); $dbh->save(); @@ -291,5 +286,4 @@ class DatabaseRepository { throw $ex; } } - } diff --git a/app/Repositories/HelperRepository.php b/app/Repositories/HelperRepository.php index 6eaa68329..add441da2 100644 --- a/app/Repositories/HelperRepository.php +++ b/app/Repositories/HelperRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,10 +21,11 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; -class HelperRepository { - +class HelperRepository +{ /** * Listing of editable files in the control panel. * @var array @@ -40,10 +41,9 @@ class HelperRepository { 'text/plain', 'text/x-perl', 'text/x-shellscript', - 'inode/x-empty' + 'inode/x-empty', ]; - public function __construct() { // @@ -58,17 +58,14 @@ class HelperRepository { */ public static function bytesToHuman($bytes, $decimals = 2) { - $sz = explode(',', 'B,KB,MB,GB'); $factor = floor((strlen($bytes) - 1) / 3); - return sprintf("%.{$decimals}f", $bytes / pow(1024, $factor)).' '.$sz[$factor]; - + return sprintf("%.{$decimals}f", $bytes / pow(1024, $factor)) . ' ' . $sz[$factor]; } public static function editableFiles() { return self::$editable; } - } diff --git a/app/Repositories/LocationRepository.php b/app/Repositories/LocationRepository.php index e70cfbd3e..94cc246bb 100644 --- a/app/Repositories/LocationRepository.php +++ b/app/Repositories/LocationRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,16 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; use Validator; - use Pterodactyl\Models; use Pterodactyl\Exceptions\DisplayValidationException; class LocationRepository { - public function __construct() { // @@ -40,13 +39,13 @@ class LocationRepository * Creates a new location on the system. * @param array $data * @throws Pterodactyl\Exceptions\DisplayValidationException - * @return integer + * @return int */ public function create(array $data) { $validator = Validator::make($data, [ 'short' => 'required|regex:/^[a-z0-9_.-]{1,10}$/i|unique:locations,short', - 'long' => 'required|string|min:1|max:255' + 'long' => 'required|string|min:1|max:255', ]); // Run validator, throw catchable and displayable exception if it fails. @@ -58,7 +57,7 @@ class LocationRepository $location = new Models\Location; $location->fill([ 'long' => $data['long'], - 'short' => $data['short'] + 'short' => $data['short'], ]); $location->save(); @@ -67,16 +66,16 @@ class LocationRepository /** * Modifies a location based on the fields passed in $data. - * @param integer $id + * @param int $id * @param array $data * @throws Pterodactyl\Exceptions\DisplayValidationException - * @return boolean + * @return bool */ public function edit($id, array $data) { $validator = Validator::make($data, [ 'short' => 'regex:/^[a-z0-9_.-]{1,10}$/i', - 'long' => 'string|min:1|max:255' + 'long' => 'string|min:1|max:255', ]); // Run validator, throw catchable and displayable exception if it fails. diff --git a/app/Repositories/NodeRepository.php b/app/Repositories/NodeRepository.php index ace645de4..4c80b8a4a 100644 --- a/app/Repositories/NodeRepository.php +++ b/app/Repositories/NodeRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,20 +21,19 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; use DB; use Validator; - +use IPTools\Network; use Pterodactyl\Models; use Pterodactyl\Services\UuidService; - -use IPTools\Network; use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Exceptions\DisplayValidationException; -class NodeRepository { - +class NodeRepository +{ public function __construct() { // @@ -70,7 +69,7 @@ class NodeRepository { } // Verify FQDN is resolvable, or if not using SSL that the IP is valid. - if (!filter_var(gethostbyname($data['fqdn']), FILTER_VALIDATE_IP)) { + if (! filter_var(gethostbyname($data['fqdn']), FILTER_VALIDATE_IP)) { throw new DisplayException('The FQDN (or IP Address) provided does not resolve to a valid IP address.'); } @@ -88,7 +87,6 @@ class NodeRepository { $node->save(); return $node->id; - } public function update($id, array $data) @@ -123,17 +121,16 @@ class NodeRepository { if (isset($data['fqdn'])) { // Verify the FQDN if using SSL - if ((isset($data['scheme']) && $data['scheme'] === 'https') || (!isset($data['scheme']) && $node->scheme === 'https')) { + if ((isset($data['scheme']) && $data['scheme'] === 'https') || (! isset($data['scheme']) && $node->scheme === 'https')) { if (filter_var($data['fqdn'], FILTER_VALIDATE_IP)) { throw new DisplayException('A fully qualified domain name is required to use secure comunication on this node.'); } } // Verify FQDN is resolvable, or if not using SSL that the IP is valid. - if (!filter_var(gethostbyname($data['fqdn']), FILTER_VALIDATE_IP)) { + if (! filter_var(gethostbyname($data['fqdn']), FILTER_VALIDATE_IP)) { throw new DisplayException('The FQDN (or IP Address) provided does not resolve to a valid IP address.'); } - } // Should we be nulling the overallocations? @@ -165,7 +162,7 @@ class NodeRepository { 'listen' => $node->daemonListen, 'ssl' => [ 'enabled' => ($node->scheme === 'https'), - 'certificate' => '/etc/letsencrypt/live/' . $node->fqdn .'/fullchain.pem', + 'certificate' => '/etc/letsencrypt/live/' . $node->fqdn . '/fullchain.pem', 'key' => '/etc/letsencrypt/live/' . $node->fqdn . '/privkey.pem', ], ], @@ -183,13 +180,12 @@ class NodeRepository { ], 'keys' => [ $node->daemonSecret, - ] + ], ], ]); } catch (\Exception $ex) { throw new DisplayException('Failed to update the node configuration, however your changes have been saved to the database. You will need to manually update the configuration file for the node to apply these changes.'); } - } public function addAllocations($id, array $allocations) @@ -199,7 +195,7 @@ class NodeRepository { DB::beginTransaction(); try { - foreach($allocations as $rawIP => $ports) { + foreach ($allocations as $rawIP => $ports) { try { $setAlias = null; $parsedIP = Network::parse($rawIP); @@ -211,25 +207,25 @@ class NodeRepository { throw $ex; } } - foreach($parsedIP as $ip) { - foreach($ports as $port) { - if (!is_int($port) && !preg_match('/^(\d{1,5})-(\d{1,5})$/', $port)) { + foreach ($parsedIP as $ip) { + foreach ($ports as $port) { + if (! is_int($port) && ! preg_match('/^(\d{1,5})-(\d{1,5})$/', $port)) { throw new DisplayException('The mapping for ' . $port . ' is invalid and cannot be processed.'); } if (preg_match('/^(\d{1,5})-(\d{1,5})$/', $port, $matches)) { - foreach(range($matches[1], $matches[2]) as $assignPort) { + foreach (range($matches[1], $matches[2]) as $assignPort) { $alloc = Models\Allocation::firstOrNew([ 'node' => $node->id, 'ip' => $ip, - 'port' => $assignPort + 'port' => $assignPort, ]); - if (!$alloc->exists) { + if (! $alloc->exists) { $alloc->fill([ 'node' => $node->id, 'ip' => $ip, 'port' => $assignPort, 'ip_alias' => $setAlias, - 'assigned_to' => null + 'assigned_to' => null, ]); $alloc->save(); } @@ -238,15 +234,15 @@ class NodeRepository { $alloc = Models\Allocation::firstOrNew([ 'node' => $node->id, 'ip' => $ip, - 'port' => $port + 'port' => $port, ]); - if (!$alloc->exists) { + if (! $alloc->exists) { $alloc->fill([ 'node' => $node->id, 'ip' => $ip, 'port' => $port, 'ip_alias' => $setAlias, - 'assigned_to' => null + 'assigned_to' => null, ]); $alloc->save(); } @@ -290,5 +286,4 @@ class NodeRepository { throw $ex; } } - } diff --git a/app/Repositories/ServerRepository.php b/app/Repositories/ServerRepository.php index 19b4abd05..a70188c85 100644 --- a/app/Repositories/ServerRepository.php +++ b/app/Repositories/ServerRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,29 +21,25 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; -use Crypt; use DB; -use Debugbar; -use Validator; use Log; - +use Crypt; +use Validator; use Pterodactyl\Models; +use Pterodactyl\Events\ServerDeleted; use Pterodactyl\Services\UuidService; use Pterodactyl\Services\DeploymentService; -use Pterodactyl\Notifications\ServerCreated; -use Pterodactyl\Events\ServerDeleted; - use Pterodactyl\Exceptions\DisplayException; -use Pterodactyl\Exceptions\AccountNotFoundException; +use Pterodactyl\Notifications\ServerCreated; use Pterodactyl\Exceptions\DisplayValidationException; class ServerRepository { - protected $daemonPermissions = [ - 's:*' + 's:*', ]; public function __construct() @@ -53,7 +49,7 @@ class ServerRepository /** * Generates a SFTP username for a server given a server name. - * format: mumble_67c7a4b0 + * format: mumble_67c7a4b0. * * @param string $name * @param string $uuid @@ -61,16 +57,15 @@ class ServerRepository */ protected function generateSFTPUsername($name, $uuid = null) { - $uuid = is_null($uuid) ? str_random(8) : $uuid; - return strtolower(substr(preg_replace('/\s+/', '', $name), 0, 6) . '_' . $uuid); + return strtolower(substr(preg_replace('/\s+/', '', $name), 0, 6) . '_' . $uuid); } /** * Adds a new server to the system. * @param array $data An array of data descriptors for creating the server. These should align to the columns in the database. - * @return integer + * @return int */ public function create(array $data) { @@ -93,22 +88,21 @@ class ServerRepository ]); $validator->sometimes('node', 'bail|required|numeric|min:1|exists:nodes,id', function ($input) { - return !($input->auto_deploy); + return ! ($input->auto_deploy); }); $validator->sometimes('ip', 'required|ip', function ($input) { - return (!$input->auto_deploy && !$input->allocation); + return ! $input->auto_deploy && ! $input->allocation; }); $validator->sometimes('port', 'required|numeric|min:1|max:65535', function ($input) { - return (!$input->auto_deploy && !$input->allocation); + return ! $input->auto_deploy && ! $input->allocation; }); $validator->sometimes('allocation', 'numeric|exists:allocations,id', function ($input) { - return !($input->auto_deploy || ($input->port && $input->ip)); + return ! ($input->auto_deploy || ($input->port && $input->ip)); }); - // Run validator, throw catchable and displayable exception if it fails. // Exception includes a JSON result of failed validation rules. if ($validator->fails()) { @@ -121,12 +115,12 @@ class ServerRepository $user = Models\User::select('id', 'email')->where('email', $data['owner'])->first(); } - if (!$user) { + if (! $user) { throw new DisplayException('The user id or email passed to the function was not found on the system.'); } $autoDeployed = false; - if (isset($data['auto_deploy']) && in_array($data['auto_deploy'], [true, 1, "1"])) { + if (isset($data['auto_deploy']) && in_array($data['auto_deploy'], [true, 1, '1'])) { // This is an auto-deployment situation // Ignore any other passed node data unset($data['node'], $data['ip'], $data['port'], $data['allocation']); @@ -140,16 +134,16 @@ class ServerRepository // Verify IP & Port are a.) free and b.) assigned to the node. // We know the node exists because of 'exists:nodes,id' in the validation - if (!$autoDeployed) { - if (!isset($data['allocation'])) { + if (! $autoDeployed) { + if (! isset($data['allocation'])) { $allocation = Models\Allocation::where('ip', $data['ip'])->where('port', $data['port'])->where('node', $data['node'])->whereNull('assigned_to')->first(); } else { - $allocation = Models\Allocation::where('id' , $data['allocation'])->where('node', $data['node'])->whereNull('assigned_to')->first(); + $allocation = Models\Allocation::where('id', $data['allocation'])->where('node', $data['node'])->whereNull('assigned_to')->first(); } } // Something failed in the query, either that combo doesn't exist, or it is in use. - if (!$allocation) { + if (! $allocation) { throw new DisplayException('The selected IP/Port combination or Allocation ID is either already in use, or unavaliable for this node.'); } @@ -158,7 +152,7 @@ class ServerRepository // We need to verify that the option exists for the service, and then check for // any required variable fields. (fields are labeled env_) $option = Models\ServiceOptions::where('id', $data['option'])->where('parent_service', $data['service'])->first(); - if (!$option) { + if (! $option) { throw new DisplayException('The requested service option does not exist for the specified service.'); } @@ -169,46 +163,45 @@ class ServerRepository $variables = Models\ServiceVariables::where('option_id', $data['option'])->get(); $variableList = []; if ($variables) { - foreach($variables as $variable) { + foreach ($variables as $variable) { // Is the variable required? - if (!$data['env_' . $variable->env_variable]) { + if (! $data['env_' . $variable->env_variable]) { if ($variable->required === 1) { throw new DisplayException('A required service option variable field (env_' . $variable->env_variable . ') was missing from the request.'); } $variableList = array_merge($variableList, [[ 'id' => $variable->id, 'env' => $variable->env_variable, - 'val' => $variable->default_value + 'val' => $variable->default_value, ]]); continue; } // Check aganist Regex Pattern - if (!is_null($variable->regex) && !preg_match($variable->regex, $data['env_' . $variable->env_variable])) { + if (! is_null($variable->regex) && ! preg_match($variable->regex, $data['env_' . $variable->env_variable])) { throw new DisplayException('Failed to validate service option variable field (env_' . $variable->env_variable . ') aganist regex (' . $variable->regex . ').'); } $variableList = array_merge($variableList, [[ 'id' => $variable->id, 'env' => $variable->env_variable, - 'val' => $data['env_' . $variable->env_variable] + 'val' => $data['env_' . $variable->env_variable], ]]); continue; } } // Check Overallocation - if (!$autoDeployed) { + if (! $autoDeployed) { if (is_numeric($node->memory_overallocate) || is_numeric($node->disk_overallocate)) { - $totals = Models\Server::select(DB::raw('SUM(memory) as memory, SUM(disk) as disk'))->where('node', $node->id)->first(); // Check memory limits if (is_numeric($node->memory_overallocate)) { $newMemory = $totals->memory + $data['memory']; $memoryLimit = ($node->memory * (1 + ($node->memory_overallocate / 100))); - if($newMemory > $memoryLimit) { + if ($newMemory > $memoryLimit) { throw new DisplayException('The amount of memory allocated to this server would put the node over its allocation limits. This node is allowed ' . ($node->memory_overallocate + 100) . '% of its assigned ' . $node->memory . 'Mb of memory (' . $memoryLimit . 'Mb) of which ' . (($totals->memory / $node->memory) * 100) . '% (' . $totals->memory . 'Mb) is in use already. By allocating this server the node would be at ' . (($newMemory / $node->memory) * 100) . '% (' . $newMemory . 'Mb) usage.'); } } @@ -217,7 +210,7 @@ class ServerRepository if (is_numeric($node->disk_overallocate)) { $newDisk = $totals->disk + $data['disk']; $diskLimit = ($node->disk * (1 + ($node->disk_overallocate / 100))); - if($newDisk > $diskLimit) { + if ($newDisk > $diskLimit) { throw new DisplayException('The amount of disk allocated to this server would put the node over its allocation limits. This node is allowed ' . ($node->disk_overallocate + 100) . '% of its assigned ' . $node->disk . 'Mb of disk (' . $diskLimit . 'Mb) of which ' . (($totals->disk / $node->disk) * 100) . '% (' . $totals->disk . 'Mb) is in use already. By allocating this server the node would be at ' . (($newDisk / $node->disk) * 100) . '% (' . $newDisk . 'Mb) usage.'); } } @@ -233,7 +226,7 @@ class ServerRepository $server = new Models\Server; $genUuid = $uuid->generate('servers', 'uuid'); $genShortUuid = $uuid->generateShort('servers', 'uuidShort', $genUuid); - + if (isset($data['custom_id'])) { $server->id = $data['custom_id']; } @@ -258,7 +251,7 @@ class ServerRepository 'daemonSecret' => $uuid->generate('servers', 'daemonSecret'), 'image' => (isset($data['custom_image_name'])) ? $data['custom_image_name'] : $option->docker_image, 'username' => $this->generateSFTPUsername($data['name'], $genShortUuid), - 'sftp_password' => Crypt::encrypt('not set') + 'sftp_password' => Crypt::encrypt('not set'), ]); $server->save(); @@ -269,16 +262,16 @@ class ServerRepository // Add Variables $environmentVariables = []; $environmentVariables = array_merge($environmentVariables, [ - 'STARTUP' => $data['startup'] + 'STARTUP' => $data['startup'], ]); - foreach($variableList as $item) { + foreach ($variableList as $item) { $environmentVariables = array_merge($environmentVariables, [ - $item['env'] => $item['val'] + $item['env'] => $item['val'], ]); Models\ServerVariables::create([ 'server_id' => $server->id, 'variable_id' => $item['id'], - 'variable_value' => $item['val'] + 'variable_value' => $item['val'], ]); } @@ -289,13 +282,13 @@ class ServerRepository 'node' => $node->name, 'service' => $service->name, 'option' => $option->name, - 'uuidShort' => $server->uuidShort + 'uuidShort' => $server->uuidShort, ]))); $client = Models\Node::guzzleRequest($node->id); $client->request('POST', '/servers', [ 'headers' => [ - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ 'uuid' => (string) $server->uuid, @@ -303,10 +296,10 @@ class ServerRepository 'build' => [ 'default' => [ 'ip' => $allocation->ip, - 'port' => (int) $allocation->port + 'port' => (int) $allocation->port, ], 'ports' => [ - (string) $allocation->ip => [ (int) $allocation->port ] + (string) $allocation->ip => [(int) $allocation->port], ], 'env' => $environmentVariables, 'memory' => (int) $server->memory, @@ -314,20 +307,21 @@ class ServerRepository 'io' => (int) $server->io, 'cpu' => (int) $server->cpu, 'disk' => (int) $server->disk, - 'image' => (isset($data['custom_image_name'])) ? $data['custom_image_name'] : $option->docker_image + 'image' => (isset($data['custom_image_name'])) ? $data['custom_image_name'] : $option->docker_image, ], 'service' => [ 'type' => $service->file, - 'option' => $option->tag + 'option' => $option->tag, ], 'keys' => [ - (string) $server->daemonSecret => $this->daemonPermissions + (string) $server->daemonSecret => $this->daemonPermissions, ], - 'rebuild' => false - ] + 'rebuild' => false, + ], ]); DB::commit(); + return $server->id; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -336,25 +330,23 @@ class ServerRepository DB::rollBack(); throw $ex; } - } /** - * [updateDetails description] - * @param integer $id + * [updateDetails description]. + * @param int $id * @param array $data - * @return boolean + * @return bool */ public function updateDetails($id, array $data) { - $uuid = new UuidService; $resetDaemonKey = false; // Validate Fields $validator = Validator::make($data, [ 'owner' => 'email|exists:users,email', - 'name' => 'regex:([\w -]{4,35})' + 'name' => 'regex:([\w -]{4,35})', ]); // Run validator, throw catchable and displayable exception if it fails. @@ -391,8 +383,9 @@ class ServerRepository $server->save(); // Do we need to update? If not, return successful. - if (!$resetDaemonKey) { + if (! $resetDaemonKey) { DB::commit(); + return true; } @@ -403,19 +396,20 @@ class ServerRepository $res = $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'exceptions' => false, 'json' => [ 'keys' => [ (string) $oldDaemonKey => [], - (string) $server->daemonSecret => $this->daemonPermissions - ] - ] + (string) $server->daemonSecret => $this->daemonPermissions, + ], + ], ]); if ($res->getStatusCode() === 204) { DB::commit(); + return true; } else { throw new DisplayException('Daemon returned a a non HTTP/204 error code. HTTP/' + $res->getStatusCode()); @@ -425,11 +419,10 @@ class ServerRepository Log::error($ex); throw new DisplayException('An error occured while attempting to update this server\'s information.'); } - } /** - * [updateContainer description] + * [updateContainer description]. * @param int $id * @param array $data * @return bool @@ -437,7 +430,7 @@ class ServerRepository public function updateContainer($id, array $data) { $validator = Validator::make($data, [ - 'image' => 'required|string' + 'image' => 'required|string', ]); // Run validator, throw catchable and displayable exception if it fails. @@ -459,16 +452,17 @@ class ServerRepository $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ 'build' => [ - 'image' => $server->image - ] - ] + 'image' => $server->image, + ], + ], ]); DB::commit(); + return true; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -477,22 +471,20 @@ class ServerRepository DB::rollBack(); throw $ex; } - } /** - * [changeBuild description] - * @param integer $id + * [changeBuild description]. + * @param int $id * @param array $data - * @return boolean + * @return bool */ public function changeBuild($id, array $data) { - $validator = Validator::make($data, [ 'default' => [ 'string', - 'regex:/^(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5]))\.(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5]))\.(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5]))\.(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5])):(\d{1,5})$/' + 'regex:/^(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5]))\.(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5]))\.(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5]))\.(\d|[1-9]\d|1\d\d|2([0-4]\d|5[0-5])):(\d{1,5})$/', ], 'add_additional' => 'nullable|array', 'remove_additional' => 'nullable|array', @@ -500,7 +492,7 @@ class ServerRepository 'swap' => 'integer|min:-1', 'io' => 'integer|min:10|max:1000', 'cpu' => 'integer|min:0', - 'disk' => 'integer|min:0' + 'disk' => 'integer|min:0', ]); // Run validator, throw catchable and displayable exception if it fails. @@ -521,14 +513,14 @@ class ServerRepository list($ip, $port) = explode(':', $data['default']); if ($ip !== $allocation->ip || (int) $port !== $allocation->port) { $selection = Models\Allocation::where('ip', $ip)->where('port', $port)->where('assigned_to', $server->id)->first(); - if (!$selection) { + if (! $selection) { throw new DisplayException('The requested default connection (' . $ip . ':' . $port . ') is not allocated to this server.'); } $server->allocation = $selection->id; $newBuild['default'] = [ 'ip' => $ip, - 'port' => (int) $port + 'port' => (int) $port, ]; // Re-Run to keep updated for rest of function @@ -542,7 +534,7 @@ class ServerRepository foreach ($data['remove_additional'] as $id => $combo) { list($ip, $port) = explode(':', $combo); // Invalid, not worth killing the whole thing, we'll just skip over it. - if (!filter_var($ip, FILTER_VALIDATE_IP) || !preg_match('/^(\d{1,5})$/', $port)) { + if (! filter_var($ip, FILTER_VALIDATE_IP) || ! preg_match('/^(\d{1,5})$/', $port)) { break; } @@ -553,7 +545,7 @@ class ServerRepository $newPorts = true; Models\Allocation::where('ip', $ip)->where('port', $port)->where('assigned_to', $server->id)->update([ - 'assigned_to' => null + 'assigned_to' => null, ]); } } @@ -563,7 +555,7 @@ class ServerRepository foreach ($data['add_additional'] as $id => $combo) { list($ip, $port) = explode(':', $combo); // Invalid, not worth killing the whole thing, we'll just skip over it. - if (!filter_var($ip, FILTER_VALIDATE_IP) || !preg_match('/^(\d{1,5})$/', $port)) { + if (! filter_var($ip, FILTER_VALIDATE_IP) || ! preg_match('/^(\d{1,5})$/', $port)) { break; } @@ -574,7 +566,7 @@ class ServerRepository $newPorts = true; Models\Allocation::where('ip', $ip)->where('port', $port)->whereNull('assigned_to')->update([ - 'assigned_to' => $server->id + 'assigned_to' => $server->id, ]); } } @@ -584,9 +576,9 @@ class ServerRepository $assignments = Models\Allocation::where('assigned_to', $server->id)->get(); foreach ($assignments as &$assignment) { if (array_key_exists((string) $assignment->ip, $additionalAssignments)) { - array_push($additionalAssignments[ (string) $assignment->ip ], (int) $assignment->port); + array_push($additionalAssignments[(string) $assignment->ip], (int) $assignment->port); } else { - $additionalAssignments[ (string) $assignment->ip ] = [ (int) $assignment->port ]; + $additionalAssignments[(string) $assignment->ip] = [(int) $assignment->port]; } } @@ -627,22 +619,23 @@ class ServerRepository // This won't be committed unless the HTTP request succeedes anyways $server->save(); - if (!empty($newBuild)) { + if (! empty($newBuild)) { $node = Models\Node::getByID($server->node); $client = Models\Node::guzzleRequest($server->node); $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ - 'build' => $newBuild - ] + 'build' => $newBuild, + ], ]); } DB::commit(); + return true; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -651,12 +644,10 @@ class ServerRepository DB::rollBack(); throw $ex; } - } public function updateStartup($id, array $data, $admin = false) { - $server = Models\Server::findOrFail($id); DB::beginTransaction(); @@ -678,13 +669,13 @@ class ServerRepository $variableList = []; if ($variables) { - foreach($variables as &$variable) { + foreach ($variables as &$variable) { // Move on if the new data wasn't even sent - if (!isset($data[$variable->env_variable])) { + if (! isset($data[$variable->env_variable])) { $variableList = array_merge($variableList, [[ 'id' => $variable->id, 'env' => $variable->env_variable, - 'val' => $variable->a_currentValue + 'val' => $variable->a_currentValue, ]]); continue; } @@ -694,7 +685,7 @@ class ServerRepository $variableList = array_merge($variableList, [[ 'id' => $variable->id, 'env' => $variable->env_variable, - 'val' => null + 'val' => null, ]]); continue; } @@ -708,19 +699,19 @@ class ServerRepository } // Variable hidden and/or not user editable - if (($variable->user_viewable === 0 || $variable->user_editable === 0) && !$admin) { + if (($variable->user_viewable === 0 || $variable->user_editable === 0) && ! $admin) { throw new DisplayException('A service option variable field (' . $variable->env_variable . ') does not exist or you do not have permission to edit it.'); } // Check aganist Regex Pattern - if (!is_null($variable->regex) && !preg_match($variable->regex, $data[$variable->env_variable])) { + if (! is_null($variable->regex) && ! preg_match($variable->regex, $data[$variable->env_variable])) { throw new DisplayException('Failed to validate service option variable field (' . $variable->env_variable . ') aganist regex (' . $variable->regex . ').'); } $variableList = array_merge($variableList, [[ 'id' => $variable->id, 'env' => $variable->env_variable, - 'val' => $data[$variable->env_variable] + 'val' => $data[$variable->env_variable], ]]); } } @@ -728,17 +719,17 @@ class ServerRepository // Add Variables $environmentVariables = []; $environmentVariables = array_merge($environmentVariables, [ - 'STARTUP' => $server->startup + 'STARTUP' => $server->startup, ]); - foreach($variableList as $item) { + foreach ($variableList as $item) { $environmentVariables = array_merge($environmentVariables, [ - $item['env'] => $item['val'] + $item['env'] => $item['val'], ]); // Update model or make a new record if it doesn't exist. $model = Models\ServerVariables::firstOrNew([ 'variable_id' => $item['id'], - 'server_id' => $server->id + 'server_id' => $server->id, ]); $model->variable_value = $item['val']; $model->save(); @@ -750,16 +741,17 @@ class ServerRepository $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ 'build' => [ - 'env|overwrite' => $environmentVariables - ] - ] + 'env|overwrite' => $environmentVariables, + ], + ], ]); DB::commit(); + return true; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -768,7 +760,6 @@ class ServerRepository DB::rollBack(); throw $ex; } - } public function deleteServer($id, $force) @@ -792,13 +783,14 @@ class ServerRepository } } - public function deleteNow($id, $force = false) { + public function deleteNow($id, $force = false) + { $server = Models\Server::withTrashed()->findOrFail($id); $node = Models\Node::findOrFail($server->node); // Handle server being restored previously or // an accidental queue. - if (!$server->trashed()) { + if (! $server->trashed()) { return; } @@ -806,7 +798,7 @@ class ServerRepository try { // Unassign Allocations Models\Allocation::where('assigned_to', $server->id)->update([ - 'assigned_to' => null + 'assigned_to' => null, ]); // Remove Variables @@ -828,7 +820,7 @@ class ServerRepository // This is the one un-recoverable point where // transactions will not save us. $repository = new DatabaseRepository; - foreach(Models\Database::select('id')->where('server_id', $server->id)->get() as &$database) { + foreach (Models\Database::select('id')->where('server_id', $server->id)->get() as &$database) { $repository->drop($database->id); } @@ -836,8 +828,8 @@ class ServerRepository $client->request('DELETE', '/servers', [ 'headers' => [ 'X-Access-Token' => $node->daemonSecret, - 'X-Access-Server' => $server->uuid - ] + 'X-Access-Server' => $server->uuid, + ], ]); $server->forceDelete(); @@ -873,13 +865,14 @@ class ServerRepository throw new DisplayException('This server was marked as having a failed install, you cannot override this.'); } $server->installed = ($server->installed === 1) ? 0 : 1; + return $server->save(); } /** * Suspends a server instance making it unable to be booted or used by a user. - * @param integer $id - * @return boolean + * @param int $id + * @return bool */ public function suspend($id, $deleted = false) { @@ -902,8 +895,8 @@ class ServerRepository $client->request('POST', '/server/suspend', [ 'headers' => [ 'X-Access-Token' => $node->daemonSecret, - 'X-Access-Server' => $server->uuid - ] + 'X-Access-Server' => $server->uuid, + ], ]); return DB::commit(); @@ -918,8 +911,8 @@ class ServerRepository /** * Unsuspends a server instance. - * @param integer $id - * @return boolean + * @param int $id + * @return bool */ public function unsuspend($id) { @@ -942,8 +935,8 @@ class ServerRepository $client->request('POST', '/server/unsuspend', [ 'headers' => [ 'X-Access-Token' => $node->daemonSecret, - 'X-Access-Server' => $server->uuid - ] + 'X-Access-Server' => $server->uuid, + ], ]); return DB::commit(); @@ -964,7 +957,7 @@ class ServerRepository $validator = Validator::make([ 'password' => $password, ], [ - 'password' => 'required|regex:/^((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})$/' + 'password' => 'required|regex:/^((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})$/', ]); if ($validator->fails()) { @@ -981,7 +974,7 @@ class ServerRepository $client->request('POST', '/server/password', [ 'headers' => [ 'X-Access-Token' => $node->daemonSecret, - 'X-Access-Server' => $server->uuid + 'X-Access-Server' => $server->uuid, ], 'json' => [ 'password' => $password, @@ -989,6 +982,7 @@ class ServerRepository ]); DB::commit(); + return true; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -997,7 +991,5 @@ class ServerRepository DB::rollBack(); throw $ex; } - } - -} \ No newline at end of file +} diff --git a/app/Repositories/ServiceRepository/Option.php b/app/Repositories/ServiceRepository/Option.php index 60476b50e..dad7e8644 100644 --- a/app/Repositories/ServiceRepository/Option.php +++ b/app/Repositories/ServiceRepository/Option.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,20 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories\ServiceRepository; use DB; use Validator; - use Pterodactyl\Models; -use Pterodactyl\Services\UuidService; - use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Exceptions\DisplayValidationException; class Option { - public function __construct() { // @@ -50,7 +47,7 @@ class Option 'tag' => 'required|string|max:255', 'executable' => 'sometimes|string|max:255', 'docker_image' => 'required|string|max:255', - 'startup' => 'sometimes|string' + 'startup' => 'sometimes|string', ]); if ($validator->fails()) { @@ -105,7 +102,7 @@ class Option 'tag' => 'sometimes|required|string|max:255', 'executable' => 'sometimes|string|max:255', 'docker_image' => 'sometimes|required|string|max:255', - 'startup' => 'sometimes|string' + 'startup' => 'sometimes|string', ]); if ($validator->fails()) { @@ -123,5 +120,4 @@ class Option $option->fill($data); $option->save(); } - } diff --git a/app/Repositories/ServiceRepository/Service.php b/app/Repositories/ServiceRepository/Service.php index 8feb92c1e..39dcf5fbe 100644 --- a/app/Repositories/ServiceRepository/Service.php +++ b/app/Repositories/ServiceRepository/Service.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,21 +21,18 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories\ServiceRepository; use DB; -use Validator; use Uuid; - +use Validator; use Pterodactyl\Models; -use Pterodactyl\Services\UuidService; - use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Exceptions\DisplayValidationException; class Service { - public function __construct() { // @@ -48,7 +45,7 @@ class Service 'description' => 'required|string', 'file' => 'required|regex:/^[\w.-]{1,50}$/', 'executable' => 'max:255|regex:/^(.*)$/', - 'startup' => 'string' + 'startup' => 'string', ]); if ($validator->fails()) { @@ -77,7 +74,7 @@ class Service 'description' => 'sometimes|required|string', 'file' => 'sometimes|required|regex:/^[\w.-]{1,50}$/', 'executable' => 'sometimes|max:255|regex:/^(.*)$/', - 'startup' => 'sometimes|string' + 'startup' => 'sometimes|string', ]); if ($validator->fails()) { @@ -109,5 +106,4 @@ class Service throw $ex; } } - } diff --git a/app/Repositories/ServiceRepository/Variable.php b/app/Repositories/ServiceRepository/Variable.php index 154a8b061..b74801207 100644 --- a/app/Repositories/ServiceRepository/Variable.php +++ b/app/Repositories/ServiceRepository/Variable.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,20 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories\ServiceRepository; use DB; use Validator; - use Pterodactyl\Models; -use Pterodactyl\Services\UuidService; - use Pterodactyl\Exceptions\DisplayException; use Pterodactyl\Exceptions\DisplayValidationException; class Variable { - public function __construct() { // @@ -52,14 +49,14 @@ class Variable 'user_viewable' => 'sometimes|required|numeric|size:1', 'user_editable' => 'sometimes|required|numeric|size:1', 'required' => 'sometimes|required|numeric|size:1', - 'regex' => 'required|string|min:1' + 'regex' => 'required|string|min:1', ]); if ($validator->fails()) { throw new DisplayValidationException($validator->errors()); } - if ($data['default_value'] !== '' && !preg_match($data['regex'], $data['default_value'])) { + if ($data['default_value'] !== '' && ! preg_match($data['regex'], $data['default_value'])) { throw new DisplayException('The default value you entered cannot violate the regex requirements.'); } @@ -77,7 +74,8 @@ class Variable $variable->save(); } - public function delete($id) { + public function delete($id) + { $variable = Models\ServiceVariables::findOrFail($id); DB::beginTransaction(); @@ -104,7 +102,7 @@ class Variable 'user_viewable' => 'sometimes|required|numeric|boolean', 'user_editable' => 'sometimes|required|numeric|boolean', 'required' => 'sometimes|required|numeric|boolean', - 'regex' => 'sometimes|required|string|min:1' + 'regex' => 'sometimes|required|string|min:1', ]); if ($validator->fails()) { @@ -114,7 +112,7 @@ class Variable $data['default_value'] = (isset($data['default_value'])) ? $data['default_value'] : $variable->default_value; $data['regex'] = (isset($data['regex'])) ? $data['regex'] : $variable->regex; - if ($data['default_value'] !== '' && !preg_match($data['regex'], $data['default_value'])) { + if ($data['default_value'] !== '' && ! preg_match($data['regex'], $data['default_value'])) { throw new DisplayException('The default value you entered cannot violate the regex requirements.'); } @@ -129,5 +127,4 @@ class Variable $variable->fill($data); $variable->save(); } - } diff --git a/app/Repositories/SubuserRepository.php b/app/Repositories/SubuserRepository.php index 1e812a14a..d7620732a 100644 --- a/app/Repositories/SubuserRepository.php +++ b/app/Repositories/SubuserRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,23 +21,20 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; use DB; +use Mail; use Settings; use Validator; -use Mail; - use Pterodactyl\Models; -use Pterodactyl\Repositories\UserRepository; use Pterodactyl\Services\UuidService; - -use Pterodactyl\Exceptions\DisplayValidationException; use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Exceptions\DisplayValidationException; class SubuserRepository { - /** * Core permissions required for every subuser on the daemon. * Without this we cannot connect the websocket or get basic @@ -46,7 +43,7 @@ class SubuserRepository */ protected $coreDaemonPermissions = [ 's:get', - 's:console' + 's:console', ]; /** @@ -101,7 +98,7 @@ class SubuserRepository // Databases 'view-databases' => null, - 'reset-db-password' => null + 'reset-db-password' => null, ]; public function __construct() @@ -111,18 +108,18 @@ class SubuserRepository /** * Creates a new subuser on the server. - * @param integer $id The ID of the server to add this subuser to. + * @param int $id The ID of the server to add this subuser to. * @param array $data * @throws DisplayValidationException * @throws DisplayException - * @return integer Returns the ID of the newly created subuser. + * @return int Returns the ID of the newly created subuser. */ public function create($sid, array $data) { $server = Models\Server::findOrFail($sid); $validator = Validator::make($data, [ 'permissions' => 'required|array', - 'email' => 'required|email' + 'email' => 'required|email', ]); if ($validator->fails()) { @@ -134,7 +131,7 @@ class SubuserRepository try { // Determine if this user exists or if we need to make them an account. $user = Models\User::where('email', $data['email'])->first(); - if (!$user) { + if (! $user) { $password = str_random(16); try { $repo = new UserRepository; @@ -151,22 +148,22 @@ class SubuserRepository $subuser->fill([ 'user_id' => $user->id, 'server_id' => $server->id, - 'daemonSecret' => (string) $uuid->generate('servers', 'uuid') + 'daemonSecret' => (string) $uuid->generate('servers', 'uuid'), ]); $subuser->save(); $daemonPermissions = $this->coreDaemonPermissions; - foreach($data['permissions'] as $permission) { + foreach ($data['permissions'] as $permission) { if (array_key_exists($permission, $this->permissions)) { // Build the daemon permissions array for sending. - if (!is_null($this->permissions[$permission])) { + if (! is_null($this->permissions[$permission])) { array_push($daemonPermissions, $this->permissions[$permission]); } $model = new Models\Permission; $model->fill([ 'user_id' => $user->id, 'server_id' => $server->id, - 'permission' => $permission + 'permission' => $permission, ]); $model->save(); } @@ -182,13 +179,13 @@ class SubuserRepository $res = $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ 'keys' => [ - $subuser->daemonSecret => $daemonPermissions - ] - ] + $subuser->daemonSecret => $daemonPermissions, + ], + ], ]); $email = $data['email']; @@ -201,6 +198,7 @@ class SubuserRepository $message->subject(Settings::get('company') . ' - Added to Server'); }); DB::commit(); + return $subuser->id; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -209,12 +207,13 @@ class SubuserRepository DB::rollBack(); throw $ex; } + return false; } /** * Revokes a users permissions on a server. - * @param integer $id The ID of the subuser row in MySQL. + * @param int $id The ID of the subuser row in MySQL. * @param array $data * @throws DisplayValidationException * @throws DisplayException @@ -236,17 +235,18 @@ class SubuserRepository $res = $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ 'keys' => [ - $subuser->daemonSecret => [] - ] - ] + $subuser->daemonSecret => [], + ], + ], ]); $subuser->delete(); DB::commit(); + return true; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -255,12 +255,13 @@ class SubuserRepository DB::rollBack(); throw $ex; } + return false; } /** * Updates permissions for a given subuser. - * @param integer $id The ID of the subuser row in MySQL. (Not the user ID) + * @param int $id The ID of the subuser row in MySQL. (Not the user ID) * @param array $data * @throws DisplayValidationException * @throws DisplayException @@ -287,17 +288,17 @@ class SubuserRepository Models\Permission::where('user_id', $subuser->user_id)->where('server_id', $subuser->server_id)->delete(); $daemonPermissions = $this->coreDaemonPermissions; - foreach($data['permissions'] as $permission) { + foreach ($data['permissions'] as $permission) { if (array_key_exists($permission, $this->permissions)) { // Build the daemon permissions array for sending. - if (!is_null($this->permissions[$permission])) { + if (! is_null($this->permissions[$permission])) { array_push($daemonPermissions, $this->permissions[$permission]); } $model = new Models\Permission; $model->fill([ 'user_id' => $data['user'], 'server_id' => $data['server'], - 'permission' => $permission + 'permission' => $permission, ]); $model->save(); } @@ -312,16 +313,17 @@ class SubuserRepository $res = $client->request('PATCH', '/server', [ 'headers' => [ 'X-Access-Server' => $server->uuid, - 'X-Access-Token' => $node->daemonSecret + 'X-Access-Token' => $node->daemonSecret, ], 'json' => [ 'keys' => [ - $subuser->daemonSecret => $daemonPermissions - ] - ] + $subuser->daemonSecret => $daemonPermissions, + ], + ], ]); DB::commit(); + return true; } catch (\GuzzleHttp\Exception\TransferException $ex) { DB::rollBack(); @@ -330,7 +332,7 @@ class SubuserRepository DB::rollBack(); throw $ex; } + return false; } - } diff --git a/app/Repositories/TaskRepository.php b/app/Repositories/TaskRepository.php index 5722ab929..b285f65be 100644 --- a/app/Repositories/TaskRepository.php +++ b/app/Repositories/TaskRepository.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,19 +21,17 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; use Cron; use Validator; - use Pterodactyl\Models; - -use Pterodactyl\Exceptions\DisplayValidationException; use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Exceptions\DisplayValidationException; class TaskRepository { - protected $defaults = [ 'year' => '*', 'day_of_week' => '*', @@ -64,6 +62,7 @@ class TaskRepository $task = Models\Task::findOrFail($id); try { $task->delete(); + return true; } catch (\Exception $ex) { throw $ex; @@ -111,20 +110,20 @@ class TaskRepository 'month' => 'string|sometimes', 'day_of_month' => 'string|sometimes', 'hour' => 'string|sometimes', - 'minute' => 'string|sometimes' + 'minute' => 'string|sometimes', ]); if ($validator->fails()) { throw new DisplayValidationException(json_encode($validator->errors())); } - if (!in_array($data['action'], $this->actions)) { + if (! in_array($data['action'], $this->actions)) { throw new DisplayException('The action provided is not valid.'); } $cron = $this->defaults; foreach ($this->defaults as $setting => $value) { - if (array_key_exists($setting, $data) && !is_null($data[$setting]) && $data[$setting] !== '') { + if (array_key_exists($setting, $data) && ! is_null($data[$setting]) && $data[$setting] !== '') { $cron[$setting] = $data[$setting]; } } @@ -157,11 +156,9 @@ class TaskRepository 'hour' => $cron['hour'], 'minute' => $cron['minute'], 'last_run' => null, - 'next_run' => $buildCron->getNextRunDate() + 'next_run' => $buildCron->getNextRunDate(), ]); return $task->save(); - } - } diff --git a/app/Repositories/UserRepository.php b/app/Repositories/UserRepository.php index 01cad4269..6bb7f2491 100644 --- a/app/Repositories/UserRepository.php +++ b/app/Repositories/UserRepository.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,26 +22,22 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Repositories; use DB; -use Settings; -use Hash; -use Validator; -use Mail; -use Carbon; use Auth; - +use Hash; +use Carbon; +use Validator; use Pterodactyl\Models; use Pterodactyl\Services\UuidService; -use Pterodactyl\Notifications\AccountCreated; - -use Pterodactyl\Exceptions\DisplayValidationException; use Pterodactyl\Exceptions\DisplayException; +use Pterodactyl\Notifications\AccountCreated; +use Pterodactyl\Exceptions\DisplayValidationException; class UserRepository { - public function __construct() { // @@ -54,7 +50,7 @@ class UserRepository * @param string|null $password An unhashed version of the user's password. * @param bool $admin Boolean value if user should be an admin or not. * @param int $token A custom user ID. - * @return bool|integer + * @return bool|int */ public function create($email, $password = null, $admin = false, $token = null) { @@ -83,7 +79,7 @@ class UserRepository $uuid = new UuidService; // Support for API Services - if (!is_null($token)) { + if (! is_null($token)) { $user->id = $token; } @@ -99,12 +95,13 @@ class UserRepository DB::table('password_resets')->insert([ 'email' => $user->email, 'token' => $token, - 'created_at' => Carbon::now()->toDateTimeString() + 'created_at' => Carbon::now()->toDateTimeString(), ]); $user->notify((new AccountCreated($token))); DB::commit(); + return $user->id; } catch (\Exception $ex) { DB::rollBack(); @@ -115,9 +112,9 @@ class UserRepository /** * Updates a user on the panel. * - * @param integer $id + * @param int $id * @param array $data An array of columns and their associated values to update for the user. - * @return boolean + * @return bool */ public function update($id, array $data) { @@ -129,7 +126,7 @@ class UserRepository 'root_admin' => 'sometimes|required|boolean', 'language' => 'sometimes|required|string|min:1|max:5', 'use_totp' => 'sometimes|required|boolean', - 'totp_secret' => 'sometimes|required|size:16' + 'totp_secret' => 'sometimes|required|size:16', ]); // Run validator, throw catchable and displayable exception if it fails. @@ -138,7 +135,7 @@ class UserRepository throw new DisplayValidationException($validator->errors()); } - if(array_key_exists('password', $data)) { + if (array_key_exists('password', $data)) { $data['password'] = Hash::make($data['password']); } @@ -153,18 +150,18 @@ class UserRepository /** * Deletes a user on the panel, returns the number of records deleted. * - * @param integer $id - * @return integer + * @param int $id + * @return int */ public function delete($id) { - if(Models\Server::where('owner', $id)->count() > 0) { + if (Models\Server::where('owner', $id)->count() > 0) { throw new DisplayException('Cannot delete a user with active servers attached to thier account.'); } // @TODO: this should probably be checked outside of this method because we won't always have Auth::user() - if(!is_null(Auth::user()) && Auth::user()->id === $id) { - throw new DisplayException('Cannot delete your own account.'); + if (! is_null(Auth::user()) && Auth::user()->id === $id) { + throw new DisplayException('Cannot delete your own account.'); } DB::beginTransaction(); @@ -175,11 +172,11 @@ class UserRepository Models\User::destroy($id); DB::commit(); + return true; } catch (\Exception $ex) { DB::rollBack(); throw $ex; } } - } diff --git a/app/Services/APILogService.php b/app/Services/APILogService.php index f1d8255be..ee2bf3b00 100644 --- a/app/Services/APILogService.php +++ b/app/Services/APILogService.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,16 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Services; use Log; - use Illuminate\Http\Request; use Pterodactyl\Models\APILog; class APILogService { - public function __constructor() { // @@ -38,7 +37,7 @@ class APILogService public static function log(Request $request, $error = null, $authorized = false) { - if ($request->bearerToken() && !empty($request->bearerToken())) { + if ($request->bearerToken() && ! empty($request->bearerToken())) { list($public, $hashed) = explode('.', $request->bearerToken()); } else { $public = null; @@ -53,7 +52,7 @@ class APILogService 'route' => $request->fullUrl(), 'content' => (empty($request->getContent())) ? null : $request->getContent(), 'user_agent' => $request->header('User-Agent'), - 'request_ip' => $request->ip() + 'request_ip' => $request->ip(), ]); $log->save(); } catch (\Exception $ex) { diff --git a/app/Services/DeploymentService.php b/app/Services/DeploymentService.php index 5d0c7d5e1..207cacc94 100644 --- a/app/Services/DeploymentService.php +++ b/app/Services/DeploymentService.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,16 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Services; use DB; - use Pterodactyl\Models; use Pterodactyl\Exceptions\DisplayException; class DeploymentService { - public function __constructor() { // @@ -62,12 +61,12 @@ class DeploymentService public static function randomNode($location, array $not = []) { $useLocation = Models\Location::where('id', $location)->first(); - if (!$useLocation) { - throw new DisplayException("The location passed was not valid and could not be found."); + if (! $useLocation) { + throw new DisplayException('The location passed was not valid and could not be found.'); } $node = Models\Node::where('location', $useLocation->id)->where('public', 1)->whereNotIn('id', $not)->inRandomOrder()->first(); - if (!$node) { + if (! $node) { throw new DisplayException("Unable to find a node in location {$useLocation->short} (id: {$useLocation->id}) that is available and has space."); } @@ -84,18 +83,19 @@ class DeploymentService * * @throws \Pterodactyl\Exceptions\DisplayException */ - public static function smartRandomNode($memory, $disk, $location = null) { + public static function smartRandomNode($memory, $disk, $location = null) + { $node = self::randomNode($location); $notIn = []; do { $return = self::checkNodeAllocation($node, $memory, $disk); - if (!$return) { + if (! $return) { $notIn = array_merge($notIn, [ - $node->id + $node->id, ]); $node = self::randomNode($location, $notIn); } - } while (!$return); + } while (! $return); return $node; } @@ -108,7 +108,7 @@ class DeploymentService public static function randomAllocation($node) { $allocation = Models\Allocation::where('node', $node)->whereNull('assigned_to')->inRandomOrder()->first(); - if (!$allocation) { + if (! $allocation) { throw new DisplayException('No available allocation could be found for the assigned node.'); } @@ -139,7 +139,7 @@ class DeploymentService $diskLimitReached = (($totals->disk + $disk) > $limit); } - return (!$diskLimitReached && !$memoryLimitReached); + return ! $diskLimitReached && ! $memoryLimitReached; } } } diff --git a/app/Services/NotificationService.php b/app/Services/NotificationService.php index 0ae6192f9..690945246 100644 --- a/app/Services/NotificationService.php +++ b/app/Services/NotificationService.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,15 +21,15 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Services; -use Pterodactyl\Models\Server; use Pterodactyl\Models\User; - +use Pterodactyl\Models\Server; use Pterodactyl\Notifications\Daemon; -class NotificationService { - +class NotificationService +{ protected $server; protected $user; @@ -53,7 +53,7 @@ class NotificationService { public function pass(array $notification) { - if (!$notification->type) { + if (! $notification->type) { return; } diff --git a/app/Services/UuidService.php b/app/Services/UuidService.php index 430c82f82..09bfde0d9 100644 --- a/app/Services/UuidService.php +++ b/app/Services/UuidService.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Services; use DB; @@ -28,9 +29,8 @@ use Uuid; class UuidService { - /** - * Constructor + * Constructor. */ public function __construct() { @@ -39,28 +39,24 @@ class UuidService /** * Generate a unique UUID validating against specified table and column. - * Defaults to `users.uuid` + * Defaults to `users.uuid`. * * @param string $table * @param string $field - * @param integer $type The type of UUID to generate. + * @param int $type The type of UUID to generate. * @return string */ public function generate($table = 'users', $field = 'uuid', $type = 4) { - $return = false; do { - $uuid = Uuid::generate($type); - if (!DB::table($table)->where($field, $uuid)->exists()) { + if (! DB::table($table)->where($field, $uuid)->exists()) { $return = $uuid; } - - } while (!$return); + } while (! $return); return (string) $return; - } /** @@ -72,21 +68,16 @@ class UuidService */ public function generateShort($table = 'servers', $field = 'uuidShort', $attachedUuid = null) { - $return = false; do { - $short = (is_null($attachedUuid)) ? substr(Uuid::generate(4), 0, 8) : substr($attachedUuid, 0, 8); $attachedUuid = null; - if (!DB::table($table)->where($field, $short)->exists()) { + if (! DB::table($table)->where($field, $short)->exists()) { $return = $short; } - - } while (!$return); + } while (! $return); return (string) $return; - } - } diff --git a/app/Services/VersionService.php b/app/Services/VersionService.php index 5afb97e46..135a04585 100644 --- a/app/Services/VersionService.php +++ b/app/Services/VersionService.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Services; use Cache; @@ -28,11 +29,10 @@ use GuzzleHttp\Client; class VersionService { - protected static $versions; /** - * Constructor + * Constructor. */ public function __construct() { @@ -78,7 +78,7 @@ class VersionService return true; } - return (version_compare(config('app.version'), self::$versions->panel) >= 0); + return version_compare(config('app.version'), self::$versions->panel) >= 0; } public static function isLatestDaemon($daemon) @@ -87,7 +87,6 @@ class VersionService return true; } - return (version_compare($daemon, self::$versions->daemon) >= 0); + return version_compare($daemon, self::$versions->daemon) >= 0; } - } diff --git a/app/Transformers/AllocationTransformer.php b/app/Transformers/AllocationTransformer.php index 2ab9e5b1f..3a8ac43f7 100644 --- a/app/Transformers/AllocationTransformer.php +++ b/app/Transformers/AllocationTransformer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Transformers; use Pterodactyl\Models\Allocation; @@ -28,9 +29,8 @@ use League\Fractal\TransformerAbstract; class AllocationTransformer extends TransformerAbstract { - /** - * Turn this item object into a generic array + * Turn this item object into a generic array. * * @return array */ @@ -38,5 +38,4 @@ class AllocationTransformer extends TransformerAbstract { return array_except($allocation, ['created_at', 'updated_at']); } - } diff --git a/app/Transformers/NodeTransformer.php b/app/Transformers/NodeTransformer.php index 9b3224c37..a5ac61442 100755 --- a/app/Transformers/NodeTransformer.php +++ b/app/Transformers/NodeTransformer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Transformers; use Pterodactyl\Models\Node; @@ -28,9 +29,8 @@ use League\Fractal\TransformerAbstract; class NodeTransformer extends TransformerAbstract { - /** - * Turn this item object into a generic array + * Turn this item object into a generic array. * * @return array */ @@ -38,5 +38,4 @@ class NodeTransformer extends TransformerAbstract { return $node; } - } diff --git a/app/Transformers/ServerTransformer.php b/app/Transformers/ServerTransformer.php index 482cf8419..a6ef28a1f 100755 --- a/app/Transformers/ServerTransformer.php +++ b/app/Transformers/ServerTransformer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Transformers; use Pterodactyl\Models\Server; @@ -28,9 +29,8 @@ use League\Fractal\TransformerAbstract; class ServerTransformer extends TransformerAbstract { - /** - * Turn this item object into a generic array + * Turn this item object into a generic array. * * @return array */ @@ -38,5 +38,4 @@ class ServerTransformer extends TransformerAbstract { return $server; } - } diff --git a/app/Transformers/UserTransformer.php b/app/Transformers/UserTransformer.php index abd90c34d..14ef4bca3 100755 --- a/app/Transformers/UserTransformer.php +++ b/app/Transformers/UserTransformer.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,6 +21,7 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ + namespace Pterodactyl\Transformers; use Pterodactyl\Models\User; @@ -28,9 +29,8 @@ use League\Fractal\TransformerAbstract; class UserTransformer extends TransformerAbstract { - /** - * Turn this item object into a generic array + * Turn this item object into a generic array. * * @return array */ @@ -38,5 +38,4 @@ class UserTransformer extends TransformerAbstract { return $user; } - } diff --git a/bootstrap/app.php b/bootstrap/app.php index 81378a886..f35c15929 100644 --- a/bootstrap/app.php +++ b/bootstrap/app.php @@ -12,7 +12,7 @@ */ $app = new Illuminate\Foundation\Application( - realpath(__DIR__.'/../') + realpath(__DIR__ . '/../') ); /* diff --git a/bootstrap/autoload.php b/bootstrap/autoload.php index 383013796..0f7519510 100644 --- a/bootstrap/autoload.php +++ b/bootstrap/autoload.php @@ -14,7 +14,7 @@ define('LARAVEL_START', microtime(true)); | */ -require __DIR__.'/../vendor/autoload.php'; +require __DIR__ . '/../vendor/autoload.php'; /* |-------------------------------------------------------------------------- @@ -27,7 +27,7 @@ require __DIR__.'/../vendor/autoload.php'; | */ -$compiledPath = __DIR__.'/cache/compiled.php'; +$compiledPath = __DIR__ . '/cache/compiled.php'; if (file_exists($compiledPath)) { require $compiledPath; diff --git a/config/debugbar.php b/config/debugbar.php index bae876c70..4c1349b40 100644 --- a/config/debugbar.php +++ b/config/debugbar.php @@ -1,6 +1,6 @@ array( + 'storage' => [ 'enabled' => true, 'driver' => 'file', // redis, file, pdo 'path' => storage_path() . '/debugbar', // For file driver 'connection' => null, // Leave null for default connection (Redis/PDO) - ), + ], /* |-------------------------------------------------------------------------- @@ -81,7 +81,7 @@ return array( | */ - 'collectors' => array( + 'collectors' => [ 'phpinfo' => true, // Php version 'messages' => true, // Messages 'time' => true, // Time Datalogger @@ -102,7 +102,7 @@ return array( 'auth' => false, // Display Laravel authentication status 'gate' => false, // Display Laravel Gate checks 'session' => true, // Display session data - ), + ], /* |-------------------------------------------------------------------------- @@ -113,33 +113,33 @@ return array( | */ - 'options' => array( - 'auth' => array( + 'options' => [ + 'auth' => [ 'show_name' => false, // Also show the users name/email in the debugbar - ), - 'db' => array( + ], + 'db' => [ 'with_params' => true, // Render SQL with the parameters substituted 'timeline' => false, // Add the queries to the timeline 'backtrace' => false, // EXPERIMENTAL: Use a backtrace to find the origin of the query in your files. - 'explain' => array( // EXPERIMENTAL: Show EXPLAIN output on queries + 'explain' => [ // EXPERIMENTAL: Show EXPLAIN output on queries 'enabled' => false, - 'types' => array('SELECT'), // array('SELECT', 'INSERT', 'UPDATE', 'DELETE'); for MySQL 5.6.3+ - ), + 'types' => ['SELECT'], // array('SELECT', 'INSERT', 'UPDATE', 'DELETE'); for MySQL 5.6.3+ + ], 'hints' => true, // Show hints for common mistakes - ), - 'mail' => array( - 'full_log' => false - ), - 'views' => array( + ], + 'mail' => [ + 'full_log' => false, + ], + 'views' => [ 'data' => false, //Note: Can slow down the application, because the data can be quite large.. - ), - 'route' => array( - 'label' => true // show complete route on bar - ), - 'logs' => array( - 'file' => null - ), - ), + ], + 'route' => [ + 'label' => true, // show complete route on bar + ], + 'logs' => [ + 'file' => null, + ], + ], /* |-------------------------------------------------------------------------- @@ -166,4 +166,4 @@ return array( */ 'route_prefix' => '_debugbar', -); +]; diff --git a/database/migrations/2016_03_18_155649_add_nullable_field_lastrun.php b/database/migrations/2016_03_18_155649_add_nullable_field_lastrun.php index 65a0b3d9c..9065947d6 100644 --- a/database/migrations/2016_03_18_155649_add_nullable_field_lastrun.php +++ b/database/migrations/2016_03_18_155649_add_nullable_field_lastrun.php @@ -1,6 +1,5 @@ wrapTable('tasks'); - DB::statement('ALTER TABLE '.$table.' CHANGE `last_run` `last_run` TIMESTAMP NULL;'); + DB::statement('ALTER TABLE ' . $table . ' CHANGE `last_run` `last_run` TIMESTAMP NULL;'); } /** @@ -24,6 +23,6 @@ class AddNullableFieldLastrun extends Migration public function down() { $table = DB::getQueryGrammar()->wrapTable('tasks'); - DB::statement('ALTER TABLE '.$table.' CHANGE `last_run` `last_run` TIMESTAMP;'); + DB::statement('ALTER TABLE ' . $table . ' CHANGE `last_run` `last_run` TIMESTAMP;'); } } diff --git a/database/migrations/2016_08_30_212718_add_ip_alias.php b/database/migrations/2016_08_30_212718_add_ip_alias.php index 4726e5068..e75930edd 100644 --- a/database/migrations/2016_08_30_212718_add_ip_alias.php +++ b/database/migrations/2016_08_30_212718_add_ip_alias.php @@ -17,12 +17,12 @@ class AddIpAlias extends Migration }); $allocations = DB::select('SELECT id, ip FROM allocations'); - foreach($allocations as $allocation) { + foreach ($allocations as $allocation) { DB::update( 'UPDATE allocations SET ip_alias = :ip WHERE id = :id', [ 'ip' => $allocation->ip, - 'id' => $allocation->id + 'id' => $allocation->id, ] ); } diff --git a/database/migrations/2016_08_30_213301_modify_ip_storage_method.php b/database/migrations/2016_08_30_213301_modify_ip_storage_method.php index e49d335d5..b77ccbea6 100644 --- a/database/migrations/2016_08_30_213301_modify_ip_storage_method.php +++ b/database/migrations/2016_08_30_213301_modify_ip_storage_method.php @@ -18,13 +18,13 @@ class ModifyIpStorageMethod extends Migration // Parse All Servers $servers = DB::select('SELECT id, ip, port, node FROM servers'); - foreach($servers as $server) { + foreach ($servers as $server) { $allocation = DB::select( 'SELECT id FROM allocations WHERE ip = :ip AND port = :port AND node = :node', [ 'ip' => $server->ip, 'port' => $server->port, - 'node' => $server->node + 'node' => $server->node, ] ); @@ -33,7 +33,7 @@ class ModifyIpStorageMethod extends Migration 'UPDATE servers SET allocation = :alocid WHERE id = :id', [ 'alocid' => $allocation[0]->id, - 'id' => $server->id + 'id' => $server->id, ] ); } @@ -44,7 +44,6 @@ class ModifyIpStorageMethod extends Migration $table->dropColumn('ip'); $table->dropColumn('port'); }); - } /** @@ -54,7 +53,6 @@ class ModifyIpStorageMethod extends Migration */ public function down() { - Schema::table('servers', function (Blueprint $table) { $table->text('ip')->after('allocation'); $table->integer('port')->unsigned()->after('ip'); @@ -62,8 +60,8 @@ class ModifyIpStorageMethod extends Migration // Find the allocations and reset the servers... $servers = DB::select('SELECT id, allocation FROM servers'); - foreach($servers as $server) { - $allocation = DB::select('SELECT * FROM allocations WHERE id = :alocid', [ 'alocid' => $server->allocation ]); + foreach ($servers as $server) { + $allocation = DB::select('SELECT * FROM allocations WHERE id = :alocid', ['alocid' => $server->allocation]); if (isset($allocation[0])) { DB::update( @@ -71,7 +69,7 @@ class ModifyIpStorageMethod extends Migration [ 'ip' => $allocation[0]->ip, 'port' => $allocation[0]->port, - 'id' => $server->id + 'id' => $server->id, ] ); } diff --git a/database/migrations/2016_09_17_194246_add_docker_image_column.php b/database/migrations/2016_09_17_194246_add_docker_image_column.php index bea676a08..58e4b87a3 100644 --- a/database/migrations/2016_09_17_194246_add_docker_image_column.php +++ b/database/migrations/2016_09_17_194246_add_docker_image_column.php @@ -4,8 +4,6 @@ use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; -use Pterodactyl\Models\Server; - class AddDockerImageColumn extends Migration { /** diff --git a/database/migrations/2016_09_29_213518_rename_double_insurgency.php b/database/migrations/2016_09_29_213518_rename_double_insurgency.php index 6c0ea8070..4fecb8bdf 100644 --- a/database/migrations/2016_09_29_213518_rename_double_insurgency.php +++ b/database/migrations/2016_09_29_213518_rename_double_insurgency.php @@ -1,7 +1,5 @@ text('user_agent'); $table->ipAddress('request_ip'); $table->timestampsTz(); - }); } diff --git a/database/migrations/2016_10_23_181719_update_misnamed_bungee.php b/database/migrations/2016_10_23_181719_update_misnamed_bungee.php index 5a91e0138..0a5316755 100644 --- a/database/migrations/2016_10_23_181719_update_misnamed_bungee.php +++ b/database/migrations/2016_10_23_181719_update_misnamed_bungee.php @@ -1,7 +1,5 @@ select('env_variable')->where('env_variable', 'BUNGE_VERSION')->update([ - 'env_variable' => 'BUNGEE_VERSION' + 'env_variable' => 'BUNGEE_VERSION', ]); } @@ -25,6 +23,5 @@ class UpdateMisnamedBungee extends Migration */ public function down() { - return; } } diff --git a/database/migrations/2016_10_23_201624_add_foreign_allocations.php b/database/migrations/2016_10_23_201624_add_foreign_allocations.php index 6b73df2d6..8ff9bdd2f 100644 --- a/database/migrations/2016_10_23_201624_add_foreign_allocations.php +++ b/database/migrations/2016_10_23_201624_add_foreign_allocations.php @@ -12,17 +12,17 @@ class AddForeignAllocations extends Migration * @return void */ public function up() - { - DB::statement('ALTER TABLE allocations + { + DB::statement('ALTER TABLE allocations MODIFY COLUMN assigned_to INT(10) UNSIGNED NULL, MODIFY COLUMN node INT(10) UNSIGNED NOT NULL '); - Schema::table('allocations', function (Blueprint $table) { - $table->foreign('assigned_to')->references('id')->on('servers'); - $table->foreign('node')->references('id')->on('nodes'); - }); - } + Schema::table('allocations', function (Blueprint $table) { + $table->foreign('assigned_to')->references('id')->on('servers'); + $table->foreign('node')->references('id')->on('nodes'); + }); + } /** * Reverse the migrations. diff --git a/database/migrations/2016_10_23_203522_add_foreign_permissions.php b/database/migrations/2016_10_23_203522_add_foreign_permissions.php index 8de3f3b8f..153ab27ce 100644 --- a/database/migrations/2016_10_23_203522_add_foreign_permissions.php +++ b/database/migrations/2016_10_23_203522_add_foreign_permissions.php @@ -34,5 +34,4 @@ class AddForeignPermissions extends Migration $table->dropIndex('permissions_server_id_foreign'); }); } - } diff --git a/database/migrations/2016_10_23_203857_add_foreign_server_variables.php b/database/migrations/2016_10_23_203857_add_foreign_server_variables.php index 116434161..c232176c7 100644 --- a/database/migrations/2016_10_23_203857_add_foreign_server_variables.php +++ b/database/migrations/2016_10_23_203857_add_foreign_server_variables.php @@ -44,5 +44,4 @@ class AddForeignServerVariables extends Migration MODIFY COLUMN variable_id MEDIUMINT(8) UNSIGNED NOT NULL '); } - } diff --git a/database/migrations/2016_10_23_204321_add_foreign_service_variables.php b/database/migrations/2016_10_23_204321_add_foreign_service_variables.php index 4f7f43ae2..291ca24e2 100644 --- a/database/migrations/2016_10_23_204321_add_foreign_service_variables.php +++ b/database/migrations/2016_10_23_204321_add_foreign_service_variables.php @@ -34,4 +34,4 @@ class AddForeignServiceVariables extends Migration DB::statement('ALTER TABLE service_variables MODIFY option_id MEDIUMINT(8) UNSIGNED NOT NULL'); } - } +} diff --git a/database/migrations/2016_11_04_000949_add_ark_service_option_fixed.php b/database/migrations/2016_11_04_000949_add_ark_service_option_fixed.php index fa8d5dde6..5a2dd6da4 100644 --- a/database/migrations/2016_11_04_000949_add_ark_service_option_fixed.php +++ b/database/migrations/2016_11_04_000949_add_ark_service_option_fixed.php @@ -1,7 +1,5 @@ select('id')->where('author', 'ptrdctyl-v040-11e6-8b77-86f30ca893d3')->where('name', 'Source Engine')->first(); // No SRCDS Service, Skipping - if (!$service) { + if (! $service) { return; } @@ -33,7 +31,7 @@ class AddArkServiceOptionFixed extends Migration 'tag' => 'ark', 'docker_image' => 'quay.io/pterodactyl/srcds:ark', 'executable' => './ShooterGameServer', - 'startup' => 'TheIsland?listen?ServerPassword={{ARK_PASSWORD}}?ServerAdminPassword={{ARK_ADMIN_PASSWORD}}?Port={{SERVER_PORT}}?MaxPlayers={{SERVER_MAX_PLAYERS}}' + 'startup' => 'TheIsland?listen?ServerPassword={{ARK_PASSWORD}}?ServerAdminPassword={{ARK_ADMIN_PASSWORD}}?Port={{SERVER_PORT}}?MaxPlayers={{SERVER_MAX_PLAYERS}}', ]); DB::table('service_variables')->insert([ @@ -45,7 +43,7 @@ class AddArkServiceOptionFixed extends Migration 'user_viewable' => 1, 'user_editable' => 1, 'required' => 0, - 'regex' => '/^(\w\.*)$/' + 'regex' => '/^(\w\.*)$/', ]); DB::table('service_variables')->insert([ @@ -57,7 +55,7 @@ class AddArkServiceOptionFixed extends Migration 'user_viewable' => 1, 'user_editable' => 1, 'required' => 0, - 'regex' => '/^(\w\.*)$/' + 'regex' => '/^(\w\.*)$/', ]); DB::table('service_variables')->insert([ @@ -69,10 +67,9 @@ class AddArkServiceOptionFixed extends Migration 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(\d{1,4})$/' + 'regex' => '/^(\d{1,4})$/', ]); }); - } /** diff --git a/database/migrations/2016_12_02_185206_correct_service_variables.php b/database/migrations/2016_12_02_185206_correct_service_variables.php index f3da07e0a..dd99c1223 100644 --- a/database/migrations/2016_12_02_185206_correct_service_variables.php +++ b/database/migrations/2016_12_02_185206_correct_service_variables.php @@ -1,7 +1,5 @@ update([ 'name' => 'Server Version', 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/', diff --git a/database/seeds/MinecraftServiceTableSeeder.php b/database/seeds/MinecraftServiceTableSeeder.php index 9f55abb80..4b33d8957 100644 --- a/database/seeds/MinecraftServiceTableSeeder.php +++ b/database/seeds/MinecraftServiceTableSeeder.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,9 +21,8 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -use Illuminate\Database\Seeder; - use Pterodactyl\Models; +use Illuminate\Database\Seeder; class MinecraftServiceTableSeeder extends Seeder { @@ -35,7 +34,7 @@ class MinecraftServiceTableSeeder extends Seeder protected $service; /** - * Stores all of the option objects + * Stores all of the option objects. * * @var array */ @@ -61,7 +60,7 @@ class MinecraftServiceTableSeeder extends Seeder 'description' => 'Minecraft - the classic game from Mojang. With support for Vanilla MC, Spigot, and many others!', 'file' => 'minecraft', 'executable' => 'java', - 'startup' => '-Xms128M -Xmx{{SERVER_MEMORY}}M -jar {{SERVER_JARFILE}}' + 'startup' => '-Xms128M -Xmx{{SERVER_MEMORY}}M -jar {{SERVER_JARFILE}}', ]); } @@ -74,7 +73,7 @@ class MinecraftServiceTableSeeder extends Seeder 'tag' => 'vanilla', 'docker_image' => 'quay.io/pterodactyl/minecraft', 'executable' => null, - 'startup' => null + 'startup' => null, ]); $this->option['spigot'] = Models\ServiceOptions::create([ @@ -84,7 +83,7 @@ class MinecraftServiceTableSeeder extends Seeder 'tag' => 'spigot', 'docker_image' => 'quay.io/pterodactyl/minecraft:spigot', 'executable' => null, - 'startup' => '-Xms128M -Xmx{{SERVER_MEMORY}}M -jar {{SERVER_JARFILE}}' + 'startup' => '-Xms128M -Xmx{{SERVER_MEMORY}}M -jar {{SERVER_JARFILE}}', ]); $this->option['sponge'] = Models\ServiceOptions::create([ @@ -94,7 +93,7 @@ class MinecraftServiceTableSeeder extends Seeder 'tag' => 'spigot', 'docker_image' => 'quay.io/pterodactyl/minecraft:sponge', 'executable' => null, - 'startup' => null + 'startup' => null, ]); $this->option['bungeecord'] = Models\ServiceOptions::create([ @@ -104,7 +103,7 @@ class MinecraftServiceTableSeeder extends Seeder 'tag' => 'bungeecord', 'docker_image' => 'quay.io/pterodactyl/minecraft:bungeecord', 'executable' => null, - 'startup' => null + 'startup' => null, ]); } @@ -127,7 +126,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([\w\d._-]+)(\.jar)$/' + 'regex' => '/^([\w\d._-]+)(\.jar)$/', ]); Models\ServiceVariables::create([ @@ -139,7 +138,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/' + 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/', ]); } @@ -154,7 +153,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([\w\d._-]+)(\.jar)$/' + 'regex' => '/^([\w\d._-]+)(\.jar)$/', ]); Models\ServiceVariables::create([ @@ -166,7 +165,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/' + 'regex' => '/^(latest|[a-zA-Z0-9_\.-]{3,7})$/', ]); Models\ServiceVariables::create([ @@ -178,7 +177,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 0, 'user_editable' => 0, 'required' => 0, - 'regex' => '/^(.*)$/' + 'regex' => '/^(.*)$/', ]); } @@ -193,7 +192,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^([a-zA-Z0-9.\-_]+)$/' + 'regex' => '/^([a-zA-Z0-9.\-_]+)$/', ]); Models\ServiceVariables::create([ @@ -205,7 +204,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([\w\d._-]+)(\.jar)$/' + 'regex' => '/^([\w\d._-]+)(\.jar)$/', ]); } @@ -220,7 +219,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(latest|[\d]{1,6})$/' + 'regex' => '/^(latest|[\d]{1,6})$/', ]); Models\ServiceVariables::create([ @@ -232,7 +231,7 @@ class MinecraftServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([\w\d._-]+)(\.jar)$/' + 'regex' => '/^([\w\d._-]+)(\.jar)$/', ]); } } diff --git a/database/seeds/SourceServiceTableSeeder.php b/database/seeds/SourceServiceTableSeeder.php index 2c4b25d55..fc2ff640f 100644 --- a/database/seeds/SourceServiceTableSeeder.php +++ b/database/seeds/SourceServiceTableSeeder.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,9 +21,8 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -use Illuminate\Database\Seeder; - use Pterodactyl\Models; +use Illuminate\Database\Seeder; class SourceServiceTableSeeder extends Seeder { @@ -35,7 +34,7 @@ class SourceServiceTableSeeder extends Seeder protected $service; /** - * Stores all of the option objects + * Stores all of the option objects. * * @var array */ @@ -61,7 +60,7 @@ class SourceServiceTableSeeder extends Seeder 'description' => 'Includes support for most Source Dedicated Server games.', 'file' => 'srcds', 'executable' => './srcds_run', - 'startup' => '-game {{SRCDS_GAME}} -console -port {{SERVER_PORT}} -strictportbind -norestart' + 'startup' => '-game {{SRCDS_GAME}} -console -port {{SERVER_PORT}} -strictportbind -norestart', ]); } @@ -74,7 +73,7 @@ class SourceServiceTableSeeder extends Seeder 'tag' => 'srcds', 'docker_image' => 'quay.io/pterodactyl/srcds', 'executable' => null, - 'startup' => '-game {{SRCDS_GAME}} -console -port {{SERVER_PORT}} +map {{SRCDS_MAP}} -strictportbind -norestart' + 'startup' => '-game {{SRCDS_GAME}} -console -port {{SERVER_PORT}} +map {{SRCDS_MAP}} -strictportbind -norestart', ]); $this->option['tf2'] = Models\ServiceOptions::create([ @@ -84,7 +83,7 @@ class SourceServiceTableSeeder extends Seeder 'tag' => 'srcds', 'docker_image' => 'quay.io/pterodactyl/srcds', 'executable' => null, - 'startup' => '-game {{SRCDS_GAME}} -console -port {{SERVER_PORT}} +map {{SRCDS_MAP}} -strictportbind -norestart' + 'startup' => '-game {{SRCDS_GAME}} -console -port {{SERVER_PORT}} +map {{SRCDS_MAP}} -strictportbind -norestart', ]); $this->option['ark'] = Models\ServiceOptions::create([ @@ -94,7 +93,7 @@ class SourceServiceTableSeeder extends Seeder 'tag' => 'ark', 'docker_image' => 'quay.io/pterodactyl/srcds:ark', 'executable' => './ShooterGameServer', - 'startup' => 'TheIsland?listen?ServerPassword={{ARK_PASSWORD}}?ServerAdminPassword={{ARK_ADMIN_PASSWORD}}?Port={{SERVER_PORT}}?MaxPlayers={{SERVER_MAX_PLAYERS}}' + 'startup' => 'TheIsland?listen?ServerPassword={{ARK_PASSWORD}}?ServerAdminPassword={{ARK_ADMIN_PASSWORD}}?Port={{SERVER_PORT}}?MaxPlayers={{SERVER_MAX_PLAYERS}}', ]); $this->option['custom'] = Models\ServiceOptions::create([ @@ -104,7 +103,7 @@ class SourceServiceTableSeeder extends Seeder 'tag' => 'srcds', 'docker_image' => 'quay.io/pterodactyl/srcds', 'executable' => null, - 'startup' => null + 'startup' => null, ]); } @@ -127,7 +126,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(17705)$/' + 'regex' => '/^(17705)$/', ]); Models\ServiceVariables::create([ @@ -139,7 +138,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(insurgency)$/' + 'regex' => '/^(insurgency)$/', ]); Models\ServiceVariables::create([ @@ -151,7 +150,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(\w{1,20})$/' + 'regex' => '/^(\w{1,20})$/', ]); } @@ -166,7 +165,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(232250)$/' + 'regex' => '/^(232250)$/', ]); Models\ServiceVariables::create([ @@ -178,7 +177,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(tf)$/' + 'regex' => '/^(tf)$/', ]); Models\ServiceVariables::create([ @@ -190,7 +189,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(\w{1,20})$/' + 'regex' => '/^(\w{1,20})$/', ]); } @@ -205,7 +204,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 0, - 'regex' => '/^(\w\.*)$/' + 'regex' => '/^(\w\.*)$/', ]); DB::table('service_variables')->insert([ @@ -217,7 +216,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 0, - 'regex' => '/^(\w\.*)$/' + 'regex' => '/^(\w\.*)$/', ]); DB::table('service_variables')->insert([ @@ -229,7 +228,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^(\d{1,4})$/' + 'regex' => '/^(\d{1,4})$/', ]); } @@ -244,7 +243,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(\d){1,6}$/' + 'regex' => '/^(\d){1,6}$/', ]); Models\ServiceVariables::create([ @@ -256,7 +255,7 @@ class SourceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(.*)$/' + 'regex' => '/^(.*)$/', ]); } } diff --git a/database/seeds/TerrariaServiceTableSeeder.php b/database/seeds/TerrariaServiceTableSeeder.php index 01c7376fe..42a0bedce 100644 --- a/database/seeds/TerrariaServiceTableSeeder.php +++ b/database/seeds/TerrariaServiceTableSeeder.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,9 +21,8 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -use Illuminate\Database\Seeder; - use Pterodactyl\Models; +use Illuminate\Database\Seeder; class TerrariaServiceTableSeeder extends Seeder { @@ -35,7 +34,7 @@ class TerrariaServiceTableSeeder extends Seeder protected $service; /** - * Stores all of the option objects + * Stores all of the option objects. * * @var array */ @@ -61,7 +60,7 @@ class TerrariaServiceTableSeeder extends Seeder 'description' => 'Terraria is a land of adventure! A land of mystery! A land that\'s yours to shape, defend, and enjoy. Your options in Terraria are limitless. Are you an action gamer with an itchy trigger finger? A master builder? A collector? An explorer? There\'s something for everyone.', 'file' => 'terraria', 'executable' => 'TerrariaServer.exe', - 'startup' => '-port {{SERVER_PORT}} -autocreate 2 -worldname World' + 'startup' => '-port {{SERVER_PORT}} -autocreate 2 -worldname World', ]); } @@ -74,7 +73,7 @@ class TerrariaServiceTableSeeder extends Seeder 'tag' => 'tshock', 'docker_image' => 'quay.io/pterodactyl/terraria:tshock', 'executable' => '', - 'startup' => '' + 'startup' => '', ]); } @@ -89,7 +88,7 @@ class TerrariaServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([0-9_\.-]{5,10})$/' + 'regex' => '/^([0-9_\.-]{5,10})$/', ]); Models\ServiceVariables::create([ @@ -101,7 +100,7 @@ class TerrariaServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(\d){1,3}$/' + 'regex' => '/^(\d){1,3}$/', ]); } } diff --git a/database/seeds/VoiceServiceTableSeeder.php b/database/seeds/VoiceServiceTableSeeder.php index 6756d0758..18876ef80 100644 --- a/database/seeds/VoiceServiceTableSeeder.php +++ b/database/seeds/VoiceServiceTableSeeder.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -21,9 +21,8 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -use Illuminate\Database\Seeder; - use Pterodactyl\Models; +use Illuminate\Database\Seeder; class VoiceServiceTableSeeder extends Seeder { @@ -35,7 +34,7 @@ class VoiceServiceTableSeeder extends Seeder protected $service; /** - * Stores all of the option objects + * Stores all of the option objects. * * @var array */ @@ -61,7 +60,7 @@ class VoiceServiceTableSeeder extends Seeder 'description' => 'Voice servers such as Mumble and Teamspeak 3.', 'file' => 'voice', 'executable' => '', - 'startup' => '' + 'startup' => '', ]); } @@ -74,7 +73,7 @@ class VoiceServiceTableSeeder extends Seeder 'tag' => 'mumble', 'docker_image' => 'quay.io/pterodactyl/voice:mumble', 'executable' => './murmur.x86', - 'startup' => '-fg' + 'startup' => '-fg', ]); $this->option['ts3'] = Models\ServiceOptions::create([ @@ -84,7 +83,7 @@ class VoiceServiceTableSeeder extends Seeder 'tag' => 'ts3', 'docker_image' => 'quay.io/pterodactyl/voice:ts3', 'executable' => './ts3server_minimal_runscript.sh', - 'startup' => 'default_voice_port={{SERVER_PORT}} query_port={{SERVER_PORT}}' + 'startup' => 'default_voice_port={{SERVER_PORT}} query_port={{SERVER_PORT}}', ]); } @@ -99,7 +98,7 @@ class VoiceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 0, 'required' => 1, - 'regex' => '/^(\d){1,6}$/' + 'regex' => '/^(\d){1,6}$/', ]); Models\ServiceVariables::create([ @@ -111,7 +110,7 @@ class VoiceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([0-9_\.-]{5,8})$/' + 'regex' => '/^([0-9_\.-]{5,8})$/', ]); Models\ServiceVariables::create([ @@ -123,7 +122,7 @@ class VoiceServiceTableSeeder extends Seeder 'user_viewable' => 1, 'user_editable' => 1, 'required' => 1, - 'regex' => '/^([0-9_\.-]{5,10})$/' + 'regex' => '/^([0-9_\.-]{5,10})$/', ]); } } diff --git a/public/index.php b/public/index.php index c5820533b..f2bd8213e 100644 --- a/public/index.php +++ b/public/index.php @@ -1,9 +1,8 @@ */ @@ -19,7 +18,7 @@ | */ -require __DIR__.'/../bootstrap/autoload.php'; +require __DIR__ . '/../bootstrap/autoload.php'; /* |-------------------------------------------------------------------------- @@ -33,7 +32,7 @@ require __DIR__.'/../bootstrap/autoload.php'; | */ -$app = require_once __DIR__.'/../bootstrap/app.php'; +$app = require_once __DIR__ . '/../bootstrap/app.php'; /* |-------------------------------------------------------------------------- diff --git a/resources/lang/de/auth.php b/resources/lang/de/auth.php index d4b7a3b6f..f560a3814 100644 --- a/resources/lang/de/auth.php +++ b/resources/lang/de/auth.php @@ -3,7 +3,7 @@ * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt * Some Modifications (c) 2015 Dylan Seidt - * Translated by Jakob Schrettenbrunner + * Translated by Jakob Schrettenbrunner . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -44,6 +44,6 @@ return [ 'sendlink' => 'Passwort Rücksetzungslink anfordern.', 'emailsent' => 'Die E-Mail mit dem Rücksetzungslink ist unterwegs.', 'remeberme' => 'Angemeldet bleiben', - 'totp_failed' => 'Das TOTP Token ist ungültig. Bitte stelle sicher dass das generierte Token gültig ist.' + 'totp_failed' => 'Das TOTP Token ist ungültig. Bitte stelle sicher dass das generierte Token gültig ist.', ]; diff --git a/resources/lang/de/base.php b/resources/lang/de/base.php index 3099ead1e..2687b2ea3 100644 --- a/resources/lang/de/base.php +++ b/resources/lang/de/base.php @@ -3,7 +3,7 @@ * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt * Some Modifications (c) 2015 Dylan Seidt - * Translated by Jakob Schrettenbrunner + * Translated by Jakob Schrettenbrunner . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -65,8 +65,8 @@ return [ 'update_email' => 'Email aktualisieren', 'new_email' => 'Neue Email', 'new_password' => 'Neues Passwort', - 'update_pass' => 'Passwort aktualisieren' + 'update_pass' => 'Passwort aktualisieren', - ] + ], ]; diff --git a/resources/lang/de/pagination.php b/resources/lang/de/pagination.php index 254555a6e..9d3da5976 100644 --- a/resources/lang/de/pagination.php +++ b/resources/lang/de/pagination.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Translated by Jakob Schrettenbrunner + * Translated by Jakob Schrettenbrunner . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/de/passwords.php b/resources/lang/de/passwords.php index 4202eba0b..8d1d2e04b 100644 --- a/resources/lang/de/passwords.php +++ b/resources/lang/de/passwords.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Translated by Jakob Schrettenbrunner + * Translated by Jakob Schrettenbrunner . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/de/server.php b/resources/lang/de/server.php index ff0a0e514..6b8b67c4d 100644 --- a/resources/lang/de/server.php +++ b/resources/lang/de/server.php @@ -3,7 +3,7 @@ * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt * Some Modifications (c) 2015 Dylan Seidt - * Translated by Jakob Schrettenbrunner + * Translated by Jakob Schrettenbrunner . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/de/strings.php b/resources/lang/de/strings.php index e2c99d88b..96b5330b7 100644 --- a/resources/lang/de/strings.php +++ b/resources/lang/de/strings.php @@ -3,7 +3,7 @@ * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt * Some Modifications (c) 2015 Dylan Seidt - * Translated by Jakob Schrettenbrunner + * Translated by Jakob Schrettenbrunner . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/en/auth.php b/resources/lang/en/auth.php index f4d886001..6e6e5b8c5 100644 --- a/resources/lang/en/auth.php +++ b/resources/lang/en/auth.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -43,6 +43,6 @@ return [ 'sendlink' => 'Send Password Reset Link', 'emailsent' => 'Your password reset email is on its way.', 'remeberme' => 'Remember Me', - 'totp_failed' => 'The TOTP token provided was invalid. Please ensure that the token generated by your device was valid.' + 'totp_failed' => 'The TOTP token provided was invalid. Please ensure that the token generated by your device was valid.', ]; diff --git a/resources/lang/en/base.php b/resources/lang/en/base.php index 02886c5a4..efcb96d25 100644 --- a/resources/lang/en/base.php +++ b/resources/lang/en/base.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -64,8 +64,8 @@ return [ 'update_email' => 'Update Email', 'new_email' => 'New Email', 'new_password' => 'New Password', - 'update_pass' => 'Update Password' + 'update_pass' => 'Update Password', - ] + ], ]; diff --git a/resources/lang/en/pagination.php b/resources/lang/en/pagination.php index edc90543c..0f9f83b5a 100644 --- a/resources/lang/en/pagination.php +++ b/resources/lang/en/pagination.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/en/passwords.php b/resources/lang/en/passwords.php index 542618ce9..c98ddd550 100644 --- a/resources/lang/en/passwords.php +++ b/resources/lang/en/passwords.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/en/server.php b/resources/lang/en/server.php index 68ac697df..ecb941332 100644 --- a/resources/lang/en/server.php +++ b/resources/lang/en/server.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/en/strings.php b/resources/lang/en/strings.php index 89e22123a..a1c102111 100644 --- a/resources/lang/en/strings.php +++ b/resources/lang/en/strings.php @@ -2,7 +2,7 @@ /** * Pterodactyl - Panel * Copyright (c) 2015 - 2016 Dane Everitt - * Some Modifications (c) 2015 Dylan Seidt + * Some Modifications (c) 2015 Dylan Seidt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/pt/auth.php b/resources/lang/pt/auth.php index 6d734d4af..c09d4b75b 100644 --- a/resources/lang/pt/auth.php +++ b/resources/lang/pt/auth.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -40,5 +40,5 @@ return [ 'sendlink' => 'Enviar link de troca de senha', 'emailsent' => 'O seu email para trocar de senha está a caminho.', 'remeberme' => 'Lembre-me', - 'totp_failed' => 'O token TOTP dado é inválido. Por favor tenha certeza que o token gerado pelo seu dispositivo era correto.' + 'totp_failed' => 'O token TOTP dado é inválido. Por favor tenha certeza que o token gerado pelo seu dispositivo era correto.', ]; diff --git a/resources/lang/pt/base.php b/resources/lang/pt/base.php index f6ef7945c..ce5f7138d 100644 --- a/resources/lang/pt/base.php +++ b/resources/lang/pt/base.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -59,6 +59,6 @@ return [ 'update_email' => 'Atualizar Email', 'new_email' => 'Novo Email', 'new_password' => 'Nova Senha', - 'update_pass' => 'Atualizar Senha' - ] + 'update_pass' => 'Atualizar Senha', + ], ]; diff --git a/resources/lang/pt/pagination.php b/resources/lang/pt/pagination.php index 2d00b6005..0c3f1baac 100644 --- a/resources/lang/pt/pagination.php +++ b/resources/lang/pt/pagination.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/pt/passwords.php b/resources/lang/pt/passwords.php index 9ade02b62..f1e0a2c9c 100644 --- a/resources/lang/pt/passwords.php +++ b/resources/lang/pt/passwords.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -36,5 +36,5 @@ return [ 'reset' => 'Sua senha foi resetada!', 'sent' => 'Nós te enviamos um email com o link para resetar sua senha!', 'token' => 'O token para resetar esta senha é inválido.', - 'user' => "Nós não pudemos achar um usuário com este endereço de email.", + 'user' => 'Nós não pudemos achar um usuário com este endereço de email.', ]; diff --git a/resources/lang/pt/server.php b/resources/lang/pt/server.php index d960088fc..aff709072 100644 --- a/resources/lang/pt/server.php +++ b/resources/lang/pt/server.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/pt/strings.php b/resources/lang/pt/strings.php index fa61c9e08..9d96200cc 100644 --- a/resources/lang/pt/strings.php +++ b/resources/lang/pt/strings.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/resources/lang/pt/validation.php b/resources/lang/pt/validation.php index 4e124fb5a..bb8d1abbf 100644 --- a/resources/lang/pt/validation.php +++ b/resources/lang/pt/validation.php @@ -1,7 +1,7 @@ + * Copyright (c) 2015 - 2016 Dane Everitt . * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal diff --git a/server.php b/server.php index f65c7c444..de038652f 100644 --- a/server.php +++ b/server.php @@ -1,12 +1,10 @@ */ - $uri = urldecode( parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH) ); @@ -14,8 +12,8 @@ $uri = urldecode( // This file allows us to emulate Apache's "mod_rewrite" functionality from the // built-in PHP web server. This provides a convenient way to test a Laravel // application without having installed a "real" web server software here. -if ($uri !== '/' && file_exists(__DIR__.'/public'.$uri)) { +if ($uri !== '/' && file_exists(__DIR__ . '/public' . $uri)) { return false; } -require_once __DIR__.'/public/index.php'; +require_once __DIR__ . '/public/index.php'; diff --git a/tests/ExampleTest.php b/tests/ExampleTest.php index 7e81d37aa..2c3a83c83 100644 --- a/tests/ExampleTest.php +++ b/tests/ExampleTest.php @@ -1,8 +1,5 @@ make(Illuminate\Contracts\Console\Kernel::class)->bootstrap(); From 04727068070a28d9b45cdb9377cea6ae672d4456 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Wed, 7 Dec 2016 19:30:55 -0500 Subject: [PATCH 18/24] Update CHANGELOG.md --- CHANGELOG.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5282fdbe2..8db9eb9de 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,13 @@ This file is a running track of new features and fixes to each version of the pa This project follows [Semantic Versioning](http://semver.org) guidelines. +## v0.5.5 (Bodacious Boreopterus) +### Added +* New API route to return allocations given a server ID. This adds support for a community-driven WHMCS module :rocket: available [here](https://github.com/hammerdawn/Pterodactyl-WHMCS). + +### Fixed +* Fixes subuser display when trying to edit an existing subuser. + ## v0.5.4 (Bodacious Boreopterus) ### Added * Changing node configuration values now automatically makes a call to the daemon and updates the configuration there. Changing daemon tokens now does not require any intervention, and takes effect immediately. SSL & Port configurations will still require a daemon reboot. From 2a101c0ffd78154b4b491a0c11b6721b072656e5 Mon Sep 17 00:00:00 2001 From: Jakob Schrettenbrunner Date: Fri, 9 Dec 2016 23:50:22 +0100 Subject: [PATCH 19/24] update to jquery terminal v0.11.22 --- public/js/jquery.terminal-0.11.22.min.js | 38 ++++++++++++++++++++++++ public/js/jquery.terminal-0.11.6.min.js | 37 ----------------------- resources/views/server/index.blade.php | 2 +- 3 files changed, 39 insertions(+), 38 deletions(-) create mode 100644 public/js/jquery.terminal-0.11.22.min.js delete mode 100755 public/js/jquery.terminal-0.11.6.min.js diff --git a/public/js/jquery.terminal-0.11.22.min.js b/public/js/jquery.terminal-0.11.22.min.js new file mode 100644 index 000000000..5d3863b88 --- /dev/null +++ b/public/js/jquery.terminal-0.11.22.min.js @@ -0,0 +1,38 @@ +/**@license + * __ _____ ________ __ + * / // _ /__ __ _____ ___ __ _/__ ___/__ ___ ______ __ __ __ ___ / / + * __ / // // // // // _ // _// // / / // _ // _// // // \/ // _ \/ / + * / / // // // // // ___// / / // / / // ___// / / / / // // /\ // // / /__ + * \___//____ \\___//____//_/ _\_ / /_//____//_/ /_/ /_//_//_/ /_/ \__\_\___/ + * \/ /____/ version 0.11.22 + * + * This file is part of jQuery Terminal. http://terminal.jcubic.pl + * + * Copyright (c) 2010-2016 Jakub Jankiewicz + * Released under the MIT license + * + * Contains: + * + * Storage plugin Distributed under the MIT License + * Copyright (c) 2010 Dave Schindler + * + * jQuery Timers licenced with the WTFPL + * + * + * Cross-Browser Split 1.1.1 + * Copyright 2007-2012 Steven Levithan + * Available under the MIT License + * + * jQuery Caret + * Copyright (c) 2009, Gideon Sireling + * 3 clause BSD License + * + * sprintf.js + * Copyright (c) 2007-2013 Alexandru Marasteanu + * licensed under 3 clause BSD license + * + * Date: Fri, 09 Dec 2016 18:23:18 +0000 + */ +(function(e){var n=function(){if(!n.cache.hasOwnProperty(arguments[0])){n.cache[arguments[0]]=n.parse(arguments[0])}return n.format.call(null,n.cache[arguments[0]],arguments)};n.format=function(e,t){var o=1,a=e.length,s="",l,f=[],c,u,h,p,m,g;for(c=0;c>>0;break;case"x":l=l.toString(16);break;case"X":l=l.toString(16).toUpperCase();break}l=/[def]/.test(h[8])&&h[3]&&l>=0?"+"+l:l;m=h[4]?h[4]=="0"?"0":h[4].charAt(1):" ";g=h[6]-String(l).length;p=h[6]?i(m,g):"";f.push(h[5]?l+p:p+l)}}return f.join("")};n.cache={};n.parse=function(e){var n=e,t=[],r=[],i=0;while(n){if((t=/^[^\x25]+/.exec(n))!==null){r.push(t[0])}else if((t=/^\x25{2}/.exec(n))!==null){r.push("%")}else if((t=/^\x25(?:([1-9]\d*)\$|\(([^\)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-fosuxX])/.exec(n))!==null){if(t[2]){i|=1;var o=[],a=t[2],s=[];if((s=/^([a-z_][a-z_\d]*)/i.exec(a))!==null){o.push(s[1]);while((a=a.substring(s[0].length))!==""){if((s=/^\.([a-z_][a-z_\d]*)/i.exec(a))!==null){o.push(s[1])}else if((s=/^\[(\d+)\]/.exec(a))!==null){o.push(s[1])}else{throw"[sprintf] huh?"}}}else{throw"[sprintf] huh?"}t[2]=o}else{i|=2}if(i===3){throw"[sprintf] mixing positional and named placeholders is not (yet) supported"}r.push(t)}else{throw"[sprintf] huh?"}n=n.substring(t[0].length)}return r};var t=function(e,t,r){r=t.slice(0);r.splice(0,0,e);return n.apply(null,r)};function r(e){return Object.prototype.toString.call(e).slice(8,-1).toLowerCase()}function i(e,n){for(var t=[];n>0;t[--n]=e){}return t.join("")}e.sprintf=n;e.vsprintf=t})(typeof global!="undefined"?global:window);(function(e,n){"use strict";e.omap=function(n,t){var r={};e.each(n,function(e,i){r[e]=t.call(n,e,i)});return r};var t={clone_object:function(n){var t={};if(typeof n=="object"){if(e.isArray(n)){return this.clone_array(n)}else if(n===null){return n}else{for(var r in n){if(e.isArray(n[r])){t[r]=this.clone_array(n[r])}else if(typeof n[r]=="object"){t[r]=this.clone_object(n[r])}else{t[r]=n[r]}}}}return t},clone_array:function(n){if(!e.isFunction(Array.prototype.map)){throw new Error("You'r browser don't support ES5 array map "+"use es5-shim")}return n.slice(0).map(function(e){if(typeof e=="object"){return this.clone_object(e)}else{return e}}.bind(this))}};var r=function(e){return t.clone_object(e)};var i=function(){var e="test",n=window.localStorage;try{n.setItem(e,"1");n.removeItem(e);return true}catch(t){return false}};var o=i();function a(e,n){var t;if(typeof e==="string"&&typeof n==="string"){localStorage[e]=n;return true}else if(typeof e==="object"&&typeof n==="undefined"){for(t in e){if(e.hasOwnProperty(t)){localStorage[t]=e[t]}}return true}return false}function s(e,n){var t,r,i;t=new Date;t.setTime(t.getTime()+31536e6);r="; expires="+t.toGMTString();if(typeof e==="string"&&typeof n==="string"){document.cookie=e+"="+n+r+"; path=/";return true}else if(typeof e==="object"&&typeof n==="undefined"){for(i in e){if(e.hasOwnProperty(i)){document.cookie=i+"="+e[i]+r+"; path=/"}}return true}return false}function l(e){return localStorage[e]}function f(e){var n,t,r,i;n=e+"=";t=document.cookie.split(";");for(r=0;ri&&i!==0||r.call(e,a)===false){h.timer.remove(e,t,r)}s.inProgress=false};s.$timerID=r.$timerID;if(!e.$timers[t][r.$timerID]){e.$timers[t][r.$timerID]=window.setInterval(s,n)}if(!this.global[t]){this.global[t]=[]}this.global[t].push(e)},remove:function(e,n,t){var r=e.$timers,i;if(r){if(!n){for(var o in r){if(r.hasOwnProperty(o)){this.remove(e,o,t)}}}else if(r[n]){if(t){if(t.$timerID){window.clearInterval(r[n][t.$timerID]);delete r[n][t.$timerID]}}else{for(var a in r[n]){if(r[n].hasOwnProperty(a)){window.clearInterval(r[n][a]);delete r[n][a]}}}for(i in r[n]){if(r[n].hasOwnProperty(i)){break}}if(!i){i=null;delete r[n]}}for(i in r){if(r.hasOwnProperty(i)){break}}if(!i){e.$timers=null}}}}});if(/(msie) ([\w.]+)/.exec(navigator.userAgent.toLowerCase())){h(window).one("unload",function(){var e=h.timer.global;for(var n in e){if(e.hasOwnProperty(n)){var t=e[n],r=t.length;while(--r){h.timer.remove(t[r],n)}}}})}(function(e){if(!String.prototype.split.toString().match(/\[native/)){return}var n=String.prototype.split,t=/()??/.exec("")[1]===e,r;r=function(r,i,o){if(Object.prototype.toString.call(i)!=="[object RegExp]"){return n.call(r,i,o)}var a=[],s=(i.ignoreCase?"i":"")+(i.multiline?"m":"")+(i.extended?"x":"")+(i.sticky?"y":""),l=0,f,c,u,h;i=new RegExp(i.source,s+"g");r+="";if(!t){f=new RegExp("^"+i.source+"$(?!\\s)",s)}o=o===e?-1>>>0:o>>>0;while(c=i.exec(r)){u=c.index+c[0].length;if(u>l){a.push(r.slice(l,c.index));if(!t&&c.length>1){c[0].replace(f,function(){for(var n=1;n1&&c.index=o){break}}if(i.lastIndex===c.index){i.lastIndex++}}if(l===r.length){if(h||!i.test("")){a.push("")}}else{a.push(r.slice(l))}return a.length>o?a.slice(0,o):a};String.prototype.split=function(e,n){return r(this,e,n)};return r})();e.fn.caret=function(e){var n=this[0];var t=n.contentEditable==="true";if(arguments.length==0){if(window.getSelection){if(t){n.focus();var r=window.getSelection().getRangeAt(0),i=r.cloneRange();i.selectNodeContents(n);i.setEnd(r.endContainer,r.endOffset);return i.toString().length}return n.selectionStart}if(document.selection){n.focus();if(t){var r=document.selection.createRange(),i=document.body.createTextRange();i.moveToElementText(n);i.setEndPoint("EndToEnd",r);return i.text.length}var e=0,o=n.createTextRange(),i=document.selection.createRange().duplicate(),a=i.getBookmark();o.moveToBookmark(a);while(o.moveStart("character",-1)!==0)e++;return e}return 0}if(e==-1)e=this[t?"text":"val"]().length;if(window.getSelection){if(t){n.focus();window.getSelection().collapse(n.firstChild,e)}else n.setSelectionRange(e,e)}else if(document.body.createTextRange){var o=document.body.createTextRange();o.moveToElementText(n);o.moveStart("character",e);o.collapse(true);o.select()}if(!t)n.focus();return e};function p(e,n){var t=[];var r=e.length;if(rt.length){if(n){break}e=0;n=true}}return t[e]}},append:function(e){t.push(e)}})}function g(n){var t=n instanceof Array?n:n?[n]:[];e.extend(this,{data:function(){return t},map:function(n){return e.map(t,n)},size:function(){return t.length},pop:function(){if(t.length===0){return null}else{var e=t[t.length-1];t=t.slice(0,t.length-1);return e}},push:function(e){t=t.concat([e]);return e},top:function(){return t.length>0?t[t.length-1]:null},clone:function(){return new g(t.slice(0))}})}function d(n,t,r){var i=true;var o="";if(typeof n==="string"&&n!==""){o=n+"_"}o+="commands";var a;if(r){a=[]}else{a=e.Storage.get(o);a=a?e.parseJSON(a):[]}var s=a.length-1;e.extend(this,{append:function(n){if(i){if(a[a.length-1]!==n){a.push(n);if(t&&a.length>t){a=a.slice(-t)}s=a.length-1;if(!r){e.Storage.set(o,JSON.stringify(a))}}}},data:function(){return a},reset:function(){s=a.length-1},last:function(){return a[a.length-1]},end:function(){return s===a.length-1},position:function(){return s},current:function(){return a[s]},next:function(){if(s0){--s}if(e!==-1){return a[s]}},clear:function(){a=[];this.purge()},enabled:function(){return i},enable:function(){i=true},purge:function(){if(!r){e.Storage.remove(o)}},disable:function(){i=false}})}var v=function(){var e=document.createElement("div");e.setAttribute("onpaste","return;");return typeof e.onpaste=="function"}();var y=true;e.fn.cmd=function(t){var r=this;var i=r.data("cmd");if(i){return i}r.addClass("cmd");r.append(''+' ');var o=e("
    {{ $db->name }}{{ $db->name }} {{ $db->host }}:{{ $db->port }} {{ $db->username }} {{ $db->c_databases }}UUID {{ $server->uuid }}
    Docker Container ID
    Docker User ID
    Owner {{ $server->a_ownerEmail }}
    Location{{ $server->a_locationName }}{{ $node->a_locationName }}
    Node{{ $server->a_nodeName }}{{ $node->name }}
    Service