2019-11-03 12:20:11 -08:00
|
|
|
<?php
|
|
|
|
|
|
2024-03-12 22:39:16 -04:00
|
|
|
namespace App\Http\Controllers\Api\Client\Servers;
|
2019-11-03 12:20:11 -08:00
|
|
|
|
2025-12-11 14:34:27 +01:00
|
|
|
use App\Enums\SubuserPermission;
|
2025-09-08 13:12:33 -04:00
|
|
|
use App\Exceptions\Model\DataValidationException;
|
|
|
|
|
use App\Exceptions\Service\Subuser\ServerSubuserExistsException;
|
|
|
|
|
use App\Exceptions\Service\Subuser\UserIsServerOwnerException;
|
2024-03-12 22:39:16 -04:00
|
|
|
use App\Facades\Activity;
|
|
|
|
|
use App\Http\Controllers\Api\Client\ClientApiController;
|
2025-09-24 13:34:19 +02:00
|
|
|
use App\Http\Requests\Api\Client\Servers\Subusers\DeleteSubuserRequest;
|
2024-03-12 22:39:16 -04:00
|
|
|
use App\Http\Requests\Api\Client\Servers\Subusers\GetSubuserRequest;
|
|
|
|
|
use App\Http\Requests\Api\Client\Servers\Subusers\StoreSubuserRequest;
|
|
|
|
|
use App\Http\Requests\Api\Client\Servers\Subusers\UpdateSubuserRequest;
|
2025-09-24 13:34:19 +02:00
|
|
|
use App\Models\Server;
|
|
|
|
|
use App\Models\Subuser;
|
|
|
|
|
use App\Models\User;
|
|
|
|
|
use App\Services\Subusers\SubuserCreationService;
|
|
|
|
|
use App\Services\Subusers\SubuserDeletionService;
|
|
|
|
|
use App\Services\Subusers\SubuserUpdateService;
|
|
|
|
|
use App\Transformers\Api\Client\SubuserTransformer;
|
2025-02-26 16:12:19 +01:00
|
|
|
use Dedoc\Scramble\Attributes\Group;
|
2025-09-24 13:34:19 +02:00
|
|
|
use Illuminate\Http\JsonResponse;
|
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
use Throwable;
|
2019-11-03 12:20:11 -08:00
|
|
|
|
2025-02-26 16:12:19 +01:00
|
|
|
#[Group('Server - Subuser')]
|
2019-11-03 12:20:11 -08:00
|
|
|
class SubuserController extends ClientApiController
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* SubuserController constructor.
|
|
|
|
|
*/
|
2020-03-27 14:23:13 -07:00
|
|
|
public function __construct(
|
2022-10-14 10:59:20 -06:00
|
|
|
private SubuserCreationService $creationService,
|
feat: Client UI translate to Filament (from React) (#416)
* Add new panel
* Add some basic resource pages
* Wip
* Wip terminal
* Wip
* Add new panel
* Add some basic resource pages
* Wip
* [Sub-Users] Add Invite
TODO: The logic with permissions
* [Sub-Users] Fix Creation
* [Cron] Add basics
* Add basic auth and messages
* Add basic buttons
* WIP on issue/353
* WIP on issue/353
* Add Database page
* Update Database Page
* Start of Backup Page
* Composer Update
* Changes
* Send input
* Remove this includes
* Better offline handling
* Consolidate top nav config
* Update Backups Page
* Update Backups
* Change name
* Add Assign All, Layout Fixes.
* conflict
* update schedule pages
* fix phpstan
* update pint.json
* add cron presets to schedule
* fix tests
* fix task creation
* schedules: disable task creation if limit is reached & disable backup action if backup limit is 0
* update activity pages
* update resources
* Update Edit User
TODO: actually save permissions when they're changed.
TODO: Figure out why Control does not update it's state... but the rest do...
* .... Sure it works.
TODO: Update permissions when you save editing a sub user.
* user: update canAccessPanel & canAccessTenant
* add helper to convert bytes into readable format
* very basic file explorer
* files: fix some stuff & remove dummy data
* files: better error handling
* files: basic file editor
* files: add some actions
* File manager updates
* files: fix paths
* Revery Composer Upgrade, Fixes SQLite
* fix: Pint (#517)
feat: MenuItems to and from admin
* Update File Editing
Updated File Editing to its own page,
Added Permission checks for file manager.
Co-authored-by: Boy132 <Boy132@users.noreply.github.com>
* add enum for editor langs
* files: add upload & pull actions
* fix build
* files: handle images
* Update to Filament v3.2.98
* files: add remaining actions
* use `authorize` instead of `hidden`
* fix canAccessTenant
* update date columns
* files: testing & fixes
* Fix File Names
Co-authored-by: lancepioch <git@lance.sh>
* Combine Pull/Upload
* Fix BulkDelete
* Uncontained tabs
* Hide Lang Selection, Move Actions
* Update Monaco, more custom
* Add livewire config
livewire limits uploads to 12MB... who knows why...
Fixed uploading a single files failing
* files: fix record url
* basic setup for settings & startup page
* make abstract class for simple app pages
* Basic Startup Page
* Update nav sort
* small cleanup
* startup: fix shouldHideComponent & getSelectOptionsFromRules
* startup: fix non editable fields & set default value
* startup: add todo for save button
* Save Variables after update & off click
Variables update when the user clicks off the input.
* Notifications are cool
* Add rule validation
* Sort variables by sortid
* pint
* Settings Page + Startup Changes
* settings: cleanup
* refactor: use server model for ServerFormPage (formerly known as SimplePage)
* Use Repeater for variables
* Add Network, Remove breadcrumbs
* Add paginated to file explorer
* Fix updating variables
* Add link to go to new client area
* fix after merge
* Add graphs to console page
Graphs still need to get the data from the web socket.
* fix pint & phpstan
* fix authorizeAccess for EditFiles and Startup page
* Fix rules on startup page
* Update console size
* Fix node name
* add "global search" to files list
requires https://github.com/pelican-dev/wings/pull/44
* remove debug dummy data
* update view action on ListServers
* enable SPA mode for app panel
* remove colors from app panel
they are defined globally in AppServiceProvider
* update global search ui a bit
(to be replaced with a custom page that is similar to the list files table)
* add own page for global search
untested - and route needs cleanup (if possible)
* fix File getRows
* remove "path" from SearchFiles (for now)
* fix caching for searched files
* add title and breadcrumbs to global search page
* make cpu & memory charts on console page working
* fix phpstan
* add missing import
* cleanup console views & widgets
* add overview stats to console
* don't be so lazy, console!
* make history working
* decode data to get array
* add missing On
* fix json_decode
* change polling to 1 sec
* hide "0" cpu/ memory
* add data to network chart
* Remove data labels
* fix data on network chart
* fix data on network chart (2nd try)
* WIP Network Stats
* Remove test
* Change MaxWidth
* run pint
* fix phpstan
* Fix storeStats cast
* make $data a string
this time for real
* update visible check for "admin" menu item
* remove account widget
* rebrand "Dashboard" to "Server List"
WIP - doesn't look good but is somewhat working
* fix canAccessPanel
* separate server list into own panel
* change path to avoid conflicts with old client area (and remove sidebar width)
* display correct icon and color on server list entries
* show total memory if server is offline
* replace custom server list page with ListRecords page
* fix tests
* fix namespace
* remove "open" button and make whole column clickable
* Update EditProfile
* run pint
* fix access to server list
* add new login page to panels
* fix next_run_at for new schedules
* use new DateTimeColumn
* add own column for file bytes
* return to server list when clicking title
* fix console loading
* handle server with "conflict state"
* add banner if server is in "conflict state"
* fix phpstan
* update docker image select
* fix permission checks on Settings & Startup pages
* fix query for activity log page
* fix activity log not being logged
* adjust ListActivities
* fix phpstan
* fix pint
* fix profile menu item link on server panel
* add ip tooltip to activity logs (and role permission)
* change backup icon
* update navigation sort
* general code cleanup
* more cleanup
* Disable Restart/Stop if server is offline
* Change rename notification
* Remove negation on abort_unless
* Add notification on save
* Single disabled closure & comment unused import
* Add required to Server Name & Nullable to description
* mutateFormDataBeforeSave doesn't work since we use forceFill
* Fix web socket connection not existing.
* Fix some subuser permissions
* add permission checks to resources
* do not allow self-deletion
* Update editing file permissions
* Fix of the previous fix
* add service for subuser updating
* Only allow save if they have file_update
* Remove unused import
* Update backup delete button
* Add Delete, remove bulks
* Update Database page
* Use Allocation Permissions
* add canAccess check to startup
* Add Permission checks to Settings page
* add service for subuser deletion
* Remove Kill permission
* Updates
* fix move files
* add redirects
* fix phpstan
* activity: remove properties from tans for now
* If alias, use that, else ip
---------
Co-authored-by: notCharles <charles@pelican.dev>
Co-authored-by: Boy132 <mail@boy132.de>
Co-authored-by: Senna <62171904+Poseidon281@users.noreply.github.com>
Co-authored-by: Boy132 <Boy132@users.noreply.github.com>
Co-authored-by: RMartinOscar <40749467+RMartinOscar@users.noreply.github.com>
2024-11-30 22:13:45 -05:00
|
|
|
private SubuserUpdateService $updateService,
|
|
|
|
|
private SubuserDeletionService $deletionService
|
2020-03-27 14:23:13 -07:00
|
|
|
) {
|
2019-11-03 12:20:11 -08:00
|
|
|
parent::__construct();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2025-02-26 16:12:19 +01:00
|
|
|
* List subusers
|
|
|
|
|
*
|
2019-11-03 12:20:11 -08:00
|
|
|
* Return the users associated with this server instance.
|
2025-03-03 14:41:19 -05:00
|
|
|
*
|
|
|
|
|
* @return array<array-key, mixed>
|
2019-11-03 12:20:11 -08:00
|
|
|
*/
|
2022-10-14 10:59:20 -06:00
|
|
|
public function index(GetSubuserRequest $request, Server $server): array
|
2019-11-03 12:20:11 -08:00
|
|
|
{
|
2019-12-28 12:03:19 -08:00
|
|
|
return $this->fractal->collection($server->subusers)
|
2019-11-03 12:20:11 -08:00
|
|
|
->transformWith($this->getTransformer(SubuserTransformer::class))
|
|
|
|
|
->toArray();
|
|
|
|
|
}
|
2020-03-27 14:23:13 -07:00
|
|
|
|
2020-08-19 20:21:12 -07:00
|
|
|
/**
|
2025-02-26 16:12:19 +01:00
|
|
|
* View subusers
|
|
|
|
|
*
|
2020-08-19 20:21:12 -07:00
|
|
|
* Returns a single subuser associated with this server instance.
|
2025-03-03 14:41:19 -05:00
|
|
|
*
|
|
|
|
|
* @return array<array-key, mixed>
|
2020-08-19 20:21:12 -07:00
|
|
|
*/
|
2024-03-22 21:32:12 -04:00
|
|
|
public function view(GetSubuserRequest $request, Server $server, User $user): array
|
2020-08-19 20:21:12 -07:00
|
|
|
{
|
|
|
|
|
$subuser = $request->attributes->get('subuser');
|
|
|
|
|
|
|
|
|
|
return $this->fractal->item($subuser)
|
|
|
|
|
->transformWith($this->getTransformer(SubuserTransformer::class))
|
|
|
|
|
->toArray();
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-27 14:23:13 -07:00
|
|
|
/**
|
2025-02-26 16:12:19 +01:00
|
|
|
* Create subuser
|
|
|
|
|
*
|
2020-03-27 14:23:13 -07:00
|
|
|
* Create a new subuser for the given server.
|
|
|
|
|
*
|
2025-03-03 14:41:19 -05:00
|
|
|
* @return array<array-key, mixed>
|
|
|
|
|
*
|
2025-09-08 13:12:33 -04:00
|
|
|
* @throws DataValidationException
|
|
|
|
|
* @throws ServerSubuserExistsException
|
|
|
|
|
* @throws UserIsServerOwnerException
|
|
|
|
|
* @throws Throwable
|
2020-03-27 14:23:13 -07:00
|
|
|
*/
|
2022-10-14 10:59:20 -06:00
|
|
|
public function store(StoreSubuserRequest $request, Server $server): array
|
2020-03-27 14:23:13 -07:00
|
|
|
{
|
2025-12-11 14:34:27 +01:00
|
|
|
$email = $request->input('email');
|
|
|
|
|
$permissions = $this->getCleanedPermissions($request);
|
|
|
|
|
|
|
|
|
|
$subuser = $this->creationService->handle($server, $email, $permissions);
|
2020-03-27 14:23:13 -07:00
|
|
|
|
2022-05-29 19:26:28 -04:00
|
|
|
Activity::event('server:subuser.create')
|
2025-12-11 14:34:27 +01:00
|
|
|
->subject($subuser->user)
|
|
|
|
|
->property(['email' => $email, 'permissions' => $subuser->permissions])
|
2022-05-29 19:26:28 -04:00
|
|
|
->log();
|
|
|
|
|
|
2025-12-11 14:34:27 +01:00
|
|
|
return $this->fractal->item($subuser)
|
2020-03-27 14:23:13 -07:00
|
|
|
->transformWith($this->getTransformer(SubuserTransformer::class))
|
|
|
|
|
->toArray();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2025-02-26 16:12:19 +01:00
|
|
|
* Update subuser
|
|
|
|
|
*
|
2020-03-27 14:23:13 -07:00
|
|
|
* Update a given subuser in the system for the server.
|
|
|
|
|
*
|
2025-03-03 14:41:19 -05:00
|
|
|
* @return array<array-key, mixed>
|
|
|
|
|
*
|
2025-09-08 13:12:33 -04:00
|
|
|
* @throws DataValidationException
|
2020-03-27 14:23:13 -07:00
|
|
|
*/
|
2024-03-22 21:32:12 -04:00
|
|
|
public function update(UpdateSubuserRequest $request, Server $server, User $user): array
|
2020-03-27 14:23:13 -07:00
|
|
|
{
|
2025-09-08 13:12:33 -04:00
|
|
|
/** @var Subuser $subuser */
|
2020-08-19 20:21:12 -07:00
|
|
|
$subuser = $request->attributes->get('subuser');
|
|
|
|
|
|
2025-12-11 14:34:27 +01:00
|
|
|
$this->updateService->handle($subuser, $server, $this->getCleanedPermissions($request));
|
2022-05-29 19:26:28 -04:00
|
|
|
|
2020-03-27 14:23:13 -07:00
|
|
|
return $this->fractal->item($subuser->refresh())
|
|
|
|
|
->transformWith($this->getTransformer(SubuserTransformer::class))
|
|
|
|
|
->toArray();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2025-02-26 16:12:19 +01:00
|
|
|
* Delete subuser
|
|
|
|
|
*
|
2020-03-27 14:23:13 -07:00
|
|
|
* Removes a subusers from a server's assignment.
|
|
|
|
|
*/
|
2024-03-22 21:32:12 -04:00
|
|
|
public function delete(DeleteSubuserRequest $request, Server $server, User $user): JsonResponse
|
2020-03-27 14:23:13 -07:00
|
|
|
{
|
2025-09-08 13:12:33 -04:00
|
|
|
/** @var Subuser $subuser */
|
2020-08-19 20:21:12 -07:00
|
|
|
$subuser = $request->attributes->get('subuser');
|
|
|
|
|
|
feat: Client UI translate to Filament (from React) (#416)
* Add new panel
* Add some basic resource pages
* Wip
* Wip terminal
* Wip
* Add new panel
* Add some basic resource pages
* Wip
* [Sub-Users] Add Invite
TODO: The logic with permissions
* [Sub-Users] Fix Creation
* [Cron] Add basics
* Add basic auth and messages
* Add basic buttons
* WIP on issue/353
* WIP on issue/353
* Add Database page
* Update Database Page
* Start of Backup Page
* Composer Update
* Changes
* Send input
* Remove this includes
* Better offline handling
* Consolidate top nav config
* Update Backups Page
* Update Backups
* Change name
* Add Assign All, Layout Fixes.
* conflict
* update schedule pages
* fix phpstan
* update pint.json
* add cron presets to schedule
* fix tests
* fix task creation
* schedules: disable task creation if limit is reached & disable backup action if backup limit is 0
* update activity pages
* update resources
* Update Edit User
TODO: actually save permissions when they're changed.
TODO: Figure out why Control does not update it's state... but the rest do...
* .... Sure it works.
TODO: Update permissions when you save editing a sub user.
* user: update canAccessPanel & canAccessTenant
* add helper to convert bytes into readable format
* very basic file explorer
* files: fix some stuff & remove dummy data
* files: better error handling
* files: basic file editor
* files: add some actions
* File manager updates
* files: fix paths
* Revery Composer Upgrade, Fixes SQLite
* fix: Pint (#517)
feat: MenuItems to and from admin
* Update File Editing
Updated File Editing to its own page,
Added Permission checks for file manager.
Co-authored-by: Boy132 <Boy132@users.noreply.github.com>
* add enum for editor langs
* files: add upload & pull actions
* fix build
* files: handle images
* Update to Filament v3.2.98
* files: add remaining actions
* use `authorize` instead of `hidden`
* fix canAccessTenant
* update date columns
* files: testing & fixes
* Fix File Names
Co-authored-by: lancepioch <git@lance.sh>
* Combine Pull/Upload
* Fix BulkDelete
* Uncontained tabs
* Hide Lang Selection, Move Actions
* Update Monaco, more custom
* Add livewire config
livewire limits uploads to 12MB... who knows why...
Fixed uploading a single files failing
* files: fix record url
* basic setup for settings & startup page
* make abstract class for simple app pages
* Basic Startup Page
* Update nav sort
* small cleanup
* startup: fix shouldHideComponent & getSelectOptionsFromRules
* startup: fix non editable fields & set default value
* startup: add todo for save button
* Save Variables after update & off click
Variables update when the user clicks off the input.
* Notifications are cool
* Add rule validation
* Sort variables by sortid
* pint
* Settings Page + Startup Changes
* settings: cleanup
* refactor: use server model for ServerFormPage (formerly known as SimplePage)
* Use Repeater for variables
* Add Network, Remove breadcrumbs
* Add paginated to file explorer
* Fix updating variables
* Add link to go to new client area
* fix after merge
* Add graphs to console page
Graphs still need to get the data from the web socket.
* fix pint & phpstan
* fix authorizeAccess for EditFiles and Startup page
* Fix rules on startup page
* Update console size
* Fix node name
* add "global search" to files list
requires https://github.com/pelican-dev/wings/pull/44
* remove debug dummy data
* update view action on ListServers
* enable SPA mode for app panel
* remove colors from app panel
they are defined globally in AppServiceProvider
* update global search ui a bit
(to be replaced with a custom page that is similar to the list files table)
* add own page for global search
untested - and route needs cleanup (if possible)
* fix File getRows
* remove "path" from SearchFiles (for now)
* fix caching for searched files
* add title and breadcrumbs to global search page
* make cpu & memory charts on console page working
* fix phpstan
* add missing import
* cleanup console views & widgets
* add overview stats to console
* don't be so lazy, console!
* make history working
* decode data to get array
* add missing On
* fix json_decode
* change polling to 1 sec
* hide "0" cpu/ memory
* add data to network chart
* Remove data labels
* fix data on network chart
* fix data on network chart (2nd try)
* WIP Network Stats
* Remove test
* Change MaxWidth
* run pint
* fix phpstan
* Fix storeStats cast
* make $data a string
this time for real
* update visible check for "admin" menu item
* remove account widget
* rebrand "Dashboard" to "Server List"
WIP - doesn't look good but is somewhat working
* fix canAccessPanel
* separate server list into own panel
* change path to avoid conflicts with old client area (and remove sidebar width)
* display correct icon and color on server list entries
* show total memory if server is offline
* replace custom server list page with ListRecords page
* fix tests
* fix namespace
* remove "open" button and make whole column clickable
* Update EditProfile
* run pint
* fix access to server list
* add new login page to panels
* fix next_run_at for new schedules
* use new DateTimeColumn
* add own column for file bytes
* return to server list when clicking title
* fix console loading
* handle server with "conflict state"
* add banner if server is in "conflict state"
* fix phpstan
* update docker image select
* fix permission checks on Settings & Startup pages
* fix query for activity log page
* fix activity log not being logged
* adjust ListActivities
* fix phpstan
* fix pint
* fix profile menu item link on server panel
* add ip tooltip to activity logs (and role permission)
* change backup icon
* update navigation sort
* general code cleanup
* more cleanup
* Disable Restart/Stop if server is offline
* Change rename notification
* Remove negation on abort_unless
* Add notification on save
* Single disabled closure & comment unused import
* Add required to Server Name & Nullable to description
* mutateFormDataBeforeSave doesn't work since we use forceFill
* Fix web socket connection not existing.
* Fix some subuser permissions
* add permission checks to resources
* do not allow self-deletion
* Update editing file permissions
* Fix of the previous fix
* add service for subuser updating
* Only allow save if they have file_update
* Remove unused import
* Update backup delete button
* Add Delete, remove bulks
* Update Database page
* Use Allocation Permissions
* add canAccess check to startup
* Add Permission checks to Settings page
* add service for subuser deletion
* Remove Kill permission
* Updates
* fix move files
* add redirects
* fix phpstan
* activity: remove properties from tans for now
* If alias, use that, else ip
---------
Co-authored-by: notCharles <charles@pelican.dev>
Co-authored-by: Boy132 <mail@boy132.de>
Co-authored-by: Senna <62171904+Poseidon281@users.noreply.github.com>
Co-authored-by: Boy132 <Boy132@users.noreply.github.com>
Co-authored-by: RMartinOscar <40749467+RMartinOscar@users.noreply.github.com>
2024-11-30 22:13:45 -05:00
|
|
|
$this->deletionService->handle($subuser, $server);
|
2020-11-03 21:01:15 -08:00
|
|
|
|
2020-08-19 20:21:12 -07:00
|
|
|
return new JsonResponse([], JsonResponse::HTTP_NO_CONTENT);
|
2020-03-27 14:23:13 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2025-12-11 14:34:27 +01:00
|
|
|
* Returns the "cleaned" permissions for subusers and parses out any permissions
|
2022-10-09 15:14:16 -07:00
|
|
|
* that were passed that do not also exist in the internally tracked list of
|
|
|
|
|
* permissions.
|
2025-03-03 14:41:19 -05:00
|
|
|
*
|
2025-12-11 14:34:27 +01:00
|
|
|
* @return string[]
|
2020-03-27 14:23:13 -07:00
|
|
|
*/
|
2025-12-11 14:34:27 +01:00
|
|
|
protected function getCleanedPermissions(Request $request): array
|
2020-03-27 14:23:13 -07:00
|
|
|
{
|
2025-12-11 14:34:27 +01:00
|
|
|
return collect($request->input('permissions') ?? [])
|
|
|
|
|
->intersect(Subuser::allPermissionKeys())
|
|
|
|
|
->push(SubuserPermission::WebsocketConnect->value)
|
|
|
|
|
->unique()
|
|
|
|
|
->values()
|
|
|
|
|
->toArray();
|
2020-03-27 14:23:13 -07:00
|
|
|
}
|
2019-11-03 12:20:11 -08:00
|
|
|
}
|