mirror of
https://github.com/YunoHost-Apps/phpbb_ynh.git
synced 2024-09-03 19:56:36 +02:00
170 lines
3.6 KiB
PHP
170 lines
3.6 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\passwords\driver;
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
* @version Version 0.1 / slightly modified for phpBB 3.1.x (using $H$ as hash type identifier)
|
||
|
*
|
||
|
* Portable PHP password hashing framework.
|
||
|
*
|
||
|
* Written by Solar Designer <solar at openwall.com> in 2004-2006 and placed in
|
||
|
* the public domain.
|
||
|
*
|
||
|
* There's absolutely no warranty.
|
||
|
*
|
||
|
* The homepage URL for this framework is:
|
||
|
*
|
||
|
* http://www.openwall.com/phpass/
|
||
|
*
|
||
|
* Please be sure to update the Version line if you edit this file in any way.
|
||
|
* It is suggested that you leave the main version number intact, but indicate
|
||
|
* your project name (after the slash) and add your own revision information.
|
||
|
*
|
||
|
* Please do not change the "private" password hashing method implemented in
|
||
|
* here, thereby making your hashes incompatible. However, if you must, please
|
||
|
* change the hash type identifier (the "$P$") to something different.
|
||
|
*
|
||
|
* Obviously, since this code is in the public domain, the above are not
|
||
|
* requirements (there can be none), but merely suggestions.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
class salted_md5 extends base
|
||
|
{
|
||
|
const PREFIX = '$H$';
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function get_prefix()
|
||
|
{
|
||
|
return self::PREFIX;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function is_legacy()
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function hash($password, $setting = '')
|
||
|
{
|
||
|
if ($setting)
|
||
|
{
|
||
|
if (($settings = $this->get_hash_settings($setting)) === false)
|
||
|
{
|
||
|
// Return md5 of password if settings do not
|
||
|
// comply with our standards. This will only
|
||
|
// happen if pre-determined settings are
|
||
|
// directly passed to the driver. The manager
|
||
|
// will not do this. Same as the old hashing
|
||
|
// implementatio in phpBB 3.0
|
||
|
return md5($password);
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$settings = $this->get_hash_settings($this->generate_salt());
|
||
|
}
|
||
|
|
||
|
$hash = md5($settings['salt'] . $password, true);
|
||
|
do
|
||
|
{
|
||
|
$hash = md5($hash . $password, true);
|
||
|
}
|
||
|
while (--$settings['count']);
|
||
|
|
||
|
$output = $settings['full'];
|
||
|
$output .= $this->helper->hash_encode64($hash, 16);
|
||
|
|
||
|
return $output;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function check($password, $hash, $user_row = array())
|
||
|
{
|
||
|
if (strlen($hash) !== 34)
|
||
|
{
|
||
|
return md5($password) === $hash;
|
||
|
}
|
||
|
|
||
|
return $this->helper->string_compare($hash, $this->hash($password, $hash));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Generate salt for hashing method
|
||
|
*
|
||
|
* @return string Salt for hashing method
|
||
|
*/
|
||
|
protected function generate_salt()
|
||
|
{
|
||
|
$count = 6;
|
||
|
|
||
|
$random = $this->helper->get_random_salt($count);
|
||
|
|
||
|
$salt = $this->get_prefix();
|
||
|
$salt .= $this->helper->itoa64[min($count + 5, 30)];
|
||
|
$salt .= $this->helper->hash_encode64($random, $count);
|
||
|
|
||
|
return $salt;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get hash settings
|
||
|
*
|
||
|
* @param string $hash The hash that contains the settings
|
||
|
*
|
||
|
* @return bool|array Array containing the count_log2, salt, and full
|
||
|
* hash settings string or false if supplied hash is empty
|
||
|
* or contains incorrect settings
|
||
|
*/
|
||
|
public function get_hash_settings($hash)
|
||
|
{
|
||
|
if (empty($hash))
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
$count_log2 = strpos($this->helper->itoa64, $hash[3]);
|
||
|
$salt = substr($hash, 4, 8);
|
||
|
|
||
|
if ($count_log2 < 7 || $count_log2 > 30 || strlen($salt) != 8)
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return array(
|
||
|
'count' => 1 << $count_log2,
|
||
|
'salt' => $salt,
|
||
|
'full' => substr($hash, 0, 12),
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function get_settings_only($hash, $full = false)
|
||
|
{
|
||
|
return substr($hash, 3, 9);
|
||
|
}
|
||
|
}
|