streams/Code/Module/Removeme.php
2022-02-15 20:08:28 -08:00

82 lines
2 KiB
PHP

<?php
namespace Code\Module;
use App;
use Code\Web\Controller;
use Code\Lib\Channel;
use Code\Render\Theme;
class Removeme 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_channel_verify']) {
return;
}
$account = App::get_account();
if (!$account) {
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('Channel removals are not allowed within 48 hours of changing the account password.') . EOL);
return;
}
}
Channel::channel_remove(local_channel(), true, true);
}
public function get()
{
if (!local_channel()) {
goaway(z_root());
}
$hash = random_string();
$_SESSION['remove_channel_verify'] = $hash;
$o .= replace_macros(Theme::get_template('removeme.tpl'), [
'$basedir' => z_root(),
'$hash' => $hash,
'$title' => t('Remove This Channel'),
'$desc' => [t('WARNING: '), t('This channel 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 Channel')
]);
return $o;
}
}