KeyStoreRsaTest.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. namespace Tests\Unit\HttpSignatures;
  3. use App\Util\HttpSignatures\KeyStore;
  4. use App\Util\HttpSignatures\Key;
  5. use Tests\Unit\HttpSignatures\TestKeys;
  6. class KeyStoreRsaTest extends \PHPUnit\Framework\TestCase
  7. {
  8. public function setUp()
  9. {
  10. openssl_pkey_export(
  11. openssl_pkey_get_private(TestKeys::rsaPrivateKey),
  12. $this->testRsaPrivateKeyPEM
  13. );
  14. $this->testRsaPublicKeyPEM = openssl_pkey_get_details(
  15. openssl_get_publickey(TestKeys::rsaPublicKey)
  16. )['key'];
  17. $this->testRsaCert = TestKeys::rsaCert;
  18. }
  19. public function testParseX509inObject()
  20. {
  21. $keySpec = ['rsaCert' => [TestKeys::rsaCert]];
  22. $this->assertTrue(Key::hasX509Certificate($keySpec));
  23. $ks = new KeyStore($keySpec);
  24. $publicKey = $ks->fetch('rsaCert')->getVerifyingKey();
  25. $this->assertEquals('asymmetric', $ks->fetch('rsaCert')->getType());
  26. $this->assertEquals(TestKeys::rsaPublicKey, $publicKey);
  27. }
  28. public function testParseRsaPublicKeyinObject()
  29. {
  30. $keySpec = ['rsaPubKey' => [TestKeys::rsaPublicKey]];
  31. $this->assertTrue(Key::hasPublicKey($keySpec));
  32. $ks = new KeyStore($keySpec);
  33. $publicKey = $ks->fetch('rsaPubKey')->getVerifyingKey();
  34. $this->assertEquals('asymmetric', $ks->fetch('rsaPubKey')->getType());
  35. $this->assertEquals(TestKeys::rsaPublicKey, $publicKey);
  36. }
  37. public function testParsePrivateKeyinObject()
  38. {
  39. $keySpec = ['rsaPrivKey' => [TestKeys::rsaPrivateKey]];
  40. $this->assertTrue(Key::hasPrivateKey($keySpec));
  41. $ks = new KeyStore($keySpec);
  42. $publicKey = $ks->fetch('rsaPrivKey')->getSigningKey();
  43. $this->assertEquals('asymmetric', $ks->fetch('rsaPrivKey')->getType());
  44. $this->assertEquals($this->testRsaPrivateKeyPEM, $publicKey);
  45. }
  46. public function testFetchRsaSigningKeySuccess()
  47. {
  48. $ks = new KeyStore(['rsakey' => TestKeys::rsaPrivateKey]);
  49. $key = $ks->fetch('rsakey');
  50. openssl_pkey_export($key->getSigningKey(), $keyStoreSigningKey);
  51. $this->assertEquals(['rsakey', $this->testRsaPrivateKeyPEM, null, 'asymmetric'], [
  52. $key->getId(), $keyStoreSigningKey, $key->getVerifyingKey(), $key->getType(), ]);
  53. }
  54. public function testFetchRsaVerifyingKeyFromCertificateSuccess()
  55. {
  56. $ks = new KeyStore(['rsacert' => TestKeys::rsaCert]);
  57. $key = $ks->fetch('rsacert');
  58. $keyStoreVerifyingKey = $key->getVerifyingKey();
  59. $this->assertEquals(['rsacert', null, $this->testRsaPublicKeyPEM, 'asymmetric'], [
  60. $key->getId(), $key->getSigningKey(), $keyStoreVerifyingKey, $key->getType(), ]);
  61. }
  62. public function testFetchRsaVerifyingKeyFromPublicKeySuccess()
  63. {
  64. $ks = new KeyStore(['rsapubkey' => TestKeys::rsaPublicKey]);
  65. $key = $ks->fetch('rsapubkey');
  66. $keyStoreVerifyingKey = $key->getVerifyingKey();
  67. $this->assertEquals(['rsapubkey', null, $this->testRsaPublicKeyPEM, 'asymmetric'], [
  68. $key->getId(), $key->getSigningKey(), $keyStoreVerifyingKey, $key->getType(), ]);
  69. }
  70. public function testFetchRsaBothSuccess()
  71. {
  72. $ks = new KeyStore(['rsaboth' => [TestKeys::rsaCert, TestKeys::rsaPrivateKey]]);
  73. $key = $ks->fetch('rsaboth');
  74. $keyStoreVerifyingKey = $key->getVerifyingKey();
  75. $keyStoreSigningKey = $key->getSigningKey();
  76. $this->assertEquals(['rsaboth', $this->testRsaPrivateKeyPEM, $this->testRsaPublicKeyPEM, 'asymmetric'], [
  77. $key->getId(), $keyStoreSigningKey, $keyStoreVerifyingKey, $key->getType(), ]);
  78. }
  79. public function testFetchRsaBothSuccessSwitched()
  80. {
  81. $ks = new KeyStore(['rsabothswitch' => [TestKeys::rsaPrivateKey, TestKeys::rsaCert]]);
  82. $key = $ks->fetch('rsabothswitch');
  83. $keyStoreVerifyingKey = $key->getVerifyingKey();
  84. $keyStoreSigningKey = $key->getSigningKey();
  85. $this->assertEquals(['rsabothswitch', $this->testRsaPrivateKeyPEM, $this->testRsaPublicKeyPEM, 'asymmetric'], [
  86. $key->getId(), $keyStoreSigningKey, $keyStoreVerifyingKey, $key->getType(), ]);
  87. }
  88. /**
  89. * @expectedException \App\Util\HttpSignatures\KeyException
  90. */
  91. public function testRsaMismatch()
  92. {
  93. $privateKey = openssl_pkey_new([
  94. 'private_key_type' => 'OPENSSL_KEYTYPE_RSA',
  95. 'private_key_bits' => 1024, ]
  96. );
  97. $ks = new Key('badpki', [TestKeys::rsaCert, $privateKey]);
  98. }
  99. }