mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-28 14:18:52 +00:00
[ticket/12352] Add driver for woltlab community framework 2 passwords
PHPBB3-12352
This commit is contained in:
parent
61a5fd59cf
commit
2d7593995e
4 changed files with 101 additions and 0 deletions
|
@ -22,6 +22,14 @@ services:
|
||||||
tags:
|
tags:
|
||||||
- { name: passwords.driver }
|
- { name: passwords.driver }
|
||||||
|
|
||||||
|
passwords.driver.bcrypt_wcf2:
|
||||||
|
class: phpbb\passwords\driver\bcrypt_wcf2
|
||||||
|
arguments:
|
||||||
|
- @passwords.driver.bcrypt
|
||||||
|
- @passwords.driver_helper
|
||||||
|
tags:
|
||||||
|
- { name: passwords.driver }
|
||||||
|
|
||||||
passwords.driver.salted_md5:
|
passwords.driver.salted_md5:
|
||||||
class: phpbb\passwords\driver\salted_md5
|
class: phpbb\passwords\driver\salted_md5
|
||||||
arguments:
|
arguments:
|
||||||
|
|
91
phpBB/phpbb/passwords/driver/bcrypt_wcf2.php
Normal file
91
phpBB/phpbb/passwords/driver/bcrypt_wcf2.php
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
<?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 bcrypt_wcf2 extends base
|
||||||
|
{
|
||||||
|
const PREFIX = '$wcf2$';
|
||||||
|
|
||||||
|
/** @var \phpbb\passwords\driver\bcrypt */
|
||||||
|
protected $bcrypt;
|
||||||
|
|
||||||
|
/** @var phpbb\passwords\driver\helper */
|
||||||
|
protected $helper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor of passwords driver object
|
||||||
|
*
|
||||||
|
* @param \phpbb\passwords\driver\bcrypt $bcrypt Salted md5 driver
|
||||||
|
* @param \phpbb\passwords\driver\helper $helper Password driver helper
|
||||||
|
*/
|
||||||
|
public function __construct(\phpbb\passwords\driver\bcrypt $bcrypt, helper $helper)
|
||||||
|
{
|
||||||
|
$this->bcrypt = $bcrypt;
|
||||||
|
$this->helper = $helper;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @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())
|
||||||
|
{
|
||||||
|
if (empty($hash))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$salt = substr($hash, 0, 29);
|
||||||
|
|
||||||
|
if (strlen($salt) != 29)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// Works for standard WCF 2.x, i.e. WBB4 and similar
|
||||||
|
return $hash === $this->bcrypt->hash($this->bcrypt->hash($password, $salt), $salt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @inheritdoc
|
||||||
|
*/
|
||||||
|
public function get_settings_only($hash, $full = false)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -34,6 +34,7 @@ class phpbb_passwords_helper_test extends \phpbb_test_case
|
||||||
'passwords.driver.md5_vb' => new \phpbb\passwords\driver\md5_vb($config, $this->driver_helper),
|
'passwords.driver.md5_vb' => new \phpbb\passwords\driver\md5_vb($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);
|
$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);
|
||||||
|
$this->passwords_drivers['passwords.driver.bcrypt_wcf2'] = new \phpbb\passwords\driver\bcrypt_wcf2($this->passwords_drivers['passwords.driver.bcrypt'], $this->driver_helper);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function data_helper_encode64()
|
public function data_helper_encode64()
|
||||||
|
|
|
@ -40,6 +40,7 @@ class phpbb_passwords_manager_test extends \phpbb_test_case
|
||||||
'passwords.driver.md5_vb' => new \phpbb\passwords\driver\md5_vb($config, $this->driver_helper),
|
'passwords.driver.md5_vb' => new \phpbb\passwords\driver\md5_vb($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);
|
$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);
|
||||||
|
$this->passwords_drivers['passwords.driver.bcrypt_wcf2'] = new \phpbb\passwords\driver\bcrypt_wcf2($this->passwords_drivers['passwords.driver.bcrypt'], $this->driver_helper);
|
||||||
|
|
||||||
$this->helper = new \phpbb\passwords\helper;
|
$this->helper = new \phpbb\passwords\helper;
|
||||||
// Set up passwords manager
|
// Set up passwords manager
|
||||||
|
|
Loading…
Add table
Reference in a new issue