mirror of
https://github.com/torrentpier/torrentpier.git
synced 2025-01-18 17:02:51 -08:00
5a8f431215
* Minor improvements * Update viewforum.tpl * Update manage_user.php * Update manage_user.php * Update manage_admin.php * Update manage_user.php * Update CHANGELOG.md
98 lines
3.5 KiB
PHP
98 lines
3.5 KiB
PHP
<?php
|
||
/**
|
||
* TorrentPier – Bull-powered BitTorrent tracker engine
|
||
*
|
||
* @copyright Copyright (c) 2005-2024 TorrentPier (https://torrentpier.com)
|
||
* @link https://github.com/torrentpier/torrentpier for the canonical source repository
|
||
* @license https://github.com/torrentpier/torrentpier/blob/master/LICENSE MIT License
|
||
*/
|
||
|
||
if (!defined('IN_AJAX')) {
|
||
die(basename(__FILE__));
|
||
}
|
||
|
||
global $userdata, $lang, $bb_cfg;
|
||
|
||
if (!$mode = (string)$this->request['mode']) {
|
||
$this->ajax_die('invalid mode (empty)');
|
||
}
|
||
|
||
if (!$user_id = (int)$this->request['user_id']) {
|
||
$this->ajax_die($lang['NO_USER_ID_SPECIFIED']);
|
||
}
|
||
|
||
// Check for demo mode
|
||
if (IN_DEMO_MODE) {
|
||
$this->ajax_die($lang['CANT_EDIT_IN_DEMO_MODE']);
|
||
}
|
||
|
||
switch ($mode) {
|
||
case 'delete_profile':
|
||
if ($userdata['user_id'] == $user_id) {
|
||
$this->ajax_die($lang['USER_DELETE_ME']);
|
||
}
|
||
if (empty($this->request['confirmed'])) {
|
||
$this->prompt_for_confirm($lang['USER_DELETE_CONFIRM']);
|
||
}
|
||
|
||
if (!in_array($user_id, explode(',', EXCLUDED_USERS))) {
|
||
\TorrentPier\Sessions::delete_user_sessions($user_id);
|
||
\TorrentPier\Legacy\Admin\Common::user_delete($user_id);
|
||
|
||
$user_id = $userdata['user_id']; // Store self user_id for redirect after successful deleting
|
||
$this->response['info'] = $lang['USER_DELETED'];
|
||
} else {
|
||
$this->ajax_die($lang['USER_DELETE_CSV']);
|
||
}
|
||
break;
|
||
case 'delete_topics':
|
||
if ($userdata['user_id'] == $user_id) {
|
||
$this->prompt_for_confirm($lang['DELETE_USER_POSTS_ME']);
|
||
}
|
||
if (empty($this->request['confirmed'])) {
|
||
$this->prompt_for_confirm($lang['DELETE_USER_ALL_POSTS_CONFIRM']);
|
||
}
|
||
|
||
$user_topics = DB()->fetch_rowset("SELECT topic_id FROM " . BB_TOPICS . " WHERE topic_poster = $user_id", 'topic_id');
|
||
$deleted_topics = \TorrentPier\Legacy\Admin\Common::topic_delete($user_topics);
|
||
$deleted_posts = \TorrentPier\Legacy\Admin\Common::post_delete('user', $user_id);
|
||
$this->response['info'] = $lang['USER_DELETED_POSTS'];
|
||
break;
|
||
case 'delete_message':
|
||
if ($userdata['user_id'] == $user_id) {
|
||
$this->prompt_for_confirm($lang['DELETE_USER_POSTS_ME']);
|
||
}
|
||
if (empty($this->request['confirmed'])) {
|
||
$this->prompt_for_confirm($lang['DELETE_USER_POSTS_CONFIRM']);
|
||
}
|
||
|
||
\TorrentPier\Legacy\Admin\Common::post_delete('user', $user_id);
|
||
$this->response['info'] = $lang['USER_DELETED_POSTS'];
|
||
break;
|
||
case 'user_activate':
|
||
if (empty($this->request['confirmed'])) {
|
||
$this->prompt_for_confirm($lang['DEACTIVATE_CONFIRM']);
|
||
}
|
||
|
||
DB()->query("UPDATE " . BB_USERS . " SET user_active = 1 WHERE user_id = " . $user_id);
|
||
$this->response['info'] = $lang['USER_ACTIVATE_ON'];
|
||
break;
|
||
case 'user_deactivate':
|
||
if ($userdata['user_id'] == $user_id) {
|
||
$this->ajax_die($lang['USER_DEACTIVATE_ME']);
|
||
}
|
||
if (empty($this->request['confirmed'])) {
|
||
$this->prompt_for_confirm($lang['ACTIVATE_CONFIRM']);
|
||
}
|
||
|
||
DB()->query("UPDATE " . BB_USERS . " SET user_active = 0 WHERE user_id = " . $user_id);
|
||
\TorrentPier\Sessions::delete_user_sessions($user_id);
|
||
$this->response['info'] = $lang['USER_ACTIVATE_OFF'];
|
||
break;
|
||
default:
|
||
$this->ajax_die('Invalid mode');
|
||
}
|
||
|
||
$this->response['mode'] = $mode;
|
||
$this->response['url'] = html_entity_decode(make_url('/') . PROFILE_URL . $user_id);
|