diff options
Diffstat (limited to 'phpBB/install/database_update.php')
| -rw-r--r-- | phpBB/install/database_update.php | 205 | 
1 files changed, 173 insertions, 32 deletions
| diff --git a/phpBB/install/database_update.php b/phpBB/install/database_update.php index 594397c815..dcdd17cbc0 100644 --- a/phpBB/install/database_update.php +++ b/phpBB/install/database_update.php @@ -7,6 +7,10 @@  *  */ +use Symfony\Component\Config\FileLocator; +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\DependencyInjection\Loader\YamlFileLoader; +  define('UPDATES_TO_VERSION', '3.1.0-dev');  // Enter any version to update from to test updates. The version within the db will not be updated. @@ -59,8 +63,6 @@ $updates_to_version = UPDATES_TO_VERSION;  $debug_from_version = DEBUG_FROM_VERSION;  $oldest_from_version = OLDEST_FROM_VERSION; -error_reporting(E_ALL); -  @set_time_limit(0);  // Include essential scripts @@ -71,17 +73,6 @@ if (!defined('PHPBB_INSTALLED') || empty($dbms) || empty($acm_type))  	die("Please read: <a href='../docs/INSTALL.html'>INSTALL.html</a> before attempting to update.");  } -// Load Extensions -if (!empty($load_extensions) && function_exists('dl')) -{ -	$load_extensions = explode(',', $load_extensions); - -	foreach ($load_extensions as $extension) -	{ -		@dl(trim($extension)); -	} -} -  // Include files  require($phpbb_root_path . 'includes/class_loader.' . $phpEx); @@ -107,21 +98,37 @@ if (!defined('EXT_TABLE'))  	define('EXT_TABLE', $table_prefix . 'ext');  } -$phpbb_class_loader_ext = new phpbb_class_loader('phpbb_ext_', $phpbb_root_path . 'ext/', ".$phpEx"); -$phpbb_class_loader_ext->register(); -$phpbb_class_loader = new phpbb_class_loader('phpbb_', $phpbb_root_path . 'includes/', ".$phpEx"); -$phpbb_class_loader->register(); +$phpbb_container = new ContainerBuilder(); +$loader = new YamlFileLoader($phpbb_container, new FileLocator(__DIR__.'/../config')); +$loader->load('services.yml'); + +// We must include the DI processor class files because the class loader +// is not yet set up +require($phpbb_root_path . 'includes/di/processor/interface.' . $phpEx); +require($phpbb_root_path . 'includes/di/processor/config.' . $phpEx); +$processor = new phpbb_di_processor_config($phpbb_root_path . 'config.' . $phpEx, $phpbb_root_path, $phpEx); +$processor->process($phpbb_container); + +// Setup class loader first +$phpbb_class_loader = $phpbb_container->get('class_loader'); +$phpbb_class_loader_ext = $phpbb_container->get('class_loader.ext');  // set up caching -$cache_factory = new phpbb_cache_factory($acm_type); -$cache = $cache_factory->get_service(); -$phpbb_class_loader_ext->set_cache($cache->get_driver()); -$phpbb_class_loader->set_cache($cache->get_driver()); +$cache = $phpbb_container->get('cache'); -$phpbb_dispatcher = new phpbb_event_dispatcher(); -$request = new phpbb_request(); -$user = new phpbb_user(); -$db = new $sql_db(); +// Instantiate some basic classes +$phpbb_dispatcher = $phpbb_container->get('dispatcher'); +$request	= $phpbb_container->get('request'); +$user		= $phpbb_container->get('user'); +$auth		= $phpbb_container->get('auth'); +$db			= $phpbb_container->get('dbal.conn'); + +$ids = array_keys($phpbb_container->findTaggedServiceIds('container.processor')); +foreach ($ids as $id) +{ +	$processor = $phpbb_container->get($id); +	$processor->process($phpbb_container); +}  // make sure request_var uses this request instance  request_var('', 0, false, false, $request); // "dependency injection" for a function @@ -597,7 +604,7 @@ function _print_footer()  	</div>  	<div id="page-footer"> -		Powered by <a href="http://www.phpbb.com/">phpBB</a>® Forum Software © phpBB Group +		Powered by <a href="https://www.phpbb.com/">phpBB</a>® Forum Software © phpBB Group  	</div>  </div> @@ -683,12 +690,12 @@ function _write_result($no_updates, $errored, $error_ary)  function _add_modules($modules_to_install)  { -	global $phpbb_root_path, $phpEx, $db, $phpbb_extension_manager; +	global $phpbb_root_path, $phpEx, $db, $phpbb_extension_manager, $config;  	// modules require an extension manager  	if (empty($phpbb_extension_manager))  	{ -		$phpbb_extension_manager = new phpbb_extension_manager($db, EXT_TABLE, $phpbb_root_path, ".$phpEx"); +		$phpbb_extension_manager = new phpbb_extension_manager($db, $config, EXT_TABLE, $phpbb_root_path, ".$phpEx");  	}  	include_once($phpbb_root_path . 'includes/acp/acp_modules.' . $phpEx); @@ -1071,6 +1078,18 @@ function database_update_info()  		'3.0.10-RC3'	=> array(),  		// No changes from 3.0.10 to 3.0.11-RC1  		'3.0.10'		=> array(), +		// Changes from 3.0.11-RC1 to 3.0.11-RC2 +		'3.0.11-RC1'	=> array( +			'add_columns'		=> array( +				PROFILE_FIELDS_TABLE			=> array( +					'field_show_novalue'		=> array('BOOL', 0), +				), +			), +		), +		// No changes from 3.0.11-RC2 to 3.0.11 +		'3.0.11-RC2'	=> array(), +		// No changes from 3.0.11 to 3.0.12-RC1 +		'3.0.11'		=> array(),  		/** @todo DROP LOGIN_ATTEMPT_TABLE.attempt_id in 3.0.12-RC1 */ @@ -1102,13 +1121,18 @@ function database_update_info()  					'style_parent_tree'		=> array('TEXT', ''),  				),  				REPORTS_TABLE		=> array( -					'reported_post_text'	=> array('MTEXT_UNI', ''), +					'reported_post_text'		=> array('MTEXT_UNI', ''), +					'reported_post_uid'			=> array('VCHAR:8', ''), +					'reported_post_bitfield'	=> array('VCHAR:255', ''),  				),  			),  			'change_columns'	=> array(  				GROUPS_TABLE		=> array(  					'group_legend'		=> array('UINT', 0),  				), +				USERS_TABLE			=> array( +					'user_timezone'		=> array('VCHAR:100', ''), +				),  			),  		),  	); @@ -1123,6 +1147,8 @@ function change_database_data(&$no_updates, $version)  {  	global $db, $errored, $error_ary, $config, $phpbb_root_path, $phpEx, $db_tools; +	$update_helpers = new phpbb_update_helpers(); +  	switch ($version)  	{  		case '3.0.0': @@ -1968,7 +1994,7 @@ function change_database_data(&$no_updates, $version)  					'user_email'			=> '',  					'user_lang'				=> $config['default_lang'],  					'user_style'			=> $config['default_style'], -					'user_timezone'			=> 0, +					'user_timezone'			=> 'UTC',  					'user_dateformat'		=> $config['default_dateformat'],  					'user_allow_massemail'	=> 0,  				); @@ -2205,6 +2231,79 @@ function change_database_data(&$no_updates, $version)  			$no_updates = false;  		break; +		// No changes from 3.0.11-RC1 to 3.0.11-RC2 +		case '3.0.11-RC1': +		break; + +		// No changes from 3.0.11-RC2 to 3.0.11 +		case '3.0.11-RC2': +		break; + +		// Changes from 3.0.11 to 3.0.12-RC1 +		case '3.0.11': +			$sql = 'UPDATE ' . MODULES_TABLE . ' +				SET module_auth = \'acl_u_sig\' +				WHERE module_class = \'ucp\' +					AND module_basename = \'profile\' +					AND module_mode = \'signature\''; +			_sql($sql, $errored, $error_ary); + +			// Update bots +			if (!function_exists('user_delete')) +			{ +				include($phpbb_root_path . 'includes/functions_user.' . $phpEx); +			} + +			$bots_updates = array( +				// Bot Deletions +				'NG-Search [Bot]'		=> false, +				'Nutch/CVS [Bot]'		=> false, +				'OmniExplorer [Bot]'	=> false, +				'Seekport [Bot]'		=> false, +				'Synoo [Bot]'			=> false, +				'WiseNut [Bot]'			=> false, + +				// Bot Updates +				// Bot name to bot user agent map +				'Baidu [Spider]'	=> 'Baiduspider', +				'Exabot [Bot]'		=> 'Exabot', +				'Voyager [Bot]'		=> 'voyager/', +				'W3C [Validator]'	=> 'W3C_Validator', +			); + +			foreach ($bots_updates as $bot_name => $bot_agent) +			{ +				$sql = 'SELECT user_id +					FROM ' . USERS_TABLE . ' +					WHERE user_type = ' . USER_IGNORE . " +						AND username_clean = '" . $db->sql_escape(utf8_clean_string($bot_name)) . "'"; +				$result = $db->sql_query($sql); +				$bot_user_id = (int) $db->sql_fetchfield('user_id'); +				$db->sql_freeresult($result); + +				if ($bot_user_id) +				{ +					if ($bot_agent === false) +					{ +						$sql = 'DELETE FROM ' . BOTS_TABLE . " +							WHERE user_id = $bot_user_id"; +						_sql($sql, $errored, $error_ary); + +						user_delete('remove', $bot_user_id); +					} +					else +					{ +						$sql = 'UPDATE ' . BOTS_TABLE . " +							SET bot_agent = '" .  $db->sql_escape($bot_agent) . "' +							WHERE user_id = $bot_user_id"; +						_sql($sql, $errored, $error_ary); +					} +				} +			} + +			$no_updates = false; +		break; +  		// Changes from 3.1.0-dev to 3.1.0-A1  		case '3.1.0-dev': @@ -2260,6 +2359,16 @@ function change_database_data(&$no_updates, $version)  				set_config('fulltext_postgres_max_word_len', 254);  			} +			if (!isset($config['fulltext_sphinx_stopwords'])) +			{ +				set_config('fulltext_sphinx_stopwords', 0); +			} + +			if (!isset($config['fulltext_sphinx_indexer_mem_limit'])) +			{ +				set_config('fulltext_sphinx_indexer_mem_limit', 512); +			} +  			if (!isset($config['load_jquery_cdn']))  			{  				set_config('load_jquery_cdn', 0); @@ -2596,10 +2705,10 @@ function change_database_data(&$no_updates, $version)  			// Create config value for displaying last subject on forum list  			if (!isset($config['display_last_subject'])) -			{			 +			{  				$config->set('display_last_subject', '1');  			} -			 +  			$no_updates = false;  			if (!isset($config['assets_version'])) @@ -2607,6 +2716,38 @@ function change_database_data(&$no_updates, $version)  				$config->set('assets_version', '1');  			} +			// If the column exists, we did not yet update the users timezone +			if ($db_tools->sql_column_exists(USERS_TABLE, 'user_dst')) +			{ +				// Update user timezones +				$sql = 'SELECT user_dst, user_timezone +					FROM ' . USERS_TABLE . ' +					GROUP BY user_timezone, user_dst'; +				$result = $db->sql_query($sql); + +				while ($row = $db->sql_fetchrow($result)) +				{ +					$sql = 'UPDATE ' . USERS_TABLE . " +						SET user_timezone = '" . $db->sql_escape($update_helpers->convert_phpbb30_timezone($row['user_timezone'], $row['user_dst'])) . "' +						WHERE user_timezone = '" . $db->sql_escape($row['user_timezone']) . "' +							AND user_dst = " . (int) $row['user_dst']; +					_sql($sql, $errored, $error_ary); +				} +				$db->sql_freeresult($result); + +				// Update board default timezone +				set_config('board_timezone', $update_helpers->convert_phpbb30_timezone($config['board_timezone'], $config['board_dst'])); + +				// After we have calculated the timezones we can delete user_dst column from user table. +				$db_tools->sql_column_remove(USERS_TABLE, 'user_dst'); +			} + +			if (!isset($config['site_home_url'])) +			{ +				$config->set('site_home_url', ''); +				$config->set('site_home_text', ''); +			} +  		break;  	}  } | 
