* @author Marcin Łojewski * * 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 . */ namespace OCA\UserSQL\Crypto; /** * Abstract Unix Crypt hash implementation. * The hash algorithm depends on the chosen salt. * * @see crypt() * @author Marcin Łojewski */ abstract class AbstractCrypt extends AbstractAlgorithm { /** * The chars used in the salt. */ const SALT_ALPHABET = "./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; /** * @inheritdoc */ public function checkPassword($password, $dbHash, $salt = null) { return hash_equals($dbHash, crypt($password, $dbHash)); } /** * @inheritdoc */ public function getPasswordHash($password, $salt = null) { return crypt($password, $this->getSalt()); } /** * Generate a salt string for the hash algorithm. * * @return string The salt string. */ protected abstract function getSalt(); }