@super-protocol/swarm-contracts-sdk 0.0.1-beta.1

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 (629) hide show
  1. package/LICENSE +66 -0
  2. package/README.md +52 -0
  3. package/dist/cjs/analytics/Analytics.d.ts +17 -0
  4. package/dist/cjs/analytics/Analytics.js +84 -0
  5. package/dist/cjs/analytics/AnalyticsError.d.ts +7 -0
  6. package/dist/cjs/analytics/AnalyticsError.js +12 -0
  7. package/dist/cjs/analytics/eventProviders/BrowserEventProvider.d.ts +19 -0
  8. package/dist/cjs/analytics/eventProviders/BrowserEventProvider.js +38 -0
  9. package/dist/cjs/analytics/eventProviders/EventProvider.d.ts +24 -0
  10. package/dist/cjs/analytics/eventProviders/EventProvider.js +25 -0
  11. package/dist/cjs/analytics/eventProviders/NodeEventProvider.d.ts +22 -0
  12. package/dist/cjs/analytics/eventProviders/NodeEventProvider.js +56 -0
  13. package/dist/cjs/analytics/transports/AxiosTransport.d.ts +4 -0
  14. package/dist/cjs/analytics/transports/AxiosTransport.js +60 -0
  15. package/dist/cjs/analytics/transports/FetchTransport.d.ts +4 -0
  16. package/dist/cjs/analytics/transports/FetchTransport.js +31 -0
  17. package/dist/cjs/analytics/types.d.ts +26 -0
  18. package/dist/cjs/analytics/types.js +3 -0
  19. package/dist/cjs/certificates/binary-splitter.d.ts +27 -0
  20. package/dist/cjs/certificates/binary-splitter.js +279 -0
  21. package/dist/cjs/certificates/crl.d.ts +6 -0
  22. package/dist/cjs/certificates/crl.js +66 -0
  23. package/dist/cjs/certificates/generator.d.ts +38 -0
  24. package/dist/cjs/certificates/generator.js +262 -0
  25. package/dist/cjs/certificates/helper.d.ts +29 -0
  26. package/dist/cjs/certificates/helper.js +216 -0
  27. package/dist/cjs/certificates/index.d.ts +5 -0
  28. package/dist/cjs/certificates/index.js +22 -0
  29. package/dist/cjs/certificates/ocsp.d.ts +14 -0
  30. package/dist/cjs/certificates/ocsp.js +320 -0
  31. package/dist/cjs/certificates/serializer.d.ts +13 -0
  32. package/dist/cjs/certificates/serializer.js +142 -0
  33. package/dist/cjs/certificates/setup-crypto.d.ts +3 -0
  34. package/dist/cjs/certificates/setup-crypto.js +48 -0
  35. package/dist/cjs/certificates/types.d.ts +122 -0
  36. package/dist/cjs/certificates/types.js +10 -0
  37. package/dist/cjs/config.d.ts +3 -0
  38. package/dist/cjs/config.js +7 -0
  39. package/dist/cjs/connectors/BaseConnector.d.ts +52 -0
  40. package/dist/cjs/connectors/BaseConnector.js +61 -0
  41. package/dist/cjs/connectors/BlockchainConnector.d.ts +78 -0
  42. package/dist/cjs/connectors/BlockchainConnector.js +325 -0
  43. package/dist/cjs/connectors/BlockchainEventsListener.d.ts +33 -0
  44. package/dist/cjs/connectors/BlockchainEventsListener.js +283 -0
  45. package/dist/cjs/connectors/index.d.ts +2 -0
  46. package/dist/cjs/connectors/index.js +11 -0
  47. package/dist/cjs/constants.d.ts +48 -0
  48. package/dist/cjs/constants.js +683 -0
  49. package/dist/cjs/contracts/SuperProtocolToken.d.ts +300 -0
  50. package/dist/cjs/contracts/SuperProtocolToken.js +3 -0
  51. package/dist/cjs/contracts/SuperProtocolToken__factory.d.ts +393 -0
  52. package/dist/cjs/contracts/SuperProtocolToken__factory.js +521 -0
  53. package/dist/cjs/contracts/typechain-types/common.d.ts +50 -0
  54. package/dist/cjs/contracts/typechain-types/common.js +3 -0
  55. package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.d.ts +3340 -0
  56. package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.js +4335 -0
  57. package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
  58. package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +10 -0
  59. package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.d.ts +1 -0
  60. package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.js +32 -0
  61. package/dist/cjs/contracts/typechain-types/factories/index.d.ts +1 -0
  62. package/dist/cjs/contracts/typechain-types/factories/index.js +32 -0
  63. package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.d.ts +2299 -0
  64. package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.js +3 -0
  65. package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
  66. package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +3 -0
  67. package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/index.d.ts +2 -0
  68. package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/index.js +3 -0
  69. package/dist/cjs/contracts/typechain-types/index.d.ts +5 -0
  70. package/dist/cjs/contracts/typechain-types/index.js +34 -0
  71. package/dist/cjs/crypto/Crypto.d.ts +70 -0
  72. package/dist/cjs/crypto/Crypto.js +137 -0
  73. package/dist/cjs/crypto/index.d.ts +4 -0
  74. package/dist/cjs/crypto/index.js +37 -0
  75. package/dist/cjs/crypto/nodejs/AES.d.ts +25 -0
  76. package/dist/cjs/crypto/nodejs/AES.js +105 -0
  77. package/dist/cjs/crypto/nodejs/ARIA.d.ts +23 -0
  78. package/dist/cjs/crypto/nodejs/ARIA.js +77 -0
  79. package/dist/cjs/crypto/nodejs/ECIES.d.ts +10 -0
  80. package/dist/cjs/crypto/nodejs/ECIES.js +107 -0
  81. package/dist/cjs/crypto/nodejs/NativeCrypto.d.ts +46 -0
  82. package/dist/cjs/crypto/nodejs/NativeCrypto.js +154 -0
  83. package/dist/cjs/crypto/nodejs/RSA-Hybrid.d.ts +15 -0
  84. package/dist/cjs/crypto/nodejs/RSA-Hybrid.js +94 -0
  85. package/dist/cjs/crypto/types.d.ts +10 -0
  86. package/dist/cjs/crypto/types.js +3 -0
  87. package/dist/cjs/crypto/utils.d.ts +15 -0
  88. package/dist/cjs/crypto/utils.js +94 -0
  89. package/dist/cjs/crypto/utils.spec.d.ts +1 -0
  90. package/dist/cjs/crypto/utils.spec.js +221 -0
  91. package/dist/cjs/errors/base.error.d.ts +3 -0
  92. package/dist/cjs/errors/base.error.js +19 -0
  93. package/dist/cjs/errors/index.d.ts +3 -0
  94. package/dist/cjs/errors/index.js +10 -0
  95. package/dist/cjs/errors/insufficient-funds.error.d.ts +19 -0
  96. package/dist/cjs/errors/insufficient-funds.error.js +57 -0
  97. package/dist/cjs/errors/not-found.error.d.ts +3 -0
  98. package/dist/cjs/errors/not-found.error.js +8 -0
  99. package/dist/cjs/errors/utils.d.ts +2 -0
  100. package/dist/cjs/errors/utils.js +30 -0
  101. package/dist/cjs/index.d.ts +58 -0
  102. package/dist/cjs/index.js +119 -0
  103. package/dist/cjs/logger.d.ts +7 -0
  104. package/dist/cjs/logger.js +12 -0
  105. package/dist/cjs/models/EtlModel.d.ts +34 -0
  106. package/dist/cjs/models/EtlModel.js +125 -0
  107. package/dist/cjs/models/index.d.ts +1 -0
  108. package/dist/cjs/models/index.js +9 -0
  109. package/dist/cjs/package.json +1 -0
  110. package/dist/cjs/polyfills.d.ts +4 -0
  111. package/dist/cjs/polyfills.js +8 -0
  112. package/dist/cjs/proto/AmdSevSnp.d.ts +194 -0
  113. package/dist/cjs/proto/AmdSevSnp.js +358 -0
  114. package/dist/cjs/proto/Compression.d.ts +43 -0
  115. package/dist/cjs/proto/Compression.js +133 -0
  116. package/dist/cjs/proto/Hash.d.ts +37 -0
  117. package/dist/cjs/proto/Hash.js +104 -0
  118. package/dist/cjs/proto/Nvtrust.d.ts +116 -0
  119. package/dist/cjs/proto/Nvtrust.js +159 -0
  120. package/dist/cjs/proto/OrderReport.d.ts +730 -0
  121. package/dist/cjs/proto/OrderReport.js +466 -0
  122. package/dist/cjs/proto/TRI.d.ts +215 -0
  123. package/dist/cjs/proto/TRI.js +318 -0
  124. package/dist/cjs/providers/storage/ChunksDownloadDecorator.d.ts +36 -0
  125. package/dist/cjs/providers/storage/ChunksDownloadDecorator.js +145 -0
  126. package/dist/cjs/providers/storage/IStorageProvider.d.ts +15 -0
  127. package/dist/cjs/providers/storage/IStorageProvider.js +3 -0
  128. package/dist/cjs/providers/storage/S3StorageProvider.d.ts +26 -0
  129. package/dist/cjs/providers/storage/S3StorageProvider.js +210 -0
  130. package/dist/cjs/providers/storage/StorageAdapter.d.ts +62 -0
  131. package/dist/cjs/providers/storage/StorageAdapter.js +300 -0
  132. package/dist/cjs/providers/storage/StorageContentWriter.d.ts +46 -0
  133. package/dist/cjs/providers/storage/StorageContentWriter.js +168 -0
  134. package/dist/cjs/providers/storage/StorageKeyValueAdapter.d.ts +26 -0
  135. package/dist/cjs/providers/storage/StorageKeyValueAdapter.js +139 -0
  136. package/dist/cjs/providers/storage/StorageMetadataReader.d.ts +20 -0
  137. package/dist/cjs/providers/storage/StorageMetadataReader.js +56 -0
  138. package/dist/cjs/providers/storage/StorjAdapter.d.ts +20 -0
  139. package/dist/cjs/providers/storage/StorjAdapter.js +60 -0
  140. package/dist/cjs/providers/storage/StorjCredentialsManager.d.ts +24 -0
  141. package/dist/cjs/providers/storage/StorjCredentialsManager.js +114 -0
  142. package/dist/cjs/providers/storage/StorjStorageProvider.d.ts +29 -0
  143. package/dist/cjs/providers/storage/StorjStorageProvider.js +146 -0
  144. package/dist/cjs/providers/storage/fs-storage-provider.d.ts +19 -0
  145. package/dist/cjs/providers/storage/fs-storage-provider.js +162 -0
  146. package/dist/cjs/providers/storage/getStorageProvider.d.ts +4 -0
  147. package/dist/cjs/providers/storage/getStorageProvider.js +23 -0
  148. package/dist/cjs/providers/storage/parseStorageCredentials.d.ts +4 -0
  149. package/dist/cjs/providers/storage/parseStorageCredentials.js +21 -0
  150. package/dist/cjs/providers/storage/types.d.ts +29 -0
  151. package/dist/cjs/providers/storage/types.js +3 -0
  152. package/dist/cjs/staticModels/Deposits.d.ts +85 -0
  153. package/dist/cjs/staticModels/Deposits.js +268 -0
  154. package/dist/cjs/staticModels/Diamond.d.ts +6 -0
  155. package/dist/cjs/staticModels/Diamond.js +22 -0
  156. package/dist/cjs/staticModels/ModelPackager.d.ts +18 -0
  157. package/dist/cjs/staticModels/ModelPackager.js +49 -0
  158. package/dist/cjs/staticModels/ProviderRewards.d.ts +5 -0
  159. package/dist/cjs/staticModels/ProviderRewards.js +81 -0
  160. package/dist/cjs/staticModels/StaticModel.d.ts +6 -0
  161. package/dist/cjs/staticModels/StaticModel.js +43 -0
  162. package/dist/cjs/staticModels/Superpro.d.ts +18 -0
  163. package/dist/cjs/staticModels/Superpro.js +47 -0
  164. package/dist/cjs/staticModels/SuperproToken.d.ts +113 -0
  165. package/dist/cjs/staticModels/SuperproToken.js +333 -0
  166. package/dist/cjs/store.d.ts +17 -0
  167. package/dist/cjs/store.js +19 -0
  168. package/dist/cjs/tee/OrderReportService.d.ts +9 -0
  169. package/dist/cjs/tee/OrderReportService.js +104 -0
  170. package/dist/cjs/tee/QuoteParser.d.ts +82 -0
  171. package/dist/cjs/tee/QuoteParser.js +410 -0
  172. package/dist/cjs/tee/TeeCertificateService.d.ts +20 -0
  173. package/dist/cjs/tee/TeeCertificateService.js +143 -0
  174. package/dist/cjs/tee/TeeSignatureVerifier.d.ts +24 -0
  175. package/dist/cjs/tee/TeeSignatureVerifier.js +118 -0
  176. package/dist/cjs/tee/errors.d.ts +11 -0
  177. package/dist/cjs/tee/errors.js +20 -0
  178. package/dist/cjs/tee/helpers.d.ts +14 -0
  179. package/dist/cjs/tee/helpers.js +115 -0
  180. package/dist/cjs/tee/interface.d.ts +63 -0
  181. package/dist/cjs/tee/interface.js +3 -0
  182. package/dist/cjs/tee/statuses.d.ts +14 -0
  183. package/dist/cjs/tee/statuses.js +20 -0
  184. package/dist/cjs/tee/types.d.ts +126 -0
  185. package/dist/cjs/tee/types.js +34 -0
  186. package/dist/cjs/types/Compressor.d.ts +5 -0
  187. package/dist/cjs/types/Compressor.js +3 -0
  188. package/dist/cjs/types/Consensus.d.ts +52 -0
  189. package/dist/cjs/types/Consensus.js +11 -0
  190. package/dist/cjs/types/DepositInfo.d.ts +6 -0
  191. package/dist/cjs/types/DepositInfo.js +3 -0
  192. package/dist/cjs/types/DistributedSecretStorage.d.ts +68 -0
  193. package/dist/cjs/types/DistributedSecretStorage.js +3 -0
  194. package/dist/cjs/types/EtlModel.d.ts +2 -0
  195. package/dist/cjs/types/EtlModel.js +3 -0
  196. package/dist/cjs/types/Events.d.ts +34 -0
  197. package/dist/cjs/types/Events.js +3 -0
  198. package/dist/cjs/types/HardwareInfo.d.ts +10 -0
  199. package/dist/cjs/types/HardwareInfo.js +3 -0
  200. package/dist/cjs/types/Marks.d.ts +9 -0
  201. package/dist/cjs/types/Marks.js +10 -0
  202. package/dist/cjs/types/Offer.d.ts +76 -0
  203. package/dist/cjs/types/Offer.js +32 -0
  204. package/dist/cjs/types/OfferVersion.d.ts +30 -0
  205. package/dist/cjs/types/OfferVersion.js +9 -0
  206. package/dist/cjs/types/OptionInfo.d.ts +8 -0
  207. package/dist/cjs/types/OptionInfo.js +3 -0
  208. package/dist/cjs/types/Order.d.ts +144 -0
  209. package/dist/cjs/types/Order.js +100 -0
  210. package/dist/cjs/types/OrderUsage.d.ts +28 -0
  211. package/dist/cjs/types/OrderUsage.js +3 -0
  212. package/dist/cjs/types/Origins.d.ts +6 -0
  213. package/dist/cjs/types/Origins.js +3 -0
  214. package/dist/cjs/types/Provider.d.ts +7 -0
  215. package/dist/cjs/types/Provider.js +3 -0
  216. package/dist/cjs/types/ProviderRewards.d.ts +5 -0
  217. package/dist/cjs/types/ProviderRewards.js +3 -0
  218. package/dist/cjs/types/ResourceLoader.d.ts +28 -0
  219. package/dist/cjs/types/ResourceLoader.js +3 -0
  220. package/dist/cjs/types/SlotInfo.d.ts +7 -0
  221. package/dist/cjs/types/SlotInfo.js +3 -0
  222. package/dist/cjs/types/SlotUsage.d.ts +11 -0
  223. package/dist/cjs/types/SlotUsage.js +9 -0
  224. package/dist/cjs/types/Superpro.d.ts +9 -0
  225. package/dist/cjs/types/Superpro.js +14 -0
  226. package/dist/cjs/types/TeeOfferInfo.d.ts +38 -0
  227. package/dist/cjs/types/TeeOfferInfo.js +3 -0
  228. package/dist/cjs/types/TeeOfferOption.d.ts +13 -0
  229. package/dist/cjs/types/TeeOfferOption.js +3 -0
  230. package/dist/cjs/types/TeeOfferSlot.d.ts +8 -0
  231. package/dist/cjs/types/TeeOfferSlot.js +3 -0
  232. package/dist/cjs/types/ValueOfferSlot.d.ts +18 -0
  233. package/dist/cjs/types/ValueOfferSlot.js +3 -0
  234. package/dist/cjs/types/Web3.d.ts +30 -0
  235. package/dist/cjs/types/Web3.js +3 -0
  236. package/dist/cjs/types/blockchainConnector/StorageAccess.d.ts +8 -0
  237. package/dist/cjs/types/blockchainConnector/StorageAccess.js +3 -0
  238. package/dist/cjs/types/index.d.ts +25 -0
  239. package/dist/cjs/types/index.js +42 -0
  240. package/dist/cjs/types/storage/StorageAccess.d.ts +7 -0
  241. package/dist/cjs/types/storage/StorageAccess.js +3 -0
  242. package/dist/cjs/types/storage/StorageFileAccess.d.ts +5 -0
  243. package/dist/cjs/types/storage/StorageFileAccess.js +3 -0
  244. package/dist/cjs/types/storage/StorageObject.d.ts +8 -0
  245. package/dist/cjs/types/storage/StorageObject.js +3 -0
  246. package/dist/cjs/utils/CryptoKeysTransformer.d.ts +42 -0
  247. package/dist/cjs/utils/CryptoKeysTransformer.js +247 -0
  248. package/dist/cjs/utils/Monitoring.d.ts +11 -0
  249. package/dist/cjs/utils/Monitoring.js +51 -0
  250. package/dist/cjs/utils/NonceTracker.d.ts +20 -0
  251. package/dist/cjs/utils/NonceTracker.js +82 -0
  252. package/dist/cjs/utils/PubSub.d.ts +9 -0
  253. package/dist/cjs/utils/PubSub.js +35 -0
  254. package/dist/cjs/utils/TxManager.d.ts +28 -0
  255. package/dist/cjs/utils/TxManager.js +285 -0
  256. package/dist/cjs/utils/cache/index.d.ts +2 -0
  257. package/dist/cjs/utils/cache/index.js +21 -0
  258. package/dist/cjs/utils/cache/memory.d.ts +19 -0
  259. package/dist/cjs/utils/cache/memory.js +66 -0
  260. package/dist/cjs/utils/cache/memory.spec.d.ts +1 -0
  261. package/dist/cjs/utils/cache/memory.spec.js +91 -0
  262. package/dist/cjs/utils/cache/types.d.ts +17 -0
  263. package/dist/cjs/utils/cache/types.js +3 -0
  264. package/dist/cjs/utils/compressors/GzipCompressor.d.ts +8 -0
  265. package/dist/cjs/utils/compressors/GzipCompressor.js +22 -0
  266. package/dist/cjs/utils/compressors/UncompressedCompressor.d.ts +8 -0
  267. package/dist/cjs/utils/compressors/UncompressedCompressor.js +17 -0
  268. package/dist/cjs/utils/compressors/index.d.ts +2 -0
  269. package/dist/cjs/utils/compressors/index.js +19 -0
  270. package/dist/cjs/utils/helper.d.ts +87 -0
  271. package/dist/cjs/utils/helper.js +576 -0
  272. package/dist/cjs/utils/helpers/calculateObjectHash.d.ts +8 -0
  273. package/dist/cjs/utils/helpers/calculateObjectHash.js +25 -0
  274. package/dist/cjs/utils/helpers/getRawRpc.d.ts +2 -0
  275. package/dist/cjs/utils/helpers/getRawRpc.js +19 -0
  276. package/dist/cjs/utils/helpers/getStreamChunks.d.ts +9 -0
  277. package/dist/cjs/utils/helpers/getStreamChunks.js +35 -0
  278. package/dist/cjs/utils/helpers/index.d.ts +5 -0
  279. package/dist/cjs/utils/helpers/index.js +22 -0
  280. package/dist/cjs/utils/helpers/promise.d.ts +2 -0
  281. package/dist/cjs/utils/helpers/promise.js +10 -0
  282. package/dist/cjs/utils/helpers/streamToBuffer.d.ts +4 -0
  283. package/dist/cjs/utils/helpers/streamToBuffer.js +13 -0
  284. package/dist/cjs/utils/helpers/tryWithInterval.d.ts +13 -0
  285. package/dist/cjs/utils/helpers/tryWithInterval.js +39 -0
  286. package/dist/cjs/utils/rent-calculator/index.d.ts +2 -0
  287. package/dist/cjs/utils/rent-calculator/index.js +19 -0
  288. package/dist/cjs/utils/rent-calculator/rent-calculator.d.ts +14 -0
  289. package/dist/cjs/utils/rent-calculator/rent-calculator.js +114 -0
  290. package/dist/cjs/utils/rent-calculator/types.d.ts +14 -0
  291. package/dist/cjs/utils/rent-calculator/types.js +3 -0
  292. package/dist/cjs/utils/resourceLoaders/BaseResourceLoader.d.ts +10 -0
  293. package/dist/cjs/utils/resourceLoaders/BaseResourceLoader.js +14 -0
  294. package/dist/cjs/utils/resourceLoaders/StorageProviderLoader.d.ts +18 -0
  295. package/dist/cjs/utils/resourceLoaders/StorageProviderLoader.js +60 -0
  296. package/dist/cjs/utils/resourceLoaders/UrlResourceLoader.d.ts +9 -0
  297. package/dist/cjs/utils/resourceLoaders/UrlResourceLoader.js +51 -0
  298. package/dist/cjs/utils/resourceLoaders/getResourceLoader.d.ts +5 -0
  299. package/dist/cjs/utils/resourceLoaders/getResourceLoader.js +15 -0
  300. package/dist/cjs/utils/resourceLoaders/index.d.ts +1 -0
  301. package/dist/cjs/utils/resourceLoaders/index.js +18 -0
  302. package/dist/cjs/utils/schema-utils/index.d.ts +2 -0
  303. package/dist/cjs/utils/schema-utils/index.js +9 -0
  304. package/dist/cjs/utils/schema-utils/serializer.d.ts +3 -0
  305. package/dist/cjs/utils/schema-utils/serializer.js +31 -0
  306. package/dist/cjs/utils/schema-utils/validator.d.ts +7 -0
  307. package/dist/cjs/utils/schema-utils/validator.js +49 -0
  308. package/dist/cjs/utils/tcb.d.ts +2 -0
  309. package/dist/cjs/utils/tcb.js +13 -0
  310. package/dist/cjs/utils/tokens/get-tokens-info.d.ts +8 -0
  311. package/dist/cjs/utils/tokens/get-tokens-info.js +32 -0
  312. package/dist/cjs/utils/tokens/index.d.ts +1 -0
  313. package/dist/cjs/utils/tokens/index.js +18 -0
  314. package/dist/cjs/utils/types.d.ts +13 -0
  315. package/dist/cjs/utils/types.js +3 -0
  316. package/dist/mjs/analytics/Analytics.d.ts +17 -0
  317. package/dist/mjs/analytics/Analytics.js +78 -0
  318. package/dist/mjs/analytics/AnalyticsError.d.ts +7 -0
  319. package/dist/mjs/analytics/AnalyticsError.js +8 -0
  320. package/dist/mjs/analytics/eventProviders/BrowserEventProvider.d.ts +19 -0
  321. package/dist/mjs/analytics/eventProviders/BrowserEventProvider.js +32 -0
  322. package/dist/mjs/analytics/eventProviders/EventProvider.d.ts +24 -0
  323. package/dist/mjs/analytics/eventProviders/EventProvider.js +22 -0
  324. package/dist/mjs/analytics/eventProviders/NodeEventProvider.d.ts +22 -0
  325. package/dist/mjs/analytics/eventProviders/NodeEventProvider.js +50 -0
  326. package/dist/mjs/analytics/transports/AxiosTransport.d.ts +4 -0
  327. package/dist/mjs/analytics/transports/AxiosTransport.js +31 -0
  328. package/dist/mjs/analytics/transports/FetchTransport.d.ts +4 -0
  329. package/dist/mjs/analytics/transports/FetchTransport.js +28 -0
  330. package/dist/mjs/analytics/types.d.ts +26 -0
  331. package/dist/mjs/analytics/types.js +2 -0
  332. package/dist/mjs/certificates/binary-splitter.d.ts +27 -0
  333. package/dist/mjs/certificates/binary-splitter.js +275 -0
  334. package/dist/mjs/certificates/crl.d.ts +6 -0
  335. package/dist/mjs/certificates/crl.js +39 -0
  336. package/dist/mjs/certificates/generator.d.ts +38 -0
  337. package/dist/mjs/certificates/generator.js +255 -0
  338. package/dist/mjs/certificates/helper.d.ts +29 -0
  339. package/dist/mjs/certificates/helper.js +186 -0
  340. package/dist/mjs/certificates/index.d.ts +5 -0
  341. package/dist/mjs/certificates/index.js +6 -0
  342. package/dist/mjs/certificates/ocsp.d.ts +14 -0
  343. package/dist/mjs/certificates/ocsp.js +290 -0
  344. package/dist/mjs/certificates/serializer.d.ts +13 -0
  345. package/dist/mjs/certificates/serializer.js +135 -0
  346. package/dist/mjs/certificates/setup-crypto.d.ts +3 -0
  347. package/dist/mjs/certificates/setup-crypto.js +22 -0
  348. package/dist/mjs/certificates/types.d.ts +122 -0
  349. package/dist/mjs/certificates/types.js +7 -0
  350. package/dist/mjs/config.d.ts +3 -0
  351. package/dist/mjs/config.js +4 -0
  352. package/dist/mjs/connectors/BaseConnector.d.ts +52 -0
  353. package/dist/mjs/connectors/BaseConnector.js +54 -0
  354. package/dist/mjs/connectors/BlockchainConnector.d.ts +78 -0
  355. package/dist/mjs/connectors/BlockchainConnector.js +320 -0
  356. package/dist/mjs/connectors/BlockchainEventsListener.d.ts +33 -0
  357. package/dist/mjs/connectors/BlockchainEventsListener.js +254 -0
  358. package/dist/mjs/connectors/index.d.ts +2 -0
  359. package/dist/mjs/connectors/index.js +3 -0
  360. package/dist/mjs/constants.d.ts +48 -0
  361. package/dist/mjs/constants.js +680 -0
  362. package/dist/mjs/contracts/SuperProtocolToken.d.ts +300 -0
  363. package/dist/mjs/contracts/SuperProtocolToken.js +2 -0
  364. package/dist/mjs/contracts/SuperProtocolToken__factory.d.ts +393 -0
  365. package/dist/mjs/contracts/SuperProtocolToken__factory.js +517 -0
  366. package/dist/mjs/contracts/typechain-types/common.d.ts +50 -0
  367. package/dist/mjs/contracts/typechain-types/common.js +2 -0
  368. package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.d.ts +3340 -0
  369. package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.js +4331 -0
  370. package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
  371. package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +6 -0
  372. package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.d.ts +1 -0
  373. package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.js +6 -0
  374. package/dist/mjs/contracts/typechain-types/factories/index.d.ts +1 -0
  375. package/dist/mjs/contracts/typechain-types/factories/index.js +6 -0
  376. package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.d.ts +2299 -0
  377. package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.js +2 -0
  378. package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
  379. package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +2 -0
  380. package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/index.d.ts +2 -0
  381. package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/index.js +2 -0
  382. package/dist/mjs/contracts/typechain-types/index.d.ts +5 -0
  383. package/dist/mjs/contracts/typechain-types/index.js +7 -0
  384. package/dist/mjs/crypto/Crypto.d.ts +70 -0
  385. package/dist/mjs/crypto/Crypto.js +132 -0
  386. package/dist/mjs/crypto/index.d.ts +4 -0
  387. package/dist/mjs/crypto/index.js +5 -0
  388. package/dist/mjs/crypto/nodejs/AES.d.ts +25 -0
  389. package/dist/mjs/crypto/nodejs/AES.js +77 -0
  390. package/dist/mjs/crypto/nodejs/ARIA.d.ts +23 -0
  391. package/dist/mjs/crypto/nodejs/ARIA.js +72 -0
  392. package/dist/mjs/crypto/nodejs/ECIES.d.ts +10 -0
  393. package/dist/mjs/crypto/nodejs/ECIES.js +82 -0
  394. package/dist/mjs/crypto/nodejs/NativeCrypto.d.ts +46 -0
  395. package/dist/mjs/crypto/nodejs/NativeCrypto.js +152 -0
  396. package/dist/mjs/crypto/nodejs/RSA-Hybrid.d.ts +15 -0
  397. package/dist/mjs/crypto/nodejs/RSA-Hybrid.js +89 -0
  398. package/dist/mjs/crypto/types.d.ts +10 -0
  399. package/dist/mjs/crypto/types.js +2 -0
  400. package/dist/mjs/crypto/utils.d.ts +15 -0
  401. package/dist/mjs/crypto/utils.js +81 -0
  402. package/dist/mjs/crypto/utils.spec.d.ts +1 -0
  403. package/dist/mjs/crypto/utils.spec.js +219 -0
  404. package/dist/mjs/errors/base.error.d.ts +3 -0
  405. package/dist/mjs/errors/base.error.js +15 -0
  406. package/dist/mjs/errors/index.d.ts +3 -0
  407. package/dist/mjs/errors/index.js +4 -0
  408. package/dist/mjs/errors/insufficient-funds.error.d.ts +19 -0
  409. package/dist/mjs/errors/insufficient-funds.error.js +53 -0
  410. package/dist/mjs/errors/not-found.error.d.ts +3 -0
  411. package/dist/mjs/errors/not-found.error.js +4 -0
  412. package/dist/mjs/errors/utils.d.ts +2 -0
  413. package/dist/mjs/errors/utils.js +22 -0
  414. package/dist/mjs/index.d.ts +58 -0
  415. package/dist/mjs/index.js +53 -0
  416. package/dist/mjs/logger.d.ts +7 -0
  417. package/dist/mjs/logger.js +7 -0
  418. package/dist/mjs/models/EtlModel.d.ts +34 -0
  419. package/dist/mjs/models/EtlModel.js +96 -0
  420. package/dist/mjs/models/index.d.ts +1 -0
  421. package/dist/mjs/models/index.js +2 -0
  422. package/dist/mjs/package.json +1 -0
  423. package/dist/mjs/polyfills.d.ts +4 -0
  424. package/dist/mjs/polyfills.js +8 -0
  425. package/dist/mjs/proto/AmdSevSnp.d.ts +194 -0
  426. package/dist/mjs/proto/AmdSevSnp.js +348 -0
  427. package/dist/mjs/proto/Compression.d.ts +43 -0
  428. package/dist/mjs/proto/Compression.js +125 -0
  429. package/dist/mjs/proto/Hash.d.ts +37 -0
  430. package/dist/mjs/proto/Hash.js +98 -0
  431. package/dist/mjs/proto/Nvtrust.d.ts +116 -0
  432. package/dist/mjs/proto/Nvtrust.js +153 -0
  433. package/dist/mjs/proto/OrderReport.d.ts +730 -0
  434. package/dist/mjs/proto/OrderReport.js +460 -0
  435. package/dist/mjs/proto/TRI.d.ts +215 -0
  436. package/dist/mjs/proto/TRI.js +312 -0
  437. package/dist/mjs/providers/storage/ChunksDownloadDecorator.d.ts +36 -0
  438. package/dist/mjs/providers/storage/ChunksDownloadDecorator.js +139 -0
  439. package/dist/mjs/providers/storage/IStorageProvider.d.ts +15 -0
  440. package/dist/mjs/providers/storage/IStorageProvider.js +2 -0
  441. package/dist/mjs/providers/storage/S3StorageProvider.d.ts +26 -0
  442. package/dist/mjs/providers/storage/S3StorageProvider.js +203 -0
  443. package/dist/mjs/providers/storage/StorageAdapter.d.ts +62 -0
  444. package/dist/mjs/providers/storage/StorageAdapter.js +270 -0
  445. package/dist/mjs/providers/storage/StorageContentWriter.d.ts +46 -0
  446. package/dist/mjs/providers/storage/StorageContentWriter.js +161 -0
  447. package/dist/mjs/providers/storage/StorageKeyValueAdapter.d.ts +26 -0
  448. package/dist/mjs/providers/storage/StorageKeyValueAdapter.js +133 -0
  449. package/dist/mjs/providers/storage/StorageMetadataReader.d.ts +20 -0
  450. package/dist/mjs/providers/storage/StorageMetadataReader.js +50 -0
  451. package/dist/mjs/providers/storage/StorjAdapter.d.ts +20 -0
  452. package/dist/mjs/providers/storage/StorjAdapter.js +54 -0
  453. package/dist/mjs/providers/storage/StorjCredentialsManager.d.ts +24 -0
  454. package/dist/mjs/providers/storage/StorjCredentialsManager.js +84 -0
  455. package/dist/mjs/providers/storage/StorjStorageProvider.d.ts +29 -0
  456. package/dist/mjs/providers/storage/StorjStorageProvider.js +140 -0
  457. package/dist/mjs/providers/storage/fs-storage-provider.d.ts +19 -0
  458. package/dist/mjs/providers/storage/fs-storage-provider.js +132 -0
  459. package/dist/mjs/providers/storage/getStorageProvider.d.ts +4 -0
  460. package/dist/mjs/providers/storage/getStorageProvider.js +18 -0
  461. package/dist/mjs/providers/storage/parseStorageCredentials.d.ts +4 -0
  462. package/dist/mjs/providers/storage/parseStorageCredentials.js +17 -0
  463. package/dist/mjs/providers/storage/types.d.ts +29 -0
  464. package/dist/mjs/providers/storage/types.js +2 -0
  465. package/dist/mjs/staticModels/Deposits.d.ts +85 -0
  466. package/dist/mjs/staticModels/Deposits.js +263 -0
  467. package/dist/mjs/staticModels/Diamond.d.ts +6 -0
  468. package/dist/mjs/staticModels/Diamond.js +17 -0
  469. package/dist/mjs/staticModels/ModelPackager.d.ts +18 -0
  470. package/dist/mjs/staticModels/ModelPackager.js +45 -0
  471. package/dist/mjs/staticModels/ProviderRewards.d.ts +5 -0
  472. package/dist/mjs/staticModels/ProviderRewards.js +76 -0
  473. package/dist/mjs/staticModels/StaticModel.d.ts +6 -0
  474. package/dist/mjs/staticModels/StaticModel.js +38 -0
  475. package/dist/mjs/staticModels/Superpro.d.ts +18 -0
  476. package/dist/mjs/staticModels/Superpro.js +45 -0
  477. package/dist/mjs/staticModels/SuperproToken.d.ts +113 -0
  478. package/dist/mjs/staticModels/SuperproToken.js +328 -0
  479. package/dist/mjs/store.d.ts +17 -0
  480. package/dist/mjs/store.js +17 -0
  481. package/dist/mjs/tee/OrderReportService.d.ts +9 -0
  482. package/dist/mjs/tee/OrderReportService.js +97 -0
  483. package/dist/mjs/tee/QuoteParser.d.ts +82 -0
  484. package/dist/mjs/tee/QuoteParser.js +381 -0
  485. package/dist/mjs/tee/TeeCertificateService.d.ts +20 -0
  486. package/dist/mjs/tee/TeeCertificateService.js +139 -0
  487. package/dist/mjs/tee/TeeSignatureVerifier.d.ts +24 -0
  488. package/dist/mjs/tee/TeeSignatureVerifier.js +111 -0
  489. package/dist/mjs/tee/errors.d.ts +11 -0
  490. package/dist/mjs/tee/errors.js +12 -0
  491. package/dist/mjs/tee/helpers.d.ts +14 -0
  492. package/dist/mjs/tee/helpers.js +110 -0
  493. package/dist/mjs/tee/interface.d.ts +63 -0
  494. package/dist/mjs/tee/interface.js +2 -0
  495. package/dist/mjs/tee/statuses.d.ts +14 -0
  496. package/dist/mjs/tee/statuses.js +17 -0
  497. package/dist/mjs/tee/types.d.ts +126 -0
  498. package/dist/mjs/tee/types.js +28 -0
  499. package/dist/mjs/types/Compressor.d.ts +5 -0
  500. package/dist/mjs/types/Compressor.js +2 -0
  501. package/dist/mjs/types/Consensus.d.ts +52 -0
  502. package/dist/mjs/types/Consensus.js +8 -0
  503. package/dist/mjs/types/DepositInfo.d.ts +6 -0
  504. package/dist/mjs/types/DepositInfo.js +2 -0
  505. package/dist/mjs/types/DistributedSecretStorage.d.ts +68 -0
  506. package/dist/mjs/types/DistributedSecretStorage.js +2 -0
  507. package/dist/mjs/types/EtlModel.d.ts +2 -0
  508. package/dist/mjs/types/EtlModel.js +2 -0
  509. package/dist/mjs/types/Events.d.ts +34 -0
  510. package/dist/mjs/types/Events.js +2 -0
  511. package/dist/mjs/types/HardwareInfo.d.ts +10 -0
  512. package/dist/mjs/types/HardwareInfo.js +2 -0
  513. package/dist/mjs/types/Marks.d.ts +9 -0
  514. package/dist/mjs/types/Marks.js +7 -0
  515. package/dist/mjs/types/Offer.d.ts +76 -0
  516. package/dist/mjs/types/Offer.js +29 -0
  517. package/dist/mjs/types/OfferVersion.d.ts +30 -0
  518. package/dist/mjs/types/OfferVersion.js +6 -0
  519. package/dist/mjs/types/OptionInfo.d.ts +8 -0
  520. package/dist/mjs/types/OptionInfo.js +2 -0
  521. package/dist/mjs/types/Order.d.ts +144 -0
  522. package/dist/mjs/types/Order.js +91 -0
  523. package/dist/mjs/types/OrderUsage.d.ts +28 -0
  524. package/dist/mjs/types/OrderUsage.js +2 -0
  525. package/dist/mjs/types/Origins.d.ts +6 -0
  526. package/dist/mjs/types/Origins.js +2 -0
  527. package/dist/mjs/types/Provider.d.ts +7 -0
  528. package/dist/mjs/types/Provider.js +2 -0
  529. package/dist/mjs/types/ProviderRewards.d.ts +5 -0
  530. package/dist/mjs/types/ProviderRewards.js +2 -0
  531. package/dist/mjs/types/ResourceLoader.d.ts +28 -0
  532. package/dist/mjs/types/ResourceLoader.js +2 -0
  533. package/dist/mjs/types/SlotInfo.d.ts +7 -0
  534. package/dist/mjs/types/SlotInfo.js +2 -0
  535. package/dist/mjs/types/SlotUsage.d.ts +11 -0
  536. package/dist/mjs/types/SlotUsage.js +6 -0
  537. package/dist/mjs/types/Superpro.d.ts +9 -0
  538. package/dist/mjs/types/Superpro.js +11 -0
  539. package/dist/mjs/types/TeeOfferInfo.d.ts +38 -0
  540. package/dist/mjs/types/TeeOfferInfo.js +2 -0
  541. package/dist/mjs/types/TeeOfferOption.d.ts +13 -0
  542. package/dist/mjs/types/TeeOfferOption.js +2 -0
  543. package/dist/mjs/types/TeeOfferSlot.d.ts +8 -0
  544. package/dist/mjs/types/TeeOfferSlot.js +2 -0
  545. package/dist/mjs/types/ValueOfferSlot.d.ts +18 -0
  546. package/dist/mjs/types/ValueOfferSlot.js +2 -0
  547. package/dist/mjs/types/Web3.d.ts +30 -0
  548. package/dist/mjs/types/Web3.js +2 -0
  549. package/dist/mjs/types/blockchainConnector/StorageAccess.d.ts +8 -0
  550. package/dist/mjs/types/blockchainConnector/StorageAccess.js +2 -0
  551. package/dist/mjs/types/index.d.ts +25 -0
  552. package/dist/mjs/types/index.js +26 -0
  553. package/dist/mjs/types/storage/StorageAccess.d.ts +7 -0
  554. package/dist/mjs/types/storage/StorageAccess.js +2 -0
  555. package/dist/mjs/types/storage/StorageFileAccess.d.ts +5 -0
  556. package/dist/mjs/types/storage/StorageFileAccess.js +2 -0
  557. package/dist/mjs/types/storage/StorageObject.d.ts +8 -0
  558. package/dist/mjs/types/storage/StorageObject.js +2 -0
  559. package/dist/mjs/utils/CryptoKeysTransformer.d.ts +42 -0
  560. package/dist/mjs/utils/CryptoKeysTransformer.js +240 -0
  561. package/dist/mjs/utils/Monitoring.d.ts +11 -0
  562. package/dist/mjs/utils/Monitoring.js +44 -0
  563. package/dist/mjs/utils/NonceTracker.d.ts +20 -0
  564. package/dist/mjs/utils/NonceTracker.js +77 -0
  565. package/dist/mjs/utils/PubSub.d.ts +9 -0
  566. package/dist/mjs/utils/PubSub.js +32 -0
  567. package/dist/mjs/utils/TxManager.d.ts +28 -0
  568. package/dist/mjs/utils/TxManager.js +278 -0
  569. package/dist/mjs/utils/cache/index.d.ts +2 -0
  570. package/dist/mjs/utils/cache/index.js +3 -0
  571. package/dist/mjs/utils/cache/memory.d.ts +19 -0
  572. package/dist/mjs/utils/cache/memory.js +61 -0
  573. package/dist/mjs/utils/cache/memory.spec.d.ts +1 -0
  574. package/dist/mjs/utils/cache/memory.spec.js +89 -0
  575. package/dist/mjs/utils/cache/types.d.ts +17 -0
  576. package/dist/mjs/utils/cache/types.js +2 -0
  577. package/dist/mjs/utils/compressors/GzipCompressor.d.ts +8 -0
  578. package/dist/mjs/utils/compressors/GzipCompressor.js +15 -0
  579. package/dist/mjs/utils/compressors/UncompressedCompressor.d.ts +8 -0
  580. package/dist/mjs/utils/compressors/UncompressedCompressor.js +13 -0
  581. package/dist/mjs/utils/compressors/index.d.ts +2 -0
  582. package/dist/mjs/utils/compressors/index.js +3 -0
  583. package/dist/mjs/utils/helper.d.ts +87 -0
  584. package/dist/mjs/utils/helper.js +526 -0
  585. package/dist/mjs/utils/helpers/calculateObjectHash.d.ts +8 -0
  586. package/dist/mjs/utils/helpers/calculateObjectHash.js +18 -0
  587. package/dist/mjs/utils/helpers/getRawRpc.d.ts +2 -0
  588. package/dist/mjs/utils/helpers/getRawRpc.js +15 -0
  589. package/dist/mjs/utils/helpers/getStreamChunks.d.ts +9 -0
  590. package/dist/mjs/utils/helpers/getStreamChunks.js +31 -0
  591. package/dist/mjs/utils/helpers/index.d.ts +5 -0
  592. package/dist/mjs/utils/helpers/index.js +6 -0
  593. package/dist/mjs/utils/helpers/promise.d.ts +2 -0
  594. package/dist/mjs/utils/helpers/promise.js +5 -0
  595. package/dist/mjs/utils/helpers/streamToBuffer.d.ts +4 -0
  596. package/dist/mjs/utils/helpers/streamToBuffer.js +9 -0
  597. package/dist/mjs/utils/helpers/tryWithInterval.d.ts +13 -0
  598. package/dist/mjs/utils/helpers/tryWithInterval.js +35 -0
  599. package/dist/mjs/utils/rent-calculator/index.d.ts +2 -0
  600. package/dist/mjs/utils/rent-calculator/index.js +3 -0
  601. package/dist/mjs/utils/rent-calculator/rent-calculator.d.ts +14 -0
  602. package/dist/mjs/utils/rent-calculator/rent-calculator.js +110 -0
  603. package/dist/mjs/utils/rent-calculator/types.d.ts +14 -0
  604. package/dist/mjs/utils/rent-calculator/types.js +2 -0
  605. package/dist/mjs/utils/resourceLoaders/BaseResourceLoader.d.ts +10 -0
  606. package/dist/mjs/utils/resourceLoaders/BaseResourceLoader.js +10 -0
  607. package/dist/mjs/utils/resourceLoaders/StorageProviderLoader.d.ts +18 -0
  608. package/dist/mjs/utils/resourceLoaders/StorageProviderLoader.js +53 -0
  609. package/dist/mjs/utils/resourceLoaders/UrlResourceLoader.d.ts +9 -0
  610. package/dist/mjs/utils/resourceLoaders/UrlResourceLoader.js +44 -0
  611. package/dist/mjs/utils/resourceLoaders/getResourceLoader.d.ts +5 -0
  612. package/dist/mjs/utils/resourceLoaders/getResourceLoader.js +11 -0
  613. package/dist/mjs/utils/resourceLoaders/index.d.ts +1 -0
  614. package/dist/mjs/utils/resourceLoaders/index.js +2 -0
  615. package/dist/mjs/utils/schema-utils/index.d.ts +2 -0
  616. package/dist/mjs/utils/schema-utils/index.js +3 -0
  617. package/dist/mjs/utils/schema-utils/serializer.d.ts +3 -0
  618. package/dist/mjs/utils/schema-utils/serializer.js +26 -0
  619. package/dist/mjs/utils/schema-utils/validator.d.ts +7 -0
  620. package/dist/mjs/utils/schema-utils/validator.js +45 -0
  621. package/dist/mjs/utils/tcb.d.ts +2 -0
  622. package/dist/mjs/utils/tcb.js +9 -0
  623. package/dist/mjs/utils/tokens/get-tokens-info.d.ts +8 -0
  624. package/dist/mjs/utils/tokens/get-tokens-info.js +25 -0
  625. package/dist/mjs/utils/tokens/index.d.ts +1 -0
  626. package/dist/mjs/utils/tokens/index.js +2 -0
  627. package/dist/mjs/utils/types.d.ts +13 -0
  628. package/dist/mjs/utils/types.js +2 -0
  629. package/package.json +103 -0
@@ -0,0 +1,381 @@
1
+ import { Certificate } from '@fidm/x509';
2
+ import * as asn1js from 'asn1js';
3
+ import * as pkijs from 'pkijs';
4
+ import { Buffer as Blob } from 'buffer';
5
+ import { TeeQuoteParserError } from './errors.js';
6
+ import { QuoteType, } from './types.js';
7
+ import { splitChain, Signature } from './helpers.js';
8
+ import * as crypto from 'crypto';
9
+ export class TeeParser {
10
+ static reportDataHashSize = 32; /* 64 in report, but we need 32 only for sha256 hash */
11
+ extractRS(cert) {
12
+ const derSignature = Buffer.from(cert.signatureValue.valueBlock.valueHexView).toString('hex');
13
+ const parsedSignature = Signature.importFromDER(derSignature);
14
+ return {
15
+ r: parsedSignature.r,
16
+ s: parsedSignature.s,
17
+ derSignature,
18
+ };
19
+ }
20
+ parsePem(pem) {
21
+ const cert = Certificate.fromPEM(Buffer.from(pem));
22
+ const asn1Certificate = asn1js.fromBER(cert.raw);
23
+ const certificate = new pkijs.Certificate({ schema: asn1Certificate.result });
24
+ const tbs = certificate.tbsView;
25
+ const { r, s } = this.extractRS(certificate);
26
+ const publicKey = cert.publicKey.keyRaw.toString('hex').slice(2);
27
+ const splitedTbs = Buffer.from(tbs).toString('hex').split(publicKey);
28
+ const x509PublicKey = '0x' + publicKey;
29
+ const x509Signature = '0x' + r + s;
30
+ return {
31
+ bodyPartOne: '0x' + splitedTbs[0],
32
+ publicKey: x509PublicKey,
33
+ bodyPartTwo: '0x' + splitedTbs[1],
34
+ signature: x509Signature,
35
+ };
36
+ }
37
+ getDataAndAdvance(blob, size) {
38
+ const buf = Blob.from(blob.data.subarray(0, size));
39
+ blob.data = Blob.from(blob.data.subarray(size));
40
+ return buf;
41
+ }
42
+ static determineQuoteType(quote) {
43
+ let type = QuoteType.SGX;
44
+ if (quote.length < 48) {
45
+ throw new TeeQuoteParserError('data has invalid length');
46
+ }
47
+ const version = Buffer.from(quote).readUInt16LE(0);
48
+ if (version === 4) {
49
+ const quoteType = Buffer.from(quote).readUInt32LE(4);
50
+ if (quoteType === 0x00000081) {
51
+ type = QuoteType.TDX;
52
+ }
53
+ else if (quoteType !== 0x00000000) {
54
+ throw new TeeQuoteParserError(`Unknown quote type ${quoteType}`);
55
+ }
56
+ }
57
+ else if (version !== 3) {
58
+ throw new TeeQuoteParserError(`Unknown quote version ${version}`);
59
+ }
60
+ return { type, version };
61
+ }
62
+ static getMrEnclave(quote) {
63
+ const teeType = TeeParser.determineQuoteType(quote);
64
+ switch (teeType.type) {
65
+ case QuoteType.SGX: {
66
+ const sgxParser = new TeeSgxParser();
67
+ const parsedSgxQuote = sgxParser.parseQuote(quote);
68
+ const parsedReport = sgxParser.parseReport(parsedSgxQuote.report);
69
+ return parsedReport.mrEnclave;
70
+ }
71
+ case QuoteType.TDX: {
72
+ const tdxParser = new TeeTdxParser();
73
+ const parsedTdxQuote = tdxParser.parseQuote(quote);
74
+ const tdBody = tdxParser.parseBody(parsedTdxQuote.tdQuoteBody);
75
+ const hash = crypto.createHash('sha256');
76
+ hash.update(tdBody.tdAttributes);
77
+ hash.update(tdBody.mrTd);
78
+ hash.update(tdBody.rtmr0);
79
+ hash.update(tdBody.rtmr1);
80
+ hash.update(tdBody.rtmr2);
81
+ hash.update(tdBody.rtmr3);
82
+ return hash.digest();
83
+ }
84
+ default:
85
+ throw new TeeQuoteParserError(`Unknown quote type`);
86
+ }
87
+ }
88
+ }
89
+ export class TeeSgxParser extends TeeParser {
90
+ static quoteHeaderSize = 48;
91
+ static pceSvnOffset = 10;
92
+ static reportSize = 384;
93
+ static userDataOffset = 28;
94
+ static userDataSize = 20;
95
+ static cpuSvnSize = 16;
96
+ static reportMrEnclaveOffset = 64;
97
+ static reportMrEnclaveSize = 32;
98
+ static reportMrSignerOffset = TeeSgxParser.reportMrEnclaveOffset + TeeSgxParser.reportMrEnclaveSize + /* reserved */ 32;
99
+ static reportMrSignerSize = 32;
100
+ static reportIsvProdIdOffset = TeeSgxParser.reportMrSignerOffset + TeeSgxParser.reportMrSignerSize + /* reserved */ 96;
101
+ static reportIsvProdIdSize = 2;
102
+ static reportIsvSvnOffset = TeeSgxParser.reportIsvProdIdOffset + TeeSgxParser.reportIsvProdIdSize;
103
+ static reportIsvSvnSize = 2;
104
+ static reportDataOffset = TeeSgxParser.reportIsvSvnOffset + TeeSgxParser.reportIsvSvnSize + /* reserved */ 60;
105
+ static reportUserDataSize = 64;
106
+ static ecdsaP256SignatureSize = 64;
107
+ static ecdsaP256PublicKeySize = 64;
108
+ parseQuote(data) {
109
+ const { quoteHeaderSize, pceSvnOffset, reportSize, userDataOffset, userDataSize, ecdsaP256SignatureSize, ecdsaP256PublicKeySize, } = TeeSgxParser;
110
+ if (data.length < quoteHeaderSize + reportSize) {
111
+ throw new TeeQuoteParserError('data has invalid length');
112
+ }
113
+ const quoteRemainder = { data: Blob.from(data) };
114
+ const quoteHeader = this.getDataAndAdvance(quoteRemainder, quoteHeaderSize);
115
+ const report = this.getDataAndAdvance(quoteRemainder, reportSize);
116
+ const version = quoteHeader.readUInt16LE(0);
117
+ const attestationKeyType = quoteHeader.readUInt16LE(2);
118
+ if (attestationKeyType > 3) {
119
+ throw new TeeQuoteParserError('quote header has invalid or unsupported attestation key type');
120
+ }
121
+ const pceSvn = quoteHeader.readUInt16LE(pceSvnOffset);
122
+ const userData = quoteHeader.slice(userDataOffset, userDataOffset + userDataSize);
123
+ const quoteSignatureDateLen = quoteRemainder.data.readUInt32LE(0);
124
+ quoteRemainder.data = Blob.from(quoteRemainder.data.subarray(4));
125
+ if (quoteSignatureDateLen != quoteRemainder.data.length) {
126
+ throw new TeeQuoteParserError(`quoteSignatureDateLen has invalid length: ${quoteRemainder.data.length} instead of ${quoteSignatureDateLen} expected`);
127
+ }
128
+ const rawQuoteSignatureDataRemainder = {
129
+ data: this.getDataAndAdvance(quoteRemainder, quoteSignatureDateLen),
130
+ };
131
+ const isvEnclaveReportSignature = this.getDataAndAdvance(rawQuoteSignatureDataRemainder, ecdsaP256SignatureSize);
132
+ const ecdsaAttestationKey = this.getDataAndAdvance(rawQuoteSignatureDataRemainder, ecdsaP256PublicKeySize);
133
+ const qeReport = this.getDataAndAdvance(rawQuoteSignatureDataRemainder, reportSize);
134
+ const qeReportSignature = this.getDataAndAdvance(rawQuoteSignatureDataRemainder, ecdsaP256SignatureSize);
135
+ const qeAuthenticationDataSize = rawQuoteSignatureDataRemainder.data.readUInt16LE(0);
136
+ rawQuoteSignatureDataRemainder.data = Blob.from(rawQuoteSignatureDataRemainder.data.subarray(2));
137
+ if (rawQuoteSignatureDataRemainder.data.length < qeAuthenticationDataSize) {
138
+ throw new TeeQuoteParserError(`qeAuthenticationDataSize has invalid length: ${rawQuoteSignatureDataRemainder.data.length} instead of ${qeAuthenticationDataSize} expected`);
139
+ }
140
+ const qeAuthenticationData = this.getDataAndAdvance(rawQuoteSignatureDataRemainder, qeAuthenticationDataSize);
141
+ const qeCertificationDataType = rawQuoteSignatureDataRemainder.data.readUInt16LE(0);
142
+ if (qeCertificationDataType < 1 || qeCertificationDataType > 7) {
143
+ throw new TeeQuoteParserError(`certificationDataType has invalid value: ${qeCertificationDataType}`);
144
+ }
145
+ const certificationDataSize = rawQuoteSignatureDataRemainder.data.readUInt32LE(2);
146
+ const qeCertificationData = rawQuoteSignatureDataRemainder.data.subarray(2 + 4);
147
+ if (certificationDataSize != qeCertificationData.length) {
148
+ throw new TeeQuoteParserError(`certificationDataSize has invalid length: $PqeCertificationData.length} instead of ${certificationDataSize} expected`);
149
+ }
150
+ const certsPems = splitChain(qeCertificationData.toString()) || []; // [device, platform, root]
151
+ const certsData = certsPems.map((pem) => this.parsePem(pem));
152
+ return {
153
+ quoteType: QuoteType.SGX,
154
+ rawHeader: quoteHeader,
155
+ header: {
156
+ version,
157
+ attestationKeyType,
158
+ pceSvn,
159
+ userData,
160
+ },
161
+ report,
162
+ isvEnclaveReportSignature,
163
+ ecdsaAttestationKey,
164
+ qeReport,
165
+ qeReportSignature,
166
+ qeAuthenticationData,
167
+ qeCertificationDataType,
168
+ qeCertificationData,
169
+ certificates: {
170
+ device: {
171
+ pem: certsPems[0],
172
+ x509Data: certsData[0],
173
+ },
174
+ platform: {
175
+ pem: certsPems[1],
176
+ x509Data: certsData[1],
177
+ },
178
+ root: {
179
+ pem: certsPems[2],
180
+ x509Data: certsData[2],
181
+ },
182
+ },
183
+ };
184
+ }
185
+ parseReport(data) {
186
+ const { reportSize, cpuSvnSize, reportMrEnclaveOffset, reportMrEnclaveSize, reportMrSignerOffset, reportMrSignerSize, reportIsvProdIdOffset, reportIsvProdIdSize, reportIsvSvnOffset, reportIsvSvnSize, reportDataOffset, reportUserDataSize, reportDataHashSize, } = TeeSgxParser;
187
+ if (data.length < reportSize) {
188
+ throw new TeeQuoteParserError('data has invalid length');
189
+ }
190
+ const report = Blob.from(data);
191
+ const cpuSvn = report.slice(0, cpuSvnSize).toString('hex');
192
+ const mrEnclave = report.slice(reportMrEnclaveOffset, reportMrEnclaveOffset + reportMrEnclaveSize);
193
+ const mrSigner = report.slice(reportMrSignerOffset, reportMrSignerOffset + reportMrSignerSize);
194
+ const isvProdId = report
195
+ .slice(reportIsvProdIdOffset, reportIsvProdIdOffset + reportIsvProdIdSize)
196
+ .readUInt16LE(0);
197
+ const isvSvn = report
198
+ .slice(reportIsvSvnOffset, reportIsvSvnOffset + reportIsvSvnSize)
199
+ .readUInt16LE(0);
200
+ const userData = report.slice(reportDataOffset, reportDataOffset + reportUserDataSize);
201
+ const dataHash = report.slice(reportDataOffset, reportDataOffset + reportDataHashSize);
202
+ return {
203
+ cpuSvn,
204
+ mrEnclave,
205
+ mrSigner,
206
+ isvProdId,
207
+ isvSvn,
208
+ userData,
209
+ dataHash,
210
+ };
211
+ }
212
+ }
213
+ export class TeeTdxParser extends TeeParser {
214
+ //High-level quote structure
215
+ static quoteHeaderSize = 48;
216
+ static tdQuoteBodySize = 584;
217
+ static quoteSignatureDataLen = 4;
218
+ // Header fields
219
+ static headerVersionSize = 2;
220
+ static headerAttestationKeyTypeSize = 2;
221
+ static headerTeeTypeSize = 4;
222
+ static headerReserved1Size = 2;
223
+ static headerReserved2Size = 2;
224
+ static headerQeVendorIdSize = 16;
225
+ static headerUserDataSize = 20;
226
+ // Body fiedls
227
+ static bodyTeeTcbSvnSize = 16;
228
+ static bodyMrSeamSize = 48;
229
+ static bodyMrSignerSeamSize = 48;
230
+ static bodySeamAttributesSize = 8;
231
+ static bodyTdAttributesSize = 8;
232
+ static bodyXfamSize = 8;
233
+ static bodyMrTdSize = 48;
234
+ static bodyMrConfigIdSize = 48;
235
+ static bodyMrOwnerSize = 48;
236
+ static bodyMrOwnerConfigSize = 48;
237
+ static bodyRtmr0Size = 48;
238
+ static bodyRtmr1Size = 48;
239
+ static bodyRtmr2Size = 48;
240
+ static bodyRtmr3Size = 48;
241
+ static bodyReportDataSize = 64;
242
+ // Signature fields
243
+ static sigQuoteSignatureSize = 64;
244
+ static sigAttestationKeySize = 64;
245
+ static sigCertDataTypeSize = 2;
246
+ static sigCertDataSzSize = 4;
247
+ static sigQeReportSize = 384;
248
+ static sigQeReportSignatureSize = 64;
249
+ static sigQeAuthenticationDataSzSize = 2;
250
+ static sigSignatureTypeSize = 2;
251
+ static sigSignatureSzSize = 4;
252
+ parseQuote(data) {
253
+ const { quoteHeaderSize, tdQuoteBodySize, quoteSignatureDataLen, sigQuoteSignatureSize, sigAttestationKeySize, sigCertDataTypeSize, sigCertDataSzSize, sigQeReportSize, sigQeReportSignatureSize, sigQeAuthenticationDataSzSize, sigSignatureTypeSize, sigSignatureSzSize, } = TeeTdxParser;
254
+ const expectedSize = quoteHeaderSize + tdQuoteBodySize + quoteSignatureDataLen;
255
+ if (data.length < expectedSize) {
256
+ throw new TeeQuoteParserError(`quote has invalid length ${data.length}, expected not less than ${expectedSize}`);
257
+ }
258
+ const quoteRemainder = { data: Blob.from(data) };
259
+ const rawHeader = this.getDataAndAdvance(quoteRemainder, quoteHeaderSize);
260
+ const tdQuoteBody = this.getDataAndAdvance(quoteRemainder, tdQuoteBodySize);
261
+ const signatureLen = this.getDataAndAdvance(quoteRemainder, quoteSignatureDataLen);
262
+ const certificationDataSize = signatureLen.readUInt32LE(0);
263
+ const expectedQuoteLen = quoteHeaderSize + tdQuoteBodySize + quoteSignatureDataLen + certificationDataSize;
264
+ if (data.length < expectedQuoteLen) {
265
+ throw new TeeQuoteParserError(`quote has invalid length ${data.length}, expected not less than ${expectedQuoteLen}`);
266
+ }
267
+ const signature = { data: this.getDataAndAdvance(quoteRemainder, certificationDataSize) };
268
+ const quoteSignature = this.getDataAndAdvance(signature, sigQuoteSignatureSize);
269
+ const ecdsaAttestationKey = this.getDataAndAdvance(signature, sigAttestationKeySize);
270
+ const certDataType = this.getDataAndAdvance(signature, sigCertDataTypeSize).readUint16LE(); //expected 6
271
+ if (certDataType !== 6)
272
+ throw new TeeQuoteParserError(`certDataType has invalid value ${certDataType}, expected 6`);
273
+ const certDataSize = this.getDataAndAdvance(signature, sigCertDataSzSize).readUint32LE();
274
+ if (signature.data.length < certDataSize)
275
+ throw new TeeQuoteParserError(`certData has invalid length ${data.length}, expected not less than ${certDataSize}`);
276
+ const qeReport = this.getDataAndAdvance(signature, sigQeReportSize);
277
+ const qeReportSignature = this.getDataAndAdvance(signature, sigQeReportSignatureSize);
278
+ const qeAuthenticationDataSize = this.getDataAndAdvance(signature, sigQeAuthenticationDataSzSize).readUint16LE();
279
+ if (signature.data.length < qeAuthenticationDataSize)
280
+ throw new TeeQuoteParserError(`qeAuthenticationData has invalid length ${data.length}, expected not less than ${qeAuthenticationDataSize}`);
281
+ const qeAuthenticationData = this.getDataAndAdvance(signature, qeAuthenticationDataSize);
282
+ const qeCertificationDataType = this.getDataAndAdvance(signature, sigSignatureTypeSize).readUint16LE(); //expected 5
283
+ if (qeCertificationDataType !== 5)
284
+ throw new TeeQuoteParserError(`signatureType has invalid value ${qeCertificationDataType}, expected 5`);
285
+ const signatureSize = this.getDataAndAdvance(signature, sigSignatureSzSize).readUint32LE();
286
+ if (signature.data.length < signatureSize)
287
+ throw new TeeQuoteParserError(`certChain has invalid length ${data.length}, expected not less than ${signatureSize}`);
288
+ const qeCertificationData = this.getDataAndAdvance(signature, signatureSize);
289
+ const certsPems = splitChain(qeCertificationData.toString()) || []; // [device, platform, root]
290
+ const certsData = certsPems.map((pem) => this.parsePem(pem));
291
+ return {
292
+ quoteType: QuoteType.TDX,
293
+ rawHeader,
294
+ header: this.parseHeader(rawHeader),
295
+ tdQuoteBody,
296
+ quoteSignature,
297
+ ecdsaAttestationKey,
298
+ certDataType,
299
+ qeReport,
300
+ qeReportSignature,
301
+ qeAuthenticationData,
302
+ qeCertificationDataType,
303
+ qeCertificationData,
304
+ certificates: {
305
+ device: {
306
+ pem: certsPems[0],
307
+ x509Data: certsData[0],
308
+ },
309
+ platform: {
310
+ pem: certsPems[1],
311
+ x509Data: certsData[1],
312
+ },
313
+ root: {
314
+ pem: certsPems[2],
315
+ x509Data: certsData[2],
316
+ },
317
+ },
318
+ };
319
+ }
320
+ parseHeader(data) {
321
+ const { headerVersionSize, headerAttestationKeyTypeSize, headerTeeTypeSize, headerReserved1Size, headerReserved2Size, headerQeVendorIdSize, headerUserDataSize, } = TeeTdxParser;
322
+ const headerRemainder = { data: Blob.from(data) };
323
+ const version = this.getDataAndAdvance(headerRemainder, headerVersionSize).readUInt16LE();
324
+ const attestationKeyType = this.getDataAndAdvance(headerRemainder, headerAttestationKeyTypeSize).readUInt16LE();
325
+ const teeType = this.getDataAndAdvance(headerRemainder, headerTeeTypeSize).readUInt32LE();
326
+ const reserved1 = this.getDataAndAdvance(headerRemainder, headerReserved1Size);
327
+ const reserved2 = this.getDataAndAdvance(headerRemainder, headerReserved2Size);
328
+ const qeVendorId = this.getDataAndAdvance(headerRemainder, headerQeVendorIdSize);
329
+ const userData = this.getDataAndAdvance(headerRemainder, headerUserDataSize);
330
+ return {
331
+ version,
332
+ attestationKeyType,
333
+ teeType,
334
+ reserved1,
335
+ reserved2,
336
+ qeVendorId,
337
+ userData,
338
+ };
339
+ }
340
+ parseBody(data) {
341
+ const { bodyTeeTcbSvnSize, bodyMrSeamSize, bodyMrSignerSeamSize, bodySeamAttributesSize, bodyTdAttributesSize, bodyXfamSize, bodyMrTdSize, bodyMrConfigIdSize, bodyMrOwnerSize, bodyMrOwnerConfigSize, bodyRtmr0Size, bodyRtmr1Size, bodyRtmr2Size, bodyRtmr3Size, bodyReportDataSize, reportDataHashSize, } = TeeTdxParser;
342
+ const bodyRemainder = { data: Blob.from(data) };
343
+ if (bodyRemainder.data.length !== TeeTdxParser.tdQuoteBodySize)
344
+ throw new TeeQuoteParserError(`body has invalid length ${bodyRemainder.data.length}, expected ${TeeTdxParser.tdQuoteBodySize}`);
345
+ const teeTcbSvn = this.getDataAndAdvance(bodyRemainder, bodyTeeTcbSvnSize);
346
+ const mrSeam = this.getDataAndAdvance(bodyRemainder, bodyMrSeamSize);
347
+ const mrSignerSeam = this.getDataAndAdvance(bodyRemainder, bodyMrSignerSeamSize);
348
+ const seamAttributes = this.getDataAndAdvance(bodyRemainder, bodySeamAttributesSize);
349
+ const tdAttributes = this.getDataAndAdvance(bodyRemainder, bodyTdAttributesSize);
350
+ const xfam = this.getDataAndAdvance(bodyRemainder, bodyXfamSize);
351
+ const mrTd = this.getDataAndAdvance(bodyRemainder, bodyMrTdSize);
352
+ const mrConfigId = this.getDataAndAdvance(bodyRemainder, bodyMrConfigIdSize);
353
+ const mrOwner = this.getDataAndAdvance(bodyRemainder, bodyMrOwnerSize);
354
+ const mrOwnerConfig = this.getDataAndAdvance(bodyRemainder, bodyMrOwnerConfigSize);
355
+ const rtmr0 = this.getDataAndAdvance(bodyRemainder, bodyRtmr0Size);
356
+ const rtmr1 = this.getDataAndAdvance(bodyRemainder, bodyRtmr1Size);
357
+ const rtmr2 = this.getDataAndAdvance(bodyRemainder, bodyRtmr2Size);
358
+ const rtmr3 = this.getDataAndAdvance(bodyRemainder, bodyRtmr3Size);
359
+ const reportData = this.getDataAndAdvance(bodyRemainder, bodyReportDataSize);
360
+ const dataHash = reportData.slice(0, reportDataHashSize);
361
+ return {
362
+ teeTcbSvn,
363
+ mrSeam,
364
+ mrSignerSeam,
365
+ seamAttributes,
366
+ tdAttributes,
367
+ xfam,
368
+ mrTd,
369
+ mrConfigId,
370
+ mrOwner,
371
+ mrOwnerConfig,
372
+ rtmr0,
373
+ rtmr1,
374
+ rtmr2,
375
+ rtmr3,
376
+ reportData,
377
+ dataHash,
378
+ };
379
+ }
380
+ }
381
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUXVvdGVQYXJzZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGVlL1F1b3RlUGFyc2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDekMsT0FBTyxLQUFLLE1BQU0sTUFBTSxRQUFRLENBQUM7QUFDakMsT0FBTyxLQUFLLEtBQUssTUFBTSxPQUFPLENBQUM7QUFDL0IsT0FBTyxFQUFFLE1BQU0sSUFBSSxJQUFJLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDeEMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2xELE9BQU8sRUFRTCxTQUFTLEdBQ1YsTUFBTSxZQUFZLENBQUM7QUFDcEIsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDckQsT0FBTyxLQUFLLE1BQU0sTUFBTSxRQUFRLENBQUM7QUFFakMsTUFBTSxPQUFnQixTQUFTO0lBQzdCLE1BQU0sQ0FBVSxrQkFBa0IsR0FBRyxFQUFFLENBQUMsQ0FBQyx1REFBdUQ7SUFDdEYsU0FBUyxDQUFDLElBQXVCO1FBQ3pDLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzlGLE1BQU0sZUFBZSxHQUFHLFNBQVMsQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLENBQUM7UUFFOUQsT0FBTztZQUNMLENBQUMsRUFBRSxlQUFlLENBQUMsQ0FBQztZQUNwQixDQUFDLEVBQUUsZUFBZSxDQUFDLENBQUM7WUFDcEIsWUFBWTtTQUNiLENBQUM7SUFDSixDQUFDO0lBRVMsUUFBUSxDQUFDLEdBQVc7UUFDNUIsTUFBTSxJQUFJLEdBQUcsV0FBVyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFD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
@@ -0,0 +1,20 @@
1
+ export declare enum ValidateTeeCertChainErrorCode {
2
+ CERT_CHAIN_IS_INVALID = "CERT_CHAIN_IS_INVALID",
3
+ NOT_ALLOWED_CHALLENGE = "NOT_ALLOWED_CHALLENGE",
4
+ CHALLENGE_IS_INVALID = "CHALLENGE_IS_INVALID"
5
+ }
6
+ export interface ValidateTeeCertChainResult {
7
+ isValid: boolean;
8
+ errorCode?: string;
9
+ errorMessage?: string;
10
+ }
11
+ export declare class TeeCertificateService {
12
+ static validateTeeCertChainOrFail(certsPem: string): Promise<void>;
13
+ static validateTeeCertChain(certsPem: string): Promise<ValidateTeeCertChainResult>;
14
+ private static validateChallenge;
15
+ private static validateGpuChallenge;
16
+ private static validateChallengeSgx;
17
+ private static validateChallengeId;
18
+ private static getGpuInfoFromCert;
19
+ private static validateCertificateWithSubtype;
20
+ }
@@ -0,0 +1,139 @@
1
+ import { SUPERPROTOCOL_CA } from '../constants.js';
2
+ import { ChallengeType, OID_CUSTOM_EXTENSION_CHALLENGE_CERTIFICATE_ID, OID_CUSTOM_EXTENSION_CHALLENGE_COMMON_ID, OID_CUSTOM_EXTENSION_CHALLENGE_ID, OID_CUSTOM_EXTENSION_CHALLENGE_SUBTYPE, OID_CUSTOM_EXTENSION_CHALLENGE_TYPE, OID_CUSTOM_EXTENSION_NVIDIA_INFO_GPU, } from '@super-protocol/pki-common';
3
+ import { TeeSignatureVerifier } from './TeeSignatureVerifier.js';
4
+ import { InvalidSignatureError, NotAllowedChallengeError } from './errors.js';
5
+ import { CertificatesHelper } from '../certificates/index.js';
6
+ import { NvtrustGPUList } from '../proto/Nvtrust.js';
7
+ export var ValidateTeeCertChainErrorCode;
8
+ (function (ValidateTeeCertChainErrorCode) {
9
+ ValidateTeeCertChainErrorCode["CERT_CHAIN_IS_INVALID"] = "CERT_CHAIN_IS_INVALID";
10
+ ValidateTeeCertChainErrorCode["NOT_ALLOWED_CHALLENGE"] = "NOT_ALLOWED_CHALLENGE";
11
+ ValidateTeeCertChainErrorCode["CHALLENGE_IS_INVALID"] = "CHALLENGE_IS_INVALID";
12
+ })(ValidateTeeCertChainErrorCode || (ValidateTeeCertChainErrorCode = {}));
13
+ export class TeeCertificateService {
14
+ static async validateTeeCertChainOrFail(certsPem) {
15
+ const result = await TeeCertificateService.validateTeeCertChain(certsPem);
16
+ if (!result.isValid) {
17
+ throw new Error(result.errorMessage);
18
+ }
19
+ }
20
+ static async validateTeeCertChain(certsPem) {
21
+ const { isValid, errorMessage } = await CertificatesHelper.validateCertChain(certsPem, SUPERPROTOCOL_CA);
22
+ if (!isValid) {
23
+ return {
24
+ isValid: false,
25
+ errorCode: ValidateTeeCertChainErrorCode.CERT_CHAIN_IS_INVALID,
26
+ errorMessage: `Cert chain is invalid! (${errorMessage})`,
27
+ };
28
+ }
29
+ // ROOT CA doesn't have challenge. but we trust it as it is in SUPERPROTOCOL_CA constant
30
+ const { certs } = CertificatesHelper.extractCAFromChain(certsPem);
31
+ const sortedCerts = CertificatesHelper.sortCertsFromLeafToRoot(certs).map((certWithKeyIdent) => certWithKeyIdent.cert);
32
+ try {
33
+ await Promise.all(sortedCerts.map((cert) => TeeCertificateService.validateChallenge(cert)));
34
+ const leafCert = sortedCerts[0];
35
+ await TeeCertificateService.validateGpuChallenge(leafCert);
36
+ }
37
+ catch (err) {
38
+ return {
39
+ isValid: false,
40
+ errorCode: err instanceof NotAllowedChallengeError
41
+ ? ValidateTeeCertChainErrorCode.NOT_ALLOWED_CHALLENGE
42
+ : ValidateTeeCertChainErrorCode.CHALLENGE_IS_INVALID,
43
+ errorMessage: `Challenge is not valid! (${err.message})`,
44
+ };
45
+ }
46
+ return { isValid: true };
47
+ }
48
+ static async validateChallenge(cert) {
49
+ const challengeType = CertificatesHelper.getExtensionValue(cert, OID_CUSTOM_EXTENSION_CHALLENGE_TYPE)?.toString('binary');
50
+ if (challengeType === ChallengeType.Untrusted) {
51
+ throw new NotAllowedChallengeError(`Cert chain has cert with Untrusted challenge`);
52
+ }
53
+ switch (challengeType) {
54
+ case ChallengeType.SGXDCAP:
55
+ TeeCertificateService.validateChallengeSgx(cert);
56
+ break;
57
+ case ChallengeType.TDX:
58
+ case ChallengeType.SEVSNP:
59
+ await TeeCertificateService.validateChallengeId(cert, challengeType);
60
+ break;
61
+ case ChallengeType.Certificate:
62
+ case ChallengeType.Token:
63
+ await TeeCertificateService.validateCertificateWithSubtype(cert, challengeType);
64
+ break;
65
+ default:
66
+ throw new NotAllowedChallengeError(`Challenge type ${challengeType || `[none]`} is missing or not allowed!`);
67
+ }
68
+ }
69
+ static validateGpuChallenge(cert) {
70
+ const gpusInfo = TeeCertificateService.getGpuInfoFromCert(cert);
71
+ const gpusInDebugMode = gpusInfo.filter((gpu) => gpu.dbgStat);
72
+ if (gpusInDebugMode.length) {
73
+ throw new Error(`The certificate contains information about GPU that is running in debug mode: ${JSON.stringify(gpusInDebugMode)}`);
74
+ }
75
+ }
76
+ static validateChallengeSgx(cert) {
77
+ const mrSignerBinaryString = CertificatesHelper.getExtensionValue(cert, OID_CUSTOM_EXTENSION_CHALLENGE_COMMON_ID);
78
+ if (!mrSignerBinaryString) {
79
+ throw new Error(`SGX challenge signature is wrong!`);
80
+ }
81
+ try {
82
+ TeeSignatureVerifier.validateSignatureSgx(mrSignerBinaryString);
83
+ }
84
+ catch (err) {
85
+ throw new Error(`SGX challenge signature is wrong!`);
86
+ }
87
+ }
88
+ static async validateChallengeId(cert, challengeType) {
89
+ const oid = challengeType === ChallengeType.Certificate
90
+ ? OID_CUSTOM_EXTENSION_CHALLENGE_CERTIFICATE_ID
91
+ : OID_CUSTOM_EXTENSION_CHALLENGE_ID;
92
+ const mrEnclaveBinaryString = CertificatesHelper.getExtensionValue(cert, oid);
93
+ if (!mrEnclaveBinaryString) {
94
+ throw new Error(`Challenge id is missing in certificate!`);
95
+ }
96
+ try {
97
+ await TeeSignatureVerifier.validateSignature(mrEnclaveBinaryString, challengeType);
98
+ }
99
+ catch (err) {
100
+ const message = `${challengeType} signature is invalid!`;
101
+ if (err instanceof InvalidSignatureError) {
102
+ throw new Error(`${message} ${err.message}`);
103
+ }
104
+ throw new Error(message);
105
+ }
106
+ }
107
+ static getGpuInfoFromCert(cert) {
108
+ let gpusInfo = { gpus: [] };
109
+ const gpusInfoRaw = CertificatesHelper.getExtensionValue(cert, OID_CUSTOM_EXTENSION_NVIDIA_INFO_GPU);
110
+ if (gpusInfoRaw) {
111
+ try {
112
+ gpusInfo = NvtrustGPUList.decode(gpusInfoRaw);
113
+ }
114
+ catch (err) {
115
+ const message = 'Failed to decode GPU info';
116
+ if (err instanceof Error) {
117
+ throw new Error(`${message} ${err.message}`);
118
+ }
119
+ throw new Error(message);
120
+ }
121
+ }
122
+ return gpusInfo.gpus;
123
+ }
124
+ static async validateCertificateWithSubtype(cert, challengeType) {
125
+ if (challengeType === ChallengeType.Certificate) {
126
+ await TeeCertificateService.validateChallengeId(cert, ChallengeType.Certificate);
127
+ }
128
+ const subType = CertificatesHelper.getExtensionValue(cert, OID_CUSTOM_EXTENSION_CHALLENGE_SUBTYPE)?.toString('binary');
129
+ switch (subType) {
130
+ case ChallengeType.TDX:
131
+ case ChallengeType.SEVSNP:
132
+ await TeeCertificateService.validateChallengeId(cert, subType);
133
+ break;
134
+ default:
135
+ throw new Error(`Unsupported subtype: ${subType}`);
136
+ }
137
+ }
138
+ }
139
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGVlQ2VydGlmaWNhdGVTZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RlZS9UZWVDZXJ0aWZpY2F0ZVNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbkQsT0FBTyxFQUNMLGFBQWEsRUFDYiw2Q0FBNkMsRUFDN0Msd0NBQXdDLEVBQ3hDLGlDQUFpQyxFQUNqQyxzQ0FBc0MsRUFDdEMsbUNBQW1DLEVBQ25DLG9DQUFvQyxHQUNyQyxNQUFNLDRCQUE0QixDQUFDO0FBQ3BDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM5RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQWtCLGNBQWMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBR3JFLE1BQU0sQ0FBTixJQUFZLDZCQUlYO0FBSkQsV0FBWSw2QkFBNkI7SUFDdkMsZ0ZBQStDLENBQUE7SUFDL0MsZ0ZBQStDLENBQUE7SUFDL0MsOEVBQTZDLENBQUE7QUFDL0MsQ0FBQyxFQUpXLDZCQUE2QixLQUE3Qiw2QkFBNkIsUUFJeEM7QUFPRCxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDLE1BQU0sQ0FBQyxLQUFLLENBQUMsMEJBQTBCLENBQUMsUUFBZ0I7UUFDdEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxxQkFBcUIsQ0FBQyxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMxRSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7SUFDSCxDQUFDO0lBRUQsTUFBTSxDQUFDLEtBQUss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
@@ -0,0 +1,24 @@
1
+ /// <reference types="node" />
2
+ import { BinaryType, GetSignatureOptions } from './types.js';
3
+ import { ChallengeType } from '@super-protocol/pki-common';
4
+ export type GetMrEnclaveSignatureFn = (mrEnclave: Buffer, challengeType: ChallengeType) => Promise<Buffer>;
5
+ export type CheckSignatureOptions = {
6
+ getMrEnclaveSignature: GetMrEnclaveSignatureFn;
7
+ };
8
+ export declare const SignatureFolderMap: Partial<Record<ChallengeType, string>>;
9
+ export declare class TeeSignatureVerifier {
10
+ /**
11
+ * Validates tee signature for SGX
12
+ * @param mrSigner - Buffer
13
+ * @throws Error If signature validation fails
14
+ */
15
+ static validateSignatureSgx(mrSigner: BinaryType): void;
16
+ /**
17
+ * Validates TDX and SEV-SNP TEE signature by verifying the MRENCLAVE
18
+ * @param mrEnclave - Binary measurement of the TEE environment to verify
19
+ * @param options - Configuration for signature validation, including getMrEnclaveSignature callback
20
+ * @throws Error If signature validation fails or signature cannot be retrieved
21
+ */
22
+ static validateSignature(mrEnclave: BinaryType, challengeType: ChallengeType, options?: CheckSignatureOptions): Promise<void>;
23
+ static getSignature(mrEnclave: Buffer, challengeType: ChallengeType, options?: GetSignatureOptions): Promise<Buffer>;
24
+ }