diff options
| -rw-r--r-- | phpBB/config/passwords.yml | 8 | ||||
| -rw-r--r-- | phpBB/phpbb/passwords/driver/md5_mybb.php | 59 | ||||
| -rw-r--r-- | tests/passwords/drivers_test.php | 25 | ||||
| -rw-r--r-- | tests/passwords/manager_test.php | 1 | 
4 files changed, 93 insertions, 0 deletions
| diff --git a/phpBB/config/passwords.yml b/phpBB/config/passwords.yml index f712e84b42..4b89d5d81a 100644 --- a/phpBB/config/passwords.yml +++ b/phpBB/config/passwords.yml @@ -72,6 +72,14 @@ services:          tags:              - { name: passwords.driver } +    passwords.driver.md5_mybb: +        class: phpbb\passwords\driver\md5_mybb +        arguments: +            - @config +            - @passwords.driver_helper +        tags: +            - { name: passwords.driver } +      passwords.driver_collection:          class: phpbb\di\service_collection          arguments: diff --git a/phpBB/phpbb/passwords/driver/md5_mybb.php b/phpBB/phpbb/passwords/driver/md5_mybb.php new file mode 100644 index 0000000000..9406546798 --- /dev/null +++ b/phpBB/phpbb/passwords/driver/md5_mybb.php @@ -0,0 +1,59 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2014 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +namespace phpbb\passwords\driver; + +/** +* @package passwords +*/ +class md5_mybb extends base +{ +	const PREFIX = '$md5_mybb$'; + +	/** +	* @inheritdoc +	*/ +	public function get_prefix() +	{ +		return self::PREFIX; +	} + +	/** +	* @inheritdoc +	*/ +	public function is_legacy() +	{ +		return true; +	} + +	/** +	* @inheritdoc +	*/ +	public function hash($password, $user_row = '') +	{ +		// Do not support hashing +		return false; +	} + +	/** +	* @inheritdoc +	*/ +	public function check($password, $hash, $user_row = array()) +	{ +		return (!empty($hash) && isset($user_row['user_passwd_salt'])) ? $hash === md5($user_row['user_passwd_salt'] . md5($password)) : false; +	} + +	/** +	* @inheritdoc +	*/ +	public function get_settings_only($hash, $full = false) +	{ +		return false; +	} +} diff --git a/tests/passwords/drivers_test.php b/tests/passwords/drivers_test.php index 3ef39df709..1f900340c7 100644 --- a/tests/passwords/drivers_test.php +++ b/tests/passwords/drivers_test.php @@ -30,6 +30,7 @@ class phpbb_passwords_helper_test extends \phpbb_test_case  			'passwords.driver.sha1_smf'	=> new \phpbb\passwords\driver\sha1_smf($config, $this->driver_helper),  			'passwords.driver.convert_password'	=> new \phpbb\passwords\driver\convert_password($config, $this->driver_helper),  			'passwords.driver.sha1'		=> new \phpbb\passwords\driver\sha1($config, $this->driver_helper), +			'passwords.driver.md5_mybb'		=> new \phpbb\passwords\driver\md5_mybb($config, $this->driver_helper),  		);  		$this->passwords_drivers['passwords.driver.md5_phpbb2']	= new \phpbb\passwords\driver\md5_phpbb2($request, $this->passwords_drivers['passwords.driver.salted_md5'], $phpbb_root_path, $php_ext);  	} @@ -172,6 +173,30 @@ class phpbb_passwords_helper_test extends \phpbb_test_case  		$this->assertSame(false, $this->passwords_drivers['passwords.driver.sha1']->get_settings_only('ae2fc75e20ee25d4520766788fbc96ae'));  	} +	public function data_md5_mybb_check() +	{ +		return array( +			array(false, 'foobar', '083d11daea8675b1b4b502c7e55f8dbd'), +			array(false, 'foobar', '083d11daea8675b1b4b502c7e55f8dbd', array('user_passwd_salt' => 'ae2fc75e')), +			array(true, 'foobar', '6022de2cc0ecf59ff14b57c6205ee170', array('user_passwd_salt' => 'ae2fc75e')), +		); +	} + +	/** +	* @dataProvider data_md5_mybb_check +	*/ +	public function test_md5_mybb_check($expected, $password, $hash, $user_row = array()) +	{ +		$this->assertSame($expected, $this->passwords_drivers['passwords.driver.md5_mybb']->check($password, $hash, $user_row)); +	} + +	public function test_md5_mybb_driver() +	{ +		$this->assertSame(false, $this->passwords_drivers['passwords.driver.md5_mybb']->hash('foobar')); + +		$this->assertSame(false, $this->passwords_drivers['passwords.driver.md5_mybb']->get_settings_only('6022de2cc0ecf59ff14b57c6205ee170')); +	} +  	protected function utf8_to_cp1252($string)  	{  		static $transform = array( diff --git a/tests/passwords/manager_test.php b/tests/passwords/manager_test.php index 2a53d79027..e2ec1972bb 100644 --- a/tests/passwords/manager_test.php +++ b/tests/passwords/manager_test.php @@ -36,6 +36,7 @@ class phpbb_passwords_manager_test extends \phpbb_test_case  			'passwords.driver.convert_password'	=> new \phpbb\passwords\driver\convert_password($config, $this->driver_helper),  			'passwords.driver.sha1_smf'	=> new \phpbb\passwords\driver\sha1_smf($config, $this->driver_helper),  			'passwords.driver.sha1'		=> new \phpbb\passwords\driver\sha1($config, $this->driver_helper), +			'passwords.driver.md5_mybb'		=> new \phpbb\passwords\driver\md5_mybb($config, $this->driver_helper),  		);  		$this->passwords_drivers['passwords.driver.md5_phpbb2']	= new \phpbb\passwords\driver\md5_phpbb2($request, $this->passwords_drivers['passwords.driver.salted_md5'], $phpbb_root_path, $php_ext); | 
