| 
									
										
										
										
											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; | 
					
						
							| 
									
										
										
										
											2014-04-27 15:48:47 +02:00
										 |  |  | 				$query .= sprintf("SELECT *, '%s' AS `board` FROM ``posts_%s`` WHERE `files` IS NOT NULL 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']); | 
					
						
							| 
									
										
										
										
											2014-04-27 15:48:47 +02:00
										 |  |  | 				if (isset($post['files'])) | 
					
						
							|  |  |  | 					$files = json_decode($post['files']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if ($files[0]->file == 'deleted') continue; | 
					
						
							| 
									
										
										
										
											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']; | 
					
						
							| 
									
										
										
										
											2014-04-27 16:19:41 +02:00
										 |  |  | 				if ($files) $post['src'] = $config['uri_thumb'] . $files[0]->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
 | 
					
						
							| 
									
										
										
										
											2014-04-27 15:48:47 +02: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()); | 
					
						
							| 
									
										
										
										
											2014-04-27 15:48:47 +02: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
										 |  |  | ?>
 |