6343edd13f1b5cdcbb6bcfe15b9542af5ebc99a3
[lhc/web/wiklou.git] / includes / SpecialStatistics.php
1 <?php
2 /**
3 *
4 * @addtogroup SpecialPage
5 */
6
7 /**
8 * constructor
9 */
10 function wfSpecialStatistics() {
11 global $wgOut, $wgLang, $wgRequest;
12 $fname = 'wfSpecialStatistics';
13
14 $action = $wgRequest->getVal( 'action' );
15
16 $dbr = wfGetDB( DB_SLAVE );
17
18 $views = SiteStats::views();
19 $edits = SiteStats::edits();
20 $good = SiteStats::articles();
21 $images = SiteStats::images();
22 $total = SiteStats::pages();
23 $users = SiteStats::users();
24 $admins = SiteStats::admins();
25 $numJobs = SiteStats::jobs();
26
27 if ($action == 'raw') {
28 $wgOut->disable();
29 header( 'Pragma: nocache' );
30 echo "total=$total;good=$good;views=$views;edits=$edits;users=$users;admins=$admins;images=$images;jobs=$numJobs\n";
31 return;
32 } else {
33 $text = '==' . wfMsg( 'sitestats' ) . "==\n" ;
34 $text .= wfMsgExt( 'sitestatstext', array ( 'parsemag' ),
35 $wgLang->formatNum( $total ),
36 $wgLang->formatNum( $good ),
37 $wgLang->formatNum( $views ),
38 $wgLang->formatNum( $edits ),
39 $wgLang->formatNum( sprintf( '%.2f', $total ? $edits / $total : 0 ) ),
40 $wgLang->formatNum( sprintf( '%.2f', $edits ? $views / $edits : 0 ) ),
41 $wgLang->formatNum( $numJobs ),
42 $wgLang->formatNum( $images )
43 );
44
45 $text .= "\n==" . wfMsg( 'userstats' ) . "==\n";
46
47 $text .= wfMsgExt( 'userstatstext', array ( 'parsemag' ),
48 $wgLang->formatNum( $users ),
49 $wgLang->formatNum( $admins ),
50 '[[' . wfMsgForContent( 'grouppage-sysop' ) . ']]', # TODO somehow remove, kept for backwards compatibility
51 $wgLang->formatNum( sprintf( '%.2f', $admins / $users * 100 ) ),
52 User::makeGroupLinkWiki( 'sysop' )
53 );
54
55 $wgOut->addWikiText( $text );
56
57 global $wgDisableCounters, $wgMiserMode, $wgUser, $wgLang, $wgContLang;
58 if( !$wgDisableCounters && !$wgMiserMode ) {
59 $page = $dbr->tableName( 'page' );
60 $sql = "SELECT page_namespace, page_title, page_counter FROM {$page} WHERE page_is_redirect = 0 AND page_counter > 0 ORDER BY page_counter DESC";
61 $sql = $dbr->limitResult($sql, 10, 0);
62 $res = $dbr->query( $sql, $fname );
63 if( $res ) {
64 $wgOut->addHtml( '<h2>' . wfMsgHtml( 'statistics-mostpopular' ) . '</h2>' );
65 $skin = $wgUser->getSkin();
66 $wgOut->addHtml( '<ol>' );
67 while( $row = $dbr->fetchObject( $res ) ) {
68 $link = $skin->makeKnownLinkObj( Title::makeTitleSafe( $row->page_namespace, $row->page_title ) );
69 $dirmark = $wgContLang->getDirMark();
70 $wgOut->addHtml( '<li>' . $link . $dirmark . ' [' . $wgLang->formatNum( $row->page_counter ) . ']</li>' );
71 }
72 $wgOut->addHtml( '</ol>' );
73 $dbr->freeResult( $res );
74 }
75 }
76
77 $footer = wfMsg( 'statistics-footer' );
78 if( !wfEmptyMsg( 'statistics-footer', $footer ) && $footer != '' )
79 $wgOut->addWikiText( $footer );
80
81 }
82 }
83