| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550 | 
							- <?php
 
- namespace Elgg\Database;
 
- /// Map a username to a cached GUID
 
- /**
 
-  * @var int[] $USERNAME_TO_GUID_MAP_CACHE
 
-  * @access private
 
-  */
 
- global $USERNAME_TO_GUID_MAP_CACHE;
 
- $USERNAME_TO_GUID_MAP_CACHE = array();
 
- /**
 
-  * WARNING: API IN FLUX. DO NOT USE DIRECTLY.
 
-  *
 
-  * @access private
 
-  *
 
-  * @package    Elgg.Core
 
-  * @subpackage Database
 
-  * @since      1.10.0
 
-  */
 
- class UsersTable {
 
- 	/**
 
- 	 * Global Elgg configuration
 
- 	 * 
 
- 	 * @var \stdClass
 
- 	 */
 
- 	private $CONFIG;
 
- 	/**
 
- 	 * Constructor
 
- 	 */
 
- 	public function __construct() {
 
- 		global $CONFIG;
 
- 		$this->CONFIG = $CONFIG;
 
- 	}
 
- 	/**
 
- 	 * Return the user specific details of a user by a row.
 
- 	 *
 
- 	 * @param int $guid The \ElggUser guid
 
- 	 *
 
- 	 * @return mixed
 
- 	 * @access private
 
- 	 */
 
- 	function getRow($guid) {
 
- 		
 
- 	
 
- 		$guid = (int)$guid;
 
- 		return _elgg_services()->db->getDataRow("SELECT * from {$this->CONFIG->dbprefix}users_entity where guid=$guid");
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Disables all of a user's entities
 
- 	 *
 
- 	 * @param int $owner_guid The owner GUID
 
- 	 *
 
- 	 * @return bool Depending on success
 
- 	 */
 
- 	function disableEntities($owner_guid) {
 
- 		
 
- 		$owner_guid = (int) $owner_guid;
 
- 		if ($entity = get_entity($owner_guid)) {
 
- 			if (_elgg_services()->events->trigger('disable', $entity->type, $entity)) {
 
- 				if ($entity->canEdit()) {
 
- 					$query = "UPDATE {$this->CONFIG->dbprefix}entities
 
- 						set enabled='no' where owner_guid={$owner_guid}
 
- 						or container_guid = {$owner_guid}";
 
- 	
 
- 					$res = _elgg_services()->db->updateData($query);
 
- 					return $res;
 
- 				}
 
- 			}
 
- 		}
 
- 	
 
- 		return false;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Ban a user
 
- 	 *
 
- 	 * @param int    $user_guid The user guid
 
- 	 * @param string $reason    A reason
 
- 	 *
 
- 	 * @return bool
 
- 	 */
 
- 	function ban($user_guid, $reason = "") {
 
- 		
 
- 	
 
- 		$user_guid = (int)$user_guid;
 
- 	
 
- 		$user = get_entity($user_guid);
 
- 	
 
- 		if (($user) && ($user->canEdit()) && ($user instanceof \ElggUser)) {
 
- 			if (_elgg_services()->events->trigger('ban', 'user', $user)) {
 
- 				// Add reason
 
- 				if ($reason) {
 
- 					create_metadata($user_guid, 'ban_reason', $reason, '', 0, ACCESS_PUBLIC);
 
- 				}
 
- 	
 
- 				// invalidate memcache for this user
 
- 				static $newentity_cache;
 
- 				if ((!$newentity_cache) && (is_memcache_available())) {
 
- 					$newentity_cache = new \ElggMemcache('new_entity_cache');
 
- 				}
 
- 	
 
- 				if ($newentity_cache) {
 
- 					$newentity_cache->delete($user_guid);
 
- 				}
 
- 	
 
- 				// Set ban flag
 
- 				$query = "UPDATE {$this->CONFIG->dbprefix}users_entity set banned='yes' where guid=$user_guid";
 
- 				return _elgg_services()->db->updateData($query);
 
- 			}
 
- 	
 
- 			return false;
 
- 		}
 
- 	
 
- 		return false;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Unban a user.
 
- 	 *
 
- 	 * @param int $user_guid Unban a user.
 
- 	 *
 
- 	 * @return bool
 
- 	 */
 
- 	function unban($user_guid) {
 
- 		
 
- 	
 
- 		$user_guid = (int)$user_guid;
 
- 	
 
- 		$user = get_entity($user_guid);
 
- 	
 
- 		if (($user) && ($user->canEdit()) && ($user instanceof \ElggUser)) {
 
- 			if (_elgg_services()->events->trigger('unban', 'user', $user)) {
 
- 				create_metadata($user_guid, 'ban_reason', '', '', 0, ACCESS_PUBLIC);
 
- 	
 
- 				// invalidate memcache for this user
 
- 				static $newentity_cache;
 
- 				if ((!$newentity_cache) && (is_memcache_available())) {
 
- 					$newentity_cache = new \ElggMemcache('new_entity_cache');
 
- 				}
 
- 	
 
- 				if ($newentity_cache) {
 
- 					$newentity_cache->delete($user_guid);
 
- 				}
 
- 	
 
- 	
 
- 				$query = "UPDATE {$this->CONFIG->dbprefix}users_entity set banned='no' where guid=$user_guid";
 
- 				return _elgg_services()->db->updateData($query);
 
- 			}
 
- 	
 
- 			return false;
 
- 		}
 
- 	
 
- 		return false;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Makes user $guid an admin.
 
- 	 *
 
- 	 * @param int $user_guid User guid
 
- 	 *
 
- 	 * @return bool
 
- 	 */
 
- 	function makeAdmin($user_guid) {
 
- 		
 
- 	
 
- 		$user = get_entity((int)$user_guid);
 
- 	
 
- 		if (($user) && ($user instanceof \ElggUser) && ($user->canEdit())) {
 
- 			if (_elgg_services()->events->trigger('make_admin', 'user', $user)) {
 
- 	
 
- 				// invalidate memcache for this user
 
- 				static $newentity_cache;
 
- 				if ((!$newentity_cache) && (is_memcache_available())) {
 
- 					$newentity_cache = new \ElggMemcache('new_entity_cache');
 
- 				}
 
- 	
 
- 				if ($newentity_cache) {
 
- 					$newentity_cache->delete($user_guid);
 
- 				}
 
- 	
 
- 				$r = _elgg_services()->db->updateData("UPDATE {$this->CONFIG->dbprefix}users_entity set admin='yes' where guid=$user_guid");
 
- 				_elgg_invalidate_cache_for_entity($user_guid);
 
- 				return $r;
 
- 			}
 
- 	
 
- 			return false;
 
- 		}
 
- 	
 
- 		return false;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Removes user $guid's admin flag.
 
- 	 *
 
- 	 * @param int $user_guid User GUID
 
- 	 *
 
- 	 * @return bool
 
- 	 */
 
- 	function removeAdmin($user_guid) {
 
- 		
 
- 	
 
- 		$user = get_entity((int)$user_guid);
 
- 	
 
- 		if (($user) && ($user instanceof \ElggUser) && ($user->canEdit())) {
 
- 			if (_elgg_services()->events->trigger('remove_admin', 'user', $user)) {
 
- 	
 
- 				// invalidate memcache for this user
 
- 				static $newentity_cache;
 
- 				if ((!$newentity_cache) && (is_memcache_available())) {
 
- 					$newentity_cache = new \ElggMemcache('new_entity_cache');
 
- 				}
 
- 	
 
- 				if ($newentity_cache) {
 
- 					$newentity_cache->delete($user_guid);
 
- 				}
 
- 	
 
- 				$r = _elgg_services()->db->updateData("UPDATE {$this->CONFIG->dbprefix}users_entity set admin='no' where guid=$user_guid");
 
- 				_elgg_invalidate_cache_for_entity($user_guid);
 
- 				return $r;
 
- 			}
 
- 	
 
- 			return false;
 
- 		}
 
- 	
 
- 		return false;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Get user by username
 
- 	 *
 
- 	 * @param string $username The user's username
 
- 	 *
 
- 	 * @return \ElggUser|false Depending on success
 
- 	 */
 
- 	function getByUsername($username) {
 
- 		global $USERNAME_TO_GUID_MAP_CACHE;
 
- 	
 
- 		// Fixes #6052. Username is frequently sniffed from the path info, which,
 
- 		// unlike $_GET, is not URL decoded. If the username was not URL encoded,
 
- 		// this is harmless.
 
- 		$username = rawurldecode($username);
 
- 	
 
- 		$username = sanitise_string($username);
 
- 		$access = _elgg_get_access_where_sql();
 
- 	
 
- 		// Caching
 
- 		if ((isset($USERNAME_TO_GUID_MAP_CACHE[$username]))
 
- 				&& (_elgg_retrieve_cached_entity($USERNAME_TO_GUID_MAP_CACHE[$username]))) {
 
- 			return _elgg_retrieve_cached_entity($USERNAME_TO_GUID_MAP_CACHE[$username]);
 
- 		}
 
- 	
 
- 		$query = "SELECT e.* FROM {$this->CONFIG->dbprefix}users_entity u
 
- 			JOIN {$this->CONFIG->dbprefix}entities e ON e.guid = u.guid
 
- 			WHERE u.username = '$username' AND $access";
 
- 	
 
- 		$entity = _elgg_services()->db->getDataRow($query, 'entity_row_to_elggstar');
 
- 		if ($entity) {
 
- 			$USERNAME_TO_GUID_MAP_CACHE[$username] = $entity->guid;
 
- 		} else {
 
- 			$entity = false;
 
- 		}
 
- 	
 
- 		return $entity;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Get an array of users from an email address
 
- 	 *
 
- 	 * @param string $email Email address.
 
- 	 *
 
- 	 * @return array
 
- 	 */
 
- 	function getByEmail($email) {
 
- 		
 
- 	
 
- 		$email = sanitise_string($email);
 
- 	
 
- 		$access = _elgg_get_access_where_sql();
 
- 	
 
- 		$query = "SELECT e.* FROM {$this->CONFIG->dbprefix}entities e
 
- 			JOIN {$this->CONFIG->dbprefix}users_entity u ON e.guid = u.guid
 
- 			WHERE email = '$email' AND $access";
 
- 	
 
- 		return _elgg_services()->db->getData($query, 'entity_row_to_elggstar');
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Return users (or the number of them) who have been active within a recent period.
 
- 	 *
 
- 	 * @param array $options Array of options with keys:
 
- 	 *
 
- 	 *   seconds (int)  => Length of period (default 600 = 10min)
 
- 	 *   limit   (int)  => Limit (default 10)
 
- 	 *   offset  (int)  => Offset (default 0)
 
- 	 *   count   (bool) => Return a count instead of users? (default false)
 
- 	 *
 
- 	 *   Formerly this was the seconds parameter.
 
- 	 *
 
- 	 * @param int   $limit   Limit (deprecated usage, use $options)
 
- 	 * @param int   $offset  Offset (deprecated usage, use $options)
 
- 	 * @param bool  $count   Count (deprecated usage, use $options)
 
- 	 *
 
- 	 * @return \ElggUser[]|int
 
- 	 */
 
- 	function findActive($options = array(), $limit = 10, $offset = 0, $count = false) {
 
- 	
 
- 		$seconds = 600; //default value
 
- 	
 
- 		if (!is_array($options)) {
 
- 			elgg_deprecated_notice("find_active_users() now accepts an \$options array", 1.9);
 
- 			if (!$options) {
 
- 				$options = $seconds; //assign default value
 
- 			}
 
- 			$options = array('seconds' => $options);
 
- 		}
 
- 		if ($limit === null) {
 
- 			$limit = _elgg_services()->config->get('default_limit');
 
- 		}
 
- 		$options = array_merge(array(
 
- 			'seconds' => $seconds,
 
- 			'limit' => $limit,
 
- 			'offset' => $offset,
 
- 			'count' => $count,
 
- 		), $options);
 
- 	
 
- 		// cast options we're sending to hook
 
- 		foreach (array('seconds', 'limit', 'offset') as $key) {
 
- 			$options[$key] = (int)$options[$key];
 
- 		}
 
- 		$options['count'] = (bool)$options['count'];
 
- 	
 
- 		// allow plugins to override
 
- 		$params = array(
 
- 			'seconds' => $options['seconds'],
 
- 			'limit' => $options['limit'],
 
- 			'offset' => $options['offset'],
 
- 			'count' => $options['count'],
 
- 			'options' => $options,
 
- 		);
 
- 		$data = _elgg_services()->hooks->trigger('find_active_users', 'system', $params, null);
 
- 		// check null because the handler could legitimately return falsey values.
 
- 		if ($data !== null) {
 
- 			return $data;
 
- 		}
 
- 	
 
- 		$dbprefix = _elgg_services()->config->get('dbprefix');
 
- 		$time = time() - $options['seconds'];
 
- 		return elgg_get_entities(array(
 
- 			'type' => 'user',
 
- 			'limit' => $options['limit'],
 
- 			'offset' => $options['offset'],
 
- 			'count' => $options['count'],
 
- 			'joins' => array("join {$dbprefix}users_entity u on e.guid = u.guid"),
 
- 			'wheres' => array("u.last_action >= {$time}"),
 
- 			'order_by' => "u.last_action desc",
 
- 		));
 
- 	}
 
- 	/**
 
- 	 * Registers a user, returning false if the username already exists
 
- 	 *
 
- 	 * @param string $username              The username of the new user
 
- 	 * @param string $password              The password
 
- 	 * @param string $name                  The user's display name
 
- 	 * @param string $email                 The user's email address
 
- 	 * @param bool   $allow_multiple_emails Allow the same email address to be
 
- 	 *                                      registered multiple times?
 
- 	 *
 
- 	 * @return int|false The new user's GUID; false on failure
 
- 	 * @throws \RegistrationException
 
- 	 */
 
- 	function register($username, $password, $name, $email, $allow_multiple_emails = false) {
 
- 	
 
- 		// no need to trim password.
 
- 		$username = trim($username);
 
- 		$name = trim(strip_tags($name));
 
- 		$email = trim($email);
 
- 	
 
- 		// A little sanity checking
 
- 		if (empty($username)
 
- 				|| empty($password)
 
- 				|| empty($name)
 
- 				|| empty($email)) {
 
- 			return false;
 
- 		}
 
- 		// Make sure a user with conflicting details hasn't registered and been disabled
 
- 		$access_status = access_get_show_hidden_status();
 
- 		access_show_hidden_entities(true);
 
- 	
 
- 		if (!validate_email_address($email)) {
 
- 			throw new \RegistrationException(_elgg_services()->translator->translate('registration:emailnotvalid'));
 
- 		}
 
- 	
 
- 		if (!validate_password($password)) {
 
- 			throw new \RegistrationException(_elgg_services()->translator->translate('registration:passwordnotvalid'));
 
- 		}
 
- 	
 
- 		if (!validate_username($username)) {
 
- 			throw new \RegistrationException(_elgg_services()->translator->translate('registration:usernamenotvalid'));
 
- 		}
 
- 	
 
- 		if ($user = get_user_by_username($username)) {
 
- 			throw new \RegistrationException(_elgg_services()->translator->translate('registration:userexists'));
 
- 		}
 
- 	
 
- 		if ((!$allow_multiple_emails) && (get_user_by_email($email))) {
 
- 			throw new \RegistrationException(_elgg_services()->translator->translate('registration:dupeemail'));
 
- 		}
 
- 	
 
- 		access_show_hidden_entities($access_status);
 
- 	
 
- 		// Create user
 
- 		$user = new \ElggUser();
 
- 		$user->username = $username;
 
- 		$user->email = $email;
 
- 		$user->name = $name;
 
- 		$user->access_id = ACCESS_PUBLIC;
 
- 		$user->setPassword($password);
 
- 		$user->owner_guid = 0; // Users aren't owned by anyone, even if they are admin created.
 
- 		$user->container_guid = 0; // Users aren't contained by anyone, even if they are admin created.
 
- 		$user->language = _elgg_services()->translator->getCurrentLanguage();
 
- 		if ($user->save() === false) {
 
- 			return false;
 
- 		}
 
- 	
 
- 		// Turn on email notifications by default
 
- 		set_user_notification_setting($user->getGUID(), 'email', true);
 
- 	
 
- 		return $user->getGUID();
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Generates a unique invite code for a user
 
- 	 *
 
- 	 * @param string $username The username of the user sending the invitation
 
- 	 *
 
- 	 * @return string Invite code
 
- 	 * @see validateInviteCode
 
- 	 */
 
- 	function generateInviteCode($username) {
 
- 		$time = time();
 
- 		return "$time." . _elgg_services()->crypto->getHmac([(int)$time, $username])->getToken();
 
- 	}
 
- 	/**
 
- 	 * Validate a user's invite code
 
- 	 *
 
- 	 * @param string $username The username
 
- 	 * @param string $code     The invite code
 
- 	 *
 
- 	 * @return bool
 
- 	 * @see generateInviteCode
 
- 	 */
 
- 	function validateInviteCode($username, $code) {
 
- 		// validate the format of the token created by ->generateInviteCode()
 
- 		if (!preg_match('~^(\d+)\.([a-zA-Z0-9\-_]+)$~', $code, $m)) {
 
- 			return false;
 
- 		}
 
- 		$time = $m[1];
 
- 		$mac = $m[2];
 
- 		return _elgg_services()->crypto->getHmac([(int)$time, $username])->matchesToken($mac);
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Set the validation status for a user.
 
- 	 *
 
- 	 * @param int    $user_guid The user's GUID
 
- 	 * @param bool   $status    Validated (true) or unvalidated (false)
 
- 	 * @param string $method    Optional method to say how a user was validated
 
- 	 * @return bool
 
- 	 */
 
- 	function setValidationStatus($user_guid, $status, $method = '') {
 
- 		$result1 = create_metadata($user_guid, 'validated', $status, '', 0, ACCESS_PUBLIC, false);
 
- 		$result2 = create_metadata($user_guid, 'validated_method', $method, '', 0, ACCESS_PUBLIC, false);
 
- 		if ($result1 && $result2) {
 
- 			return true;
 
- 		} else {
 
- 			return false;
 
- 		}
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Gets the validation status of a user.
 
- 	 *
 
- 	 * @param int $user_guid The user's GUID
 
- 	 * @return bool|null Null means status was not set for this user.
 
- 	 */
 
- 	function getValidationStatus($user_guid) {
 
- 		$md = elgg_get_metadata(array(
 
- 			'guid' => $user_guid,
 
- 			'metadata_name' => 'validated'
 
- 		));
 
- 		if ($md == false) {
 
- 			return null;
 
- 		}
 
- 	
 
- 		if ($md[0]->value) {
 
- 			return true;
 
- 		}
 
- 	
 
- 		return false;
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Sets the last action time of the given user to right now.
 
- 	 *
 
- 	 * @param int $user_guid The user GUID
 
- 	 *
 
- 	 * @return void
 
- 	 */
 
- 	function setLastAction($user_guid) {
 
- 		$user_guid = (int) $user_guid;
 
- 		
 
- 		$time = time();
 
- 	
 
- 		$query = "UPDATE {$this->CONFIG->dbprefix}users_entity
 
- 			set prev_last_action = last_action,
 
- 			last_action = {$time} where guid = {$user_guid}";
 
- 	
 
- 		execute_delayed_write_query($query);
 
- 	}
 
- 	
 
- 	/**
 
- 	 * Sets the last logon time of the given user to right now.
 
- 	 *
 
- 	 * @param int $user_guid The user GUID
 
- 	 *
 
- 	 * @return void
 
- 	 */
 
- 	function setLastLogin($user_guid) {
 
- 		$user_guid = (int) $user_guid;
 
- 		
 
- 		$time = time();
 
- 	
 
- 		$query = "UPDATE {$this->CONFIG->dbprefix}users_entity
 
- 			set prev_last_login = last_login, last_login = {$time} where guid = {$user_guid}";
 
- 	
 
- 		execute_delayed_write_query($query);
 
- 	}
 
- 		
 
- }
 
 
  |