API bug 10046: incorrect action produces invalid response format
[lhc/web/wiklou.git] / includes / SpecialStatistics.php
index 92ec95d..1c9e0ab 100644 (file)
@@ -1,62 +1,84 @@
 <?php
 /**
- *
- * @package MediaWiki
- * @subpackage SpecialPage
- */
+*
+* @addtogroup SpecialPage
+*/
 
 /**
- * constructor
- */
+* constructor
+*/
 function wfSpecialStatistics() {
-       global $wgUser, $wgOut, $wgLang;
+       global $wgOut, $wgLang, $wgRequest;
        $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_id) 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 = $dbr->query( $sql, $fname );
-       $row = $dbr->fetchObject( $res );
-       $views = $row->ss_total_views;
-       $edits = $row->ss_total_edits;
-       $good = $row->ss_good_articles;
-
-       $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->addWikiText( $text );
-       $wgOut->addHTML( '<h2>' . wfMsg( 'userstats' ) . "</h2>\n" );
-
-       $sql = "SELECT COUNT(user_id) AS total FROM $user";
-       $res = $dbr->query( $sql, $fname );
-       $row = $dbr->fetchObject( $res );
-       $total = $row->total;
-
-       $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 = '[[' . wfMsg( 'administrators' ) . ']]';
-
-       $text = wfMsg( 'userstatstext',
-               $wgLang->formatNum( $total ),
-               $wgLang->formatNum( $admins ), $ap );
-       $wgOut->addWikiText( $text );
+       $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 );
+               
+       }
 }
-?>
\ No newline at end of file
+?>