Fix model not found error when editing an existing subuser.
This commit is contained in:
parent
205a10cd72
commit
e4ef8caf2d
|
@ -15,6 +15,7 @@ This project follows [Semantic Versioning](http://semver.org) guidelines.
|
||||||
* `[beta.2]` — New attempt at fixing the issues when rendering files in the browser file editor on certain browsers.
|
* `[beta.2]` — New attempt at fixing the issues when rendering files in the browser file editor on certain browsers.
|
||||||
* `[beta.2]` — Fixes broken auto-deploy time checking causing no tokens to work.
|
* `[beta.2]` — Fixes broken auto-deploy time checking causing no tokens to work.
|
||||||
* `[beta.2]` — Fixes display of subusers after creation.
|
* `[beta.2]` — Fixes display of subusers after creation.
|
||||||
|
* `[beta.2]` — Fixes bug throwing model not found exception when editing an existing subuser.
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
* Deleting a server safely now continues even if the daemon reports a `HTTP/404` missing server error (requires `Daemon@0.4.0-beta.2.1`)
|
* Deleting a server safely now continues even if the daemon reports a `HTTP/404` missing server error (requires `Daemon@0.4.0-beta.2.1`)
|
||||||
|
|
|
@ -26,8 +26,12 @@ namespace Pterodactyl\Repositories;
|
||||||
|
|
||||||
use DB;
|
use DB;
|
||||||
use Validator;
|
use Validator;
|
||||||
use Pterodactyl\Models;
|
use Pterodactyl\Models\User;
|
||||||
|
use Pterodactyl\Models\Server;
|
||||||
|
use Pterodactyl\Models\Subuser;
|
||||||
|
use Pterodactyl\Models\Permission;
|
||||||
use Pterodactyl\Services\UuidService;
|
use Pterodactyl\Services\UuidService;
|
||||||
|
use GuzzleHttp\Exception\TransferException;
|
||||||
use Pterodactyl\Exceptions\DisplayException;
|
use Pterodactyl\Exceptions\DisplayException;
|
||||||
use Pterodactyl\Exceptions\DisplayValidationException;
|
use Pterodactyl\Exceptions\DisplayValidationException;
|
||||||
|
|
||||||
|
@ -57,7 +61,7 @@ class SubuserRepository
|
||||||
*/
|
*/
|
||||||
public function create($sid, array $data)
|
public function create($sid, array $data)
|
||||||
{
|
{
|
||||||
$server = Models\Server::with('node')->findOrFail($sid);
|
$server = Server::with('node')->findOrFail($sid);
|
||||||
|
|
||||||
$validator = Validator::make($data, [
|
$validator = Validator::make($data, [
|
||||||
'permissions' => 'required|array',
|
'permissions' => 'required|array',
|
||||||
|
@ -72,7 +76,7 @@ class SubuserRepository
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// Determine if this user exists or if we need to make them an account.
|
// Determine if this user exists or if we need to make them an account.
|
||||||
$user = Models\User::where('email', $data['email'])->first();
|
$user = User::where('email', $data['email'])->first();
|
||||||
if (! $user) {
|
if (! $user) {
|
||||||
try {
|
try {
|
||||||
$repo = new UserRepository;
|
$repo = new UserRepository;
|
||||||
|
@ -88,18 +92,18 @@ class SubuserRepository
|
||||||
}
|
}
|
||||||
} elseif ($server->owner_id === $user->id) {
|
} elseif ($server->owner_id === $user->id) {
|
||||||
throw new DisplayException('You cannot add the owner of a server as a subuser.');
|
throw new DisplayException('You cannot add the owner of a server as a subuser.');
|
||||||
} elseif (Models\Subuser::select('id')->where('user_id', $user->id)->where('server_id', $server->id)->first()) {
|
} elseif (Subuser::select('id')->where('user_id', $user->id)->where('server_id', $server->id)->first()) {
|
||||||
throw new DisplayException('A subuser with that email already exists for this server.');
|
throw new DisplayException('A subuser with that email already exists for this server.');
|
||||||
}
|
}
|
||||||
|
|
||||||
$uuid = new UuidService;
|
$uuid = new UuidService;
|
||||||
$subuser = Models\Subuser::create([
|
$subuser = Subuser::create([
|
||||||
'user_id' => $user->id,
|
'user_id' => $user->id,
|
||||||
'server_id' => $server->id,
|
'server_id' => $server->id,
|
||||||
'daemonSecret' => (string) $uuid->generate('servers', 'uuid'),
|
'daemonSecret' => (string) $uuid->generate('servers', 'uuid'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$perms = Models\Permission::list(true);
|
$perms = Permission::list(true);
|
||||||
$daemonPermissions = $this->coreDaemonPermissions;
|
$daemonPermissions = $this->coreDaemonPermissions;
|
||||||
|
|
||||||
foreach ($data['permissions'] as $permission) {
|
foreach ($data['permissions'] as $permission) {
|
||||||
|
@ -109,7 +113,7 @@ class SubuserRepository
|
||||||
array_push($daemonPermissions, $perms[$permission]);
|
array_push($daemonPermissions, $perms[$permission]);
|
||||||
}
|
}
|
||||||
|
|
||||||
Models\Permission::create([
|
Permission::create([
|
||||||
'subuser_id' => $subuser->id,
|
'subuser_id' => $subuser->id,
|
||||||
'permission' => $permission,
|
'permission' => $permission,
|
||||||
]);
|
]);
|
||||||
|
@ -134,7 +138,7 @@ class SubuserRepository
|
||||||
DB::commit();
|
DB::commit();
|
||||||
|
|
||||||
return $subuser;
|
return $subuser;
|
||||||
} catch (\GuzzleHttp\Exception\TransferException $ex) {
|
} catch (TransferException $ex) {
|
||||||
DB::rollBack();
|
DB::rollBack();
|
||||||
throw new DisplayException('There was an error attempting to connect to the daemon to add this user.', $ex);
|
throw new DisplayException('There was an error attempting to connect to the daemon to add this user.', $ex);
|
||||||
} catch (\Exception $ex) {
|
} catch (\Exception $ex) {
|
||||||
|
@ -155,7 +159,7 @@ class SubuserRepository
|
||||||
*/
|
*/
|
||||||
public function delete($id)
|
public function delete($id)
|
||||||
{
|
{
|
||||||
$subuser = Models\Subuser::with('server.node')->findOrFail($id);
|
$subuser = Subuser::with('server.node')->findOrFail($id);
|
||||||
$server = $subuser->server;
|
$server = $subuser->server;
|
||||||
|
|
||||||
DB::beginTransaction();
|
DB::beginTransaction();
|
||||||
|
@ -177,7 +181,7 @@ class SubuserRepository
|
||||||
}
|
}
|
||||||
$subuser->delete();
|
$subuser->delete();
|
||||||
DB::commit();
|
DB::commit();
|
||||||
} catch (\GuzzleHttp\Exception\TransferException $ex) {
|
} catch (TransferException $ex) {
|
||||||
DB::rollBack();
|
DB::rollBack();
|
||||||
throw new DisplayException('There was an error attempting to connect to the daemon to delete this subuser.', $ex);
|
throw new DisplayException('There was an error attempting to connect to the daemon to delete this subuser.', $ex);
|
||||||
} catch (\Exception $ex) {
|
} catch (\Exception $ex) {
|
||||||
|
@ -208,7 +212,7 @@ class SubuserRepository
|
||||||
throw new DisplayValidationException(json_encode($validator->all()));
|
throw new DisplayValidationException(json_encode($validator->all()));
|
||||||
}
|
}
|
||||||
|
|
||||||
$subuser = Models\Subuser::with('server.node')->findOrFail($id);
|
$subuser = Subuser::with('server.node')->findOrFail($id);
|
||||||
$server = $subuser->server;
|
$server = $subuser->server;
|
||||||
|
|
||||||
DB::beginTransaction();
|
DB::beginTransaction();
|
||||||
|
@ -227,7 +231,7 @@ class SubuserRepository
|
||||||
if (! is_null($perms[$permission])) {
|
if (! is_null($perms[$permission])) {
|
||||||
array_push($daemonPermissions, $perms[$permission]);
|
array_push($daemonPermissions, $perms[$permission]);
|
||||||
}
|
}
|
||||||
Models\Permission::create([
|
Permission::create([
|
||||||
'subuser_id' => $subuser->id,
|
'subuser_id' => $subuser->id,
|
||||||
'permission' => $permission,
|
'permission' => $permission,
|
||||||
]);
|
]);
|
||||||
|
@ -249,7 +253,7 @@ class SubuserRepository
|
||||||
]);
|
]);
|
||||||
|
|
||||||
DB::commit();
|
DB::commit();
|
||||||
} catch (\GuzzleHttp\Exception\TransferException $ex) {
|
} catch (TransferException $ex) {
|
||||||
DB::rollBack();
|
DB::rollBack();
|
||||||
throw new DisplayException('There was an error attempting to connect to the daemon to update permissions.', $ex);
|
throw new DisplayException('There was an error attempting to connect to the daemon to update permissions.', $ex);
|
||||||
} catch (\Exception $ex) {
|
} catch (\Exception $ex) {
|
||||||
|
|
Loading…
Reference in New Issue