mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-25 05:36:13 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			176 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			176 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // -------------------------------------------------------------
 | |
| //
 | |
| // $Id$
 | |
| //
 | |
| // FILENAME  : fill.php
 | |
| // STARTED   : Mon Sep 15, 2003
 | |
| // COPYRIGHT : © 2001, 2003 phpBB Group
 | |
| // WWW       : http://www.phpbb.com/
 | |
| // LICENCE   : GPL vs2.0 [ see /docs/COPYING ]
 | |
| //
 | |
| // -------------------------------------------------------------
 | |
| 
 | |
| define('IN_PHPBB', true);
 | |
| $phpbb_root_path = './';
 | |
| $phpEx = substr(strrchr(__FILE__, '.'), 1);
 | |
| include($phpbb_root_path . 'common.'.$phpEx);
 | |
| include($phpbb_root_path . 'includes/functions_admin.'.$phpEx);
 | |
| 
 | |
| set_time_limit(0);
 | |
| header('Expires: 0');
 | |
| ignore_user_abort(true);
 | |
| 
 | |
| // number of topics to create
 | |
| $num_topics = 5000000;
 | |
| 
 | |
| // number of topics to be generated per call
 | |
| $batch_size = 100000;
 | |
| 
 | |
| // max number of posts per topic
 | |
| $posts_per_topic = 500000;
 | |
| 
 | |
| 
 | |
| // general vars
 | |
| $mode = (isset($_REQUEST['mode'])) ? $_REQUEST['mode'] : 'generate';
 | |
| $start = (isset($_REQUEST['start'])) ? intval($_REQUEST['start']) : 0;
 | |
| 
 | |
| switch ($mode)
 | |
| {
 | |
| 	case 'generate':
 | |
| 		$user_ids = $forum_ids = $topic_rows = array();
 | |
| 
 | |
| 		$sql = 'SELECT user_id FROM ' . USERS_TABLE;
 | |
| 		$result = $db->sql_query($sql);
 | |
| 		while ($row = $db->sql_fetchrow($result))
 | |
| 		{
 | |
| 			$user_ids[] = $row['user_id'];
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 
 | |
| 		$sql = 'SELECT forum_id FROM ' . FORUMS_TABLE . ' WHERE forum_type = ' . FORUM_POST;
 | |
| 		$result = $db->sql_query($sql);
 | |
| 		while ($row = $db->sql_fetchrow($result))
 | |
| 		{
 | |
| 			$forum_ids[$row['forum_id']] = $row['forum_id'];
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 
 | |
| 		if (!$start)
 | |
| 		{
 | |
| 			$db->sql_query('TRUNCATE TABLE ' . POSTS_TABLE);
 | |
| 			$db->sql_query('TRUNCATE TABLE ' . TOPICS_TABLE);
 | |
| 			$db->sql_query('TRUNCATE TABLE ' . TOPICS_TABLE . '_prefetch');
 | |
| 		}
 | |
| 
 | |
| 		$db->sql_query('LOCK TABLES ' . POSTS_TABLE . ' WRITE, ' . TOPICS_TABLE . ' WRITE');
 | |
| 
 | |
| 		for ($topic_id = $start + 1; $topic_id < min($start + $batch_size, $num_topics + 1); ++$topic_id)
 | |
| 		{
 | |
| 			$forum_id = array_rand($forum_ids);
 | |
| 
 | |
| 			if (count($topic_rows) == 10)
 | |
| 			{
 | |
| 				$sql = 'INSERT IGNORE INTO ' . TOPICS_TABLE . " (topic_id, forum_id, topic_title, topic_reported)
 | |
| 					VALUES " . implode(', ', $topic_rows);
 | |
| 				$db->sql_query($sql);
 | |
| 
 | |
| 				$topic_rows = array();
 | |
| 			}
 | |
| 
 | |
| 			$topic_rows[] = "($topic_id, $forum_id, '$forum_id-$topic_id', " . (($topic_id % 34) ? '0' : '1') . ')';
 | |
| 
 | |
| 			$sql = 'INSERT IGNORE INTO ' . POSTS_TABLE . ' (topic_id, forum_id, poster_id, post_subject, post_text, post_username, post_approved, post_time, post_reported)
 | |
| 				VALUES ';
 | |
| 
 | |
| 			$rows = array();
 | |
| 			$post_time = mt_rand(0, time());
 | |
| 
 | |
| 			$num_posts = mt_rand(1, $posts_per_topic);
 | |
| 			for ($i = 0; $i < $num_posts; ++$i)
 | |
| 			{
 | |
| 				$poster_id = $user_ids[array_rand($user_ids)];
 | |
| 				$poster_name = ($poster_id == ANONYMOUS) ? rndm_username() : '';
 | |
| 				$rows[] = "($topic_id, $forum_id, $poster_id, '$forum_id-$topic_id-$i', '$forum_id-$topic_id-$i', '$poster_name', " . (mt_rand(0, 12) ? '1' : '0') . ', ' . ($post_time + $i * 60) . ', ' . (mt_rand(0, 32) ? '0' : '1') . ')';
 | |
| 			}
 | |
| 
 | |
| 			$db->sql_query($sql . implode(', ', $rows));
 | |
| 		}
 | |
| 
 | |
| 		if (count($topic_rows))
 | |
| 		{
 | |
| 			$sql = 'INSERT IGNORE INTO ' . TOPICS_TABLE . " (topic_id, forum_id, topic_title, topic_reported)
 | |
| 				VALUES " . implode(', ', $topic_rows);
 | |
| 			$db->sql_query($sql);
 | |
| 		}
 | |
| 
 | |
| 		$db->sql_query('UNLOCK TABLES');
 | |
| 
 | |
| 		if ($topic_id >= $num_topics)
 | |
| 		{
 | |
| 			echo '<meta http-equiv="refresh" content="0; url=fill.' . $phpEx . '?mode=sync&' . time() . '">And now for something completely different...';
 | |
| 
 | |
| 			$db->sql_query('ANALYZE TABLES ' . TOPICS_TABLE . ', ' . POSTS_TABLE);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			echo '<meta http-equiv="refresh" content="0; url=fill.' . $phpEx . '?start=' . $topic_id . '&' . time() . '">To the next page... (' . $topic_id . '/' . $num_topics . ')';
 | |
| 		}
 | |
| 	break;
 | |
| 
 | |
| 	case 'sync':
 | |
| 		error_reporting(E_ALL);
 | |
| 		$sync_all = TRUE;
 | |
| 
 | |
| 		if ($sync_all)
 | |
| 		{
 | |
| 			$s = explode(' ', microtime());
 | |
| 			sync('topic', '', '', TRUE, FALSE);
 | |
| //			sync('forum');
 | |
| 			$e = explode(' ', microtime());
 | |
| 
 | |
| 			echo '<pre><b>' . ($e[0] + $e[1] - $s[0] - $s[1]) . '</b></pre>';
 | |
| 			echo '<a href="fill.' . $phpEx . '">Here we go again</a>';
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$batch_size = $batch_size * 10;
 | |
| 			$end = $start + $batch_size;
 | |
| 
 | |
| 			$s = explode(' ', microtime());
 | |
| 			sync('topic', 'range', "topic_id BETWEEN $start AND $end", TRUE, FALSE);
 | |
| 			$e = explode(' ', microtime());
 | |
| 
 | |
| 			echo '<pre>Time taken: <b>' . ($e[0] + $e[1] - $s[0] - $s[1]) . '</b></pre>';
 | |
| 
 | |
| 			if ($end < $num_topics)
 | |
| 			{
 | |
| 				$start += $batch_size;
 | |
| 				echo '<meta http-equiv="refresh" content="0; url=fill.' . $phpEx . "?mode=sync&start=$start&" . time() . "\">And now for something completely different... ($start/$num_topics)";
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				echo '<a href="fill.' . $phpEx . '">Here we go again</a>';
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if (isset($_GET['explain']))
 | |
| 		{
 | |
| 			trigger_error('Done');
 | |
| 		}
 | |
| }
 | |
| 
 | |
| function rndm_username()
 | |
| {
 | |
| 	static $usernames;
 | |
| 
 | |
| 	if (!isset($usernames))
 | |
| 	{
 | |
| 		$usernames = get_defined_functions();
 | |
| 		$usernames = $usernames['internal'];
 | |
| 	}
 | |
| 
 | |
| 	return $usernames[array_rand($usernames)];
 | |
| }
 | |
| 
 | |
| ?>
 |