51 lines
1.1 KiB
PHP
51 lines
1.1 KiB
PHP
<?php
|
|
# $Id$
|
|
/**
|
|
* See deferred.doc
|
|
*
|
|
* @package MediaWiki
|
|
*/
|
|
|
|
/**
|
|
*
|
|
* @package MediaWiki
|
|
*/
|
|
class SiteStatsUpdate {
|
|
|
|
var $mViews, $mEdits, $mGood;
|
|
|
|
function SiteStatsUpdate( $views, $edits, $good ) {
|
|
$this->mViews = $views;
|
|
$this->mEdits = $edits;
|
|
$this->mGood = $good;
|
|
}
|
|
|
|
function doUpdate() {
|
|
$a = array();
|
|
|
|
if ( $this->mViews < 0 ) { $m = '-1'; }
|
|
else if ( $this->mViews > 0 ) { $m = '+1'; }
|
|
else $m = '';
|
|
array_push( $a, "ss_total_views=(ss_total_views$m)" );
|
|
|
|
if ( $this->mEdits < 0 ) { $m = '-1'; }
|
|
else if ( $this->mEdits > 0 ) { $m = '+1'; }
|
|
else $m = '';
|
|
array_push( $a, "ss_total_edits=(ss_total_edits$m)" );
|
|
|
|
if ( $this->mGood < 0 ) { $m = '-1'; }
|
|
else if ( $this->mGood > 0 ) { $m = '+1'; }
|
|
else $m = '';
|
|
array_push( $a, "ss_good_articles=(ss_good_articles$m)" );
|
|
|
|
$db =& wfGetDB( DB_MASTER );
|
|
$site_stats = $db->tableName( 'site_stats' );
|
|
$lowpri = $db->lowPriorityOption();
|
|
|
|
$sql = "UPDATE $lowpri $site_stats SET " . implode ( ',', $a ) .
|
|
' WHERE ss_row_id=1';
|
|
$db->query( $sql, 'SiteStatsUpdate::doUpdate' );
|
|
}
|
|
}
|
|
|
|
?>
|