8 isset(
$user) or require
$_SERVER[
'DOCUMENT_ROOT'] .
'/page/404.php';
10 header(
"Content-type: application/json");
12 array_walk_recursive(
$_POST,
function (&$item) {
13 $item = trim(htmlspecialchars($item, ENT_QUOTES));
16 if (empty(
$_POST[
'email']) || !filter_var(trim(
$_POST[
'email']), FILTER_VALIDATE_EMAIL)) {
17 exit(json_encode([
'error' =>
'Email указан некорректно']));
20 if (empty(
$_POST[
'password']) || mb_strlen(trim(
$_POST[
'password']),
'utf-8') < 5) {
21 exit(json_encode([
'error' =>
'В пароле должно быть минимум 5 символов']));
24 if (Wrong\Auth\User::match(
$_POST[
'email'])) {
25 exit(json_encode([
'error' =>
'Пользователь с этим email уже существует']));
28 $_POST[
'groups'] = array_map(
'intval', array_values(array_intersect(
$user->subordinate_groups, empty(
$_POST[
'groups']) ? [] : array_keys(
$_POST[
'groups']))));
30 if (empty(
$_POST[
'owner_group']) || !in_array(
$_POST[
'owner_group'],
$user->subordinate_groups)) {
31 exit(json_encode([
'error' =>
'"Группа владелец" не найдена среди подчиненных групп']));
34 if (($models_limit = Wrong\Database\Controller::find(
$_POST[
'owner_group'],
'id',
'groups')->models_limit) && $models_limit <= Wrong\Rights\Group::count_all_owner_models(
$_POST[
'owner_group'])) {
35 exit(json_encode([
'error' =>
'Лимит моделей для данной группы исчерпан']));
39 exit(json_encode([
'result' =>
'ok',
'message' =>
'Пользователь успешно создан']));
42 exit(json_encode([
'error' =>
'Ошибка']));
if(empty($_POST['email'])||!filter_var(trim($_POST['email']), FILTER_VALIDATE_EMAIL)) if(empty($_POST['password'])||mb_strlen(trim($_POST['password']), 'utf-8')< 5) if(Wrong\Auth\User::match($_POST['email'])) $_POST['groups']
setcookie('FROM_UID', $uid, [ 'expires'=> time()+31536000, 'path'=> '/', 'domain'=> $_SERVER['HTTP_HOST'], 'secure'=> Wrong\Start\Env::$e->IS_SECURE, 'httponly'=> false, 'samesite'=> Wrong\Start\Env::$e->IS_SECURE ? 'None' :'Lax']) or setcookie('FROM_UID' $_SERVER['HTTP_HOST']
if(($dbh=Connect::getInstance(true) ->dbh) && $dbh->query("SHOW TABLES") ->fetchAll() && $dbh->query("SELECT COUNT(*) FROM `users`") ->fetchColumn()) if(!empty($_POST)) exit