* @subpackage Parser
[lhc/web/wiklou.git] / includes / SpecialStatistics.php
index b353ecf..1a0ad99 100644 (file)
@@ -1,53 +1,62 @@
-<?
-
-function wfSpecialStatistics()
-{
-       global $wgUser, $wgOut;
-       $fname = "wfSpecialStatistics";
-
-       $wgOut->addHTML( "<h2>" . wfMsg( "sitestats" ) . "</h2>\n" );
-
-       $sql = "SELECT COUNT(cur_id) AS total FROM cur";
-       $res = wfQuery( $sql, DB_READ, $fname );
-       $row = wfFetchObject( $res );
+<?php
+/**
+ *
+ * @package MediaWiki
+ * @subpackage SpecialPage
+ */
+
+/**
+ * constructor
+ */
+function wfSpecialStatistics() {
+       global $wgUser, $wgOut, $wgLang;
+       $fname = 'wfSpecialStatistics';
+
+       $wgOut->addHTML( '<h2>' . wfMsg( 'sitestats' ) . "</h2>\n" );
+       
+       $dbr =& wfGetDB( DB_SLAVE );
+       extract( $dbr->tableNames( 'page', 'site_stats', 'user', 'user_rights' ) );
+
+       $sql = "SELECT COUNT(page_namespace) AS total FROM $page";
+       $res = $dbr->query( $sql, $fname );
+       $row = $dbr->fetchObject( $res );
        $total = $row->total;
 
        $sql = "SELECT ss_total_views, ss_total_edits, ss_good_articles " .
-         "FROM site_stats WHERE ss_row_id=1";
-       $res = wfQuery( $sql, DB_READ, $fname );
-       $row = wfFetchObject( $res );
+         "FROM $site_stats WHERE ss_row_id=1";
+       $res = $dbr->query( $sql, $fname );
+       $row = $dbr->fetchObject( $res );
        $views = $row->ss_total_views;
        $edits = $row->ss_total_edits;
        $good = $row->ss_good_articles;
 
-       $text = str_replace( "$1", $total, wfMsg( "sitestatstext" ) );
-       $text = str_replace( "$2", $good, $text );
-       $text = str_replace( "$3", $views, $text );
-       $text = str_replace( "$4", $edits, $text );
-       $text = str_replace( "$5", sprintf( "%.2f", $total ? $edits / $total : 0 ), $text );
-       $text = str_replace( "$6", sprintf( "%.2f", $edits ? $views / $edits : 0 ), $text );
+       $text = wfMsg( 'sitestatstext',
+               $wgLang->formatNum( $total ),
+               $wgLang->formatNum( $good ),
+               $wgLang->formatNum( $views ),
+               $wgLang->formatNum( $edits ),
+               $wgLang->formatNum( sprintf( '%.2f', $total ? $edits / $total : 0 ) ),
+               $wgLang->formatNum( sprintf( '%.2f', $edits ? $views / $edits : 0 ) ) );
 
-       $wgOut->addHTML( $text );
-       $wgOut->addHTML( "<h2>" . wfMsg( "userstats" ) . "</h2>\n" );
+       $wgOut->addWikiText( $text );
+       $wgOut->addHTML( '<h2>' . wfMsg( 'userstats' ) . "</h2>\n" );
 
-       $sql = "SELECT COUNT(user_id) AS total FROM user";
-       $res = wfQuery( $sql, DB_READ, $fname );
-       $row = wfFetchObject( $res );
+       $sql = "SELECT COUNT(user_id) AS total FROM $user";
+       $res = $dbr->query( $sql, $fname );
+       $row = $dbr->fetchObject( $res );
        $total = $row->total;
 
-       $sql = "SELECT COUNT(user_id) AS total FROM user " .
-         "WHERE user_rights LIKE '%sysop%'";
-       $res = wfQuery( $sql, DB_READ, $fname );
-       $row = wfFetchObject( $res );
+       $sql = "SELECT COUNT(ur_user) AS total FROM $user_rights WHERE ur_rights LIKE '%sysop%'";
+       $res = $dbr->query( $sql, $fname );
+       $row = $dbr->fetchObject( $res );
        $admins = $row->total;
 
        $sk = $wgUser->getSkin();
-       $ap = $sk->makeKnownLink( wfMsg( "administrators" ), "" );
+       $ap = '[[' . wfMsg( 'administrators' ) . ']]';
 
-       $text = str_replace( "$1", $total, wfMsg( "userstatstext" ) );
-       $text = str_replace( "$2", $admins, $text );
-       $text = str_replace( "$3", $ap, $text );
-       $wgOut->addHTML( $text );
+       $text = wfMsg( 'userstatstext',
+               $wgLang->formatNum( $total ),
+               $wgLang->formatNum( $admins ), $ap );
+       $wgOut->addWikiText( $text );
 }
-
 ?>