aboutsummaryrefslogtreecommitdiffstats
path: root/includes/SiteStatsUpdate.php
blob: 900956b6398da93d1f3c11a7ee29ddcd91a4b0ba (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
<?php
# $Id$
# See deferred.doc

class SiteStatsUpdate {

	var $mViews, $mEdits, $mGood;

	function SiteStatsUpdate( $views, $edits, $good )
	{
		$this->mViews = $views;
		$this->mEdits = $edits;
		$this->mGood = $good;
	}

	function doUpdate()
	{
		global $wgIsMySQL;
		$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)" );
		$lowpri=$wgIsMySQL?"LOW_PRIORITY":"";
		$sql = "UPDATE $lowpri site_stats SET " . implode ( ",", $a ) .
		  " WHERE ss_row_id=1";
		wfQuery( $sql, DB_WRITE, "SiteStatsUpdate::doUpdate" );
	}
}

?>