FusionDirectory
class_passwordMethodSmd5.inc
Go to the documentation of this file.
1 <?php
2 /*
3  This code is part of FusionDirectory (http://www.fusiondirectory.org/)
4 
5  Copyright (C) 2003-2010 Cajus Pollmeier
6  Copyright (C) 2011-2019 FusionDirectory
7 
8  This program is free software; you can redistribute it and/or modify
9  it under the terms of the GNU General Public License as published by
10  the Free Software Foundation; either version 2 of the License, or
11  (at your option) any later version.
12 
13  This program is distributed in the hope that it will be useful,
14  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  GNU General Public License for more details.
17 
18  You should have received a copy of the GNU General Public License
19  along with this program; if not, write to the Free Software
20  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
21 */
22 
33 {
37  function __construct ()
38  {
39  }
40 
46  public function is_available (): bool
47  {
48  return function_exists('md5');
49  }
50 
59  public function generate_hash (string $pwd, bool $locked = FALSE): string
60  {
61  $salt0 = substr(pack('h*', md5(random_int(0, PHP_INT_MAX))), 0, 8);
62  $salt = substr(pack('H*', md5($salt0 . $pwd)), 0, 4);
63  return '{SMD5}'.($locked ? '!' : '').base64_encode(pack('H*', md5($pwd . $salt)) . $salt);
64  }
65 
66  function checkPassword ($pwd, $hash): bool
67  {
68  $hash = base64_decode(substr($hash, 6));
69  $salt = substr($hash, 16);
70  $hash = substr($hash, 0, 16);
71  $nhash = pack('H*', md5($pwd . $salt));
72  return ($nhash == $hash);
73  }
74 
78  static function get_hash_name ()
79  {
80  return 'smd5';
81  }
82 }
static get_hash_name()
Get the hash name.
generate_hash(string $pwd, bool $locked=FALSE)
Generate template hash.
__construct()
passwordMethodSmd5 Constructor
This class contains all the functions for sdm5 password method.
This class contains all the basic function for password methods.