315 lines
15 KiB
PHP
315 lines
15 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* [Discuz!] (C)2001-2099 Comsenz Inc.
|
||
|
* This is NOT a freeware, use is subject to license terms
|
||
|
*
|
||
|
* $Id: moderate_member.php 33688 2013-08-02 03:00:15Z nemohou $
|
||
|
*/
|
||
|
|
||
|
if(!defined('IN_DISCUZ') || !defined('IN_ADMINCP')) {
|
||
|
exit('Access Denied');
|
||
|
}
|
||
|
|
||
|
$do = empty($do) ? 'mod' : $do;
|
||
|
|
||
|
if($do == 'mod') {
|
||
|
|
||
|
if(!submitcheck('modsubmit')) {
|
||
|
$count = C::t('common_member_validate')->fetch_all_status_by_count();
|
||
|
|
||
|
$sendemail = isset($_GET['sendemail']) ? $_GET['sendemail'] : 0;
|
||
|
$checksendemail = $sendemail ? 'checked' : '';
|
||
|
|
||
|
$start_limit = ($page - 1) * $_G['setting']['memberperpage'];
|
||
|
|
||
|
$validatenum = C::t('common_member_validate')->count_by_status(0);
|
||
|
$members = '';
|
||
|
if($validatenum) {
|
||
|
$multipage = multi($validatenum, $_G['setting']['memberperpage'], $page, ADMINSCRIPT.'?action=moderate&operation=members&sendemail='.$sendemail);
|
||
|
$vuids = array();
|
||
|
loadcache('fields_register');
|
||
|
require_once libfile('function/profile');
|
||
|
loadcache('usergroups');
|
||
|
$allvalidate = C::t('common_member_validate')->fetch_all_invalidate($start_limit, $_G['setting']['memberperpage']);
|
||
|
$uids = array_keys($allvalidate);
|
||
|
$allmember = C::t('common_member')->fetch_all($uids, false, 0);
|
||
|
$allmemberstatus = C::t('common_member_status')->fetch_all($uids, false, 0);
|
||
|
$allmemberprofile = C::t('common_member_profile')->fetch_all($uids, false, 0);
|
||
|
foreach($allvalidate as $uid => $member) {
|
||
|
$member = array_merge((array)$member, (array)$allmember[$uid], (array)$allmemberstatus[$uid], (array)$allmemberprofile[$uid]);
|
||
|
if($member['groupid'] != 8 && $member['freeze'] != 2) {
|
||
|
$vuids[$uid] = $uid;
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
$fields = !empty($member['field']) ? dunserialize($member['field']) : array();
|
||
|
$str = '';
|
||
|
foreach($_G['cache']['fields_register'] as $field) {
|
||
|
if(!$field['available'] || in_array($field['fieldid'], array('uid', 'constellation', 'zodiac', 'birthmonth', 'birthyear', 'birthprovince', 'birthdist', 'birthcommunity', 'resideprovince', 'residedist', 'residecommunity'))) {
|
||
|
continue;
|
||
|
}
|
||
|
$member[$field['fieldid']] = !empty($member[$field['fieldid']]) ? $member[$field['fieldid']] : $fields[$field['fieldid']];
|
||
|
if($member[$field['fieldid']]) {
|
||
|
$fieldstr = profile_show($field['fieldid'], $member);
|
||
|
$str .= $field['title'].':'.$fieldstr."<br/>";
|
||
|
}
|
||
|
}
|
||
|
$str = !empty($str) ? '<br/>'.$str : '';
|
||
|
$member['regdate'] = dgmdate($member['regdate']);
|
||
|
$member['submitdate'] = dgmdate($member['submitdate']);
|
||
|
$member['moddate'] = $member['moddate'] ? dgmdate($member['moddate']) : $lang['none'];
|
||
|
$member['admin'] = $member['admin'] ? "<a href=\"home.php?mod=space&username=".rawurlencode($member['admin'])."\" target=\"_blank\">$member[admin]</a>" : $lang['none'];
|
||
|
$members .= "<tr class=\"hover\" id=\"mod_uid_{$member[uid]}\"><td class=\"rowform\" style=\"width:80px;\"><ul class=\"nofloat\"><li><input id=\"mod_uid_{$member[uid]}_1\" class=\"radio\" type=\"radio\" name=\"modtype[$member[uid]]\" value=\"invalidate\" onclick=\"set_bg('invalidate', $member[uid]);\"><label for=\"mod_uid_{$member[uid]}_1\">$lang[invalidate]</label></li><li><input id=\"mod_uid_{$member[uid]}_2\" class=\"radio\" type=\"radio\" name=\"modtype[$member[uid]]\" value=\"validate\" onclick=\"set_bg('validate', $member[uid]);\"><label for=\"mod_uid_{$member[uid]}_2\">$lang[validate]</label></li>\n".
|
||
|
"<li>".($member['groupid'] == 8 ? "<input id=\"mod_uid_{$member[uid]}_3\" class=\"radio\" type=\"radio\" name=\"modtype[$member[uid]]\" value=\"delete\" onclick=\"set_bg('delete', $member[uid]);\"><label for=\"mod_uid_{$member[uid]}_3\">$lang[delete]</label>" : "<input disabled class=\"radio\" type=\"radio\" />$lang[delete]")."</li><li><input id=\"mod_uid_{$member[uid]}_4\" class=\"radio\" type=\"radio\" name=\"modtype[$member[uid]]\" value=\"ignore\" onclick=\"set_bg('ignore', $member[uid]);\"><label for=\"mod_uid_{$member[uid]}_4\">$lang[ignore]</label></li></ul></td><td><b><a href=\"home.php?mod=space&uid=$member[uid]\" target=\"_blank\">$member[username]</a></b>\n".$_G['cache']['usergroups'][$member['groupid']]['grouptitle'].
|
||
|
"<br />$lang[members_edit_regdate]: $member[regdate]<br />$lang[members_edit_regip]: $member[regip] ".convertip($member['regip'])."<br />$lang[members_edit_lastip]: $member[lastip] ".convertip($member['lastip'])."<br />Email: $member[email]$str</td>\n".
|
||
|
"<td align=\"center\"><textarea rows=\"4\" name=\"userremark[$member[uid]]\" style=\"width: 95%; word-break: break-all\">$member[message]</textarea></td>\n".
|
||
|
"<td>$lang[moderate_members_submit_times]: $member[submittimes]<br />$lang[moderate_members_submit_time]: $member[submitdate]<br />$lang[moderate_members_admin]: $member[admin]<br />\n".
|
||
|
"$lang[moderate_members_mod_time]: $member[moddate]</td><td><textarea rows=\"4\" id=\"remark[$member[uid]]\" name=\"remark[$member[uid]]\" style=\"width: 95%; word-break: break-all\">$member[remark]</textarea></td></tr>\n";
|
||
|
}
|
||
|
}
|
||
|
shownav('user', 'nav_modmembers');
|
||
|
showsubmenu('nav_moderate_users', array(
|
||
|
array('nav_moderate_users_mod', 'moderate&operation=members&do=mod', 1),
|
||
|
array('clean', 'moderate&operation=members&do=del', 0)
|
||
|
));
|
||
|
showtips('moderate_members_tips');
|
||
|
$moderate_members_bad_reason = cplang('moderate_members_bad_reason');
|
||
|
$moderate_members_succeed = cplang('moderate_members_succeed');
|
||
|
echo <<<EOT
|
||
|
<script type="text/javascript">
|
||
|
function set_bg(operation, uid) {
|
||
|
if(operation == 'invalidate') {
|
||
|
$('mod_uid_' + uid).className = "mod_invalidate";
|
||
|
$('remark[' + uid + ']').value = '$moderate_members_bad_reason';
|
||
|
} else if(operation == 'validate') {
|
||
|
$('mod_uid_' + uid).className = "mod_validate";
|
||
|
$('remark[' + uid + ']').value = '$moderate_members_succeed';
|
||
|
} else if(operation == 'ignore') {
|
||
|
$('mod_uid_' + uid).className = "mod_ignore";
|
||
|
$('remark[' + uid + ']').value = '';
|
||
|
} else if(operation == 'delete') {
|
||
|
$('mod_uid_' + uid).className = "mod_delete";
|
||
|
$('remark[' + uid + ']').value = '';
|
||
|
}
|
||
|
$('chk_apply_all').disabled = true;
|
||
|
$('chk_apply_all').checked = false;
|
||
|
}
|
||
|
function set_bg_all(operation) {
|
||
|
var trs = $('cpform').getElementsByTagName('TR');
|
||
|
for(var i in trs) {
|
||
|
if(trs[i].id && trs[i].id.substr(0, 8) == 'mod_uid_') {
|
||
|
uid = trs[i].id.substr(8);
|
||
|
if(operation == 'invalidate') {
|
||
|
trs[i].className = 'mod_invalidate';
|
||
|
$('remark[' + uid + ']').value = '$moderate_members_bad_reason';
|
||
|
} else if(operation == 'validate') {
|
||
|
trs[i].className = 'mod_validate';
|
||
|
$('remark[' + uid + ']').value = '$moderate_members_succeed';
|
||
|
} else if(operation == 'ignore') {
|
||
|
trs[i].className = 'mod_ignore';
|
||
|
$('remark[' + uid + ']').value = '';
|
||
|
} else if(operation == 'delete') {
|
||
|
trs[i].className = 'mod_delete';
|
||
|
$('remark[' + uid + ']').value = '';
|
||
|
}else if(operation == 'cancel') {
|
||
|
trs[i].className = '';
|
||
|
$('remark[' + uid + ']').value = '';
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if(operation != 'cancel') {
|
||
|
$('chk_apply_all').disabled = false;
|
||
|
$('chk_apply_all').value = operation;
|
||
|
} else {
|
||
|
$('chk_apply_all').disabled = true;
|
||
|
$('chk_apply_all').checked = false;
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|
||
|
function cancelallcheck() {
|
||
|
var form = $('cpform');
|
||
|
var checkall = 'chkall';
|
||
|
for(var i = 0; i < form.elements.length; i++) {
|
||
|
var e = form.elements[i];
|
||
|
if(e.type == 'radio') {
|
||
|
e.checked = '';
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
EOT;
|
||
|
showformheader('moderate&operation=members&do=mod');
|
||
|
showtableheader('moderate_members', 'fixpadding');
|
||
|
showsubtitle(array('operation', 'members_edit_info', 'moderate_members_message', 'moderate_members_info', 'moderate_members_remark'));
|
||
|
echo $members;
|
||
|
showsubmit('modsubmit', 'submit', '', '<a href="#all" onclick="checkAll(\'option\', $(\'cpform\'), \'invalidate\');set_bg_all(\'invalidate\');">'.cplang('moderate_all_invalidate').'</a> <a href="#all" onclick="checkAll(\'option\', $(\'cpform\'), \'validate\');set_bg_all(\'validate\');">'.cplang('moderate_all_validate').'</a> <a href="#all" onclick="checkAll(\'option\', $(\'cpform\'), \'delete\');set_bg_all(\'delete\');">'.cplang('moderate_all_delete').'</a> <a href="#all" onclick="checkAll(\'option\', $(\'cpform\'), \'ignore\');set_bg_all(\'ignore\');">'.cplang('moderate_all_ignore').'</a> <a href="#all" onclick="cancelallcheck();set_bg_all(\'cancel\');">'.cplang('moderate_all_cancel').'</a><input class="checkbox" type="checkbox" name="apply_all" id="chk_apply_all" value="1" disabled="disabled" />'.cplang('moderate_apply_all').' <input class="checkbox" type="checkbox" name="sendemail" id="sendemail" value="1" '.$checksendemail.' /><label for="sendemail"> '.cplang('moderate_members_email').'</label>', $multipage);
|
||
|
showtablefooter();
|
||
|
showformfooter();
|
||
|
|
||
|
} else {
|
||
|
|
||
|
$moderation = array('invalidate' => array(), 'validate' => array(), 'delete' => array(), 'ignore' => array());
|
||
|
|
||
|
$uids = array();
|
||
|
$uidsql = '';
|
||
|
if(!$_GET['apply_all']) {
|
||
|
if(is_array($_GET['modtype'])) {
|
||
|
foreach($_GET['modtype'] as $uid => $act) {
|
||
|
$uid = intval($uid);
|
||
|
$uids[$uid] = $uid;
|
||
|
$moderation[$act][$uid] = $uid;
|
||
|
}
|
||
|
$uidsql = 'v.uid IN ('.dimplode($uids).') AND';
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$members = array();
|
||
|
|
||
|
$allmembervalidate = $uids ? C::t('common_member_validate')->fetch_all($uids) : C::t('common_member_validate')->range();
|
||
|
foreach(C::t('common_member')->fetch_all(array_keys($allmembervalidate), false, 0) as $uid => $member) {
|
||
|
if($member['groupid'] == 8 || $member['freeze'] == 2) {
|
||
|
$members[$uid] = $member;
|
||
|
}
|
||
|
}
|
||
|
$alluids = array_keys($members);
|
||
|
if($_GET['apply_all']) {
|
||
|
$moderation[$_GET['apply_all']] = array_merge($alluids, $moderation[$_GET['apply_all']]);
|
||
|
}
|
||
|
if(!empty($members)) {
|
||
|
$numdeleted = $numinvalidated = $numvalidated = 0;
|
||
|
|
||
|
if(!empty($moderation['delete']) && is_array($moderation['delete'])) {
|
||
|
$deluids = array_intersect($moderation['delete'], $alluids);
|
||
|
$numdeleted = count($deluids);
|
||
|
|
||
|
C::t('common_member')->delete_no_validate($deluids);
|
||
|
|
||
|
loaducenter();
|
||
|
uc_user_delete($deluids);
|
||
|
} else {
|
||
|
$moderation['delete'] = array();
|
||
|
}
|
||
|
|
||
|
if(!empty($moderation['validate']) && is_array($moderation['validate'])) {
|
||
|
|
||
|
$validateuids = array_intersect($moderation['validate'], $alluids);
|
||
|
C::t('common_member')->update($validateuids, array('adminid' => 0, 'groupid' => $_G['setting']['newusergroupid'], 'freeze' => 0));
|
||
|
$numvalidated = count($validateuids);
|
||
|
C::t('common_member_validate')->delete($validateuids);
|
||
|
} else {
|
||
|
$moderation['validate'] = array();
|
||
|
}
|
||
|
|
||
|
if(!empty($moderation['invalidate']) && is_array($moderation['invalidate'])) {
|
||
|
$invalidateuids = array_intersect($moderation['invalidate'], $alluids);
|
||
|
$numinvalidated = count($invalidateuids);
|
||
|
foreach($invalidateuids as $uid) {
|
||
|
C::t('common_member_validate')->update($uid, array('moddate' => $_G['timestamp'], 'admin' => $_G['username'], 'status' => '1', 'remark' => dhtmlspecialchars($_GET['remark'][$uid])));
|
||
|
}
|
||
|
} else {
|
||
|
$moderation['invalidate'] = array();
|
||
|
}
|
||
|
|
||
|
foreach(array('validate', 'invalidate') as $o) {
|
||
|
foreach($moderation[$o] as $uid) {
|
||
|
if($_GET['remark'][$uid]) {
|
||
|
switch($o) {
|
||
|
case 'validate':
|
||
|
notification_add($uid, 'mod_member', 'member_moderate_validate', array('remark' => $_GET['remark'][$uid]));
|
||
|
break;
|
||
|
case 'invalidate':
|
||
|
notification_add($uid, 'mod_member', 'member_moderate_invalidate', array('remark' => $_GET['remark'][$uid]));
|
||
|
break;
|
||
|
}
|
||
|
} else {
|
||
|
switch($o) {
|
||
|
case 'validate':
|
||
|
notification_add($uid, 'mod_member', 'member_moderate_validate_no_remark');
|
||
|
break;
|
||
|
case 'invalidate':
|
||
|
notification_add($uid, 'mod_member', 'member_moderate_invalidate_no_remark');
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if($_GET['sendemail']) {
|
||
|
if(!function_exists('sendmail')) {
|
||
|
include libfile('function/mail');
|
||
|
}
|
||
|
foreach(array('delete', 'validate', 'invalidate') as $o) {
|
||
|
foreach($moderation[$o] as $uid) {
|
||
|
if(isset($members[$uid])) {
|
||
|
$member = $members[$uid];
|
||
|
$member['regdate'] = dgmdate($member['regdate']);
|
||
|
$member['submitdate'] = dgmdate($member['submitdate']);
|
||
|
$member['moddate'] = dgmdate(TIMESTAMP);
|
||
|
$member['operation'] = $o;
|
||
|
$member['remark'] = $_GET['remark'][$uid] ? dhtmlspecialchars($_GET['remark'][$uid]) : $lang['none'];
|
||
|
$moderate_member_message = lang('email', 'moderate_member_message', array(
|
||
|
'username' => $member['username'],
|
||
|
'bbname' => $_G['setting']['bbname'],
|
||
|
'regdate' => $member['regdate'],
|
||
|
'submitdate' => $member['submitdate'],
|
||
|
'submittimes' => $member['submittimes'],
|
||
|
'message' => $member['message'],
|
||
|
'modresult' => lang('email', 'moderate_member_'.$member['operation']),
|
||
|
'moddate' => $member['moddate'],
|
||
|
'adminusername' => $_G['member']['username'],
|
||
|
'remark' => $member['remark'],
|
||
|
'siteurl' => $_G['siteurl'],
|
||
|
));
|
||
|
|
||
|
if(!sendmail("$member[username] <$member[email]>", lang('email', 'moderate_member_subject'), $moderate_member_message)) {
|
||
|
runlog('sendmail', "$member[email] sendmail failed.");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
cpmsg('moderate_members_op_succeed', "action=moderate&operation=members&page=$page", 'succeed', array('numvalidated' => $numvalidated, 'numinvalidated' => $numinvalidated, 'numdeleted' => $numdeleted));
|
||
|
|
||
|
}
|
||
|
|
||
|
} elseif($do == 'del') {
|
||
|
|
||
|
if(!submitcheck('prunesubmit', 1)) {
|
||
|
|
||
|
shownav('user', 'nav_modmembers');
|
||
|
showsubmenu('nav_moderate_users', array(
|
||
|
array('nav_moderate_users_mod', 'moderate&operation=members&do=mod', 0),
|
||
|
array('clean', 'moderate&operation=members&do=del', 1)
|
||
|
));
|
||
|
showtips('moderate_members_tips');
|
||
|
showformheader('moderate&operation=members&do=del');
|
||
|
showtableheader('moderate_members_prune');
|
||
|
showsetting('moderate_members_prune_submitmore', 'submitmore', '5', 'text');
|
||
|
showsetting('moderate_members_prune_regbefore', 'regbefore', '30', 'text');
|
||
|
showsetting('moderate_members_prune_modbefore', 'modbefore', '15', 'text');
|
||
|
showsetting('moderate_members_prune_regip', 'regip', '', 'text');
|
||
|
showsubmit('prunesubmit');
|
||
|
showtablefooter();
|
||
|
showformfooter();
|
||
|
|
||
|
} else {
|
||
|
|
||
|
$uids = C::t('common_member_validate')->fetch_all_validate_uid($_GET['submitmore'], $_GET['regbefore'], $_GET['modbefore'], $_GET['regip']);
|
||
|
if((!$membernum = count($uids))) {
|
||
|
cpmsg('members_search_noresults', '', 'error');
|
||
|
} elseif(!$_GET['confirmed']) {
|
||
|
cpmsg('members_delete_confirm', "action=moderate&operation=members&do=del&submitmore=".rawurlencode($_GET['submitmore'])."®before=".rawurlencode($_GET['regbefore'])."®ip=".rawurlencode($_GET['regip'])."&prunesubmit=yes", 'form', array('membernum' => $membernum));
|
||
|
} else {
|
||
|
$numdeleted = C::t('common_member')->delete_no_validate(array_keys($uids));
|
||
|
|
||
|
cpmsg('members_delete_succeed', '', 'succeed', array('numdeleted' => $numdeleted));
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
?>
|