*
* 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\HashAlgorithm\Base;
/**
* Cryptographic utilities trait.
* @author Marcin Łojewski
*/
trait Utils
{
/**
* Convert hexadecimal message to its base64 form.
* @param $hex string Hexadecimal encoded message.
* @return string Same message encoded in base64.
*/
private static function hexToBase64($hex)
{
$hexChr = '';
foreach (str_split($hex, 2) as $hexPair) {
$hexChr .= chr(hexdec($hexPair));
}
return base64_encode($hexChr);
}
/**
* Generate random string from given alphabet.
* @param $length int Output string length.
* @param $alphabet string Output string alphabet.
* @return string Random string from given alphabet.
*/
private static function randomString($length, $alphabet)
{
$string = "";
for ($i = 0; $i != $length; ++$i) {
$string .= $alphabet[mt_rand(0, strlen($alphabet) - 1)];
}
return $string;
}
}