streams/Zotlabs/Module/Removeme.php

76 lines
1.6 KiB
PHP

<?php
namespace Zotlabs\Module;
use App;
use Zotlabs\Web\Controller;
class Removeme extends Controller {
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_remove(local_channel(),true,true);
}
function get() {
if (! local_channel()) {
goaway(z_root());
}
$hash = random_string();
$_SESSION['remove_channel_verify'] = $hash;
$o .= replace_macros(get_markup_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;
}
}