mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 21:21:32 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			244 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			244 lines
		
	
	
		
			7.3 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.
 | |
| *
 | |
| */
 | |
| 
 | |
| namespace phpbb;
 | |
| 
 | |
| /**
 | |
| * User loader class
 | |
| *
 | |
| * This handles loading users from the database and
 | |
| * storing in them in a temporary cache so we do not
 | |
| * have to query the same user multiple times in
 | |
| * different services.
 | |
| */
 | |
| class user_loader
 | |
| {
 | |
| 	/** @var \phpbb\avatar\helper */
 | |
| 	protected $avatar_helper;
 | |
| 
 | |
| 	/** @var \phpbb\db\driver\driver_interface */
 | |
| 	protected $db = null;
 | |
| 
 | |
| 	/** @var string */
 | |
| 	protected $phpbb_root_path = null;
 | |
| 
 | |
| 	/** @var string */
 | |
| 	protected $php_ext = null;
 | |
| 
 | |
| 	/** @var string */
 | |
| 	protected $users_table = null;
 | |
| 
 | |
| 	/**
 | |
| 	* Users loaded from the DB
 | |
| 	*
 | |
| 	* @var array Array of user data that we've loaded from the DB
 | |
| 	*/
 | |
| 	protected $users = array();
 | |
| 
 | |
| 	/**
 | |
| 	* User loader constructor
 | |
| 	*
 | |
| 	* @param \phpbb\avatar\helper $avatar_helper Avatar helper object
 | |
| 	* @param \phpbb\db\driver\driver_interface $db A database connection
 | |
| 	* @param string $phpbb_root_path Path to the phpbb includes directory.
 | |
| 	* @param string $php_ext php file extension
 | |
| 	* @param string $users_table The name of the database table (phpbb_users)
 | |
| 	*/
 | |
| 	public function __construct(\phpbb\avatar\helper $avatar_helper, \phpbb\db\driver\driver_interface $db, $phpbb_root_path, $php_ext, $users_table)
 | |
| 	{
 | |
| 		$this->avatar_helper = $avatar_helper;
 | |
| 		$this->db = $db;
 | |
| 
 | |
| 		$this->phpbb_root_path = $phpbb_root_path;
 | |
| 		$this->php_ext = $php_ext;
 | |
| 
 | |
| 		$this->users_table = $users_table;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Load user helper
 | |
| 	*
 | |
| 	* @param array $user_ids
 | |
| 	* @param array $ignore_types user types to ignore
 | |
| 	*/
 | |
| 	public function load_users(array $user_ids, array $ignore_types = array())
 | |
| 	{
 | |
| 		$user_ids[] = ANONYMOUS;
 | |
| 
 | |
| 		// Make user_ids unique and convert to integer.
 | |
| 		$user_ids = array_map('intval', array_unique($user_ids));
 | |
| 
 | |
| 		// Do not load users we already have in $this->users
 | |
| 		$user_ids = array_diff($user_ids, array_keys($this->users));
 | |
| 
 | |
| 		if (count($user_ids))
 | |
| 		{
 | |
| 			$sql = 'SELECT *
 | |
| 				FROM ' . $this->users_table . '
 | |
| 				WHERE ' . $this->db->sql_in_set('user_id', $user_ids) . '
 | |
| 					AND ' . $this->db->sql_in_set('user_type', $ignore_types, true, true);
 | |
| 			$result = $this->db->sql_query($sql);
 | |
| 
 | |
| 			while ($row = $this->db->sql_fetchrow($result))
 | |
| 			{
 | |
| 				$this->users[$row['user_id']] = $row;
 | |
| 			}
 | |
| 			$this->db->sql_freeresult($result);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Load a user by username
 | |
| 	*
 | |
| 	* Stores the full data in the user cache so they do not need to be loaded again
 | |
| 	* Returns the user id so you may use get_user() from the returned value
 | |
| 	*
 | |
| 	* @param string $username Raw username to load (will be cleaned)
 | |
| 	* @return int User ID for the username
 | |
| 	*/
 | |
| 	public function load_user_by_username($username)
 | |
| 	{
 | |
| 		$sql = 'SELECT *
 | |
| 			FROM ' . $this->users_table . "
 | |
| 			WHERE username_clean = '" . $this->db->sql_escape(utf8_clean_string($username)) . "'";
 | |
| 		$result = $this->db->sql_query($sql);
 | |
| 		$row = $this->db->sql_fetchrow($result);
 | |
| 		$this->db->sql_freeresult($result);
 | |
| 
 | |
| 		if ($row)
 | |
| 		{
 | |
| 			$this->users[$row['user_id']] = $row;
 | |
| 
 | |
| 			return $row['user_id'];
 | |
| 		}
 | |
| 
 | |
| 		return ANONYMOUS;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Get a user row from our users cache
 | |
| 	*
 | |
| 	* @param int $user_id User ID of the user you want to retrieve
 | |
| 	* @param bool $query Should we query the database if this user has not yet been loaded?
 | |
| 	* 						Typically this should be left as false and you should make sure
 | |
| 	* 						you load users ahead of time with load_users()
 | |
| 	* @return array|false Row from the database of the user or Anonymous if the user wasn't loaded/does not exist
 | |
| 	* 						or bool False if the anonymous user was not loaded
 | |
| 	*/
 | |
| 	public function get_user(int $user_id, bool $query = false)
 | |
| 	{
 | |
| 		if (isset($this->users[$user_id]))
 | |
| 		{
 | |
| 			return $this->users[$user_id];
 | |
| 		}
 | |
| 		// Query them if we must (if ANONYMOUS is sent as the user_id and we have not loaded Anonymous yet, we must load Anonymous as a last resort)
 | |
| 		else if ($query || $user_id == ANONYMOUS)
 | |
| 		{
 | |
| 			$this->load_users(array($user_id));
 | |
| 
 | |
| 			return $user_id != ANONYMOUS ? $this->get_user($user_id) : $this->users[$user_id] ?? false;
 | |
| 		}
 | |
| 
 | |
| 		return $this->get_user(ANONYMOUS);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Get username
 | |
| 	*
 | |
| 	* @param int $user_id User ID of the user you want to retrieve the username for
 | |
| 	* @param string $mode The mode to load (same as get_username_string). One of the following:
 | |
| 	* 			profile (for getting an url to the profile)
 | |
| 	* 			username (for obtaining the username)
 | |
| 	* 			colour (for obtaining the user colour)
 | |
| 	* 			full (for obtaining a html string representing a coloured link to the users profile)
 | |
| 	* 			no_profile (the same as full but forcing no profile link)
 | |
| 	* @param string|bool $guest_username Optional parameter to specify the guest username. It will be used in favor of the GUEST language variable then.
 | |
| 	* @param string|bool $custom_profile_url Optional parameter to specify a profile url. The user id get appended to this url as &u={user_id}
 | |
| 	* @param bool $query Should we query the database if this user has not yet been loaded?
 | |
| 	* 						Typically this should be left as false and you should make sure
 | |
| 	* 						you load users ahead of time with load_users()
 | |
| 	* @return string
 | |
| 	*/
 | |
| 	public function get_username(int $user_id, string $mode, $guest_username = false, $custom_profile_url = false, bool $query = false): string
 | |
| 	{
 | |
| 		if (!($user = $this->get_user($user_id, $query)))
 | |
| 		{
 | |
| 			return '';
 | |
| 		}
 | |
| 
 | |
| 		return get_username_string($mode, $user['user_id'], $user['username'], $user['user_colour'], $guest_username, $custom_profile_url);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Get avatar
 | |
| 	*
 | |
| 	* @param int $user_id User ID of the user you want to retrieve the avatar for
 | |
| 	* @param bool $query Should we query the database if this user has not yet been loaded?
 | |
| 	* 						Typically this should be left as false and you should make sure
 | |
| 	* 						you load users ahead of time with load_users()
 | |
| 	* @param bool $lazy If true, will be lazy loaded (requires JS)
 | |
| 	* @return array
 | |
| 	*/
 | |
| 	public function get_avatar($user_id, $query = false, $lazy = false)
 | |
| 	{
 | |
| 		if (!($user = $this->get_user($user_id, $query)))
 | |
| 		{
 | |
| 			return [];
 | |
| 		}
 | |
| 
 | |
| 		$row = [
 | |
| 			'avatar'		=> $user['user_avatar'],
 | |
| 			'avatar_type'	=> $user['user_avatar_type'],
 | |
| 			'avatar_width'	=> $user['user_avatar_width'],
 | |
| 			'avatar_height'	=> $user['user_avatar_height'],
 | |
| 		];
 | |
| 
 | |
| 		return $this->avatar_helper->get_avatar($row, 'USER_AVATAR', false, $lazy);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Get rank
 | |
| 	*
 | |
| 	* @param int $user_id User ID of the user you want to retrieve the rank for
 | |
| 	* @param bool $query Should we query the database if this user has not yet been loaded?
 | |
| 	* 						Typically this should be left as false and you should make sure
 | |
| 	* 						you load users ahead of time with load_users()
 | |
| 	* @return array Array with keys 'rank_title', 'rank_img', and 'rank_img_src'
 | |
| 	*/
 | |
| 	public function get_rank(int $user_id, bool $query = false): array
 | |
| 	{
 | |
| 		if (!($user = $this->get_user($user_id, $query)))
 | |
| 		{
 | |
| 			return [];
 | |
| 		}
 | |
| 
 | |
| 		if (!function_exists('phpbb_get_user_rank'))
 | |
| 		{
 | |
| 			include($this->phpbb_root_path . 'includes/functions_display.' . $this->php_ext);
 | |
| 		}
 | |
| 
 | |
| 		$rank = array(
 | |
| 			'rank_title',
 | |
| 			'rank_img',
 | |
| 			'rank_img_src',
 | |
| 		);
 | |
| 
 | |
| 		$user_rank_data = phpbb_get_user_rank($user, ($user['user_id'] == ANONYMOUS ? false : $user['user_posts']));
 | |
| 		$rank['rank_title'] = $user_rank_data['title'];
 | |
| 		$rank['rank_img'] = $user_rank_data['img'];
 | |
| 		$rank['rank_img_src'] = $user_rank_data['img_src'];
 | |
| 
 | |
| 		return $rank;
 | |
| 	}
 | |
| }
 |