/**
  * @param array[string] $parts
  * @param array[string => mixed] $mod
  * @return string
  */
 public static function main($parts, $mod)
 {
     Models\User::checkPermissions($mod['cuser'], 'UserAdmin', true);
     $errors = [];
     if (empty($_POST['email'])) {
         $errors[] = 'No email address given';
     } elseif (filter_var($_POST['email'], FILTER_VALIDATE_EMAIL) === false) {
         $errors[] = 'Invalid email address';
     }
     if (empty($_POST['password']) || empty($_POST['password_confirm'])) {
         $errors[] = 'Both password fields need to be filled out';
     } elseif ($_POST['password'] !== $_POST['password_confirm']) {
         $errors[] = 'The passwords don\'t match';
     }
     if (count($errors) > 0) {
         Session::setOnce('error', $errors);
         return NekoPHP::redirect(NekoPHP::getModuleUrl() . '/create');
     }
     try {
         $user = new Models\User();
         $user->setEmail($_POST['email']);
         $user->setPassword($_POST['password']);
         if (!$user->create()) {
             throw new \Exception($user->exception()->getMessage());
         }
         $user->getInfo()->setRealname($_POST['realname']);
         $user->getInfo()->update();
         $user->getPermissions()->setUserAdmin(isset($_POST['permission_user_admin']));
         $user->getPermissions()->update();
         // @todo: send out an email to the newly created user
     } catch (\Exception $e) {
         Session::setOnce('error', $e->getMessage());
         return NekoPHP::redirect(NekoPHP::getModuleUrl() . '/create/');
     }
     Session::setOnce('success', 'Account created');
     return NekoPHP::redirect(NekoPHP::getModuleUrl() . '/profile/' . $user->getId());
 }
Example #2
0
<?php

namespace NekoPHP\Modules\User;

use NekoPHP\Console;
use NekoPHP\Modules\User\Models\User;
Console::printInfo('Welcome to interactive user creation!');
do {
    $email = Console::ask('Email address');
} while (filter_var($email, FILTER_VALIDATE_EMAIL) === false);
do {
    $pass = Console::ask('Password');
} while ($pass === '');
$user = new User();
$user->setEmail($email);
$user->setPassword($pass);
if (!$user->create()) {
    Console::printError($user->exception()->getMessage());
    exit;
}
Console::printDebug('User created with ID ' . $user->getId());