2011-04-15 04:53:29 +10:00
< ? php
require 'info.php' ;
2013-07-18 12:06:26 -04:00
function recentposts_build ( $action , $settings , $board ) {
2011-04-15 04:53:29 +10:00
// Possible values for $action:
// - all (rebuild everything, initialization)
// - news (news has been updated)
// - boards (board list changed)
// - post (a post has been made)
2013-07-18 12:06:26 -04:00
// - post-thread (a thread has been made)
2011-04-15 04:53:29 +10:00
2011-05-28 01:43:04 +10:00
$b = new RecentPosts ();
2011-04-17 01:28:25 +10:00
$b -> build ( $action , $settings );
2011-04-15 04:53:29 +10:00
}
// Wrap functions in a class so they don't interfere with normal Tinyboard operations
2011-05-28 01:43:04 +10:00
class RecentPosts {
2011-04-17 01:28:25 +10:00
public function build ( $action , $settings ) {
2011-04-15 04:53:29 +10:00
global $config , $_theme ;
2012-05-06 01:33:10 +10:00
if ( $action == 'all' ) {
2013-01-06 13:40:33 +01:00
copy ( 'templates/themes/recent/' . $settings [ 'basecss' ], $config [ 'dir' ][ 'home' ] . $settings [ 'css' ]);
2011-04-15 04:53:29 +10:00
}
2011-04-17 01:28:25 +10:00
$this -> excluded = explode ( ' ' , $settings [ 'exclude' ]);
2013-08-25 23:26:41 -04:00
if ( $action == 'all' || $action == 'post' || $action == 'post-thread' || $action == 'post-delete' )
2012-02-14 20:46:06 +11:00
file_write ( $config [ 'dir' ][ 'home' ] . $settings [ 'html' ], $this -> homepage ( $settings ));
2011-04-15 04:53:29 +10:00
}
// Build news page
2011-04-17 01:28:25 +10:00
public function homepage ( $settings ) {
2011-04-15 04:53:29 +10:00
global $config , $board ;
2012-02-14 20:46:06 +11:00
$recent_images = Array ();
$recent_posts = Array ();
$stats = Array ();
2011-04-15 04:53:29 +10:00
$boards = listBoards ();
2012-02-14 20:46:06 +11:00
$query = '' ;
2012-05-06 01:33:10 +10:00
foreach ( $boards as & $_board ) {
if ( in_array ( $_board [ 'uri' ], $this -> excluded ))
2012-02-14 20:46:06 +11:00
continue ;
2013-07-31 22:14:26 -04:00
$query .= sprintf ( " SELECT *, '%s' AS `board` FROM ``posts_%s`` WHERE `file` IS NOT NULL AND `file` != 'deleted' AND `thumb` != 'spoiler' UNION ALL " , $_board [ 'uri' ], $_board [ 'uri' ]);
2012-02-14 20:46:06 +11:00
}
$query = preg_replace ( '/UNION ALL $/' , 'ORDER BY `time` DESC LIMIT ' . ( int ) $settings [ 'limit_images' ], $query );
2014-04-20 23:33:52 +02:00
if ( $query == '' ) {
error ( _ ( " Can't build the RecentPosts theme, because there are no boards to be fetched. " ));
}
2012-02-14 20:46:06 +11:00
$query = query ( $query ) or error ( db_error ());
2011-04-15 04:53:29 +10:00
2013-07-31 20:51:43 -04:00
while ( $post = $query -> fetch ( PDO :: FETCH_ASSOC )) {
2012-02-14 20:46:06 +11:00
openBoard ( $post [ 'board' ]);
2011-04-15 04:53:29 +10:00
2012-02-14 20:46:06 +11:00
// board settings won't be available in the template file, so generate links now
$post [ 'link' ] = $config [ 'root' ] . $board [ 'dir' ] . $config [ 'dir' ][ 'res' ] . sprintf ( $config [ 'file_page' ], ( $post [ 'thread' ] ? $post [ 'thread' ] : $post [ 'id' ])) . '#' . $post [ 'id' ];
$post [ 'src' ] = $config [ 'uri_thumb' ] . $post [ 'thumb' ];
2011-04-15 04:53:29 +10:00
2012-02-14 20:46:06 +11:00
$recent_images [] = $post ;
}
2011-04-15 04:53:29 +10:00
2012-02-14 20:46:06 +11:00
$query = '' ;
2012-05-06 01:33:10 +10:00
foreach ( $boards as & $_board ) {
if ( in_array ( $_board [ 'uri' ], $this -> excluded ))
2012-02-14 20:46:06 +11:00
continue ;
2013-07-31 22:14:26 -04:00
$query .= sprintf ( " SELECT *, '%s' AS `board` FROM ``posts_%s`` UNION ALL " , $_board [ 'uri' ], $_board [ 'uri' ]);
2012-02-14 20:46:06 +11:00
}
$query = preg_replace ( '/UNION ALL $/' , 'ORDER BY `time` DESC LIMIT ' . ( int ) $settings [ 'limit_posts' ], $query );
$query = query ( $query ) or error ( db_error ());
2011-04-15 04:53:29 +10:00
2013-07-31 20:51:43 -04:00
while ( $post = $query -> fetch ( PDO :: FETCH_ASSOC )) {
2012-02-14 20:46:06 +11:00
openBoard ( $post [ 'board' ]);
2011-04-15 04:53:29 +10:00
2012-02-14 20:46:06 +11:00
$post [ 'link' ] = $config [ 'root' ] . $board [ 'dir' ] . $config [ 'dir' ][ 'res' ] . sprintf ( $config [ 'file_page' ], ( $post [ 'thread' ] ? $post [ 'thread' ] : $post [ 'id' ])) . '#' . $post [ 'id' ];
$post [ 'snippet' ] = pm_snippet ( $post [ 'body' ], 30 );
$post [ 'board_name' ] = $board [ 'name' ];
2011-04-15 04:53:29 +10:00
2012-02-14 20:46:06 +11:00
$recent_posts [] = $post ;
}
2011-04-15 04:53:29 +10:00
2012-02-14 20:46:06 +11:00
// Total posts
2013-07-31 20:51:43 -04:00
$query = 'SELECT SUM(`top`) FROM (' ;
2012-05-06 01:33:10 +10:00
foreach ( $boards as & $_board ) {
if ( in_array ( $_board [ 'uri' ], $this -> excluded ))
2012-02-14 20:46:06 +11:00
continue ;
2013-07-31 22:14:26 -04:00
$query .= sprintf ( " SELECT MAX(`id`) AS `top` FROM ``posts_%s`` UNION ALL " , $_board [ 'uri' ]);
2012-02-14 20:46:06 +11:00
}
$query = preg_replace ( '/UNION ALL $/' , ') AS `posts_all`' , $query );
$query = query ( $query ) or error ( db_error ());
2013-07-31 20:51:43 -04:00
$stats [ 'total_posts' ] = number_format ( $query -> fetchColumn ());
2012-02-14 20:46:06 +11:00
// Unique IPs
2013-07-31 20:51:43 -04:00
$query = 'SELECT COUNT(DISTINCT(`ip`)) FROM (' ;
2012-05-06 01:33:10 +10:00
foreach ( $boards as & $_board ) {
if ( in_array ( $_board [ 'uri' ], $this -> excluded ))
2012-02-14 20:46:06 +11:00
continue ;
2013-07-31 22:14:26 -04:00
$query .= sprintf ( " SELECT `ip` FROM ``posts_%s`` UNION ALL " , $_board [ 'uri' ]);
2012-02-14 20:46:06 +11:00
}
$query = preg_replace ( '/UNION ALL $/' , ') AS `posts_all`' , $query );
$query = query ( $query ) or error ( db_error ());
2013-07-31 20:51:43 -04:00
$stats [ 'unique_posters' ] = number_format ( $query -> fetchColumn ());
2012-02-14 20:46:06 +11:00
// Active content
2013-07-31 20:51:43 -04:00
$query = 'SELECT SUM(`filesize`) FROM (' ;
2012-05-06 01:33:10 +10:00
foreach ( $boards as & $_board ) {
if ( in_array ( $_board [ 'uri' ], $this -> excluded ))
2012-02-14 20:46:06 +11:00
continue ;
2013-07-31 22:14:26 -04:00
$query .= sprintf ( " SELECT `filesize` FROM ``posts_%s`` UNION ALL " , $_board [ 'uri' ]);
2012-02-14 20:46:06 +11:00
}
$query = preg_replace ( '/UNION ALL $/' , ') AS `posts_all`' , $query );
$query = query ( $query ) or error ( db_error ());
2013-07-31 20:51:43 -04:00
$stats [ 'active_content' ] = $query -> fetchColumn ();
2012-02-14 20:46:06 +11:00
return Element ( 'themes/recent/recent.html' , Array (
'settings' => $settings ,
'config' => $config ,
'boardlist' => createBoardlist (),
'recent_images' => $recent_images ,
'recent_posts' => $recent_posts ,
'stats' => $stats
));
2011-04-15 04:53:29 +10:00
}
};
2011-06-11 17:09:51 +10:00
?>