mirror of
				https://github.com/delight-im/PHP-Auth.git
				synced 2025-10-25 04:46:06 +02:00 
			
		
		
		
	Permit restriction to selector in 'deleteRememberDirectiveForUserById'
This commit is contained in:
		| @@ -454,8 +454,8 @@ final class Auth extends UserManager { | |||||||
| 		$this->setRememberCookie($selector, $token, $expires); | 		$this->setRememberCookie($selector, $token, $expires); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	protected function deleteRememberDirectiveForUserById($userId) { | 	protected function deleteRememberDirectiveForUserById($userId, $selector = null) { | ||||||
| 		parent::deleteRememberDirectiveForUserById($userId); | 		parent::deleteRememberDirectiveForUserById($userId, $selector); | ||||||
|  |  | ||||||
| 		$this->setRememberCookie(null, null, \time() - 3600); | 		$this->setRememberCookie(null, null, \time() - 3600); | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -371,13 +371,22 @@ abstract class UserManager { | |||||||
| 	 * Clears an existing directive that keeps the user logged in ("remember me") | 	 * Clears an existing directive that keeps the user logged in ("remember me") | ||||||
| 	 * | 	 * | ||||||
| 	 * @param int $userId the ID of the user who shouldn't be kept signed in anymore | 	 * @param int $userId the ID of the user who shouldn't be kept signed in anymore | ||||||
|  | 	 * @param string $selector (optional) the selector which the deletion should be restricted to | ||||||
| 	 * @throws AuthError if an internal problem occurred (do *not* catch) | 	 * @throws AuthError if an internal problem occurred (do *not* catch) | ||||||
| 	 */ | 	 */ | ||||||
| 	protected function deleteRememberDirectiveForUserById($userId) { | 	protected function deleteRememberDirectiveForUserById($userId, $selector = null) { | ||||||
|  | 		$whereMappings = []; | ||||||
|  |  | ||||||
|  | 		if (isset($selector)) { | ||||||
|  | 			$whereMappings['selector'] = (string) $selector; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		$whereMappings['user'] = (int) $userId; | ||||||
|  |  | ||||||
| 		try { | 		try { | ||||||
| 			$this->db->delete( | 			$this->db->delete( | ||||||
| 				$this->dbTablePrefix . 'users_remembered', | 				$this->dbTablePrefix . 'users_remembered', | ||||||
| 				[ 'user' => $userId ] | 				$whereMappings | ||||||
| 			); | 			); | ||||||
| 		} | 		} | ||||||
| 		catch (Error $e) { | 		catch (Error $e) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user