2014-06-04 00:11:57 -05:00
|
|
|
<?php
|
2022-02-16 20:25:59 -06:00
|
|
|
|
2014-06-04 00:11:57 -05:00
|
|
|
/**
|
|
|
|
* @author Jim Wigginton <terrafrost@php.net>
|
2014-12-10 00:02:44 +01:00
|
|
|
* @copyright 2014 Jim Wigginton
|
2014-06-04 00:11:57 -05:00
|
|
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
|
|
|
*/
|
|
|
|
|
2022-06-04 10:31:21 -05:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2022-02-22 20:48:51 -06:00
|
|
|
namespace phpseclib3\Tests\Unit\File\X509;
|
|
|
|
|
2019-11-06 23:41:40 -06:00
|
|
|
use phpseclib3\Crypt\RSA;
|
2022-01-30 09:34:42 -06:00
|
|
|
use phpseclib3\File\X509;
|
2022-02-22 20:48:51 -06:00
|
|
|
use phpseclib3\Tests\PhpseclibTestCase;
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2022-02-22 20:48:51 -06:00
|
|
|
class SPKACTest extends PhpseclibTestCase
|
2014-06-04 00:11:57 -05:00
|
|
|
{
|
2022-06-04 10:31:21 -05:00
|
|
|
public function testLoadSPKAC(): void
|
2014-06-04 00:11:57 -05:00
|
|
|
{
|
2014-06-05 09:23:22 -05:00
|
|
|
$test = 'MIICQDCCASgwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQChgo9mWzQm3TSwGgpZnIc54' .
|
|
|
|
'TZ8gYpfAO/AI0etvyWDqnFfdNCUQsqxTdSi6/rtrJdLGBsszRGrRIc/0JqmjM+jCHGYutLeo4xwgr' .
|
|
|
|
'a3HAZrWDypL5IlRWnLmLA4U/qGXCXNSk+9NrJl39X3IDA8o/aOJyr9iMUJMvswcWjVjPom3NhAgmJ' .
|
|
|
|
'ZwW0vUEMw9zszExpiRnGSO5XXntQW2qvfzo+J3NzS3BBbKxEmTsfOLHextcXeFQUaBQHXB/WOtweW' .
|
|
|
|
'Y/Bd4iZ8ETmhal28g1HWVcTFPD+V+KPRFeARlVEW6JmcJucW2WdJlBGKXXXPEfdHrDS3OgD/eDWfM' .
|
|
|
|
'JE4mChZ/icxAgMBAAEWADANBgkqhkiG9w0BAQQFAAOCAQEAUMvIKhlSgEgbC081b/FJwh6mbuVgYN' .
|
|
|
|
'ZV37Ts2WjrHoDFlabu9WXU8xzgaXct3sO51vJM5I36rY4UPyc6w3y9dLaamEwKUoWnpHG8mlXs2JG' .
|
|
|
|
'GEUOvxh5z9yfk/2ZmdCVBlKnU1LDB+ZDyNyNh5B0YULrJKw9e0jV+ymP7srwUSBcdUfZh1KEKGVIN' .
|
|
|
|
'Uv4J3GuL8V63E2unWCHGRPw4EmFVTbWpgMx96XR7p/pMavu6/pVKgYQqWLOmEeOK+dmT/QVon28d5' .
|
|
|
|
'dmeL7aWrpP+3x3L0A9cATksracQX676XogdAEXJ59fcr/S5AGw1TFErbyBbfyeAWvzDZIXeMXpb9h' .
|
|
|
|
'yNtA==';
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2014-12-09 16:53:05 -08:00
|
|
|
$x509 = new X509();
|
2014-06-04 00:11:57 -05:00
|
|
|
|
|
|
|
$spkac = $x509->loadSPKAC($test);
|
|
|
|
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsArray($spkac);
|
2014-06-04 00:11:57 -05:00
|
|
|
|
|
|
|
$spkac = $x509->loadSPKAC('SPKAC=' . $test);
|
|
|
|
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsArray($spkac);
|
2014-06-04 00:11:57 -05:00
|
|
|
|
|
|
|
$this->assertTrue(
|
|
|
|
$x509->validateSignature(),
|
|
|
|
'Failed asserting that the signature is valid'
|
|
|
|
);
|
|
|
|
|
|
|
|
$pubKey = $x509->getPublicKey();
|
|
|
|
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsString("$pubKey");
|
2014-06-04 00:11:57 -05:00
|
|
|
}
|
|
|
|
|
2022-06-04 10:31:21 -05:00
|
|
|
public function testSaveSPKAC(): void
|
2014-06-04 00:11:57 -05:00
|
|
|
{
|
2019-06-23 21:51:38 -05:00
|
|
|
$privatekey = RSA::createKey(512)
|
|
|
|
->withPadding(RSA::SIGNATURE_PKCS1)
|
|
|
|
->withHash('sha1');
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2014-12-09 16:53:05 -08:00
|
|
|
$x509 = new X509();
|
2016-04-30 16:23:35 -05:00
|
|
|
$x509->setPrivateKey($privatekey);
|
2014-06-04 00:11:57 -05:00
|
|
|
$x509->setChallenge('...');
|
|
|
|
|
|
|
|
$spkac = $x509->signSPKAC();
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsArray($spkac);
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsString($x509->saveSPKAC($spkac));
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2014-12-09 16:53:05 -08:00
|
|
|
$x509 = new X509();
|
2018-02-15 05:29:14 -06:00
|
|
|
$x509->setPrivateKey($privatekey);
|
2014-06-04 00:11:57 -05:00
|
|
|
|
|
|
|
$spkac = $x509->signSPKAC();
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsArray($spkac);
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2020-12-12 15:11:04 -06:00
|
|
|
$this->assertIsString($x509->saveSPKAC($spkac));
|
2014-06-04 00:11:57 -05:00
|
|
|
}
|
|
|
|
|
2022-06-04 10:31:21 -05:00
|
|
|
public function testBadSignatureSPKAC(): void
|
2014-06-04 00:11:57 -05:00
|
|
|
{
|
2014-06-05 09:23:22 -05:00
|
|
|
$test = 'MIICQDCCASgwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQChgo9mWzQm3TSwGgpZnIc54' .
|
|
|
|
'TZ8gYpfAO/AI0etvyWDqnFfdNCUQsqxTdSi6/rtrJdLGBsszRGrRIc/0JqmjM+jCHGYutLeo4xwgr' .
|
|
|
|
'a3HAZrWDypL5IlRWnLmLA4U/qGXCXNSk+9NrJl39X3IDA8o/aOJyr9iMUJMvswcWjVjPom3NhAgmJ' .
|
|
|
|
'ZwW0vUEMw9zszExpiRnGSO5XXntQW2qvfzo+J3NzS3BBbKxEmTsfOLHextcXeFQUaBQHXB/WOtweW' .
|
|
|
|
'Y/Bd4iZ8ETmhal28g1HWVcTFPD+V+KPRFeARlVEW6JmcJucW2WdJlBGKXXXPEfdHrDS3OgD/eDWfM' .
|
|
|
|
'JE4mChZ/icxAgMBAAEWADANBgkqhkiG9w0BAQQFAAOCAQEAUMvIKhlSgEgbC081b/FJwh6mbuVgYN' .
|
|
|
|
'ZV37Ts2WjrHoDFlabu9WXU8xzgaXct3sO51vJM5I36rY4UPyc6w3y9dLaamEwKUoWnpHG8mlXs2JG' .
|
|
|
|
'GEUOvxh5z9yfk/2ZmdCVBlKnU1LDB+ZDyNyNh5B0YULrJKw9e0jV+ymP7srwUSBcdUfZh1KEKGVIN' .
|
|
|
|
'Uv4J3GuL8V63E2unWCHGRPw4EmFVTbWpgMx96XR7p/pMavu6/pVKgYQqWLOmEeOK+dmT/QVon28d5' .
|
|
|
|
'dmeL7aWrpP+3x3L0A9cATksracQX676XogdAEXJ59fcr/S5AGw1TFErbyBbfyeAWvzDZIXeMXpb9h' .
|
|
|
|
'yNtA==';
|
2014-06-04 00:11:57 -05:00
|
|
|
|
2014-12-09 16:53:05 -08:00
|
|
|
$x509 = new X509();
|
2014-06-04 00:11:57 -05:00
|
|
|
|
|
|
|
$spkac = $x509->loadSPKAC($test);
|
|
|
|
|
|
|
|
$spkac['publicKeyAndChallenge']['challenge'] = 'zzzz';
|
|
|
|
|
|
|
|
$x509->loadSPKAC($x509->saveSPKAC($spkac));
|
|
|
|
|
|
|
|
$this->assertFalse(
|
|
|
|
$x509->validateSignature(),
|
|
|
|
'Failed asserting that the signature is invalid'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|