X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fregmod.php;h=295d8df25f5a02066c41d74376f8bdd0941f7bb4;hb=2db6171641bd3cd468b965470d9da56e82512e00;hp=aa64986d069e486891ab6ebaeecf76696569c8cf;hpb=c845415a99ebc348103815a7b2c55b15c75cdd24;p=friendica.git diff --git a/mod/regmod.php b/mod/regmod.php index aa64986d06..295d8df25f 100644 --- a/mod/regmod.php +++ b/mod/regmod.php @@ -2,65 +2,50 @@ /** * @file mod/regmod.php */ + use Friendica\App; use Friendica\Core\Config; use Friendica\Core\L10n; use Friendica\Core\System; use Friendica\Core\Worker; -use Friendica\Database\DBM; +use Friendica\Database\DBA; +use Friendica\Model\Register; use Friendica\Model\User; use Friendica\Module\Login; -require_once 'include/enotify.php'; - function user_allow($hash) { - $a = get_app(); - - $register = q("SELECT * FROM `register` WHERE `hash` = '%s' LIMIT 1", - dbesc($hash) - ); - + $a = \get_app(); - if (!DBM::is_result($register)) { + $register = Register::getByHash($hash); + if (!DBA::isResult($register)) { return false; } - $user = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", - intval($register[0]['uid']) - ); - - if (!DBM::is_result($user)) { - killme(); + $user = User::getById($register['uid']); + if (!DBA::isResult($user)) { + exit(); } - $r = q("DELETE FROM `register` WHERE `hash` = '%s'", - dbesc($register[0]['hash']) - ); + Register::deleteByHash($hash); + DBA::update('user', ['blocked' => false, 'verified' => true], ['uid' => $register['uid']]); - $r = q("UPDATE `user` SET `blocked` = 0, `verified` = 1 WHERE `uid` = %d", - intval($register[0]['uid']) - ); + $profile = DBA::selectFirst('profile', ['net-publish'], ['uid' => $register['uid'], 'is-default' => true]); - $r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default` = 1", - intval($user[0]['uid']) - ); - if (DBM::is_result($r) && $r[0]['net-publish']) { - $url = System::baseUrl() . '/profile/' . $user[0]['nickname']; - if ($url && strlen(Config::get('system', 'directory'))) { - Worker::add(PRIORITY_LOW, "Directory", $url); - } + if (DBA::isResult($profile) && $profile['net-publish'] && Config::get('system', 'directory')) { + $url = System::baseUrl() . '/profile/' . $user['nickname']; + Worker::add(PRIORITY_LOW, "Directory", $url); } - L10n::pushLang($register[0]['language']); + L10n::pushLang($register['language']); $res = User::sendRegisterOpenEmail( - $user[0]['email'], - $a->config['sitename'], - System::baseUrl(), - $user[0]['username'], - $register[0]['password']); + $user, + Config::get('config', 'sitename'), + $a->getBaseUrl(), + ($register['password'] ?? '') ?: 'Sent in a previous email' + ); L10n::popLang(); @@ -75,42 +60,38 @@ function user_allow($hash) // allowed to have friends on this system function user_deny($hash) { - $register = q("SELECT * FROM `register` WHERE `hash` = '%s' LIMIT 1", - dbesc($hash) - ); - - if (!DBM::is_result($register)) { + $register = Register::getByHash($hash); + if (!DBA::isResult($register)) { return false; } - $user = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", - intval($register[0]['uid']) - ); + $user = User::getById($register['uid']); + if (!DBA::isResult($user)) { + exit(); + } - dba::delete('user', ['uid' => $register[0]['uid']]); - dba::delete('register', ['hash' => $register[0]['hash']]); + DBA::delete('user', ['uid' => $register['uid']]); - notice(L10n::t('Registration revoked for %s', $user[0]['username']) . EOL); + Register::deleteByHash($register['hash']); + + notice(L10n::t('Registration revoked for %s', $user['username']) . EOL); return true; } function regmod_content(App $a) { - global $lang; - if (!local_user()) { info(L10n::t('Please login.') . EOL); - $o = '

' . Login::form($a->query_string, $a->config['register_policy'] == REGISTER_CLOSED ? 0 : 1); - return $o; + return Login::form($a->query_string, intval(Config::get('config', 'register_policy')) === \Friendica\Module\Register::CLOSED ? 0 : 1); } - if ((!is_site_admin()) || (x($_SESSION, 'submanage') && intval($_SESSION['submanage']))) { + if (!is_site_admin() || !empty($_SESSION['submanage'])) { notice(L10n::t('Permission denied.') . EOL); return ''; } if ($a->argc != 3) { - killme(); + exit(); } $cmd = $a->argv[1]; @@ -118,13 +99,11 @@ function regmod_content(App $a) if ($cmd === 'deny') { user_deny($hash); - goaway(System::baseUrl() . "/admin/users/"); - killme(); + $a->internalRedirect('admin/users/'); } if ($cmd === 'allow') { user_allow($hash); - goaway(System::baseUrl() . "/admin/users/"); - killme(); + $a->internalRedirect('admin/users/'); } }