2022-02-22 20:48:51 -06:00
|
|
|
<?php
|
|
|
|
|
2022-06-04 10:31:21 -05:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2022-02-22 20:48:51 -06:00
|
|
|
namespace phpseclib3\Tests\Unit\Crypt\EC;
|
|
|
|
|
|
|
|
use phpseclib3\Common\Functions\Strings;
|
|
|
|
use phpseclib3\Crypt\EC\Curves\Ed448;
|
2022-08-18 08:05:57 -05:00
|
|
|
use phpseclib3\Exception\UnexpectedValueException;
|
2022-02-22 20:48:51 -06:00
|
|
|
|
|
|
|
class Ed448PrivateKey
|
|
|
|
{
|
2022-07-08 21:42:28 -05:00
|
|
|
public static function load($key, ?string $password = null): array
|
2022-02-22 20:48:51 -06:00
|
|
|
{
|
|
|
|
if (!Strings::is_stringable($key)) {
|
2022-08-18 08:05:57 -05:00
|
|
|
throw new UnexpectedValueException('Key should be a string - not a ' . gettype($key));
|
2022-02-22 20:48:51 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
$components = ['curve' => new Ed448()];
|
2022-07-28 16:23:01 +02:00
|
|
|
$arr = $components['curve']->extractSecret($key);
|
|
|
|
$components['dA'] = $arr['dA'];
|
|
|
|
$components['secret'] = $arr['secret'];
|
2022-02-22 20:48:51 -06:00
|
|
|
$components['QA'] = $components['curve']->multiplyPoint($components['curve']->getBasePoint(), $components['dA']);
|
|
|
|
|
|
|
|
return $components;
|
|
|
|
}
|
|
|
|
}
|