SHA1 and MD5 hash implementation.

This commit is contained in:
Marcin Łojewski
2018-02-28 21:37:51 +01:00
parent 3251067b38
commit 7872d98dd6
3 changed files with 152 additions and 2 deletions

75
lib/HashAlgorithm/MD5.php Normal file
View File

@@ -0,0 +1,75 @@
<?php
/**
* Nextcloud - user_sql
* Copyright (C) 2012-2018 Andreas Böhler <dev (at) aboehler (dot) at>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
namespace OCA\user_sql\HashAlgorithm;
/**
* MD5 password hash implementation.
* @author Marcin Łojewski <dev@mlojewski.me>
*/
class MD5 implements HashAlgorithm
{
/**
* @var MD5
*/
private static $instance;
private function __construct()
{
}
/**
* @return MD5
*/
public static function getInstance()
{
if (self::$instance === null) {
self::$instance = new MD5();
}
return self::$instance;
}
/**
* @inheritdoc
*/
public function getVisibleName()
{
return "MD5";
}
/**
* @inheritdoc
*/
public function getPasswordHash($password)
{
return md5($password);
}
/**
* @inheritdoc
*/
public function checkPassword($password, $dbHash)
{
return md5($password) === $dbHash;
}
private function __clone()
{
}
}

View File

@@ -0,0 +1,75 @@
<?php
/**
* Nextcloud - user_sql
* Copyright (C) 2012-2018 Andreas Böhler <dev (at) aboehler (dot) at>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
namespace OCA\user_sql\HashAlgorithm;
/**
* SHA1 password hash implementation.
* @author Marcin Łojewski <dev@mlojewski.me>
*/
class SHA1 implements HashAlgorithm
{
/**
* @var SHA1
*/
private static $instance;
private function __construct()
{
}
/**
* @return SHA1
*/
public static function getInstance()
{
if (self::$instance === null) {
self::$instance = new SHA1();
}
return self::$instance;
}
/**
* @inheritdoc
*/
public function getVisibleName()
{
return "SHA1";
}
/**
* @inheritdoc
*/
public function getPasswordHash($password)
{
return sha1($password);
}
/**
* @inheritdoc
*/
public function checkPassword($password, $dbHash)
{
return sha1($password) === $dbHash;
}
private function __clone()
{
}
}

View File

@@ -104,7 +104,7 @@ $cfgClass = 'section';
<p><label for="set_crypt_type"><?php p($l->t('Encryption Type')); ?></label> <p><label for="set_crypt_type"><?php p($l->t('Encryption Type')); ?></label>
<?php $crypt_types = array( <?php $crypt_types = array(
'drupal' => 'Drupal 7', 'drupal' => 'Drupal 7',
'md5' => 'MD5', 'MD5' => 'MD5',
'md5crypt' => 'MD5 Crypt', 'md5crypt' => 'MD5 Crypt',
'Cleartext' => 'Cleartext', 'Cleartext' => 'Cleartext',
'mysql_encrypt' => 'mySQL ENCRYPT()', 'mysql_encrypt' => 'mySQL ENCRYPT()',
@@ -115,7 +115,7 @@ $cfgClass = 'section';
'joomla2' => 'Joomla > 2.5.18 phpass', 'joomla2' => 'Joomla > 2.5.18 phpass',
'ssha256' => 'Salted SSHA256', 'ssha256' => 'Salted SSHA256',
'redmine' => 'Redmine', 'redmine' => 'Redmine',
'sha1' => 'SHA1', 'SHA1' => 'SHA1',
'courier_md5' => 'Courier base64-encoded MD5', 'courier_md5' => 'Courier base64-encoded MD5',
'courier_md5raw' => 'Courier hexadecimal MD5', 'courier_md5raw' => 'Courier hexadecimal MD5',
'courier_sha1' => 'Courier base64-encoded SHA1', 'courier_sha1' => 'Courier base64-encoded SHA1',