111 lines
3.1 KiB
PHP
111 lines
3.1 KiB
PHP
|
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
namespace PhpMyAdmin\Controllers\Server;
|
||
|
|
||
|
use PhpMyAdmin\ConfigStorage\Relation;
|
||
|
use PhpMyAdmin\ConfigStorage\UserGroups;
|
||
|
use PhpMyAdmin\Controllers\AbstractController;
|
||
|
use PhpMyAdmin\DatabaseInterface;
|
||
|
use PhpMyAdmin\Message;
|
||
|
use PhpMyAdmin\ResponseRenderer;
|
||
|
use PhpMyAdmin\Template;
|
||
|
|
||
|
use function __;
|
||
|
|
||
|
/**
|
||
|
* Displays the 'User groups' sub page under 'Users' page.
|
||
|
*/
|
||
|
class UserGroupsController extends AbstractController
|
||
|
{
|
||
|
/** @var Relation */
|
||
|
private $relation;
|
||
|
|
||
|
/** @var DatabaseInterface */
|
||
|
private $dbi;
|
||
|
|
||
|
public function __construct(
|
||
|
ResponseRenderer $response,
|
||
|
Template $template,
|
||
|
Relation $relation,
|
||
|
DatabaseInterface $dbi
|
||
|
) {
|
||
|
parent::__construct($response, $template);
|
||
|
$this->relation = $relation;
|
||
|
$this->dbi = $dbi;
|
||
|
}
|
||
|
|
||
|
public function __invoke(): void
|
||
|
{
|
||
|
$configurableMenusFeature = $this->relation->getRelationParameters()->configurableMenusFeature;
|
||
|
if ($configurableMenusFeature === null) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$this->addScriptFiles(['server/user_groups.js']);
|
||
|
|
||
|
/**
|
||
|
* Only allowed to superuser
|
||
|
*/
|
||
|
if (! $this->dbi->isSuperUser()) {
|
||
|
$this->response->addHTML(
|
||
|
Message::error(__('No Privileges'))->getDisplay()
|
||
|
);
|
||
|
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$this->response->addHTML('<div class="container-fluid">');
|
||
|
$this->render('server/privileges/subnav', [
|
||
|
'active' => 'user-groups',
|
||
|
'is_super_user' => $this->dbi->isSuperUser(),
|
||
|
]);
|
||
|
|
||
|
/**
|
||
|
* Delete user group
|
||
|
*/
|
||
|
if (! empty($_POST['deleteUserGroup'])) {
|
||
|
UserGroups::delete($configurableMenusFeature, $_POST['userGroup']);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add a new user group
|
||
|
*/
|
||
|
if (! empty($_POST['addUserGroupSubmit'])) {
|
||
|
UserGroups::edit($configurableMenusFeature, $_POST['userGroup'], true);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Update a user group
|
||
|
*/
|
||
|
if (! empty($_POST['editUserGroupSubmit'])) {
|
||
|
UserGroups::edit($configurableMenusFeature, $_POST['userGroup']);
|
||
|
}
|
||
|
|
||
|
if (isset($_POST['viewUsers'])) {
|
||
|
// Display users belonging to a user group
|
||
|
$this->response->addHTML(UserGroups::getHtmlForListingUsersofAGroup(
|
||
|
$configurableMenusFeature,
|
||
|
$_POST['userGroup']
|
||
|
));
|
||
|
}
|
||
|
|
||
|
if (isset($_GET['addUserGroup'])) {
|
||
|
// Display add user group dialog
|
||
|
$this->response->addHTML(UserGroups::getHtmlToEditUserGroup($configurableMenusFeature));
|
||
|
} elseif (isset($_POST['editUserGroup'])) {
|
||
|
// Display edit user group dialog
|
||
|
$this->response->addHTML(UserGroups::getHtmlToEditUserGroup(
|
||
|
$configurableMenusFeature,
|
||
|
$_POST['userGroup']
|
||
|
));
|
||
|
} else {
|
||
|
// Display user groups table
|
||
|
$this->response->addHTML(UserGroups::getHtmlForUserGroupsTable($configurableMenusFeature));
|
||
|
}
|
||
|
|
||
|
$this->response->addHTML('</div>');
|
||
|
}
|
||
|
}
|