File Manager Lite
Dir:
/home/u540325668/domains/dumbafarm.in/public_html/src/Core/Security
Upload
[..]
FolderGuardInterface.php (1.51 KB)
Edit
Rename
Del
GeneralConfiguration.php (2.28 KB)
Edit
Rename
Del
HtaccessFolderGuard.php (2.48 KB)
Edit
Rename
Del
OAuth2/
Rename
Del
OpenSsl/
Rename
Del
PasswordGenerator.php (3.05 KB)
Edit
Rename
Del
PasswordPolicyConfiguration.php (4.16 KB)
Edit
Rename
Del
Edit: PasswordGenerator.php
<?php /** * Copyright since 2007 PrestaShop SA and Contributors * PrestaShop is an International Registered Trademark & Property of PrestaShop SA * * NOTICE OF LICENSE * * This source file is subject to the Open Software License (OSL 3.0) * that is bundled with this package in the file LICENSE.md. * It is also available through the world-wide-web at this URL: * https://opensource.org/licenses/OSL-3.0 * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@prestashop.com so we can send you a copy immediately. * * DISCLAIMER * * Do not edit or add to this file if you wish to upgrade PrestaShop to newer * versions in the future. If you wish to customize PrestaShop for your * needs please refer to https://devdocs.prestashop.com/ for more information. * * @author PrestaShop SA and Contributors <contact@prestashop.com> * @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) */ namespace PrestaShop\PrestaShop\Core\Security; use PrestaShop\PrestaShop\Core\Security\OpenSsl\OpenSSLInterface; class PasswordGenerator { public const PASSWORDGEN_FLAG_NUMERIC = 'NUMERIC'; public const PASSWORDGEN_FLAG_NO_NUMERIC = 'NO_NUMERIC'; public const PASSWORDGEN_FLAG_RANDOM = 'RANDOM'; public const PASSWORDGEN_FLAG_ALPHANUMERIC = 'ALPHANUMERIC'; /** * @var OpenSSLInterface */ private $cryptography; public function __construct(OpenSSLInterface $cryptography) { $this->cryptography = $cryptography; } /** * Random password generator. * * @param int $length Desired length (optional) * @param string $type Output type (NUMERIC, ALPHANUMERIC, NO_NUMERIC, RANDOM) * * @return string Password */ public function generatePassword(int $length = 8, string $type = self::PASSWORDGEN_FLAG_ALPHANUMERIC): string { if ($length <= 0) { throw new \InvalidArgumentException('Invalid length for password'); } switch ($type) { case static::PASSWORDGEN_FLAG_NUMERIC: $str = '0123456789'; break; case static::PASSWORDGEN_FLAG_NO_NUMERIC: $str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'; break; case static::PASSWORDGEN_FLAG_RANDOM: $num_bytes = (int) ceil($length * 0.75); $bytes = $this->cryptography->getBytes($num_bytes); return substr(base64_encode($bytes), 0, $length); case static::PASSWORDGEN_FLAG_ALPHANUMERIC: default: $str = 'abcdefghijkmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'; break; } $bytes = $this->cryptography->getBytes($length); $position = 0; $result = ''; for ($i = 0; $i < $length; ++$i) { $position = ($position + ord($bytes[$i])) % strlen($str); $result .= $str[$position]; } return $result; } }
Simpan