* Allow Xml::check() $attribs parameter to override 'value' attribute
[mediawiki.git] / includes / SpecialStatistics.php
bloba5a0fc3a7cf8586a2d4b05398ecc69ba7e5a6428
1 <?php
2 /**
4 * @package MediaWiki
5 * @subpackage SpecialPage
6 */
8 /**
9 * constructor
11 function wfSpecialStatistics() {
12 global $wgOut, $wgLang, $wgRequest;
13 $fname = 'wfSpecialStatistics';
15 $action = $wgRequest->getVal( 'action' );
17 $dbr =& wfGetDB( DB_SLAVE );
19 $views = SiteStats::views();
20 $edits = SiteStats::edits();
21 $good = SiteStats::articles();
22 $images = SiteStats::images();
23 $total = SiteStats::pages();
24 $users = SiteStats::users();
26 $admins = $dbr->selectField( 'user_groups', 'COUNT(*)', array( 'ug_group' => 'sysop' ), $fname );
27 $numJobs = $dbr->selectField( 'job', 'COUNT(*)', '', $fname );
29 if ($action == 'raw') {
30 $wgOut->disable();
31 header( 'Pragma: nocache' );
32 echo "total=$total;good=$good;views=$views;edits=$edits;users=$users;admins=$admins;images=$images;jobs=$numJobs\n";
33 return;
34 } else {
35 $text = '==' . wfMsg( 'sitestats' ) . "==\n" ;
36 $text .= wfMsg( 'sitestatstext',
37 $wgLang->formatNum( $total ),
38 $wgLang->formatNum( $good ),
39 $wgLang->formatNum( $views ),
40 $wgLang->formatNum( $edits ),
41 $wgLang->formatNum( sprintf( '%.2f', $total ? $edits / $total : 0 ) ),
42 $wgLang->formatNum( sprintf( '%.2f', $edits ? $views / $edits : 0 ) ),
43 $wgLang->formatNum( $numJobs ),
44 $wgLang->formatNum( $images )
47 $text .= "\n==" . wfMsg( 'userstats' ) . "==\n";
49 $text .= wfMsg( 'userstatstext',
50 $wgLang->formatNum( $users ),
51 $wgLang->formatNum( $admins ),
52 '[[' . wfMsgForContent( 'grouppage-sysop' ) . ']]', # TODO somehow remove, kept for backwards compatibility
53 $wgLang->formatNum( sprintf( '%.2f', $admins / $users * 100 ) ),
54 User::makeGroupLinkWiki( 'sysop' )
57 $wgOut->addWikiText( $text );
59 global $wgDisableCounters, $wgMiserMode, $wgUser, $wgLang, $wgContLang;
60 if( !$wgDisableCounters && !$wgMiserMode ) {
61 $page = $dbr->tableName( 'page' );
62 $sql = "SELECT page_namespace, page_title, page_counter FROM {$page} WHERE page_is_redirect = 0 AND page_counter > 0 ORDER BY page_counter DESC";
63 $sql = $dbr->limitResult($sql, 10, 0);
64 $res = $dbr->query( $sql, $fname );
65 if( $res ) {
66 $wgOut->addHtml( '<h2>' . wfMsgHtml( 'statistics-mostpopular' ) . '</h2>' );
67 $skin =& $wgUser->getSkin();
68 $wgOut->addHtml( '<ol>' );
69 while( $row = $dbr->fetchObject( $res ) ) {
70 $link = $skin->makeKnownLinkObj( Title::makeTitleSafe( $row->page_namespace, $row->page_title ) );
71 $dirmark = $wgContLang->getDirMark();
72 $wgOut->addHtml( '<li>' . $link . $dirmark . ' [' . $wgLang->formatNum( $row->page_counter ) . ']</li>' );
74 $wgOut->addHtml( '</ol>' );
75 $dbr->freeResult( $res );