. */ require_once("auth.php"); // sets $mysqli, $user /** * Exit with xml response * @param boolean $isError Error if true * @param string $errorMessage Optional error message */ function exitWithStatus($isError, $errorMessage = NULL) { header("Content-type: text/xml"); $xml = new XMLWriter(); $xml->openURI("php://output"); $xml->startDocument("1.0"); $xml->setIndent(true); $xml->startElement('root'); $xml->writeElement("error", (int) $isError); if ($isError) { $xml->writeElement("message", $errorMessage); } $xml->endElement(); $xml->endDocument(); $xml->flush(); exit; } $login = isset($_REQUEST['login']) ? trim($_REQUEST['login']) : NULL; $hash = isset($_REQUEST['pass']) ? password_hash($_REQUEST['pass'], PASSWORD_DEFAULT) : NULL; if ($user->isAdmin && !empty($login) && !empty($hash)) { $newUser = new uUser($login); if ($newUser->isValid) { exitWithStatus(true, $lang["userexists"]); } if ($newUser->add($login, $hash) === false) { exitWithStatus(true, $mysqli->error); } } exitWithStatus(false); ?>