Files
grocy/controllers/UsersController.php

76 lines
2.2 KiB
PHP
Raw Normal View History

2018-07-25 19:28:15 +02:00
<?php
namespace Grocy\Controllers;
use Grocy\Controllers\Users\User;
2023-05-13 14:43:51 +02:00
use Psr\Http\Message\ResponseInterface as Response;
use Psr\Http\Message\ServerRequestInterface as Request;
2018-07-25 19:28:15 +02:00
class UsersController extends BaseController
{
2023-05-13 14:43:51 +02:00
public function PermissionList(Request $request, Response $response, array $args)
2018-07-25 19:28:15 +02:00
{
User::checkPermission($request, User::PERMISSION_USERS_READ);
2020-08-31 20:40:31 +02:00
return $this->renderPage($response, 'userpermissions', [
'user' => $this->getDatabase()->users($args['userId']),
'permissions' => $this->getDatabase()->uihelper_user_permissions()
->where('parent IS NULL')->where('user_id', $args['userId'])
2018-07-25 19:28:15 +02:00
]);
}
2023-05-13 14:43:51 +02:00
public function UserEditForm(Request $request, Response $response, array $args)
2018-07-25 19:28:15 +02:00
{
if ($args['userId'] == 'new')
{
User::checkPermission($request, User::PERMISSION_USERS_CREATE);
return $this->renderPage($response, 'userform', [
'mode' => 'create',
'userfields' => $this->getUserfieldsService()->GetFields('users')
2018-07-25 19:28:15 +02:00
]);
}
else
{
2020-08-31 20:40:31 +02:00
if ($args['userId'] == GROCY_USER_ID)
{
User::checkPermission($request, User::PERMISSION_USERS_EDIT_SELF);
2020-08-31 20:40:31 +02:00
}
else
{
User::checkPermission($request, User::PERMISSION_USERS_EDIT);
}
return $this->renderPage($response, 'userform', [
2020-08-31 20:40:31 +02:00
'user' => $this->getDatabase()->users($args['userId']),
'mode' => 'edit',
'userfields' => $this->getUserfieldsService()->GetFields('users'),
'userfieldValues' => $this->getUserfieldsService()->GetAllValues('users')
2018-07-25 19:28:15 +02:00
]);
}
}
2023-05-13 14:43:51 +02:00
public function UserSettings(Request $request, Response $response, array $args)
{
return $this->renderPage($response, 'usersettings', [
'languages' => array_filter(scandir(__DIR__ . '/../localization'), function ($item)
{
2020-08-31 20:40:31 +02:00
if ($item == '.' || $item == '..')
{
return false;
2020-08-31 20:40:31 +02:00
}
return is_dir(__DIR__ . '/../localization/' . $item);
})
]);
}
2020-08-31 20:40:31 +02:00
2023-05-13 14:43:51 +02:00
public function UsersList(Request $request, Response $response, array $args)
2020-08-31 20:40:31 +02:00
{
User::checkPermission($request, User::PERMISSION_USERS_READ);
return $this->renderPage($response, 'users', [
'users' => $this->getDatabase()->users()->orderBy('username'),
'userfields' => $this->getUserfieldsService()->GetFields('users'),
'userfieldValues' => $this->getUserfieldsService()->GetAllValues('users')
2020-08-31 20:40:31 +02:00
]);
}
2018-07-25 19:28:15 +02:00
}