2015-05-22 09:13:52 +00:00
|
|
|
<?php
|
2020-10-14 22:19:31 +00:00
|
|
|
|
2021-07-19 05:53:45 +00:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2018-08-04 22:05:14 +00:00
|
|
|
namespace App\Controller\Admin;
|
2015-05-22 09:13:52 +00:00
|
|
|
|
2019-02-18 00:52:01 +00:00
|
|
|
use App\Form\PermissionsForm;
|
2019-08-09 15:00:21 +00:00
|
|
|
use App\Http\Response;
|
|
|
|
use App\Http\ServerRequest;
|
2020-02-06 02:35:13 +00:00
|
|
|
use App\Session\Flash;
|
2021-07-06 11:36:09 +00:00
|
|
|
use DI\FactoryInterface;
|
2018-11-17 15:30:28 +00:00
|
|
|
use Psr\Http\Message\ResponseInterface;
|
2015-05-22 09:13:52 +00:00
|
|
|
|
2019-04-14 02:05:42 +00:00
|
|
|
class PermissionsController extends AbstractAdminCrudController
|
2015-05-22 09:13:52 +00:00
|
|
|
{
|
2021-04-23 05:24:12 +00:00
|
|
|
public function __construct(
|
2021-07-06 11:36:09 +00:00
|
|
|
FactoryInterface $factory
|
2021-04-23 05:24:12 +00:00
|
|
|
) {
|
2021-07-06 11:36:09 +00:00
|
|
|
parent::__construct($factory->make(PermissionsForm::class));
|
2020-10-22 07:18:05 +00:00
|
|
|
|
2019-04-14 02:05:42 +00:00
|
|
|
$this->csrf_namespace = 'admin_permissions';
|
2015-05-22 09:13:52 +00:00
|
|
|
}
|
2017-01-24 00:35:16 +00:00
|
|
|
|
2019-08-09 15:00:21 +00:00
|
|
|
public function indexAction(ServerRequest $request, Response $response): ResponseInterface
|
2015-05-22 09:13:52 +00:00
|
|
|
{
|
2020-12-02 00:36:09 +00:00
|
|
|
$all_roles = $this->em->createQuery(
|
|
|
|
<<<'DQL'
|
|
|
|
SELECT r, rp, s
|
|
|
|
FROM App\Entity\Role r
|
|
|
|
LEFT JOIN r.users u
|
|
|
|
LEFT JOIN r.permissions rp
|
|
|
|
LEFT JOIN rp.station s
|
|
|
|
ORDER BY r.id ASC
|
|
|
|
DQL
|
|
|
|
)->getArrayResult();
|
2015-05-22 09:13:52 +00:00
|
|
|
|
2016-10-07 20:57:42 +00:00
|
|
|
$roles = [];
|
2016-09-27 04:16:34 +00:00
|
|
|
|
2021-07-06 11:36:09 +00:00
|
|
|
$actions = $request->getAcl()->listPermissions();
|
2019-01-05 15:25:20 +00:00
|
|
|
|
2017-01-24 00:35:16 +00:00
|
|
|
foreach ($all_roles as $role) {
|
2016-10-07 20:57:42 +00:00
|
|
|
$role['permissions_global'] = [];
|
|
|
|
$role['permissions_station'] = [];
|
|
|
|
|
2017-01-24 00:35:16 +00:00
|
|
|
foreach ($role['permissions'] as $permission) {
|
|
|
|
if ($permission['station']) {
|
2020-10-14 22:19:31 +00:00
|
|
|
// phpcs:disable Generic.Files.LineLength
|
2019-01-05 15:25:20 +00:00
|
|
|
$role['permissions_station'][$permission['station']['name']][] = $actions['station'][$permission['action_name']];
|
2020-10-14 22:19:31 +00:00
|
|
|
// phpcs:enable
|
2017-01-24 00:35:16 +00:00
|
|
|
} else {
|
2019-01-05 15:25:20 +00:00
|
|
|
$role['permissions_global'][] = $actions['global'][$permission['action_name']];
|
2017-01-24 00:35:16 +00:00
|
|
|
}
|
2016-10-07 20:57:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$roles[] = $role;
|
2015-05-22 09:13:52 +00:00
|
|
|
}
|
|
|
|
|
2019-08-09 15:00:21 +00:00
|
|
|
return $request->getView()->renderToResponse($response, 'admin/permissions/index', [
|
2018-02-01 11:49:40 +00:00
|
|
|
'roles' => $roles,
|
2019-09-24 02:22:08 +00:00
|
|
|
'csrf' => $request->getCsrf()->generate($this->csrf_namespace),
|
2018-02-01 11:49:40 +00:00
|
|
|
]);
|
2015-05-22 09:13:52 +00:00
|
|
|
}
|
|
|
|
|
2021-07-19 05:53:45 +00:00
|
|
|
public function editAction(ServerRequest $request, Response $response, int $id = null): ResponseInterface
|
2015-05-22 09:13:52 +00:00
|
|
|
{
|
2020-10-14 22:19:31 +00:00
|
|
|
if (false !== $this->doEdit($request, $id)) {
|
|
|
|
$request->getFlash()->addMessage(
|
|
|
|
'<b>' . ($id ? __('Permission updated.') : __('Permission added.')) . '</b>',
|
|
|
|
Flash::SUCCESS
|
|
|
|
);
|
2021-07-19 05:53:45 +00:00
|
|
|
return $response->withRedirect((string)$request->getRouter()->named('admin:permissions:index'));
|
2015-05-22 09:13:52 +00:00
|
|
|
}
|
|
|
|
|
2021-07-19 05:53:45 +00:00
|
|
|
return $request->getView()->renderToResponse(
|
|
|
|
$response,
|
|
|
|
'system/form_page',
|
|
|
|
[
|
|
|
|
'form' => $this->form,
|
|
|
|
'render_mode' => 'edit',
|
|
|
|
'title' => $id ? __('Edit Permission') : __('Add Permission'),
|
|
|
|
]
|
|
|
|
);
|
2015-05-22 09:13:52 +00:00
|
|
|
}
|
|
|
|
|
2021-07-19 05:53:45 +00:00
|
|
|
public function deleteAction(
|
|
|
|
ServerRequest $request,
|
|
|
|
Response $response,
|
|
|
|
int $id,
|
|
|
|
string $csrf
|
|
|
|
): ResponseInterface {
|
2020-10-14 22:19:31 +00:00
|
|
|
$this->doDelete($request, $id, $csrf);
|
2017-01-24 00:35:16 +00:00
|
|
|
|
2019-09-24 02:22:08 +00:00
|
|
|
$request->getFlash()->addMessage('<b>' . __('Permission deleted.') . '</b>', Flash::SUCCESS);
|
2021-07-19 05:53:45 +00:00
|
|
|
return $response->withRedirect((string)$request->getRouter()->named('admin:permissions:index'));
|
2015-05-22 09:13:52 +00:00
|
|
|
}
|
2018-08-04 22:05:14 +00:00
|
|
|
}
|