react-native-quick-crypto 1.0.10 → 1.0.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (293) hide show
  1. package/android/CMakeLists.txt +16 -0
  2. package/cpp/argon2/HybridArgon2.cpp +103 -0
  3. package/cpp/argon2/HybridArgon2.hpp +32 -0
  4. package/cpp/certificate/HybridCertificate.cpp +42 -0
  5. package/cpp/certificate/HybridCertificate.hpp +16 -0
  6. package/cpp/cipher/CCMCipher.cpp +4 -1
  7. package/cpp/cipher/ChaCha20Cipher.cpp +3 -1
  8. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +5 -5
  9. package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +1 -2
  10. package/cpp/cipher/HybridCipher.cpp +68 -1
  11. package/cpp/cipher/HybridCipher.hpp +6 -0
  12. package/cpp/cipher/HybridRsaCipher.cpp +0 -13
  13. package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +7 -5
  14. package/cpp/cipher/XChaCha20Poly1305Cipher.hpp +1 -2
  15. package/cpp/cipher/XSalsa20Cipher.cpp +4 -0
  16. package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +7 -5
  17. package/cpp/cipher/XSalsa20Poly1305Cipher.hpp +1 -2
  18. package/cpp/dh/HybridDhKeyPair.cpp +179 -0
  19. package/cpp/dh/HybridDhKeyPair.hpp +37 -0
  20. package/cpp/dsa/HybridDsaKeyPair.cpp +128 -0
  21. package/cpp/dsa/HybridDsaKeyPair.hpp +32 -0
  22. package/cpp/ecdh/HybridECDH.cpp +42 -120
  23. package/cpp/ecdh/HybridECDH.hpp +1 -0
  24. package/cpp/keys/HybridKeyObjectHandle.cpp +150 -128
  25. package/cpp/keys/HybridKeyObjectHandle.hpp +6 -3
  26. package/cpp/keys/KeyObjectData.hpp +2 -0
  27. package/cpp/kmac/HybridKmac.cpp +83 -0
  28. package/cpp/kmac/HybridKmac.hpp +31 -0
  29. package/cpp/mldsa/HybridMlDsaKeyPair.cpp +11 -20
  30. package/cpp/mldsa/HybridMlDsaKeyPair.hpp +4 -2
  31. package/cpp/mlkem/HybridMlKemKeyPair.cpp +319 -0
  32. package/cpp/mlkem/HybridMlKemKeyPair.hpp +48 -0
  33. package/cpp/prime/HybridPrime.cpp +81 -0
  34. package/cpp/prime/HybridPrime.hpp +20 -0
  35. package/cpp/sign/SignUtils.hpp +9 -26
  36. package/cpp/utils/QuickCryptoUtils.cpp +44 -0
  37. package/cpp/utils/QuickCryptoUtils.hpp +39 -0
  38. package/cpp/x509/HybridX509Certificate.cpp +174 -0
  39. package/cpp/x509/HybridX509Certificate.hpp +51 -0
  40. package/lib/commonjs/argon2.js +39 -0
  41. package/lib/commonjs/argon2.js.map +1 -0
  42. package/lib/commonjs/certificate.js +35 -0
  43. package/lib/commonjs/certificate.js.map +1 -0
  44. package/lib/commonjs/cipher.js +23 -2
  45. package/lib/commonjs/cipher.js.map +1 -1
  46. package/lib/commonjs/dhKeyPair.js +109 -0
  47. package/lib/commonjs/dhKeyPair.js.map +1 -0
  48. package/lib/commonjs/dsa.js +92 -0
  49. package/lib/commonjs/dsa.js.map +1 -0
  50. package/lib/commonjs/ec.js +18 -18
  51. package/lib/commonjs/ec.js.map +1 -1
  52. package/lib/commonjs/ecdh.js +37 -0
  53. package/lib/commonjs/ecdh.js.map +1 -1
  54. package/lib/commonjs/ed.js +9 -9
  55. package/lib/commonjs/ed.js.map +1 -1
  56. package/lib/commonjs/hash.js +17 -12
  57. package/lib/commonjs/hash.js.map +1 -1
  58. package/lib/commonjs/hkdf.js.map +1 -1
  59. package/lib/commonjs/index.js +57 -0
  60. package/lib/commonjs/index.js.map +1 -1
  61. package/lib/commonjs/keys/classes.js +11 -9
  62. package/lib/commonjs/keys/classes.js.map +1 -1
  63. package/lib/commonjs/keys/generateKeyPair.js +11 -0
  64. package/lib/commonjs/keys/generateKeyPair.js.map +1 -1
  65. package/lib/commonjs/keys/index.js +24 -0
  66. package/lib/commonjs/keys/index.js.map +1 -1
  67. package/lib/commonjs/keys/signVerify.js +0 -2
  68. package/lib/commonjs/keys/signVerify.js.map +1 -1
  69. package/lib/commonjs/mlkem.js +219 -0
  70. package/lib/commonjs/mlkem.js.map +1 -0
  71. package/lib/commonjs/pbkdf2.js +18 -1
  72. package/lib/commonjs/pbkdf2.js.map +1 -1
  73. package/lib/commonjs/prime.js +84 -0
  74. package/lib/commonjs/prime.js.map +1 -0
  75. package/lib/commonjs/rsa.js +7 -7
  76. package/lib/commonjs/rsa.js.map +1 -1
  77. package/lib/commonjs/specs/argon2.nitro.js +6 -0
  78. package/lib/commonjs/specs/argon2.nitro.js.map +1 -0
  79. package/lib/commonjs/specs/certificate.nitro.js +6 -0
  80. package/lib/commonjs/specs/certificate.nitro.js.map +1 -0
  81. package/lib/commonjs/specs/dhKeyPair.nitro.js +6 -0
  82. package/lib/commonjs/specs/dhKeyPair.nitro.js.map +1 -0
  83. package/lib/commonjs/specs/dsaKeyPair.nitro.js +6 -0
  84. package/lib/commonjs/specs/dsaKeyPair.nitro.js.map +1 -0
  85. package/lib/commonjs/specs/kmac.nitro.js +6 -0
  86. package/lib/commonjs/specs/kmac.nitro.js.map +1 -0
  87. package/lib/commonjs/specs/mlKemKeyPair.nitro.js +6 -0
  88. package/lib/commonjs/specs/mlKemKeyPair.nitro.js.map +1 -0
  89. package/lib/commonjs/specs/prime.nitro.js +6 -0
  90. package/lib/commonjs/specs/prime.nitro.js.map +1 -0
  91. package/lib/commonjs/specs/x509certificate.nitro.js +6 -0
  92. package/lib/commonjs/specs/x509certificate.nitro.js.map +1 -0
  93. package/lib/commonjs/subtle.js +385 -114
  94. package/lib/commonjs/subtle.js.map +1 -1
  95. package/lib/commonjs/utils/conversion.js +3 -3
  96. package/lib/commonjs/utils/conversion.js.map +1 -1
  97. package/lib/commonjs/utils/hashnames.js +31 -0
  98. package/lib/commonjs/utils/hashnames.js.map +1 -1
  99. package/lib/commonjs/utils/types.js.map +1 -1
  100. package/lib/commonjs/x509certificate.js +189 -0
  101. package/lib/commonjs/x509certificate.js.map +1 -0
  102. package/lib/module/argon2.js +34 -0
  103. package/lib/module/argon2.js.map +1 -0
  104. package/lib/module/certificate.js +30 -0
  105. package/lib/module/certificate.js.map +1 -0
  106. package/lib/module/cipher.js +23 -3
  107. package/lib/module/cipher.js.map +1 -1
  108. package/lib/module/dhKeyPair.js +102 -0
  109. package/lib/module/dhKeyPair.js.map +1 -0
  110. package/lib/module/dsa.js +85 -0
  111. package/lib/module/dsa.js.map +1 -0
  112. package/lib/module/ec.js +6 -6
  113. package/lib/module/ec.js.map +1 -1
  114. package/lib/module/ecdh.js +37 -0
  115. package/lib/module/ecdh.js.map +1 -1
  116. package/lib/module/ed.js +1 -1
  117. package/lib/module/ed.js.map +1 -1
  118. package/lib/module/hash.js +17 -12
  119. package/lib/module/hash.js.map +1 -1
  120. package/lib/module/hkdf.js.map +1 -1
  121. package/lib/module/index.js +15 -0
  122. package/lib/module/index.js.map +1 -1
  123. package/lib/module/keys/classes.js +11 -9
  124. package/lib/module/keys/classes.js.map +1 -1
  125. package/lib/module/keys/generateKeyPair.js +11 -0
  126. package/lib/module/keys/generateKeyPair.js.map +1 -1
  127. package/lib/module/keys/index.js +25 -1
  128. package/lib/module/keys/index.js.map +1 -1
  129. package/lib/module/keys/signVerify.js +0 -2
  130. package/lib/module/keys/signVerify.js.map +1 -1
  131. package/lib/module/mlkem.js +211 -0
  132. package/lib/module/mlkem.js.map +1 -0
  133. package/lib/module/pbkdf2.js +18 -1
  134. package/lib/module/pbkdf2.js.map +1 -1
  135. package/lib/module/prime.js +77 -0
  136. package/lib/module/prime.js.map +1 -0
  137. package/lib/module/rsa.js +1 -1
  138. package/lib/module/rsa.js.map +1 -1
  139. package/lib/module/specs/argon2.nitro.js +4 -0
  140. package/lib/module/specs/argon2.nitro.js.map +1 -0
  141. package/lib/module/specs/certificate.nitro.js +4 -0
  142. package/lib/module/specs/certificate.nitro.js.map +1 -0
  143. package/lib/module/specs/dhKeyPair.nitro.js +4 -0
  144. package/lib/module/specs/dhKeyPair.nitro.js.map +1 -0
  145. package/lib/module/specs/dsaKeyPair.nitro.js +4 -0
  146. package/lib/module/specs/dsaKeyPair.nitro.js.map +1 -0
  147. package/lib/module/specs/kmac.nitro.js +4 -0
  148. package/lib/module/specs/kmac.nitro.js.map +1 -0
  149. package/lib/module/specs/mlKemKeyPair.nitro.js +4 -0
  150. package/lib/module/specs/mlKemKeyPair.nitro.js.map +1 -0
  151. package/lib/module/specs/prime.nitro.js +4 -0
  152. package/lib/module/specs/prime.nitro.js.map +1 -0
  153. package/lib/module/specs/x509certificate.nitro.js +4 -0
  154. package/lib/module/specs/x509certificate.nitro.js.map +1 -0
  155. package/lib/module/subtle.js +386 -116
  156. package/lib/module/subtle.js.map +1 -1
  157. package/lib/module/utils/conversion.js +3 -4
  158. package/lib/module/utils/conversion.js.map +1 -1
  159. package/lib/module/utils/hashnames.js +31 -0
  160. package/lib/module/utils/hashnames.js.map +1 -1
  161. package/lib/module/utils/types.js.map +1 -1
  162. package/lib/module/x509certificate.js +184 -0
  163. package/lib/module/x509certificate.js.map +1 -0
  164. package/lib/tsconfig.tsbuildinfo +1 -1
  165. package/lib/typescript/argon2.d.ts +16 -0
  166. package/lib/typescript/argon2.d.ts.map +1 -0
  167. package/lib/typescript/certificate.d.ts +8 -0
  168. package/lib/typescript/certificate.d.ts.map +1 -0
  169. package/lib/typescript/cipher.d.ts +15 -0
  170. package/lib/typescript/cipher.d.ts.map +1 -1
  171. package/lib/typescript/dhKeyPair.d.ts +19 -0
  172. package/lib/typescript/dhKeyPair.d.ts.map +1 -0
  173. package/lib/typescript/dsa.d.ts +19 -0
  174. package/lib/typescript/dsa.d.ts.map +1 -0
  175. package/lib/typescript/ec.d.ts +1 -1
  176. package/lib/typescript/ec.d.ts.map +1 -1
  177. package/lib/typescript/ecdh.d.ts +3 -0
  178. package/lib/typescript/ecdh.d.ts.map +1 -1
  179. package/lib/typescript/ed.d.ts +1 -1
  180. package/lib/typescript/ed.d.ts.map +1 -1
  181. package/lib/typescript/hash.d.ts.map +1 -1
  182. package/lib/typescript/hkdf.d.ts +2 -6
  183. package/lib/typescript/hkdf.d.ts.map +1 -1
  184. package/lib/typescript/index.d.ts +32 -4
  185. package/lib/typescript/index.d.ts.map +1 -1
  186. package/lib/typescript/keys/classes.d.ts +7 -5
  187. package/lib/typescript/keys/classes.d.ts.map +1 -1
  188. package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -1
  189. package/lib/typescript/keys/index.d.ts +2 -2
  190. package/lib/typescript/keys/index.d.ts.map +1 -1
  191. package/lib/typescript/keys/signVerify.d.ts.map +1 -1
  192. package/lib/typescript/mlkem.d.ts +30 -0
  193. package/lib/typescript/mlkem.d.ts.map +1 -0
  194. package/lib/typescript/pbkdf2.d.ts +2 -2
  195. package/lib/typescript/pbkdf2.d.ts.map +1 -1
  196. package/lib/typescript/prime.d.ts +19 -0
  197. package/lib/typescript/prime.d.ts.map +1 -0
  198. package/lib/typescript/rsa.d.ts +1 -1
  199. package/lib/typescript/rsa.d.ts.map +1 -1
  200. package/lib/typescript/specs/argon2.nitro.d.ts +9 -0
  201. package/lib/typescript/specs/argon2.nitro.d.ts.map +1 -0
  202. package/lib/typescript/specs/certificate.nitro.d.ts +10 -0
  203. package/lib/typescript/specs/certificate.nitro.d.ts.map +1 -0
  204. package/lib/typescript/specs/cipher.nitro.d.ts +9 -0
  205. package/lib/typescript/specs/cipher.nitro.d.ts.map +1 -1
  206. package/lib/typescript/specs/dhKeyPair.nitro.d.ts +14 -0
  207. package/lib/typescript/specs/dhKeyPair.nitro.d.ts.map +1 -0
  208. package/lib/typescript/specs/dsaKeyPair.nitro.d.ts +13 -0
  209. package/lib/typescript/specs/dsaKeyPair.nitro.d.ts.map +1 -0
  210. package/lib/typescript/specs/ecdh.nitro.d.ts +1 -0
  211. package/lib/typescript/specs/ecdh.nitro.d.ts.map +1 -1
  212. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +1 -0
  213. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
  214. package/lib/typescript/specs/kmac.nitro.d.ts +10 -0
  215. package/lib/typescript/specs/kmac.nitro.d.ts.map +1 -0
  216. package/lib/typescript/specs/mlKemKeyPair.nitro.d.ts +18 -0
  217. package/lib/typescript/specs/mlKemKeyPair.nitro.d.ts.map +1 -0
  218. package/lib/typescript/specs/prime.nitro.d.ts +11 -0
  219. package/lib/typescript/specs/prime.nitro.d.ts.map +1 -0
  220. package/lib/typescript/specs/x509certificate.nitro.d.ts +34 -0
  221. package/lib/typescript/specs/x509certificate.nitro.d.ts.map +1 -0
  222. package/lib/typescript/subtle.d.ts +12 -0
  223. package/lib/typescript/subtle.d.ts.map +1 -1
  224. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  225. package/lib/typescript/utils/hashnames.d.ts +1 -1
  226. package/lib/typescript/utils/hashnames.d.ts.map +1 -1
  227. package/lib/typescript/utils/types.d.ts +25 -9
  228. package/lib/typescript/utils/types.d.ts.map +1 -1
  229. package/lib/typescript/x509certificate.d.ts +64 -0
  230. package/lib/typescript/x509certificate.d.ts.map +1 -0
  231. package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +8 -0
  232. package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +80 -0
  233. package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +80 -0
  234. package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +12 -0
  235. package/nitrogen/generated/shared/c++/CipherInfo.hpp +104 -0
  236. package/nitrogen/generated/shared/c++/HybridArgon2Spec.cpp +22 -0
  237. package/nitrogen/generated/shared/c++/HybridArgon2Spec.hpp +66 -0
  238. package/nitrogen/generated/shared/c++/HybridCertificateSpec.cpp +23 -0
  239. package/nitrogen/generated/shared/c++/HybridCertificateSpec.hpp +64 -0
  240. package/nitrogen/generated/shared/c++/HybridCipherSpec.cpp +1 -0
  241. package/nitrogen/generated/shared/c++/HybridCipherSpec.hpp +4 -0
  242. package/nitrogen/generated/shared/c++/HybridDhKeyPairSpec.cpp +27 -0
  243. package/nitrogen/generated/shared/c++/HybridDhKeyPairSpec.hpp +69 -0
  244. package/nitrogen/generated/shared/c++/HybridDsaKeyPairSpec.cpp +26 -0
  245. package/nitrogen/generated/shared/c++/HybridDsaKeyPairSpec.hpp +68 -0
  246. package/nitrogen/generated/shared/c++/HybridECDHSpec.cpp +1 -0
  247. package/nitrogen/generated/shared/c++/HybridECDHSpec.hpp +1 -0
  248. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +1 -0
  249. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +1 -0
  250. package/nitrogen/generated/shared/c++/HybridKmacSpec.cpp +23 -0
  251. package/nitrogen/generated/shared/c++/HybridKmacSpec.hpp +66 -0
  252. package/nitrogen/generated/shared/c++/HybridMlKemKeyPairSpec.cpp +31 -0
  253. package/nitrogen/generated/shared/c++/HybridMlKemKeyPairSpec.hpp +74 -0
  254. package/nitrogen/generated/shared/c++/HybridPrimeSpec.cpp +24 -0
  255. package/nitrogen/generated/shared/c++/HybridPrimeSpec.hpp +67 -0
  256. package/nitrogen/generated/shared/c++/HybridX509CertificateHandleSpec.cpp +46 -0
  257. package/nitrogen/generated/shared/c++/HybridX509CertificateHandleSpec.hpp +96 -0
  258. package/package.json +4 -1
  259. package/src/argon2.ts +83 -0
  260. package/src/certificate.ts +41 -0
  261. package/src/cipher.ts +41 -3
  262. package/src/dhKeyPair.ts +156 -0
  263. package/src/dsa.ts +129 -0
  264. package/src/ec.ts +9 -9
  265. package/src/ecdh.ts +59 -0
  266. package/src/ed.ts +2 -2
  267. package/src/hash.ts +34 -11
  268. package/src/hkdf.ts +2 -7
  269. package/src/index.ts +16 -0
  270. package/src/keys/classes.ts +26 -14
  271. package/src/keys/generateKeyPair.ts +14 -0
  272. package/src/keys/index.ts +37 -2
  273. package/src/keys/signVerify.ts +0 -5
  274. package/src/mlkem.ts +350 -0
  275. package/src/pbkdf2.ts +34 -5
  276. package/src/prime.ts +134 -0
  277. package/src/rsa.ts +1 -1
  278. package/src/specs/argon2.nitro.ts +29 -0
  279. package/src/specs/certificate.nitro.ts +8 -0
  280. package/src/specs/cipher.nitro.ts +14 -0
  281. package/src/specs/dhKeyPair.nitro.ts +14 -0
  282. package/src/specs/dsaKeyPair.nitro.ts +13 -0
  283. package/src/specs/ecdh.nitro.ts +1 -0
  284. package/src/specs/keyObjectHandle.nitro.ts +5 -0
  285. package/src/specs/kmac.nitro.ts +12 -0
  286. package/src/specs/mlKemKeyPair.nitro.ts +32 -0
  287. package/src/specs/prime.nitro.ts +18 -0
  288. package/src/specs/x509certificate.nitro.ts +38 -0
  289. package/src/subtle.ts +821 -136
  290. package/src/utils/conversion.ts +10 -4
  291. package/src/utils/hashnames.ts +33 -2
  292. package/src/utils/types.ts +64 -8
  293. package/src/x509certificate.ts +277 -0
@@ -0,0 +1,27 @@
1
+ ///
2
+ /// HybridDhKeyPairSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridDhKeyPairSpec.hpp"
9
+
10
+ namespace margelo::nitro::crypto {
11
+
12
+ void HybridDhKeyPairSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("generateKeyPair", &HybridDhKeyPairSpec::generateKeyPair);
18
+ prototype.registerHybridMethod("generateKeyPairSync", &HybridDhKeyPairSpec::generateKeyPairSync);
19
+ prototype.registerHybridMethod("setPrimeLength", &HybridDhKeyPairSpec::setPrimeLength);
20
+ prototype.registerHybridMethod("setPrime", &HybridDhKeyPairSpec::setPrime);
21
+ prototype.registerHybridMethod("setGenerator", &HybridDhKeyPairSpec::setGenerator);
22
+ prototype.registerHybridMethod("getPublicKey", &HybridDhKeyPairSpec::getPublicKey);
23
+ prototype.registerHybridMethod("getPrivateKey", &HybridDhKeyPairSpec::getPrivateKey);
24
+ });
25
+ }
26
+
27
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,69 @@
1
+ ///
2
+ /// HybridDhKeyPairSpec.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/HybridObject.hpp>)
11
+ #include <NitroModules/HybridObject.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+
16
+
17
+
18
+ #include <NitroModules/Promise.hpp>
19
+ #include <NitroModules/ArrayBuffer.hpp>
20
+
21
+ namespace margelo::nitro::crypto {
22
+
23
+ using namespace margelo::nitro;
24
+
25
+ /**
26
+ * An abstract base class for `DhKeyPair`
27
+ * Inherit this class to create instances of `HybridDhKeyPairSpec` in C++.
28
+ * You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
29
+ * @example
30
+ * ```cpp
31
+ * class HybridDhKeyPair: public HybridDhKeyPairSpec {
32
+ * public:
33
+ * HybridDhKeyPair(...): HybridObject(TAG) { ... }
34
+ * // ...
35
+ * };
36
+ * ```
37
+ */
38
+ class HybridDhKeyPairSpec: public virtual HybridObject {
39
+ public:
40
+ // Constructor
41
+ explicit HybridDhKeyPairSpec(): HybridObject(TAG) { }
42
+
43
+ // Destructor
44
+ ~HybridDhKeyPairSpec() override = default;
45
+
46
+ public:
47
+ // Properties
48
+
49
+
50
+ public:
51
+ // Methods
52
+ virtual std::shared_ptr<Promise<void>> generateKeyPair() = 0;
53
+ virtual void generateKeyPairSync() = 0;
54
+ virtual void setPrimeLength(double primeLength) = 0;
55
+ virtual void setPrime(const std::shared_ptr<ArrayBuffer>& prime) = 0;
56
+ virtual void setGenerator(double generator) = 0;
57
+ virtual std::shared_ptr<ArrayBuffer> getPublicKey() = 0;
58
+ virtual std::shared_ptr<ArrayBuffer> getPrivateKey() = 0;
59
+
60
+ protected:
61
+ // Hybrid Setup
62
+ void loadHybridMethods() override;
63
+
64
+ protected:
65
+ // Tag for logging
66
+ static constexpr auto TAG = "DhKeyPair";
67
+ };
68
+
69
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,26 @@
1
+ ///
2
+ /// HybridDsaKeyPairSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridDsaKeyPairSpec.hpp"
9
+
10
+ namespace margelo::nitro::crypto {
11
+
12
+ void HybridDsaKeyPairSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("generateKeyPair", &HybridDsaKeyPairSpec::generateKeyPair);
18
+ prototype.registerHybridMethod("generateKeyPairSync", &HybridDsaKeyPairSpec::generateKeyPairSync);
19
+ prototype.registerHybridMethod("setModulusLength", &HybridDsaKeyPairSpec::setModulusLength);
20
+ prototype.registerHybridMethod("setDivisorLength", &HybridDsaKeyPairSpec::setDivisorLength);
21
+ prototype.registerHybridMethod("getPublicKey", &HybridDsaKeyPairSpec::getPublicKey);
22
+ prototype.registerHybridMethod("getPrivateKey", &HybridDsaKeyPairSpec::getPrivateKey);
23
+ });
24
+ }
25
+
26
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,68 @@
1
+ ///
2
+ /// HybridDsaKeyPairSpec.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/HybridObject.hpp>)
11
+ #include <NitroModules/HybridObject.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+
16
+
17
+
18
+ #include <NitroModules/Promise.hpp>
19
+ #include <NitroModules/ArrayBuffer.hpp>
20
+
21
+ namespace margelo::nitro::crypto {
22
+
23
+ using namespace margelo::nitro;
24
+
25
+ /**
26
+ * An abstract base class for `DsaKeyPair`
27
+ * Inherit this class to create instances of `HybridDsaKeyPairSpec` in C++.
28
+ * You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
29
+ * @example
30
+ * ```cpp
31
+ * class HybridDsaKeyPair: public HybridDsaKeyPairSpec {
32
+ * public:
33
+ * HybridDsaKeyPair(...): HybridObject(TAG) { ... }
34
+ * // ...
35
+ * };
36
+ * ```
37
+ */
38
+ class HybridDsaKeyPairSpec: public virtual HybridObject {
39
+ public:
40
+ // Constructor
41
+ explicit HybridDsaKeyPairSpec(): HybridObject(TAG) { }
42
+
43
+ // Destructor
44
+ ~HybridDsaKeyPairSpec() override = default;
45
+
46
+ public:
47
+ // Properties
48
+
49
+
50
+ public:
51
+ // Methods
52
+ virtual std::shared_ptr<Promise<void>> generateKeyPair() = 0;
53
+ virtual void generateKeyPairSync() = 0;
54
+ virtual void setModulusLength(double modulusLength) = 0;
55
+ virtual void setDivisorLength(double divisorLength) = 0;
56
+ virtual std::shared_ptr<ArrayBuffer> getPublicKey() = 0;
57
+ virtual std::shared_ptr<ArrayBuffer> getPrivateKey() = 0;
58
+
59
+ protected:
60
+ // Hybrid Setup
61
+ void loadHybridMethods() override;
62
+
63
+ protected:
64
+ // Tag for logging
65
+ static constexpr auto TAG = "DsaKeyPair";
66
+ };
67
+
68
+ } // namespace margelo::nitro::crypto
@@ -21,6 +21,7 @@ namespace margelo::nitro::crypto {
21
21
  prototype.registerHybridMethod("setPrivateKey", &HybridECDHSpec::setPrivateKey);
22
22
  prototype.registerHybridMethod("getPublicKey", &HybridECDHSpec::getPublicKey);
23
23
  prototype.registerHybridMethod("setPublicKey", &HybridECDHSpec::setPublicKey);
24
+ prototype.registerHybridMethod("convertKey", &HybridECDHSpec::convertKey);
24
25
  });
25
26
  }
26
27
 
@@ -56,6 +56,7 @@ namespace margelo::nitro::crypto {
56
56
  virtual void setPrivateKey(const std::shared_ptr<ArrayBuffer>& privateKey) = 0;
57
57
  virtual std::shared_ptr<ArrayBuffer> getPublicKey() = 0;
58
58
  virtual void setPublicKey(const std::shared_ptr<ArrayBuffer>& publicKey) = 0;
59
+ virtual std::shared_ptr<ArrayBuffer> convertKey(const std::shared_ptr<ArrayBuffer>& key, const std::string& curve, double format) = 0;
59
60
 
60
61
  protected:
61
62
  // Hybrid Setup
@@ -19,6 +19,7 @@ namespace margelo::nitro::crypto {
19
19
  prototype.registerHybridMethod("getAsymmetricKeyType", &HybridKeyObjectHandleSpec::getAsymmetricKeyType);
20
20
  prototype.registerHybridMethod("init", &HybridKeyObjectHandleSpec::init);
21
21
  prototype.registerHybridMethod("initECRaw", &HybridKeyObjectHandleSpec::initECRaw);
22
+ prototype.registerHybridMethod("initPqcRaw", &HybridKeyObjectHandleSpec::initPqcRaw);
22
23
  prototype.registerHybridMethod("initJwk", &HybridKeyObjectHandleSpec::initJwk);
23
24
  prototype.registerHybridMethod("keyDetail", &HybridKeyObjectHandleSpec::keyDetail);
24
25
  prototype.registerHybridMethod("keyEquals", &HybridKeyObjectHandleSpec::keyEquals);
@@ -80,6 +80,7 @@ namespace margelo::nitro::crypto {
80
80
  virtual AsymmetricKeyType getAsymmetricKeyType() = 0;
81
81
  virtual bool init(KeyType keyType, const std::variant<std::shared_ptr<ArrayBuffer>, std::string>& key, std::optional<KFormatType> format, std::optional<KeyEncoding> type, const std::optional<std::shared_ptr<ArrayBuffer>>& passphrase) = 0;
82
82
  virtual bool initECRaw(const std::string& namedCurve, const std::shared_ptr<ArrayBuffer>& keyData) = 0;
83
+ virtual bool initPqcRaw(const std::string& algorithmName, const std::shared_ptr<ArrayBuffer>& keyData, bool isPublic) = 0;
83
84
  virtual std::optional<KeyType> initJwk(const JWK& keyData, std::optional<NamedCurve> namedCurve) = 0;
84
85
  virtual KeyDetail keyDetail() = 0;
85
86
  virtual bool keyEquals(const std::shared_ptr<HybridKeyObjectHandleSpec>& other) = 0;
@@ -0,0 +1,23 @@
1
+ ///
2
+ /// HybridKmacSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridKmacSpec.hpp"
9
+
10
+ namespace margelo::nitro::crypto {
11
+
12
+ void HybridKmacSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("createKmac", &HybridKmacSpec::createKmac);
18
+ prototype.registerHybridMethod("update", &HybridKmacSpec::update);
19
+ prototype.registerHybridMethod("digest", &HybridKmacSpec::digest);
20
+ });
21
+ }
22
+
23
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,66 @@
1
+ ///
2
+ /// HybridKmacSpec.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/HybridObject.hpp>)
11
+ #include <NitroModules/HybridObject.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+
16
+
17
+
18
+ #include <string>
19
+ #include <NitroModules/ArrayBuffer.hpp>
20
+ #include <optional>
21
+
22
+ namespace margelo::nitro::crypto {
23
+
24
+ using namespace margelo::nitro;
25
+
26
+ /**
27
+ * An abstract base class for `Kmac`
28
+ * Inherit this class to create instances of `HybridKmacSpec` in C++.
29
+ * You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
30
+ * @example
31
+ * ```cpp
32
+ * class HybridKmac: public HybridKmacSpec {
33
+ * public:
34
+ * HybridKmac(...): HybridObject(TAG) { ... }
35
+ * // ...
36
+ * };
37
+ * ```
38
+ */
39
+ class HybridKmacSpec: public virtual HybridObject {
40
+ public:
41
+ // Constructor
42
+ explicit HybridKmacSpec(): HybridObject(TAG) { }
43
+
44
+ // Destructor
45
+ ~HybridKmacSpec() override = default;
46
+
47
+ public:
48
+ // Properties
49
+
50
+
51
+ public:
52
+ // Methods
53
+ virtual void createKmac(const std::string& algorithm, const std::shared_ptr<ArrayBuffer>& key, double outputLength, const std::optional<std::shared_ptr<ArrayBuffer>>& customization) = 0;
54
+ virtual void update(const std::shared_ptr<ArrayBuffer>& data) = 0;
55
+ virtual std::shared_ptr<ArrayBuffer> digest() = 0;
56
+
57
+ protected:
58
+ // Hybrid Setup
59
+ void loadHybridMethods() override;
60
+
61
+ protected:
62
+ // Tag for logging
63
+ static constexpr auto TAG = "Kmac";
64
+ };
65
+
66
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,31 @@
1
+ ///
2
+ /// HybridMlKemKeyPairSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridMlKemKeyPairSpec.hpp"
9
+
10
+ namespace margelo::nitro::crypto {
11
+
12
+ void HybridMlKemKeyPairSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("setVariant", &HybridMlKemKeyPairSpec::setVariant);
18
+ prototype.registerHybridMethod("generateKeyPair", &HybridMlKemKeyPairSpec::generateKeyPair);
19
+ prototype.registerHybridMethod("generateKeyPairSync", &HybridMlKemKeyPairSpec::generateKeyPairSync);
20
+ prototype.registerHybridMethod("getPublicKey", &HybridMlKemKeyPairSpec::getPublicKey);
21
+ prototype.registerHybridMethod("getPrivateKey", &HybridMlKemKeyPairSpec::getPrivateKey);
22
+ prototype.registerHybridMethod("setPublicKey", &HybridMlKemKeyPairSpec::setPublicKey);
23
+ prototype.registerHybridMethod("setPrivateKey", &HybridMlKemKeyPairSpec::setPrivateKey);
24
+ prototype.registerHybridMethod("encapsulate", &HybridMlKemKeyPairSpec::encapsulate);
25
+ prototype.registerHybridMethod("encapsulateSync", &HybridMlKemKeyPairSpec::encapsulateSync);
26
+ prototype.registerHybridMethod("decapsulate", &HybridMlKemKeyPairSpec::decapsulate);
27
+ prototype.registerHybridMethod("decapsulateSync", &HybridMlKemKeyPairSpec::decapsulateSync);
28
+ });
29
+ }
30
+
31
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,74 @@
1
+ ///
2
+ /// HybridMlKemKeyPairSpec.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/HybridObject.hpp>)
11
+ #include <NitroModules/HybridObject.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+
16
+
17
+
18
+ #include <string>
19
+ #include <NitroModules/Promise.hpp>
20
+ #include <NitroModules/ArrayBuffer.hpp>
21
+
22
+ namespace margelo::nitro::crypto {
23
+
24
+ using namespace margelo::nitro;
25
+
26
+ /**
27
+ * An abstract base class for `MlKemKeyPair`
28
+ * Inherit this class to create instances of `HybridMlKemKeyPairSpec` in C++.
29
+ * You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
30
+ * @example
31
+ * ```cpp
32
+ * class HybridMlKemKeyPair: public HybridMlKemKeyPairSpec {
33
+ * public:
34
+ * HybridMlKemKeyPair(...): HybridObject(TAG) { ... }
35
+ * // ...
36
+ * };
37
+ * ```
38
+ */
39
+ class HybridMlKemKeyPairSpec: public virtual HybridObject {
40
+ public:
41
+ // Constructor
42
+ explicit HybridMlKemKeyPairSpec(): HybridObject(TAG) { }
43
+
44
+ // Destructor
45
+ ~HybridMlKemKeyPairSpec() override = default;
46
+
47
+ public:
48
+ // Properties
49
+
50
+
51
+ public:
52
+ // Methods
53
+ virtual void setVariant(const std::string& variant) = 0;
54
+ virtual std::shared_ptr<Promise<void>> generateKeyPair(double publicFormat, double publicType, double privateFormat, double privateType) = 0;
55
+ virtual void generateKeyPairSync(double publicFormat, double publicType, double privateFormat, double privateType) = 0;
56
+ virtual std::shared_ptr<ArrayBuffer> getPublicKey() = 0;
57
+ virtual std::shared_ptr<ArrayBuffer> getPrivateKey() = 0;
58
+ virtual void setPublicKey(const std::shared_ptr<ArrayBuffer>& keyData, double format, double type) = 0;
59
+ virtual void setPrivateKey(const std::shared_ptr<ArrayBuffer>& keyData, double format, double type) = 0;
60
+ virtual std::shared_ptr<Promise<std::shared_ptr<ArrayBuffer>>> encapsulate() = 0;
61
+ virtual std::shared_ptr<ArrayBuffer> encapsulateSync() = 0;
62
+ virtual std::shared_ptr<Promise<std::shared_ptr<ArrayBuffer>>> decapsulate(const std::shared_ptr<ArrayBuffer>& ciphertext) = 0;
63
+ virtual std::shared_ptr<ArrayBuffer> decapsulateSync(const std::shared_ptr<ArrayBuffer>& ciphertext) = 0;
64
+
65
+ protected:
66
+ // Hybrid Setup
67
+ void loadHybridMethods() override;
68
+
69
+ protected:
70
+ // Tag for logging
71
+ static constexpr auto TAG = "MlKemKeyPair";
72
+ };
73
+
74
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,24 @@
1
+ ///
2
+ /// HybridPrimeSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridPrimeSpec.hpp"
9
+
10
+ namespace margelo::nitro::crypto {
11
+
12
+ void HybridPrimeSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("generatePrime", &HybridPrimeSpec::generatePrime);
18
+ prototype.registerHybridMethod("generatePrimeSync", &HybridPrimeSpec::generatePrimeSync);
19
+ prototype.registerHybridMethod("checkPrime", &HybridPrimeSpec::checkPrime);
20
+ prototype.registerHybridMethod("checkPrimeSync", &HybridPrimeSpec::checkPrimeSync);
21
+ });
22
+ }
23
+
24
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,67 @@
1
+ ///
2
+ /// HybridPrimeSpec.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/HybridObject.hpp>)
11
+ #include <NitroModules/HybridObject.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+
16
+
17
+
18
+ #include <NitroModules/ArrayBuffer.hpp>
19
+ #include <NitroModules/Promise.hpp>
20
+ #include <optional>
21
+
22
+ namespace margelo::nitro::crypto {
23
+
24
+ using namespace margelo::nitro;
25
+
26
+ /**
27
+ * An abstract base class for `Prime`
28
+ * Inherit this class to create instances of `HybridPrimeSpec` in C++.
29
+ * You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
30
+ * @example
31
+ * ```cpp
32
+ * class HybridPrime: public HybridPrimeSpec {
33
+ * public:
34
+ * HybridPrime(...): HybridObject(TAG) { ... }
35
+ * // ...
36
+ * };
37
+ * ```
38
+ */
39
+ class HybridPrimeSpec: public virtual HybridObject {
40
+ public:
41
+ // Constructor
42
+ explicit HybridPrimeSpec(): HybridObject(TAG) { }
43
+
44
+ // Destructor
45
+ ~HybridPrimeSpec() override = default;
46
+
47
+ public:
48
+ // Properties
49
+
50
+
51
+ public:
52
+ // Methods
53
+ virtual std::shared_ptr<Promise<std::shared_ptr<ArrayBuffer>>> generatePrime(double size, bool safe, const std::optional<std::shared_ptr<ArrayBuffer>>& add, const std::optional<std::shared_ptr<ArrayBuffer>>& rem) = 0;
54
+ virtual std::shared_ptr<ArrayBuffer> generatePrimeSync(double size, bool safe, const std::optional<std::shared_ptr<ArrayBuffer>>& add, const std::optional<std::shared_ptr<ArrayBuffer>>& rem) = 0;
55
+ virtual std::shared_ptr<Promise<bool>> checkPrime(const std::shared_ptr<ArrayBuffer>& candidate, double checks) = 0;
56
+ virtual bool checkPrimeSync(const std::shared_ptr<ArrayBuffer>& candidate, double checks) = 0;
57
+
58
+ protected:
59
+ // Hybrid Setup
60
+ void loadHybridMethods() override;
61
+
62
+ protected:
63
+ // Tag for logging
64
+ static constexpr auto TAG = "Prime";
65
+ };
66
+
67
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,46 @@
1
+ ///
2
+ /// HybridX509CertificateHandleSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridX509CertificateHandleSpec.hpp"
9
+
10
+ namespace margelo::nitro::crypto {
11
+
12
+ void HybridX509CertificateHandleSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("init", &HybridX509CertificateHandleSpec::init);
18
+ prototype.registerHybridMethod("subject", &HybridX509CertificateHandleSpec::subject);
19
+ prototype.registerHybridMethod("subjectAltName", &HybridX509CertificateHandleSpec::subjectAltName);
20
+ prototype.registerHybridMethod("issuer", &HybridX509CertificateHandleSpec::issuer);
21
+ prototype.registerHybridMethod("infoAccess", &HybridX509CertificateHandleSpec::infoAccess);
22
+ prototype.registerHybridMethod("validFrom", &HybridX509CertificateHandleSpec::validFrom);
23
+ prototype.registerHybridMethod("validTo", &HybridX509CertificateHandleSpec::validTo);
24
+ prototype.registerHybridMethod("validFromDate", &HybridX509CertificateHandleSpec::validFromDate);
25
+ prototype.registerHybridMethod("validToDate", &HybridX509CertificateHandleSpec::validToDate);
26
+ prototype.registerHybridMethod("signatureAlgorithm", &HybridX509CertificateHandleSpec::signatureAlgorithm);
27
+ prototype.registerHybridMethod("signatureAlgorithmOid", &HybridX509CertificateHandleSpec::signatureAlgorithmOid);
28
+ prototype.registerHybridMethod("serialNumber", &HybridX509CertificateHandleSpec::serialNumber);
29
+ prototype.registerHybridMethod("fingerprint", &HybridX509CertificateHandleSpec::fingerprint);
30
+ prototype.registerHybridMethod("fingerprint256", &HybridX509CertificateHandleSpec::fingerprint256);
31
+ prototype.registerHybridMethod("fingerprint512", &HybridX509CertificateHandleSpec::fingerprint512);
32
+ prototype.registerHybridMethod("raw", &HybridX509CertificateHandleSpec::raw);
33
+ prototype.registerHybridMethod("pem", &HybridX509CertificateHandleSpec::pem);
34
+ prototype.registerHybridMethod("publicKey", &HybridX509CertificateHandleSpec::publicKey);
35
+ prototype.registerHybridMethod("keyUsage", &HybridX509CertificateHandleSpec::keyUsage);
36
+ prototype.registerHybridMethod("ca", &HybridX509CertificateHandleSpec::ca);
37
+ prototype.registerHybridMethod("checkIssued", &HybridX509CertificateHandleSpec::checkIssued);
38
+ prototype.registerHybridMethod("checkPrivateKey", &HybridX509CertificateHandleSpec::checkPrivateKey);
39
+ prototype.registerHybridMethod("verify", &HybridX509CertificateHandleSpec::verify);
40
+ prototype.registerHybridMethod("checkHost", &HybridX509CertificateHandleSpec::checkHost);
41
+ prototype.registerHybridMethod("checkEmail", &HybridX509CertificateHandleSpec::checkEmail);
42
+ prototype.registerHybridMethod("checkIP", &HybridX509CertificateHandleSpec::checkIP);
43
+ });
44
+ }
45
+
46
+ } // namespace margelo::nitro::crypto
@@ -0,0 +1,96 @@
1
+ ///
2
+ /// HybridX509CertificateHandleSpec.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/HybridObject.hpp>)
11
+ #include <NitroModules/HybridObject.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+
16
+ // Forward declaration of `HybridKeyObjectHandleSpec` to properly resolve imports.
17
+ namespace margelo::nitro::crypto { class HybridKeyObjectHandleSpec; }
18
+ // Forward declaration of `HybridX509CertificateHandleSpec` to properly resolve imports.
19
+ namespace margelo::nitro::crypto { class HybridX509CertificateHandleSpec; }
20
+
21
+ #include <NitroModules/ArrayBuffer.hpp>
22
+ #include <string>
23
+ #include <memory>
24
+ #include "HybridKeyObjectHandleSpec.hpp"
25
+ #include <vector>
26
+ #include "HybridX509CertificateHandleSpec.hpp"
27
+ #include <optional>
28
+
29
+ namespace margelo::nitro::crypto {
30
+
31
+ using namespace margelo::nitro;
32
+
33
+ /**
34
+ * An abstract base class for `X509CertificateHandle`
35
+ * Inherit this class to create instances of `HybridX509CertificateHandleSpec` in C++.
36
+ * You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
37
+ * @example
38
+ * ```cpp
39
+ * class HybridX509CertificateHandle: public HybridX509CertificateHandleSpec {
40
+ * public:
41
+ * HybridX509CertificateHandle(...): HybridObject(TAG) { ... }
42
+ * // ...
43
+ * };
44
+ * ```
45
+ */
46
+ class HybridX509CertificateHandleSpec: public virtual HybridObject {
47
+ public:
48
+ // Constructor
49
+ explicit HybridX509CertificateHandleSpec(): HybridObject(TAG) { }
50
+
51
+ // Destructor
52
+ ~HybridX509CertificateHandleSpec() override = default;
53
+
54
+ public:
55
+ // Properties
56
+
57
+
58
+ public:
59
+ // Methods
60
+ virtual void init(const std::shared_ptr<ArrayBuffer>& buffer) = 0;
61
+ virtual std::string subject() = 0;
62
+ virtual std::string subjectAltName() = 0;
63
+ virtual std::string issuer() = 0;
64
+ virtual std::string infoAccess() = 0;
65
+ virtual std::string validFrom() = 0;
66
+ virtual std::string validTo() = 0;
67
+ virtual double validFromDate() = 0;
68
+ virtual double validToDate() = 0;
69
+ virtual std::string signatureAlgorithm() = 0;
70
+ virtual std::string signatureAlgorithmOid() = 0;
71
+ virtual std::string serialNumber() = 0;
72
+ virtual std::string fingerprint() = 0;
73
+ virtual std::string fingerprint256() = 0;
74
+ virtual std::string fingerprint512() = 0;
75
+ virtual std::shared_ptr<ArrayBuffer> raw() = 0;
76
+ virtual std::string pem() = 0;
77
+ virtual std::shared_ptr<HybridKeyObjectHandleSpec> publicKey() = 0;
78
+ virtual std::vector<std::string> keyUsage() = 0;
79
+ virtual bool ca() = 0;
80
+ virtual bool checkIssued(const std::shared_ptr<HybridX509CertificateHandleSpec>& other) = 0;
81
+ virtual bool checkPrivateKey(const std::shared_ptr<HybridKeyObjectHandleSpec>& key) = 0;
82
+ virtual bool verify(const std::shared_ptr<HybridKeyObjectHandleSpec>& key) = 0;
83
+ virtual std::optional<std::string> checkHost(const std::string& name, double flags) = 0;
84
+ virtual std::optional<std::string> checkEmail(const std::string& email, double flags) = 0;
85
+ virtual std::optional<std::string> checkIP(const std::string& ip) = 0;
86
+
87
+ protected:
88
+ // Hybrid Setup
89
+ void loadHybridMethods() override;
90
+
91
+ protected:
92
+ // Tag for logging
93
+ static constexpr auto TAG = "X509CertificateHandle";
94
+ };
95
+
96
+ } // namespace margelo::nitro::crypto