mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-25 21:56:32 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			571 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			571 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
| *
 | |
| * This file is part of the phpBB Forum Software package.
 | |
| *
 | |
| * @copyright (c) phpBB Limited <https://www.phpbb.com>
 | |
| * @license GNU General Public License, version 2 (GPL-2.0)
 | |
| *
 | |
| * For full copyright and license information, please see
 | |
| * the docs/CREDITS.txt file.
 | |
| *
 | |
| */
 | |
| 
 | |
| /**
 | |
| * @ignore
 | |
| */
 | |
| if (!defined('IN_PHPBB'))
 | |
| {
 | |
| 	exit;
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Get user avatar
 | |
| *
 | |
| * @deprecated 3.1.0-a1 (To be removed: 4.0.0)
 | |
| *
 | |
| * @param string $avatar Users assigned avatar name
 | |
| * @param int $avatar_type Type of avatar
 | |
| * @param string $avatar_width Width of users avatar
 | |
| * @param string $avatar_height Height of users avatar
 | |
| * @param string $alt Optional language string for alt tag within image, can be a language key or text
 | |
| * @param bool $ignore_config Ignores the config-setting, to be still able to view the avatar in the UCP
 | |
| * @param bool $lazy If true, will be lazy loaded (requires JS)
 | |
| *
 | |
| * @return string Avatar image
 | |
| */
 | |
| function get_user_avatar($avatar, $avatar_type, $avatar_width, $avatar_height, $alt = 'USER_AVATAR', $ignore_config = false, $lazy = false)
 | |
| {
 | |
| 	// map arguments to new function phpbb_get_avatar()
 | |
| 	$row = array(
 | |
| 		'avatar'		=> $avatar,
 | |
| 		'avatar_type'	=> $avatar_type,
 | |
| 		'avatar_width'	=> $avatar_width,
 | |
| 		'avatar_height'	=> $avatar_height,
 | |
| 	);
 | |
| 
 | |
| 	return phpbb_get_avatar($row, $alt, $ignore_config, $lazy);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Hash the password
 | |
| *
 | |
| * @deprecated 3.1.0-a2 (To be removed: 4.0.0)
 | |
| *
 | |
| * @param string $password Password to be hashed
 | |
| *
 | |
| * @return string|bool Password hash or false if something went wrong during hashing
 | |
| */
 | |
| function phpbb_hash($password)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	/* @var $passwords_manager \phpbb\passwords\manager */
 | |
| 	$passwords_manager = $phpbb_container->get('passwords.manager');
 | |
| 	return $passwords_manager->hash($password);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Check for correct password
 | |
| *
 | |
| * @deprecated 3.1.0-a2 (To be removed: 4.0.0)
 | |
| *
 | |
| * @param string $password The password in plain text
 | |
| * @param string $hash The stored password hash
 | |
| *
 | |
| * @return bool Returns true if the password is correct, false if not.
 | |
| */
 | |
| function phpbb_check_hash($password, $hash)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	/* @var $passwords_manager \phpbb\passwords\manager */
 | |
| 	$passwords_manager = $phpbb_container->get('passwords.manager');
 | |
| 	return $passwords_manager->check($password, $hash);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Eliminates useless . and .. components from specified path.
 | |
| *
 | |
| * Deprecated, use storage helper class instead
 | |
| *
 | |
| * @param string $path Path to clean
 | |
| * @return string Cleaned path
 | |
| *
 | |
| * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
| */
 | |
| function phpbb_clean_path($path)
 | |
| {
 | |
| 	return \phpbb\filesystem\helper::clean_path($path);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Pick a timezone
 | |
| *
 | |
| * @param	string		$default			A timezone to select
 | |
| * @param	boolean		$truncate			Shall we truncate the options text
 | |
| *
 | |
| * @return		string		Returns the options for timezone selector only
 | |
| *
 | |
| * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
| */
 | |
| function tz_select($default = '', $truncate = false)
 | |
| {
 | |
| 	global $template, $user;
 | |
| 
 | |
| 	return phpbb_timezone_select($template, $user, $default, $truncate);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Cache moderators. Called whenever permissions are changed
 | |
| * via admin_permissions. Changes of usernames and group names
 | |
| * must be carried through for the moderators table.
 | |
| *
 | |
| * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
| * @return null
 | |
| */
 | |
| function cache_moderators()
 | |
| {
 | |
| 	global $db, $cache, $auth;
 | |
| 	return phpbb_cache_moderators($db, $cache, $auth);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Removes moderators and administrators from foe lists.
 | |
| *
 | |
| * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
| * @param array|bool $group_id If an array, remove all members of this group from foe lists, or false to ignore
 | |
| * @param array|bool $user_id If an array, remove this user from foe lists, or false to ignore
 | |
| * @return null
 | |
| */
 | |
| function update_foes($group_id = false, $user_id = false)
 | |
| {
 | |
| 	global $db, $auth;
 | |
| 	return phpbb_update_foes($db, $auth, $group_id, $user_id);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Get user rank title and image
 | |
| *
 | |
| * @param int $user_rank the current stored users rank id
 | |
| * @param int $user_posts the users number of posts
 | |
| * @param string &$rank_title the rank title will be stored here after execution
 | |
| * @param string &$rank_img the rank image as full img tag is stored here after execution
 | |
| * @param string &$rank_img_src the rank image source is stored here after execution
 | |
| *
 | |
| * @deprecated 3.1.0-RC5 (To be removed: 4.0.0)
 | |
| *
 | |
| * Note: since we do not want to break backwards-compatibility, this function will only properly assign ranks to guests if you call it for them with user_posts == false
 | |
| */
 | |
| function get_user_rank($user_rank, $user_posts, &$rank_title, &$rank_img, &$rank_img_src)
 | |
| {
 | |
| 	global $phpbb_root_path, $phpEx;
 | |
| 	if (!function_exists('phpbb_get_user_rank'))
 | |
| 	{
 | |
| 		include($phpbb_root_path . 'includes/functions_display.' . $phpEx);
 | |
| 	}
 | |
| 
 | |
| 	$rank_data = phpbb_get_user_rank(array('user_rank' => $user_rank), $user_posts);
 | |
| 	$rank_title = $rank_data['title'];
 | |
| 	$rank_img = $rank_data['img'];
 | |
| 	$rank_img_src = $rank_data['img_src'];
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Retrieve contents from remotely stored file
 | |
|  *
 | |
|  * @deprecated	3.1.2	Use file_downloader instead
 | |
|  */
 | |
| function get_remote_file($host, $directory, $filename, &$errstr, &$errno, $port = 80, $timeout = 6)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	// Get file downloader and assign $errstr and $errno
 | |
| 	/* @var $file_downloader \phpbb\file_downloader */
 | |
| 	$file_downloader = $phpbb_container->get('file_downloader');
 | |
| 
 | |
| 	$file_data = $file_downloader->get($host, $directory, $filename, $port, $timeout);
 | |
| 	$errstr = $file_downloader->get_error_string();
 | |
| 	$errno = $file_downloader->get_error_number();
 | |
| 
 | |
| 	return $file_data;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Add log entry
 | |
|  *
 | |
|  * @param	string	$mode				The mode defines which log_type is used and from which log the entry is retrieved
 | |
|  * @param	int		$forum_id			Mode 'mod' ONLY: forum id of the related item, NOT INCLUDED otherwise
 | |
|  * @param	int		$topic_id			Mode 'mod' ONLY: topic id of the related item, NOT INCLUDED otherwise
 | |
|  * @param	int		$reportee_id		Mode 'user' ONLY: user id of the reportee, NOT INCLUDED otherwise
 | |
|  * @param	string	$log_operation		Name of the operation
 | |
|  * @param	array	$additional_data	More arguments can be added, depending on the log_type
 | |
|  *
 | |
|  * @return	int|bool		Returns the log_id, if the entry was added to the database, false otherwise.
 | |
|  *
 | |
|  * @deprecated	3.1.0 (To be removed: 4.0.0)
 | |
|  */
 | |
| function add_log()
 | |
| {
 | |
| 	global $phpbb_log, $user;
 | |
| 
 | |
| 	$args = func_get_args();
 | |
| 	$mode = array_shift($args);
 | |
| 
 | |
| 	// This looks kind of dirty, but add_log has some additional data before the log_operation
 | |
| 	$additional_data = array();
 | |
| 	switch ($mode)
 | |
| 	{
 | |
| 		case 'admin':
 | |
| 		case 'critical':
 | |
| 			break;
 | |
| 		case 'mod':
 | |
| 			$additional_data['forum_id'] = array_shift($args);
 | |
| 			$additional_data['topic_id'] = array_shift($args);
 | |
| 			break;
 | |
| 		case 'user':
 | |
| 			$additional_data['reportee_id'] = array_shift($args);
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	$log_operation = array_shift($args);
 | |
| 	$additional_data = array_merge($additional_data, $args);
 | |
| 
 | |
| 	$user_id = (empty($user->data)) ? ANONYMOUS : $user->data['user_id'];
 | |
| 	$user_ip = (empty($user->ip)) ? '' : $user->ip;
 | |
| 
 | |
| 	return $phpbb_log->add($mode, $user_id, $user_ip, $log_operation, time(), $additional_data);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Sets a configuration option's value.
 | |
|  *
 | |
|  * Please note that this function does not update the is_dynamic value for
 | |
|  * an already existing config option.
 | |
|  *
 | |
|  * @param string $config_name   The configuration option's name
 | |
|  * @param string $config_value  New configuration value
 | |
|  * @param bool   $is_dynamic    Whether this variable should be cached (false) or
 | |
|  *                              if it changes too frequently (true) to be
 | |
|  *                              efficiently cached.
 | |
|  *
 | |
|  * @return null
 | |
|  *
 | |
|  * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
|  */
 | |
| function set_config($config_name, $config_value, $is_dynamic = false, \phpbb\config\config $set_config = null)
 | |
| {
 | |
| 	static $config = null;
 | |
| 
 | |
| 	if ($set_config !== null)
 | |
| 	{
 | |
| 		$config = $set_config;
 | |
| 
 | |
| 		if (empty($config_name))
 | |
| 		{
 | |
| 			return;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	$config->set($config_name, $config_value, !$is_dynamic);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Increments an integer config value directly in the database.
 | |
|  *
 | |
|  * @param string $config_name   The configuration option's name
 | |
|  * @param int    $increment     Amount to increment by
 | |
|  * @param bool   $is_dynamic    Whether this variable should be cached (false) or
 | |
|  *                              if it changes too frequently (true) to be
 | |
|  *                              efficiently cached.
 | |
|  *
 | |
|  * @return null
 | |
|  *
 | |
|  * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
|  */
 | |
| function set_config_count($config_name, $increment, $is_dynamic = false, \phpbb\config\config $set_config = null)
 | |
| {
 | |
| 	static $config = null;
 | |
| 	if ($set_config !== null)
 | |
| 	{
 | |
| 		$config = $set_config;
 | |
| 		if (empty($config_name))
 | |
| 		{
 | |
| 			return;
 | |
| 		}
 | |
| 	}
 | |
| 	$config->increment($config_name, $increment, !$is_dynamic);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Wrapper function of \phpbb\request\request::variable which exists for backwards compatability.
 | |
|  * See {@link \phpbb\request\request_interface::variable \phpbb\request\request_interface::variable} for
 | |
|  * documentation of this function's use.
 | |
|  *
 | |
|  * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
|  * @param	mixed			$var_name	The form variable's name from which data shall be retrieved.
 | |
|  * 										If the value is an array this may be an array of indizes which will give
 | |
|  * 										direct access to a value at any depth. E.g. if the value of "var" is array(1 => "a")
 | |
|  * 										then specifying array("var", 1) as the name will return "a".
 | |
|  * 										If you pass an instance of {@link \phpbb\request\request_interface phpbb_request_interface}
 | |
|  * 										as this parameter it will overwrite the current request class instance. If you do
 | |
|  * 										not do so, it will create its own instance (but leave superglobals enabled).
 | |
|  * @param	mixed			$default	A default value that is returned if the variable was not set.
 | |
|  * 										This function will always return a value of the same type as the default.
 | |
|  * @param	bool			$multibyte	If $default is a string this paramater has to be true if the variable may contain any UTF-8 characters
 | |
|  *										Default is false, causing all bytes outside the ASCII range (0-127) to be replaced with question marks
 | |
|  * @param	bool			$cookie		This param is mapped to \phpbb\request\request_interface::COOKIE as the last param for
 | |
|  * 										\phpbb\request\request_interface::variable for backwards compatability reasons.
 | |
|  * @param	\phpbb\request\request_interface|null|false	If an instance of \phpbb\request\request_interface is given the instance is stored in
 | |
|  *										a static variable and used for all further calls where this parameters is null. Until
 | |
|  *										the function is called with an instance it automatically creates a new \phpbb\request\request
 | |
|  *										instance on every call. By passing false this per-call instantiation can be restored
 | |
|  *										after having passed in a \phpbb\request\request_interface instance.
 | |
|  *
 | |
|  * @return	mixed	The value of $_REQUEST[$var_name] run through {@link set_var set_var} to ensure that the type is the
 | |
|  * 					the same as that of $default. If the variable is not set $default is returned.
 | |
|  */
 | |
| function request_var($var_name, $default, $multibyte = false, $cookie = false, $request = null)
 | |
| {
 | |
| 	// This is all just an ugly hack to add "Dependency Injection" to a function
 | |
| 	// the only real code is the function call which maps this function to a method.
 | |
| 	static $static_request = null;
 | |
| 	if ($request instanceof \phpbb\request\request_interface)
 | |
| 	{
 | |
| 		$static_request = $request;
 | |
| 		if (empty($var_name))
 | |
| 		{
 | |
| 			return;
 | |
| 		}
 | |
| 	}
 | |
| 	else if ($request === false)
 | |
| 	{
 | |
| 		$static_request = null;
 | |
| 		if (empty($var_name))
 | |
| 		{
 | |
| 			return;
 | |
| 		}
 | |
| 	}
 | |
| 	$tmp_request = $static_request;
 | |
| 	// no request class set, create a temporary one ourselves to keep backwards compatibility
 | |
| 	if ($tmp_request === null)
 | |
| 	{
 | |
| 		// false param: enable super globals, so the created request class does not
 | |
| 		// make super globals inaccessible everywhere outside this function.
 | |
| 		$tmp_request = new \phpbb\request\request(new \phpbb\request\type_cast_helper(), false);
 | |
| 	}
 | |
| 	return $tmp_request->variable($var_name, $default, $multibyte, ($cookie) ? \phpbb\request\request_interface::COOKIE : \phpbb\request\request_interface::REQUEST);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Get tables of a database
 | |
|  *
 | |
|  * @deprecated 3.1.0 (To be removed: 4.0.0)
 | |
|  */
 | |
| function get_tables(&$db)
 | |
| {
 | |
| 	$db_tools_factory = new \phpbb\db\tools\factory();
 | |
| 	$db_tools = $db_tools_factory->get($db);
 | |
| 
 | |
| 	return $db_tools->sql_list_tables();
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Global function for chmodding directories and files for internal use
 | |
|  *
 | |
|  * This function determines owner and group whom the file belongs to and user and group of PHP and then set safest possible file permissions.
 | |
|  * The function determines owner and group from common.php file and sets the same to the provided file.
 | |
|  * The function uses bit fields to build the permissions.
 | |
|  * The function sets the appropiate execute bit on directories.
 | |
|  *
 | |
|  * Supported constants representing bit fields are:
 | |
|  *
 | |
|  * CHMOD_ALL - all permissions (7)
 | |
|  * CHMOD_READ - read permission (4)
 | |
|  * CHMOD_WRITE - write permission (2)
 | |
|  * CHMOD_EXECUTE - execute permission (1)
 | |
|  *
 | |
|  * NOTE: The function uses POSIX extension and fileowner()/filegroup() functions. If any of them is disabled, this function tries to build proper permissions, by calling is_readable() and is_writable() functions.
 | |
|  *
 | |
|  * @param string	$filename	The file/directory to be chmodded
 | |
|  * @param int	$perms		Permissions to set
 | |
|  *
 | |
|  * @return bool	true on success, otherwise false
 | |
|  *
 | |
|  * @deprecated 3.2.0-dev	use \phpbb\filesystem\filesystem::phpbb_chmod() instead
 | |
|  */
 | |
| function phpbb_chmod($filename, $perms = CHMOD_READ)
 | |
| {
 | |
| 	global $phpbb_filesystem;
 | |
| 
 | |
| 	try
 | |
| 	{
 | |
| 		$phpbb_filesystem->phpbb_chmod($filename, $perms);
 | |
| 	}
 | |
| 	catch (\phpbb\filesystem\exception\filesystem_exception $e)
 | |
| 	{
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Test if a file/directory is writable
 | |
|  *
 | |
|  * This function calls the native is_writable() when not running under
 | |
|  * Windows and it is not disabled.
 | |
|  *
 | |
|  * @param string $file Path to perform write test on
 | |
|  * @return bool True when the path is writable, otherwise false.
 | |
|  *
 | |
|  * @deprecated 3.2.0-dev	use \phpbb\filesystem\filesystem::is_writable() instead
 | |
|  */
 | |
| function phpbb_is_writable($file)
 | |
| {
 | |
| 	global $phpbb_filesystem;
 | |
| 
 | |
| 	return $phpbb_filesystem->is_writable($file);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Checks if a path ($path) is absolute or relative
 | |
|  *
 | |
|  * @param string $path Path to check absoluteness of
 | |
|  * @return boolean
 | |
|  *
 | |
|  * @deprecated 3.2.0-dev	use \phpbb\filesystem\helper::is_absolute_path() instead
 | |
|  */
 | |
| function phpbb_is_absolute($path)
 | |
| {
 | |
| 	return \phpbb\filesystem\helper::is_absolute_path($path);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * A wrapper for realpath
 | |
|  *
 | |
|  * @deprecated 3.2.0-dev	use \phpbb\filesystem\helper::realpath() instead
 | |
|  */
 | |
| function phpbb_realpath($path)
 | |
| {
 | |
| 	return \phpbb\filesystem\helper::realpath($path);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Determine which plural form we should use.
 | |
|  * For some languages this is not as simple as for English.
 | |
|  *
 | |
|  * @param $rule		int			ID of the plural rule we want to use, see http://wiki.phpbb.com/Plural_Rules#Plural_Rules
 | |
|  * @param $number	int|float	The number we want to get the plural case for. Float numbers are floored.
 | |
|  * @return	int		The plural-case we need to use for the number plural-rule combination
 | |
|  *
 | |
|  * @deprecated 3.2.0-dev (To be removed: 4.0.0)
 | |
|  */
 | |
| function phpbb_get_plural_form($rule, $number)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	/** @var \phpbb\language\language $language */
 | |
| 	$language = $phpbb_container->get('language');
 | |
| 	return $language->get_plural_form($number, $rule);
 | |
| }
 | |
| 
 | |
| /**
 | |
| * @return bool Always true
 | |
| * @deprecated 3.2.0-dev
 | |
| */
 | |
| function phpbb_pcre_utf8_support()
 | |
| {
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Casts a variable to the given type.
 | |
|  *
 | |
|  * @deprecated 3.1 (To be removed 4.0.0)
 | |
|  */
 | |
| function set_var(&$result, $var, $type, $multibyte = false)
 | |
| {
 | |
| 	// no need for dependency injection here, if you have the object, call the method yourself!
 | |
| 	$type_cast_helper = new \phpbb\request\type_cast_helper();
 | |
| 	$type_cast_helper->set_var($result, $var, $type, $multibyte);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Delete Attachments
 | |
|  *
 | |
|  * @deprecated 3.2.0-a1 (To be removed: 4.0.0)
 | |
|  *
 | |
|  * @param string $mode can be: post|message|topic|attach|user
 | |
|  * @param mixed $ids can be: post_ids, message_ids, topic_ids, attach_ids, user_ids
 | |
|  * @param bool $resync set this to false if you are deleting posts or topics
 | |
|  */
 | |
| function delete_attachments($mode, $ids, $resync = true)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	/** @var \phpbb\attachment\manager $attachment_manager */
 | |
| 	$attachment_manager = $phpbb_container->get('attachment.manager');
 | |
| 	$num_deleted = $attachment_manager->delete($mode, $ids, $resync);
 | |
| 
 | |
| 	unset($attachment_manager);
 | |
| 
 | |
| 	return $num_deleted;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Delete attached file
 | |
|  *
 | |
|  * @deprecated 3.2.0-a1 (To be removed: 4.0.0)
 | |
|  */
 | |
| function phpbb_unlink($filename, $mode = 'file', $entry_removed = false)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	/** @var \phpbb\attachment\manager $attachment_manager */
 | |
| 	$attachment_manager = $phpbb_container->get('attachment.manager');
 | |
| 	$unlink = $attachment_manager->unlink($filename, $mode, $entry_removed);
 | |
| 	unset($attachment_manager);
 | |
| 
 | |
| 	return $unlink;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Display reasons
 | |
|  *
 | |
|  * @deprecated 3.2.0-dev (To be removed: 4.0.0)
 | |
|  */
 | |
| function display_reasons($reason_id = 0)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	$phpbb_container->get('phpbb.report.report_reason_list_provider')->display_reasons($reason_id);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Upload Attachment - filedata is generated here
 | |
|  * Uses upload class
 | |
|  *
 | |
|  * @deprecated 3.2.0-a1 (To be removed: 4.0.0)
 | |
|  *
 | |
|  * @param string			$form_name		The form name of the file upload input
 | |
|  * @param int			$forum_id		The id of the forum
 | |
|  * @param bool			$local			Whether the file is local or not
 | |
|  * @param string			$local_storage	The path to the local file
 | |
|  * @param bool			$is_message		Whether it is a PM or not
 | |
|  * @param array			$local_filedata	A filespec object created for the local file
 | |
|  *
 | |
|  * @return array File data array
 | |
|  */
 | |
| function upload_attachment($form_name, $forum_id, $local = false, $local_storage = '', $is_message = false, $local_filedata = false)
 | |
| {
 | |
| 	global $phpbb_container;
 | |
| 
 | |
| 	/** @var \phpbb\attachment\manager $attachment_manager */
 | |
| 	$attachment_manager = $phpbb_container->get('attachment.manager');
 | |
| 	$file = $attachment_manager->upload($form_name, $forum_id, $local, $local_storage, $is_message, $local_filedata);
 | |
| 	unset($attachment_manager);
 | |
| 
 | |
| 	return $file;
 | |
| }
 |