2014-09-24 01:26:27 +02:00
< ? php
include " inc/functions.php " ;
include " inc/mod/auth.php " ;
2014-09-26 03:15:17 +02:00
include " inc/countries.php " ;
2014-09-24 01:26:27 +02:00
$admin = isset ( $mod [ " type " ]) && $mod [ " type " ] <= 30 ;
if ( php_sapi_name () == 'fpm-fcgi' && ! $admin ) {
error ( 'Cannot be run directly.' );
}
$boards = listBoards ();
$total_posts_hour = 0 ;
$total_posts = 0 ;
foreach ( $boards as $i => $board ) {
//$query = prepare(sprintf("SELECT (SELECT MAX(id) from ``posts_%s``) AS max, (SELECT MAX(id) FROM ``posts_%s`` WHERE FROM_UNIXTIME(time) < DATE_SUB(NOW(), INTERVAL 1 HOUR)) AS oldmax, (SELECT MAX(id) from ``posts_%s``) AS max_d, (SELECT MAX(id) FROM ``posts_%s`` WHERE FROM_UNIXTIME(time) < DATE_SUB(NOW(), INTERVAL 1 DAY)) AS oldmax_d, (SELECT count(id) FROM ``posts_%s``) AS count;", $board['uri'], $board['uri'], $board['uri'], $board['uri'], $board['uri']));
$query = prepare ( sprintf ( "
SELECT MAX ( id ) max , ( SELECT COUNT ( * ) FROM `` posts_ % s `` WHERE FROM_UNIXTIME ( time ) > DATE_SUB ( NOW (), INTERVAL 1 DAY )) ppd ,
( SELECT COUNT ( * ) FROM `` posts_ % s `` WHERE FROM_UNIXTIME ( time ) > DATE_SUB ( NOW (), INTERVAL 1 HOUR )) pph ,
2014-09-29 09:17:00 +02:00
( SELECT count ( id ) FROM `` posts_ % s `` ) count ,
2014-10-07 03:01:01 +02:00
( SELECT COUNT ( DISTINCT ip ) FROM `` posts_ % s `` WHERE FROM_UNIXTIME ( time ) > DATE_SUB ( NOW (), INTERVAL 3 DAY )) uniq_ip
2014-09-29 09:17:00 +02:00
FROM `` posts_ % s ``
" , $board['uri'] , $board['uri'] , $board['uri'] , $board['uri'] , $board['uri'] ));
2014-09-24 01:26:27 +02:00
$query -> execute () or error ( db_error ( $query ));
$r = $query -> fetch ( PDO :: FETCH_ASSOC );
$pph = $r [ 'pph' ];
$ppd = $r [ 'ppd' ];
$total_posts_hour += $pph ;
$total_posts += $r [ 'max' ];
$boards [ $i ][ 'pph' ] = $pph ;
$boards [ $i ][ 'ppd' ] = $ppd ;
$boards [ $i ][ 'max' ] = $r [ 'max' ];
2014-09-29 09:17:00 +02:00
$boards [ $i ][ 'uniq_ip' ] = $r [ 'uniq_ip' ];
2014-09-24 01:26:27 +02:00
}
usort ( $boards ,
function ( $a , $b ) {
2014-10-07 03:01:01 +02:00
$x = $b [ 'uniq_ip' ] - $a [ 'uniq_ip' ];
2014-09-24 01:26:27 +02:00
if ( $x ) { return $x ;
//} else { return strcmp($a['uri'], $b['uri']); }
} else { return $b [ 'max' ] - $a [ 'max' ]; }
});
$hidden_boards_total = 0 ;
2014-09-27 01:52:02 +02:00
$rows = array ();
2014-09-24 01:26:27 +02:00
foreach ( $boards as $i => & $board ) {
$board_config = @ file_get_contents ( $board [ 'uri' ] . '/config.php' );
$boardCONFIG = array ();
if ( $board_config && $board [ 'uri' ] !== 'int' ) {
$board_config = str_replace ( '$config' , '$boardCONFIG' , $board_config );
$board_config = str_replace ( '<?php' , '' , $board_config );
eval ( $board_config );
}
2014-10-08 05:54:00 +02:00
$showboard = $board [ 'indexed' ];
2014-09-24 01:26:27 +02:00
$locale = isset ( $boardCONFIG [ 'locale' ]) ? $boardCONFIG [ 'locale' ] : 'en' ;
2014-09-25 22:50:37 +02:00
$board [ 'title' ] = utf8tohtml ( $board [ 'title' ]);
2014-09-24 01:26:27 +02:00
$locale_arr = explode ( '_' , $locale );
$locale_short = isset ( $locale_arr [ 1 ]) ? strtolower ( $locale_arr [ 1 ]) : strtolower ( $locale_arr [ 0 ]);
$locale_short = str_replace ( '.utf-8' , '' , $locale_short );
2014-09-26 03:15:17 +02:00
$country = get_country ( $locale_short );
2014-09-26 03:38:23 +02:00
if ( $board [ 'uri' ] === 'int' ) { $locale_short = 'eo' ; $locale = 'eo' ; $country = 'Esperanto' ;}
2014-09-24 01:26:27 +02:00
2014-09-27 06:58:41 +02:00
$board [ 'img' ] = " <img class= \" flag flag- $locale_short\ " src = \ " /static/blank.gif \" style= \" width:16px;height:11px; \" alt= \" $country\ " title = \ " $country\ " > " ;
2014-09-24 01:26:27 +02:00
if ( $showboard || $admin ) {
if ( ! $showboard ) {
$lock = ' <i class="fa fa-lock" title="No index"></i>' ;
} else {
$lock = '' ;
}
$board [ 'ago' ] = human_time_diff ( strtotime ( $board [ 'time' ]));
} else {
unset ( $boards [ $i ]);
$hidden_boards_total += 1 ;
}
}
$n_boards = sizeof ( $boards );
$t_boards = $hidden_boards_total + $n_boards ;
$config [ 'additional_javascript' ] = array ( 'js/jquery.min.js' , 'js/jquery.tablesorter.min.js' );
2014-09-27 01:52:02 +02:00
$body = Element ( " 8chan/boards.html " , array ( " config " => $config , " n_boards " => $n_boards , " t_boards " => $t_boards , " hidden_boards_total " => $hidden_boards_total , " total_posts " => $total_posts , " total_posts_hour " => $total_posts_hour , " boards " => $boards , " last_update " => date ( 'r' ), " uptime_p " => shell_exec ( 'uptime -p' )));
2014-09-24 01:26:27 +02:00
$html = Element ( " page.html " , array ( " config " => $config , " body " => $body , " title " => " Boards on ∞chan " ));
if ( $admin ) {
echo $html ;
} else {
file_write ( " boards.json " , json_encode ( $boards ));
2014-10-22 06:04:46 +02:00
array_splice ( $boards , 20 );
file_write ( " boards-top20.json " , json_encode ( $boards ));
2014-09-24 01:26:27 +02:00
file_write ( " boards.html " , $html );
echo 'Done' ;
}