-<?
-
-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, $fname );
- $row = wfFetchObject( $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, $fname );
- $row = wfFetchObject( $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", $edits / $total ), $text );
- $text = str_replace( "$6", sprintf( "%.2f", $views / $edits ), $text );
-
- $wgOut->addHTML( $text );
- $wgOut->addHTML( "<h2>" . wfMsg( "userstats" ) . "</h2>\n" );
-
- $sql = "SELECT COUNT(user_id) AS total FROM user";
- $res = wfQuery( $sql, $fname );
- $row = wfFetchObject( $res );
- $total = $row->total;
-
- $sql = "SELECT COUNT(user_id) AS total FROM user " .
- "WHERE user_rights LIKE '%sysop%'";
- $res = wfQuery( $sql, $fname );
- $row = wfFetchObject( $res );
- $admins = $row->total;
-
- $sk = $wgUser->getSkin();
- $ap = $sk->makeKnownLink( wfMsg( "administrators" ), "" );
-
- $text = str_replace( "$1", $total, wfMsg( "userstatstext" ) );
- $text = str_replace( "$2", $admins, $text );
- $text = str_replace( "$3", $ap, $text );
- $wgOut->addHTML( $text );
-}
+<?php
+/**
+*
+* @addtogroup SpecialPage
+*/
+
+/**
+* constructor
+*/
+function wfSpecialStatistics() {
+ global $wgOut, $wgLang, $wgRequest;
+ $fname = 'wfSpecialStatistics';
+
+ $action = $wgRequest->getVal( 'action' );
+
+ $dbr = wfGetDB( DB_SLAVE );
+
+ $views = SiteStats::views();
+ $edits = SiteStats::edits();
+ $good = SiteStats::articles();
+ $images = SiteStats::images();
+ $total = SiteStats::pages();
+ $users = SiteStats::users();
+
+ $admins = $dbr->selectField( 'user_groups', 'COUNT(*)', array( 'ug_group' => 'sysop' ), $fname );
+ $numJobs = $dbr->estimateRowCount('job');
+ if ($action == 'raw') {
+ $wgOut->disable();
+ header( 'Pragma: nocache' );
+ echo "total=$total;good=$good;views=$views;edits=$edits;users=$users;admins=$admins;images=$images;jobs=$numJobs\n";
+ return;
+ } else {
+ $text = '==' . wfMsg( 'sitestats' ) . "==\n" ;
+ $text .= wfMsgExt( 'sitestatstext', array ( 'parsemag' ),
+ $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 ) ),
+ $wgLang->formatNum( $numJobs ),
+ $wgLang->formatNum( $images )
+ );
+
+ $text .= "\n==" . wfMsg( 'userstats' ) . "==\n";
+
+ $text .= wfMsgExt( 'userstatstext', array ( 'parsemag' ),
+ $wgLang->formatNum( $users ),
+ $wgLang->formatNum( $admins ),
+ '[[' . wfMsgForContent( 'grouppage-sysop' ) . ']]', # TODO somehow remove, kept for backwards compatibility
+ $wgLang->formatNum( sprintf( '%.2f', $admins / $users * 100 ) ),
+ User::makeGroupLinkWiki( 'sysop' )
+ );
+
+ $wgOut->addWikiText( $text );
+
+ global $wgDisableCounters, $wgMiserMode, $wgUser, $wgLang, $wgContLang;
+ if( !$wgDisableCounters && !$wgMiserMode ) {
+ $page = $dbr->tableName( 'page' );
+ $sql = "SELECT page_namespace, page_title, page_counter FROM {$page} WHERE page_is_redirect = 0 AND page_counter > 0 ORDER BY page_counter DESC";
+ $sql = $dbr->limitResult($sql, 10, 0);
+ $res = $dbr->query( $sql, $fname );
+ if( $res ) {
+ $wgOut->addHtml( '<h2>' . wfMsgHtml( 'statistics-mostpopular' ) . '</h2>' );
+ $skin = $wgUser->getSkin();
+ $wgOut->addHtml( '<ol>' );
+ while( $row = $dbr->fetchObject( $res ) ) {
+ $link = $skin->makeKnownLinkObj( Title::makeTitleSafe( $row->page_namespace, $row->page_title ) );
+ $dirmark = $wgContLang->getDirMark();
+ $wgOut->addHtml( '<li>' . $link . $dirmark . ' [' . $wgLang->formatNum( $row->page_counter ) . ']</li>' );
+ }
+ $wgOut->addHtml( '</ol>' );
+ $dbr->freeResult( $res );
+ }
+ }
+
+ $footer = wfMsg( 'statistics-footer' );
+ if( !wfEmptyMsg( 'statistics-footer', $footer ) && $footer != '' )
+ $wgOut->addWikiText( $footer );
+
+ }
+}
?>