📄 counter.inc.php
字号:
<?php
/*
[Discuz!] (C)2001-2007 Comsenz Inc.
This is NOT a freeware, use is subject to license terms
$Id: counter.inc.php 13670 2008-05-04 08:30:52Z monkey $
*/
if(!defined('IN_DISCUZ') || !defined('IN_ADMINCP')) {
exit('Access Denied');
}
cpheader();
$pertask = isset($pertask) ? intval($pertask) : 100;
$current = isset($current) && $current > 0 ? intval($current) : 0;
$next = $current + $pertask;
if(submitcheck('forumsubmit', 1)) {
$nextlink = "admincp.php?action=counter¤t=$next&pertask=$pertask&forumsubmit=yes";
$processed = 0;
$queryf = $db->query("SELECT fid FROM {$tablepre}forums WHERE type<>'group' LIMIT $current, $pertask");
while($forum = $db->fetch_array($queryf)) {
$processed = 1;
extract($db->fetch_first("SELECT COUNT(*) AS threads, SUM(replies)+COUNT(*) AS posts FROM {$tablepre}threads WHERE fid='$forum[fid]' AND displayorder>='0'"));
$thread = $db->fetch_first("SELECT tid, subject, lastpost, lastposter FROM {$tablepre}threads WHERE fid='$forum[fid]' AND displayorder>='0' ORDER BY lastpost DESC LIMIT 1");
$lastpost = addslashes("$thread[tid]\t$thread[subject]\t$thread[lastpost]\t$thread[lastposter]");
$db->query("UPDATE {$tablepre}forums SET threads='$threads', posts='$posts', lastpost='$lastpost' WHERE fid='$forum[fid]'");
}
if($processed) {
cpmsg("$lang[counter_forum]: $lang[counter_processing]", $nextlink, 'loading');
} else {
$db->query("UPDATE {$tablepre}forums SET threads='0', posts='0' WHERE type='group'");
cpmsg('counter_forum_succeed', 'admincp.php?action=counter', 'succeed');
}
} elseif(submitcheck('digestsubmit', 1)) {
if(!$current) {
$db->query("UPDATE {$tablepre}members SET digestposts=0", 'UNBUFFERED');
$current = 0;
}
$nextlink = "admincp.php?action=counter¤t=$next&pertask=$pertask&digestsubmit=yes";
$processed = 0;
$membersarray = $postsarray = array();
$query = $db->query("SELECT authorid FROM {$tablepre}threads WHERE digest<>'0' AND displayorder>='0' LIMIT $current, $pertask");
while($thread = $db->fetch_array($query)) {
$processed = 1;
$membersarray[$thread['authorid']]++;
}
foreach($membersarray as $uid => $posts) {
$postsarray[$posts] .= ','.$uid;
}
unset($membersarray);
foreach($postsarray as $posts => $uids) {
$db->query("UPDATE {$tablepre}members SET digestposts=digestposts+'$posts' WHERE uid IN (0$uids)", 'UNBUFFERED');
}
if($processed) {
cpmsg("$lang[counter_digest]: $lang[counter_processing]", $nextlink, 'loading');
} else {
cpmsg('counter_digest_succeed', 'admincp.php?action=counter', 'succeed');
}
} elseif(submitcheck('membersubmit', 1)) {
$nextlink = "admincp.php?action=counter¤t=$next&pertask=$pertask&membersubmit=yes";
$processed = 0;
$queryt = $db->query("SELECT uid FROM {$tablepre}members LIMIT $current, $pertask");
while($mem = $db->fetch_array($queryt)) {
$processed = 1;
$query = $db->query("SELECT COUNT(*) FROM {$tablepre}posts WHERE authorid='$mem[uid]' AND invisible='0'");
$db->query("UPDATE {$tablepre}members SET posts='".$db->result($query, 0)."' WHERE uid='$mem[uid]'");
}
if($processed) {
cpmsg("$lang[counter_member]: $lang[counter_processing]", $nextlink, 'loading');
} else {
cpmsg('counter_member_succeed', 'admincp.php?action=counter', 'succeed');
}
} elseif(submitcheck('threadsubmit', 1)) {
$nextlink = "admincp.php?action=counter¤t=$next&pertask=$pertask&threadsubmit=yes";
$processed = 0;
$queryt = $db->query("SELECT tid, replies FROM {$tablepre}threads WHERE displayorder>='0' LIMIT $current, $pertask");
while($threads = $db->fetch_array($queryt)) {
$processed = 1;
$replynum = $db->result_first("SELECT COUNT(*) FROM {$tablepre}posts WHERE tid='$threads[tid]' AND invisible='0'");
$replynum--;
if($threads['replies'] != $replynum) {
$db->query("UPDATE LOW_PRIORITY {$tablepre}threads SET replies='$replynum' WHERE tid='$threads[tid]'", 'UNBUFFERED');
}
}
if($processed) {
cpmsg("$lang[counter_thread]: $lang[counter_processing]", $nextlink, 'loading');
} else {
cpmsg('counter_thread_succeed', 'admincp.php?action=counter', 'succeed');
}
} elseif(submitcheck('movedthreadsubmit', 1)) {
$nextlink = "admincp.php?action=counter¤t=$next&pertask=$pertask&movedthreadsubmit=yes";
$processed = 0;
$tids = 0;
$query = $db->query("SELECT t1.tid, t2.tid AS threadexists FROM {$tablepre}threads t1
LEFT JOIN {$tablepre}threads t2 ON t2.tid=t1.closed AND t2.displayorder>='0'
WHERE t1.closed>'1' LIMIT $current, $pertask");
while($thread = $db->fetch_array($query)) {
$processed = 1;
if($thread['threadexists']) {
$tids .= ','.$thread['tid'];
}
}
if($tids) {
$db->query("DELETE FROM {$tablepre}threads WHERE tid IN ($tids)", 'UNBUFFERED');
}
if($processed) {
cpmsg("$lang[counter_moved_thread]: $lang[counter_processing]", $nextlink, 'loading');
} else {
cpmsg('counter_moved_thread_succeed', 'admincp.php?action=counter', 'succeed');
}
} elseif(submitcheck('cleanupsubmit', 1)) {
$nextlink = "admincp.php?action=counter¤t=$next&pertask=$pertask&cleanupsubmit=yes";
$processed = 0;
$queryt = $db->query("SELECT tid,fid FROM {$tablepre}favorites LIMIT $current, $pertask");
while($fav = $db->fetch_array($queryt)) {
$processed = 1;
if($fav['tid']) {
$favtid[]= $fav['tid'];
} elseif($fav['fid']) {
$favfid[]= $fav['fid'];
}
}
if(!empty($favtid)) {
foreach($favtid as $tid) {
if(!$db->result_first("SELECT tid FROM {$tablepre}threads WHERE tid='$tid'")) {
$db->query("DELETE FROM {$tablepre}favorites WHERE tid='$tid'");
$db->query("DELETE FROM {$tablepre}rewardlog WHERE tid='$tid'");
}
}
}
if(!empty($favfid)) {
foreach($favfid as $fid) {
if(!$db->result_first("SELECT fid FROM {$tablepre}forums WHERE fid='$fid'")) {
$db->query("DELETE FROM {$tablepre}favorites WHERE fid='$fid'");
}
}
}
if($processed) {
cpmsg("$lang[counter_moved_favorites_logs]: $lang[counter_processing]", $nextlink, 'loading');
} else {
cpmsg('counter_moved_favorites_logs_succeed', 'admincp.php?action=counter', 'succeed');
}
} else {
shownav('tools', 'nav_updatecounters');
showsubmenu('nav_updatecounters');
showformheader('counter');
showtableheader();
showsubtitle(array('', 'counter_amount'));
showhiddenfields(array('pertask' => ''));
showtablerow('', array('class="td21"'), array(
"$lang[counter_forum]:",
'<input name="pertask1" type="text" class="txt" value="15" /><input type="submit" class="btn" name="forumsubmit" onclick="this.form.pertask.value=this.form.pertask1.value" value="'.$lang['submit'].'" />'
));
showtablerow('', array('class="td21"'), array(
"$lang[counter_digest]:",
'<input name="pertask2" type="text" class="txt" value="1000" /><input type="submit" class="btn" name="digestsubmit" onclick="this.form.pertask.value=this.form.pertask2.value" value="'.$lang['submit'].'" />'
));
showtablerow('', array('class="td21"'), array(
"$lang[counter_member]:",
'<input name="pertask3" type="text" class="txt" value="1000" /><input type="submit" class="btn" name="membersubmit" onclick="this.form.pertask.value=this.form.pertask3.value" value="'.$lang['submit'].'" />'
));
showtablerow('', array('class="td21"'), array(
"$lang[counter_thread]:",
'<input name="pertask4" type="text" class="txt" value="500" /><input type="submit" class="btn" name="threadsubmit" onclick="this.form.pertask.value=this.form.pertask4.value" value="'.$lang['submit'].'" />'
));
showtablerow('', array('class="td21"'), array(
"$lang[counter_moved_thread]:",
'<input name="pertask5" type="text" class="txt" value="100" /><input type="submit" class="btn" name="movedthreadsubmit" onclick="this.form.pertask.value=this.form.pertask5.value" value="'.$lang['submit'].'" />'
));
showtablerow('', array('class="td21"'), array(
"$lang[counter_moved_favorites_logs]:",
'<input name="pertask6" type="text" class="txt" value="100" /><input type="submit" class="btn" name="cleanupsubmit" onclick="this.form.pertask.value=this.form.pertask6.value" value="'.$lang['submit'].'" />'
));
showtablefooter();
showformfooter();
}
?>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -