2004-01-06 22:09:19 +00:00
|
|
|
<?php
|
2008-08-05 22:43:14 +00:00
|
|
|
// This file is part of BOINC.
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 University of California
|
|
|
|
//
|
|
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
|
|
// under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation,
|
|
|
|
// either version 3 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// BOINC is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
// See the GNU Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
2004-01-06 22:09:19 +00:00
|
|
|
|
2008-06-19 03:44:27 +00:00
|
|
|
// The forum tables contain items that can become inconsistent
|
|
|
|
// due to bugs and DB gremlins.
|
|
|
|
// This script repairs some of them.
|
2005-02-09 18:09:26 +00:00
|
|
|
|
2008-06-19 03:58:19 +00:00
|
|
|
ini_set("memory_limit", "1024M");
|
|
|
|
|
2008-06-19 03:44:27 +00:00
|
|
|
require_once("../inc/forum_db.inc");
|
2004-01-06 22:09:19 +00:00
|
|
|
|
|
|
|
function update_thread_timestamps() {
|
2008-06-19 03:44:27 +00:00
|
|
|
$threads = BoincThread::enum();
|
|
|
|
foreach ($threads as $thread) {
|
2004-01-06 22:09:19 +00:00
|
|
|
$q = "select max(timestamp) as foo from post where thread=$thread->id";
|
|
|
|
$r2 = mysql_query($q);
|
|
|
|
$m = mysql_fetch_object($r2);
|
|
|
|
echo "id: $thread->id; min: $m->foo\n";
|
|
|
|
mysql_free_result($r2);
|
|
|
|
$n = $m->foo;
|
|
|
|
if ($n) {
|
|
|
|
$q = "update thread set timestamp=$n where id=$thread->id";
|
|
|
|
mysql_query($q);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function update_user_posts() {
|
2008-06-19 03:44:27 +00:00
|
|
|
$users = BoincUser::enum();
|
|
|
|
foreach ($users as $user) {
|
|
|
|
$num = BoincPost::count("user=$user->id");
|
|
|
|
if ($num != $user->posts) {
|
|
|
|
echo "user $user->id: $user->posts $num\n";
|
|
|
|
$user->update("posts=$num");
|
2004-01-06 22:09:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-06-19 03:44:27 +00:00
|
|
|
function update_thread_replies() {
|
|
|
|
$threads = BoincThread::enum();
|
|
|
|
foreach ($threads as $t) {
|
2008-06-19 03:58:19 +00:00
|
|
|
$n = BoincPost::count("thread=$t->id and hidden=0");
|
2008-06-19 03:44:27 +00:00
|
|
|
$n--;
|
|
|
|
if ($t->replies != $n) {
|
|
|
|
$t->update("replies=$n");
|
|
|
|
echo "updated thread $t->id; $t->replies -> $n\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//update_thread_replies(); exit();
|
|
|
|
|
|
|
|
echo "You must uncomment a function call in the script\n";
|
2004-01-06 22:09:19 +00:00
|
|
|
?>
|