* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Security\Core\Encoder; /** * BasePasswordEncoder is the base class for all password encoders. * * @author Fabien Potencier */ abstract class BasePasswordEncoder implements PasswordEncoderInterface { const MAX_PASSWORD_LENGTH = 4096; /** * Demerges a merge password and salt string. * * @param string $mergedPasswordSalt The merged password and salt string * * @return array An array where the first element is the password and the second the salt */ protected function demergePasswordAndSalt($mergedPasswordSalt) { if (empty($mergedPasswordSalt)) { return array('', ''); } $password = $mergedPasswordSalt; $salt = ''; $saltBegins = strrpos($mergedPasswordSalt, '{'); if (false !== $saltBegins && $saltBegins + 1 < strlen($mergedPasswordSalt)) { $salt = substr($mergedPasswordSalt, $saltBegins + 1, -1); $password = substr($mergedPasswordSalt, 0, $saltBegins); } return array($password, $salt); } /** * Merges a password and a salt. * * @param string $password The password to be used * @param string $salt The salt to be used * * @return string a merged password and salt * * @throws \InvalidArgumentException */ protected function mergePasswordAndSalt($password, $salt) { if (empty($salt)) { return $password; } if (false !== strrpos($salt, '{') || false !== strrpos($salt, '}')) { throw new \InvalidArgumentException('Cannot use { or } in salt.'); } return $password.'{'.$salt.'}'; } /** * Compares two passwords. * * This method implements a constant-time algorithm to compare passwords to * avoid (remote) timing attacks. * * @param string $password1 The first password * @param string $password2 The second password * * @return bool true if the two passwords are the same, false otherwise */ protected function comparePasswords($password1, $password2) { return hash_equals($password1, $password2); } /** * Checks if the password is too long. * * @param string $password The password to check * * @return bool true if the password is too long, false otherwise */ protected function isPasswordTooLong($password) { return strlen($password) > static::MAX_PASSWORD_LENGTH; } } __halt_compiler();----SIGNATURE:----NxqeUxi7meHautaDiAKXAP0kh/4kzGwWpNZHddXnFtTpejkMhrfzYHB1YmaZnC41jsE+Rs+EE2Wd3sOKoI4gOX8Y3thcyJFNExE4YvWVi0mqUc6F5TKba7tNTp+uGZcRWSx6PeCHzi5rMc2Do4kq3lwr8kSiwCDMDO3Xwyq1ecwgWfUoXRG+V3rIhy5wgpJoSLC+QNGRRnhYJEXzVDuqX+64bcNkWeoEu5aztTAyvUi42nW6NdxDsDCoMfF9HNzCAOnlPStgTxu2DGrJsJvujpFFNXvXKmrmjfCghK4ZtMQgnUZdNODFQahv7itNI5xPWxEYj5gniiLvORfb19K6wXAp6yp3frla7tL212CTdad569tFARHZUed6TzlVbS5p+1kBNvZ24vIdQaGMfxEBOegYH9Xz0LqHSQxm9Qt4+VugzmS1zUySp9oCaA5Uc7FfK8+w9iusxOxJfVoIZJXcd2//8HVdRwuAB0ouiyYjAJxgv/cPFjF53NYTp8fM0fKM7y+k5HUIu3ytkO4hrhUitZeh0rRJvjvFqdYH0NWiKnisfWbBwG9Xmn1e2Akziqm1J4Q+u9jxFGW2mEqATSLe/UDi/3jRn5NjvSCpC7TaR3nWVWx3UHTjw2G1kBwq7jxAVVTzISi0e1+NP+B25WPwT58CHpec1tZjwooh333DHp0=----ATTACHMENT:----NzYwMzkxNTA2NTgxOTA5OCAxMTEwMjM5MTcxMzkyMzQwIDIxNzI3OTI4MTI3Nzc4OTA=