4738a1a0663fa6817ac8b90f93940778f5e356b1
[lhc/web/wiklou.git] / includes / specials / SpecialAncientpages.php
1 <?php
2 /**
3 * @file
4 * @ingroup SpecialPage
5 */
6
7 /**
8 * Implements Special:Ancientpages
9 * @ingroup SpecialPage
10 */
11 class AncientPagesPage extends QueryPage {
12
13 function getName() {
14 return "Ancientpages";
15 }
16
17 function isExpensive() {
18 return true;
19 }
20
21 function isSyndicated() { return false; }
22
23 function getSQL() {
24 global $wgDBtype;
25 $db = wfGetDB( DB_SLAVE );
26 $page = $db->tableName( 'page' );
27 $revision = $db->tableName( 'revision' );
28
29 switch ($wgDBtype) {
30 case 'mysql':
31 $epoch = 'UNIX_TIMESTAMP(rev_timestamp)';
32 break;
33 case 'oracle':
34 $epoch = '((trunc(rev_timestamp) - to_date(\'19700101\',\'YYYYMMDD\')) * 86400)';
35 break;
36 default:
37 $epoch = 'EXTRACT(epoch FROM rev_timestamp)';
38 }
39
40 return
41 "SELECT 'Ancientpages' as type,
42 page_namespace as namespace,
43 page_title as title,
44 $epoch as value
45 FROM $page, $revision
46 WHERE page_namespace=".NS_MAIN." AND page_is_redirect=0
47 AND page_latest=rev_id";
48 }
49
50 function sortDescending() {
51 return false;
52 }
53
54 function formatResult( $skin, $result ) {
55 global $wgLang, $wgContLang;
56
57 $d = $wgLang->timeanddate( wfTimestamp( TS_MW, $result->value ), true );
58 $title = Title::makeTitle( $result->namespace, $result->title );
59 $link = $skin->linkKnown(
60 $title,
61 htmlspecialchars( $wgContLang->convert( $title->getPrefixedText() ) )
62 );
63 return wfSpecialList($link, htmlspecialchars($d) );
64 }
65 }
66
67 function wfSpecialAncientpages() {
68 list( $limit, $offset ) = wfCheckLimits();
69
70 $app = new AncientPagesPage();
71
72 $app->doQuery( $offset, $limit );
73 }