39a3c8ea17cacd7886e5fe18314670ebc18e7256
[lhc/web/wiklou.git] / includes / SpecialAncientpages.php
1 <?php
2 /**
3 *
4 * @package MediaWiki
5 * @subpackage SpecialPage
6 */
7
8 /**
9 *
10 * @package MediaWiki
11 * @subpackage SpecialPage
12 */
13 class AncientPagesPage extends QueryPage {
14
15 function getName() {
16 return "Ancientpages";
17 }
18
19 function isExpensive() {
20 return true;
21 }
22
23 function isSyndicated() { return false; }
24
25 function getSQL() {
26 global $wgDBtype;
27 $db =& wfGetDB( DB_SLAVE );
28 $page = $db->tableName( 'page' );
29 $revision = $db->tableName( 'revision' );
30 #$use_index = $db->useIndexClause( 'cur_timestamp' ); # FIXME! this is gone
31 $epoch = $wgDBtype == 'mysql' ? 'UNIX_TIMESTAMP(rev_timestamp)' :
32 'EXTRACT(epoch FROM rev_timestamp)';
33 return
34 "SELECT 'Ancientpages' as type,
35 page_namespace as namespace,
36 page_title as title,
37 $epoch as value
38 FROM $page, $revision
39 WHERE page_namespace=".NS_MAIN." AND page_is_redirect=0
40 AND page_latest=rev_id";
41 }
42
43 function sortDescending() {
44 return false;
45 }
46
47 function formatResult( $skin, $result ) {
48 global $wgLang, $wgContLang;
49
50 $d = $wgLang->timeanddate( wfTimestamp( TS_MW, $result->value ), true );
51 $title = Title::makeTitle( $result->namespace, $result->title );
52 $link = $skin->makeKnownLinkObj( $title, htmlspecialchars( $wgContLang->convert( $title->getPrefixedText() ) ) );
53 return wfSpecialList($link, $d);
54 }
55 }
56
57 function wfSpecialAncientpages() {
58 list( $limit, $offset ) = wfCheckLimits();
59
60 $app = new AncientPagesPage();
61
62 $app->doQuery( $offset, $limit );
63 }
64
65 ?>