mirror of
https://codeberg.org/streams/streams.git
synced 2024-09-20 04:35:26 +00:00
82 lines
2 KiB
PHP
82 lines
2 KiB
PHP
<?php
|
|
|
|
namespace Code\Module;
|
|
|
|
use App;
|
|
use Code\Web\Controller;
|
|
use Code\Lib\Account;
|
|
use Code\Render\Theme;
|
|
|
|
|
|
class Removeaccount extends Controller
|
|
{
|
|
|
|
public function post()
|
|
{
|
|
|
|
if (!local_channel()) {
|
|
return;
|
|
}
|
|
|
|
if ($_SESSION['delegate']) {
|
|
return;
|
|
}
|
|
|
|
if ((!x($_POST, 'qxz_password')) || (!strlen(trim($_POST['qxz_password'])))) {
|
|
return;
|
|
}
|
|
|
|
if ((!x($_POST, 'verify')) || (!strlen(trim($_POST['verify'])))) {
|
|
return;
|
|
}
|
|
|
|
if ($_POST['verify'] !== $_SESSION['remove_account_verify']) {
|
|
return;
|
|
}
|
|
|
|
$account = App::get_account();
|
|
$account_id = get_account_id();
|
|
|
|
if (!($account && $account_id)) {
|
|
return;
|
|
}
|
|
|
|
$x = account_verify_password($account['account_email'], $_POST['qxz_password']);
|
|
if (!($x && $x['account'])) {
|
|
return;
|
|
}
|
|
|
|
if ($account['account_password_changed'] > NULL_DATE) {
|
|
$d1 = datetime_convert('UTC', 'UTC', 'now - 48 hours');
|
|
if ($account['account_password_changed'] > d1) {
|
|
notice(t('Account removals are not allowed within 48 hours of changing the account password.') . EOL);
|
|
return;
|
|
}
|
|
}
|
|
|
|
Account::remove($account_id);
|
|
}
|
|
|
|
public function get()
|
|
{
|
|
|
|
if (!local_channel()) {
|
|
goaway(z_root());
|
|
}
|
|
|
|
$hash = random_string();
|
|
|
|
$_SESSION['remove_account_verify'] = $hash;
|
|
|
|
$o .= replace_macros(Theme::get_template('removeaccount.tpl'), [
|
|
'$basedir' => z_root(),
|
|
'$hash' => $hash,
|
|
'$title' => t('Remove This Account'),
|
|
'$desc' => [t('WARNING: '), t('This account and all its channels will be completely removed from this server. '), t('This action is permanent and can not be undone!')],
|
|
'$passwd' => t('Please enter your password for verification:'),
|
|
'$submit' => t('Remove Account')
|
|
]);
|
|
|
|
return $o;
|
|
}
|
|
}
|