@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.
- package/LICENSE +66 -0
- package/README.md +52 -0
- package/dist/cjs/analytics/Analytics.d.ts +17 -0
- package/dist/cjs/analytics/Analytics.js +84 -0
- package/dist/cjs/analytics/AnalyticsError.d.ts +7 -0
- package/dist/cjs/analytics/AnalyticsError.js +12 -0
- package/dist/cjs/analytics/eventProviders/BrowserEventProvider.d.ts +19 -0
- package/dist/cjs/analytics/eventProviders/BrowserEventProvider.js +38 -0
- package/dist/cjs/analytics/eventProviders/EventProvider.d.ts +24 -0
- package/dist/cjs/analytics/eventProviders/EventProvider.js +25 -0
- package/dist/cjs/analytics/eventProviders/NodeEventProvider.d.ts +22 -0
- package/dist/cjs/analytics/eventProviders/NodeEventProvider.js +56 -0
- package/dist/cjs/analytics/transports/AxiosTransport.d.ts +4 -0
- package/dist/cjs/analytics/transports/AxiosTransport.js +60 -0
- package/dist/cjs/analytics/transports/FetchTransport.d.ts +4 -0
- package/dist/cjs/analytics/transports/FetchTransport.js +31 -0
- package/dist/cjs/analytics/types.d.ts +26 -0
- package/dist/cjs/analytics/types.js +3 -0
- package/dist/cjs/certificates/binary-splitter.d.ts +27 -0
- package/dist/cjs/certificates/binary-splitter.js +279 -0
- package/dist/cjs/certificates/crl.d.ts +6 -0
- package/dist/cjs/certificates/crl.js +66 -0
- package/dist/cjs/certificates/generator.d.ts +38 -0
- package/dist/cjs/certificates/generator.js +262 -0
- package/dist/cjs/certificates/helper.d.ts +29 -0
- package/dist/cjs/certificates/helper.js +216 -0
- package/dist/cjs/certificates/index.d.ts +5 -0
- package/dist/cjs/certificates/index.js +22 -0
- package/dist/cjs/certificates/ocsp.d.ts +14 -0
- package/dist/cjs/certificates/ocsp.js +320 -0
- package/dist/cjs/certificates/serializer.d.ts +13 -0
- package/dist/cjs/certificates/serializer.js +142 -0
- package/dist/cjs/certificates/setup-crypto.d.ts +3 -0
- package/dist/cjs/certificates/setup-crypto.js +48 -0
- package/dist/cjs/certificates/types.d.ts +122 -0
- package/dist/cjs/certificates/types.js +10 -0
- package/dist/cjs/config.d.ts +3 -0
- package/dist/cjs/config.js +7 -0
- package/dist/cjs/connectors/BaseConnector.d.ts +52 -0
- package/dist/cjs/connectors/BaseConnector.js +61 -0
- package/dist/cjs/connectors/BlockchainConnector.d.ts +78 -0
- package/dist/cjs/connectors/BlockchainConnector.js +325 -0
- package/dist/cjs/connectors/BlockchainEventsListener.d.ts +33 -0
- package/dist/cjs/connectors/BlockchainEventsListener.js +283 -0
- package/dist/cjs/connectors/index.d.ts +2 -0
- package/dist/cjs/connectors/index.js +11 -0
- package/dist/cjs/constants.d.ts +48 -0
- package/dist/cjs/constants.js +683 -0
- package/dist/cjs/contracts/SuperProtocolToken.d.ts +300 -0
- package/dist/cjs/contracts/SuperProtocolToken.js +3 -0
- package/dist/cjs/contracts/SuperProtocolToken__factory.d.ts +393 -0
- package/dist/cjs/contracts/SuperProtocolToken__factory.js +521 -0
- package/dist/cjs/contracts/typechain-types/common.d.ts +50 -0
- package/dist/cjs/contracts/typechain-types/common.js +3 -0
- package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.d.ts +3340 -0
- package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.js +4335 -0
- package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
- package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +10 -0
- package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.d.ts +1 -0
- package/dist/cjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.js +32 -0
- package/dist/cjs/contracts/typechain-types/factories/index.d.ts +1 -0
- package/dist/cjs/contracts/typechain-types/factories/index.js +32 -0
- package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.d.ts +2299 -0
- package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.js +3 -0
- package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
- package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +3 -0
- package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/index.d.ts +2 -0
- package/dist/cjs/contracts/typechain-types/hardhat-diamond-abi/index.js +3 -0
- package/dist/cjs/contracts/typechain-types/index.d.ts +5 -0
- package/dist/cjs/contracts/typechain-types/index.js +34 -0
- package/dist/cjs/crypto/Crypto.d.ts +70 -0
- package/dist/cjs/crypto/Crypto.js +137 -0
- package/dist/cjs/crypto/index.d.ts +4 -0
- package/dist/cjs/crypto/index.js +37 -0
- package/dist/cjs/crypto/nodejs/AES.d.ts +25 -0
- package/dist/cjs/crypto/nodejs/AES.js +105 -0
- package/dist/cjs/crypto/nodejs/ARIA.d.ts +23 -0
- package/dist/cjs/crypto/nodejs/ARIA.js +77 -0
- package/dist/cjs/crypto/nodejs/ECIES.d.ts +10 -0
- package/dist/cjs/crypto/nodejs/ECIES.js +107 -0
- package/dist/cjs/crypto/nodejs/NativeCrypto.d.ts +46 -0
- package/dist/cjs/crypto/nodejs/NativeCrypto.js +154 -0
- package/dist/cjs/crypto/nodejs/RSA-Hybrid.d.ts +15 -0
- package/dist/cjs/crypto/nodejs/RSA-Hybrid.js +94 -0
- package/dist/cjs/crypto/types.d.ts +10 -0
- package/dist/cjs/crypto/types.js +3 -0
- package/dist/cjs/crypto/utils.d.ts +15 -0
- package/dist/cjs/crypto/utils.js +94 -0
- package/dist/cjs/crypto/utils.spec.d.ts +1 -0
- package/dist/cjs/crypto/utils.spec.js +221 -0
- package/dist/cjs/errors/base.error.d.ts +3 -0
- package/dist/cjs/errors/base.error.js +19 -0
- package/dist/cjs/errors/index.d.ts +3 -0
- package/dist/cjs/errors/index.js +10 -0
- package/dist/cjs/errors/insufficient-funds.error.d.ts +19 -0
- package/dist/cjs/errors/insufficient-funds.error.js +57 -0
- package/dist/cjs/errors/not-found.error.d.ts +3 -0
- package/dist/cjs/errors/not-found.error.js +8 -0
- package/dist/cjs/errors/utils.d.ts +2 -0
- package/dist/cjs/errors/utils.js +30 -0
- package/dist/cjs/index.d.ts +58 -0
- package/dist/cjs/index.js +119 -0
- package/dist/cjs/logger.d.ts +7 -0
- package/dist/cjs/logger.js +12 -0
- package/dist/cjs/models/EtlModel.d.ts +34 -0
- package/dist/cjs/models/EtlModel.js +125 -0
- package/dist/cjs/models/index.d.ts +1 -0
- package/dist/cjs/models/index.js +9 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/polyfills.d.ts +4 -0
- package/dist/cjs/polyfills.js +8 -0
- package/dist/cjs/proto/AmdSevSnp.d.ts +194 -0
- package/dist/cjs/proto/AmdSevSnp.js +358 -0
- package/dist/cjs/proto/Compression.d.ts +43 -0
- package/dist/cjs/proto/Compression.js +133 -0
- package/dist/cjs/proto/Hash.d.ts +37 -0
- package/dist/cjs/proto/Hash.js +104 -0
- package/dist/cjs/proto/Nvtrust.d.ts +116 -0
- package/dist/cjs/proto/Nvtrust.js +159 -0
- package/dist/cjs/proto/OrderReport.d.ts +730 -0
- package/dist/cjs/proto/OrderReport.js +466 -0
- package/dist/cjs/proto/TRI.d.ts +215 -0
- package/dist/cjs/proto/TRI.js +318 -0
- package/dist/cjs/providers/storage/ChunksDownloadDecorator.d.ts +36 -0
- package/dist/cjs/providers/storage/ChunksDownloadDecorator.js +145 -0
- package/dist/cjs/providers/storage/IStorageProvider.d.ts +15 -0
- package/dist/cjs/providers/storage/IStorageProvider.js +3 -0
- package/dist/cjs/providers/storage/S3StorageProvider.d.ts +26 -0
- package/dist/cjs/providers/storage/S3StorageProvider.js +210 -0
- package/dist/cjs/providers/storage/StorageAdapter.d.ts +62 -0
- package/dist/cjs/providers/storage/StorageAdapter.js +300 -0
- package/dist/cjs/providers/storage/StorageContentWriter.d.ts +46 -0
- package/dist/cjs/providers/storage/StorageContentWriter.js +168 -0
- package/dist/cjs/providers/storage/StorageKeyValueAdapter.d.ts +26 -0
- package/dist/cjs/providers/storage/StorageKeyValueAdapter.js +139 -0
- package/dist/cjs/providers/storage/StorageMetadataReader.d.ts +20 -0
- package/dist/cjs/providers/storage/StorageMetadataReader.js +56 -0
- package/dist/cjs/providers/storage/StorjAdapter.d.ts +20 -0
- package/dist/cjs/providers/storage/StorjAdapter.js +60 -0
- package/dist/cjs/providers/storage/StorjCredentialsManager.d.ts +24 -0
- package/dist/cjs/providers/storage/StorjCredentialsManager.js +114 -0
- package/dist/cjs/providers/storage/StorjStorageProvider.d.ts +29 -0
- package/dist/cjs/providers/storage/StorjStorageProvider.js +146 -0
- package/dist/cjs/providers/storage/fs-storage-provider.d.ts +19 -0
- package/dist/cjs/providers/storage/fs-storage-provider.js +162 -0
- package/dist/cjs/providers/storage/getStorageProvider.d.ts +4 -0
- package/dist/cjs/providers/storage/getStorageProvider.js +23 -0
- package/dist/cjs/providers/storage/parseStorageCredentials.d.ts +4 -0
- package/dist/cjs/providers/storage/parseStorageCredentials.js +21 -0
- package/dist/cjs/providers/storage/types.d.ts +29 -0
- package/dist/cjs/providers/storage/types.js +3 -0
- package/dist/cjs/staticModels/Deposits.d.ts +85 -0
- package/dist/cjs/staticModels/Deposits.js +268 -0
- package/dist/cjs/staticModels/Diamond.d.ts +6 -0
- package/dist/cjs/staticModels/Diamond.js +22 -0
- package/dist/cjs/staticModels/ModelPackager.d.ts +18 -0
- package/dist/cjs/staticModels/ModelPackager.js +49 -0
- package/dist/cjs/staticModels/ProviderRewards.d.ts +5 -0
- package/dist/cjs/staticModels/ProviderRewards.js +81 -0
- package/dist/cjs/staticModels/StaticModel.d.ts +6 -0
- package/dist/cjs/staticModels/StaticModel.js +43 -0
- package/dist/cjs/staticModels/Superpro.d.ts +18 -0
- package/dist/cjs/staticModels/Superpro.js +47 -0
- package/dist/cjs/staticModels/SuperproToken.d.ts +113 -0
- package/dist/cjs/staticModels/SuperproToken.js +333 -0
- package/dist/cjs/store.d.ts +17 -0
- package/dist/cjs/store.js +19 -0
- package/dist/cjs/tee/OrderReportService.d.ts +9 -0
- package/dist/cjs/tee/OrderReportService.js +104 -0
- package/dist/cjs/tee/QuoteParser.d.ts +82 -0
- package/dist/cjs/tee/QuoteParser.js +410 -0
- package/dist/cjs/tee/TeeCertificateService.d.ts +20 -0
- package/dist/cjs/tee/TeeCertificateService.js +143 -0
- package/dist/cjs/tee/TeeSignatureVerifier.d.ts +24 -0
- package/dist/cjs/tee/TeeSignatureVerifier.js +118 -0
- package/dist/cjs/tee/errors.d.ts +11 -0
- package/dist/cjs/tee/errors.js +20 -0
- package/dist/cjs/tee/helpers.d.ts +14 -0
- package/dist/cjs/tee/helpers.js +115 -0
- package/dist/cjs/tee/interface.d.ts +63 -0
- package/dist/cjs/tee/interface.js +3 -0
- package/dist/cjs/tee/statuses.d.ts +14 -0
- package/dist/cjs/tee/statuses.js +20 -0
- package/dist/cjs/tee/types.d.ts +126 -0
- package/dist/cjs/tee/types.js +34 -0
- package/dist/cjs/types/Compressor.d.ts +5 -0
- package/dist/cjs/types/Compressor.js +3 -0
- package/dist/cjs/types/Consensus.d.ts +52 -0
- package/dist/cjs/types/Consensus.js +11 -0
- package/dist/cjs/types/DepositInfo.d.ts +6 -0
- package/dist/cjs/types/DepositInfo.js +3 -0
- package/dist/cjs/types/DistributedSecretStorage.d.ts +68 -0
- package/dist/cjs/types/DistributedSecretStorage.js +3 -0
- package/dist/cjs/types/EtlModel.d.ts +2 -0
- package/dist/cjs/types/EtlModel.js +3 -0
- package/dist/cjs/types/Events.d.ts +34 -0
- package/dist/cjs/types/Events.js +3 -0
- package/dist/cjs/types/HardwareInfo.d.ts +10 -0
- package/dist/cjs/types/HardwareInfo.js +3 -0
- package/dist/cjs/types/Marks.d.ts +9 -0
- package/dist/cjs/types/Marks.js +10 -0
- package/dist/cjs/types/Offer.d.ts +76 -0
- package/dist/cjs/types/Offer.js +32 -0
- package/dist/cjs/types/OfferVersion.d.ts +30 -0
- package/dist/cjs/types/OfferVersion.js +9 -0
- package/dist/cjs/types/OptionInfo.d.ts +8 -0
- package/dist/cjs/types/OptionInfo.js +3 -0
- package/dist/cjs/types/Order.d.ts +144 -0
- package/dist/cjs/types/Order.js +100 -0
- package/dist/cjs/types/OrderUsage.d.ts +28 -0
- package/dist/cjs/types/OrderUsage.js +3 -0
- package/dist/cjs/types/Origins.d.ts +6 -0
- package/dist/cjs/types/Origins.js +3 -0
- package/dist/cjs/types/Provider.d.ts +7 -0
- package/dist/cjs/types/Provider.js +3 -0
- package/dist/cjs/types/ProviderRewards.d.ts +5 -0
- package/dist/cjs/types/ProviderRewards.js +3 -0
- package/dist/cjs/types/ResourceLoader.d.ts +28 -0
- package/dist/cjs/types/ResourceLoader.js +3 -0
- package/dist/cjs/types/SlotInfo.d.ts +7 -0
- package/dist/cjs/types/SlotInfo.js +3 -0
- package/dist/cjs/types/SlotUsage.d.ts +11 -0
- package/dist/cjs/types/SlotUsage.js +9 -0
- package/dist/cjs/types/Superpro.d.ts +9 -0
- package/dist/cjs/types/Superpro.js +14 -0
- package/dist/cjs/types/TeeOfferInfo.d.ts +38 -0
- package/dist/cjs/types/TeeOfferInfo.js +3 -0
- package/dist/cjs/types/TeeOfferOption.d.ts +13 -0
- package/dist/cjs/types/TeeOfferOption.js +3 -0
- package/dist/cjs/types/TeeOfferSlot.d.ts +8 -0
- package/dist/cjs/types/TeeOfferSlot.js +3 -0
- package/dist/cjs/types/ValueOfferSlot.d.ts +18 -0
- package/dist/cjs/types/ValueOfferSlot.js +3 -0
- package/dist/cjs/types/Web3.d.ts +30 -0
- package/dist/cjs/types/Web3.js +3 -0
- package/dist/cjs/types/blockchainConnector/StorageAccess.d.ts +8 -0
- package/dist/cjs/types/blockchainConnector/StorageAccess.js +3 -0
- package/dist/cjs/types/index.d.ts +25 -0
- package/dist/cjs/types/index.js +42 -0
- package/dist/cjs/types/storage/StorageAccess.d.ts +7 -0
- package/dist/cjs/types/storage/StorageAccess.js +3 -0
- package/dist/cjs/types/storage/StorageFileAccess.d.ts +5 -0
- package/dist/cjs/types/storage/StorageFileAccess.js +3 -0
- package/dist/cjs/types/storage/StorageObject.d.ts +8 -0
- package/dist/cjs/types/storage/StorageObject.js +3 -0
- package/dist/cjs/utils/CryptoKeysTransformer.d.ts +42 -0
- package/dist/cjs/utils/CryptoKeysTransformer.js +247 -0
- package/dist/cjs/utils/Monitoring.d.ts +11 -0
- package/dist/cjs/utils/Monitoring.js +51 -0
- package/dist/cjs/utils/NonceTracker.d.ts +20 -0
- package/dist/cjs/utils/NonceTracker.js +82 -0
- package/dist/cjs/utils/PubSub.d.ts +9 -0
- package/dist/cjs/utils/PubSub.js +35 -0
- package/dist/cjs/utils/TxManager.d.ts +28 -0
- package/dist/cjs/utils/TxManager.js +285 -0
- package/dist/cjs/utils/cache/index.d.ts +2 -0
- package/dist/cjs/utils/cache/index.js +21 -0
- package/dist/cjs/utils/cache/memory.d.ts +19 -0
- package/dist/cjs/utils/cache/memory.js +66 -0
- package/dist/cjs/utils/cache/memory.spec.d.ts +1 -0
- package/dist/cjs/utils/cache/memory.spec.js +91 -0
- package/dist/cjs/utils/cache/types.d.ts +17 -0
- package/dist/cjs/utils/cache/types.js +3 -0
- package/dist/cjs/utils/compressors/GzipCompressor.d.ts +8 -0
- package/dist/cjs/utils/compressors/GzipCompressor.js +22 -0
- package/dist/cjs/utils/compressors/UncompressedCompressor.d.ts +8 -0
- package/dist/cjs/utils/compressors/UncompressedCompressor.js +17 -0
- package/dist/cjs/utils/compressors/index.d.ts +2 -0
- package/dist/cjs/utils/compressors/index.js +19 -0
- package/dist/cjs/utils/helper.d.ts +87 -0
- package/dist/cjs/utils/helper.js +576 -0
- package/dist/cjs/utils/helpers/calculateObjectHash.d.ts +8 -0
- package/dist/cjs/utils/helpers/calculateObjectHash.js +25 -0
- package/dist/cjs/utils/helpers/getRawRpc.d.ts +2 -0
- package/dist/cjs/utils/helpers/getRawRpc.js +19 -0
- package/dist/cjs/utils/helpers/getStreamChunks.d.ts +9 -0
- package/dist/cjs/utils/helpers/getStreamChunks.js +35 -0
- package/dist/cjs/utils/helpers/index.d.ts +5 -0
- package/dist/cjs/utils/helpers/index.js +22 -0
- package/dist/cjs/utils/helpers/promise.d.ts +2 -0
- package/dist/cjs/utils/helpers/promise.js +10 -0
- package/dist/cjs/utils/helpers/streamToBuffer.d.ts +4 -0
- package/dist/cjs/utils/helpers/streamToBuffer.js +13 -0
- package/dist/cjs/utils/helpers/tryWithInterval.d.ts +13 -0
- package/dist/cjs/utils/helpers/tryWithInterval.js +39 -0
- package/dist/cjs/utils/rent-calculator/index.d.ts +2 -0
- package/dist/cjs/utils/rent-calculator/index.js +19 -0
- package/dist/cjs/utils/rent-calculator/rent-calculator.d.ts +14 -0
- package/dist/cjs/utils/rent-calculator/rent-calculator.js +114 -0
- package/dist/cjs/utils/rent-calculator/types.d.ts +14 -0
- package/dist/cjs/utils/rent-calculator/types.js +3 -0
- package/dist/cjs/utils/resourceLoaders/BaseResourceLoader.d.ts +10 -0
- package/dist/cjs/utils/resourceLoaders/BaseResourceLoader.js +14 -0
- package/dist/cjs/utils/resourceLoaders/StorageProviderLoader.d.ts +18 -0
- package/dist/cjs/utils/resourceLoaders/StorageProviderLoader.js +60 -0
- package/dist/cjs/utils/resourceLoaders/UrlResourceLoader.d.ts +9 -0
- package/dist/cjs/utils/resourceLoaders/UrlResourceLoader.js +51 -0
- package/dist/cjs/utils/resourceLoaders/getResourceLoader.d.ts +5 -0
- package/dist/cjs/utils/resourceLoaders/getResourceLoader.js +15 -0
- package/dist/cjs/utils/resourceLoaders/index.d.ts +1 -0
- package/dist/cjs/utils/resourceLoaders/index.js +18 -0
- package/dist/cjs/utils/schema-utils/index.d.ts +2 -0
- package/dist/cjs/utils/schema-utils/index.js +9 -0
- package/dist/cjs/utils/schema-utils/serializer.d.ts +3 -0
- package/dist/cjs/utils/schema-utils/serializer.js +31 -0
- package/dist/cjs/utils/schema-utils/validator.d.ts +7 -0
- package/dist/cjs/utils/schema-utils/validator.js +49 -0
- package/dist/cjs/utils/tcb.d.ts +2 -0
- package/dist/cjs/utils/tcb.js +13 -0
- package/dist/cjs/utils/tokens/get-tokens-info.d.ts +8 -0
- package/dist/cjs/utils/tokens/get-tokens-info.js +32 -0
- package/dist/cjs/utils/tokens/index.d.ts +1 -0
- package/dist/cjs/utils/tokens/index.js +18 -0
- package/dist/cjs/utils/types.d.ts +13 -0
- package/dist/cjs/utils/types.js +3 -0
- package/dist/mjs/analytics/Analytics.d.ts +17 -0
- package/dist/mjs/analytics/Analytics.js +78 -0
- package/dist/mjs/analytics/AnalyticsError.d.ts +7 -0
- package/dist/mjs/analytics/AnalyticsError.js +8 -0
- package/dist/mjs/analytics/eventProviders/BrowserEventProvider.d.ts +19 -0
- package/dist/mjs/analytics/eventProviders/BrowserEventProvider.js +32 -0
- package/dist/mjs/analytics/eventProviders/EventProvider.d.ts +24 -0
- package/dist/mjs/analytics/eventProviders/EventProvider.js +22 -0
- package/dist/mjs/analytics/eventProviders/NodeEventProvider.d.ts +22 -0
- package/dist/mjs/analytics/eventProviders/NodeEventProvider.js +50 -0
- package/dist/mjs/analytics/transports/AxiosTransport.d.ts +4 -0
- package/dist/mjs/analytics/transports/AxiosTransport.js +31 -0
- package/dist/mjs/analytics/transports/FetchTransport.d.ts +4 -0
- package/dist/mjs/analytics/transports/FetchTransport.js +28 -0
- package/dist/mjs/analytics/types.d.ts +26 -0
- package/dist/mjs/analytics/types.js +2 -0
- package/dist/mjs/certificates/binary-splitter.d.ts +27 -0
- package/dist/mjs/certificates/binary-splitter.js +275 -0
- package/dist/mjs/certificates/crl.d.ts +6 -0
- package/dist/mjs/certificates/crl.js +39 -0
- package/dist/mjs/certificates/generator.d.ts +38 -0
- package/dist/mjs/certificates/generator.js +255 -0
- package/dist/mjs/certificates/helper.d.ts +29 -0
- package/dist/mjs/certificates/helper.js +186 -0
- package/dist/mjs/certificates/index.d.ts +5 -0
- package/dist/mjs/certificates/index.js +6 -0
- package/dist/mjs/certificates/ocsp.d.ts +14 -0
- package/dist/mjs/certificates/ocsp.js +290 -0
- package/dist/mjs/certificates/serializer.d.ts +13 -0
- package/dist/mjs/certificates/serializer.js +135 -0
- package/dist/mjs/certificates/setup-crypto.d.ts +3 -0
- package/dist/mjs/certificates/setup-crypto.js +22 -0
- package/dist/mjs/certificates/types.d.ts +122 -0
- package/dist/mjs/certificates/types.js +7 -0
- package/dist/mjs/config.d.ts +3 -0
- package/dist/mjs/config.js +4 -0
- package/dist/mjs/connectors/BaseConnector.d.ts +52 -0
- package/dist/mjs/connectors/BaseConnector.js +54 -0
- package/dist/mjs/connectors/BlockchainConnector.d.ts +78 -0
- package/dist/mjs/connectors/BlockchainConnector.js +320 -0
- package/dist/mjs/connectors/BlockchainEventsListener.d.ts +33 -0
- package/dist/mjs/connectors/BlockchainEventsListener.js +254 -0
- package/dist/mjs/connectors/index.d.ts +2 -0
- package/dist/mjs/connectors/index.js +3 -0
- package/dist/mjs/constants.d.ts +48 -0
- package/dist/mjs/constants.js +680 -0
- package/dist/mjs/contracts/SuperProtocolToken.d.ts +300 -0
- package/dist/mjs/contracts/SuperProtocolToken.js +2 -0
- package/dist/mjs/contracts/SuperProtocolToken__factory.d.ts +393 -0
- package/dist/mjs/contracts/SuperProtocolToken__factory.js +517 -0
- package/dist/mjs/contracts/typechain-types/common.d.ts +50 -0
- package/dist/mjs/contracts/typechain-types/common.js +2 -0
- package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.d.ts +3340 -0
- package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/App__factory.js +4331 -0
- package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
- package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +6 -0
- package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.d.ts +1 -0
- package/dist/mjs/contracts/typechain-types/factories/hardhat-diamond-abi/index.js +6 -0
- package/dist/mjs/contracts/typechain-types/factories/index.d.ts +1 -0
- package/dist/mjs/contracts/typechain-types/factories/index.js +6 -0
- package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.d.ts +2299 -0
- package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/App.js +2 -0
- package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.d.ts +1 -0
- package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/HardhatDiamondABI.sol/index.js +2 -0
- package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/index.d.ts +2 -0
- package/dist/mjs/contracts/typechain-types/hardhat-diamond-abi/index.js +2 -0
- package/dist/mjs/contracts/typechain-types/index.d.ts +5 -0
- package/dist/mjs/contracts/typechain-types/index.js +7 -0
- package/dist/mjs/crypto/Crypto.d.ts +70 -0
- package/dist/mjs/crypto/Crypto.js +132 -0
- package/dist/mjs/crypto/index.d.ts +4 -0
- package/dist/mjs/crypto/index.js +5 -0
- package/dist/mjs/crypto/nodejs/AES.d.ts +25 -0
- package/dist/mjs/crypto/nodejs/AES.js +77 -0
- package/dist/mjs/crypto/nodejs/ARIA.d.ts +23 -0
- package/dist/mjs/crypto/nodejs/ARIA.js +72 -0
- package/dist/mjs/crypto/nodejs/ECIES.d.ts +10 -0
- package/dist/mjs/crypto/nodejs/ECIES.js +82 -0
- package/dist/mjs/crypto/nodejs/NativeCrypto.d.ts +46 -0
- package/dist/mjs/crypto/nodejs/NativeCrypto.js +152 -0
- package/dist/mjs/crypto/nodejs/RSA-Hybrid.d.ts +15 -0
- package/dist/mjs/crypto/nodejs/RSA-Hybrid.js +89 -0
- package/dist/mjs/crypto/types.d.ts +10 -0
- package/dist/mjs/crypto/types.js +2 -0
- package/dist/mjs/crypto/utils.d.ts +15 -0
- package/dist/mjs/crypto/utils.js +81 -0
- package/dist/mjs/crypto/utils.spec.d.ts +1 -0
- package/dist/mjs/crypto/utils.spec.js +219 -0
- package/dist/mjs/errors/base.error.d.ts +3 -0
- package/dist/mjs/errors/base.error.js +15 -0
- package/dist/mjs/errors/index.d.ts +3 -0
- package/dist/mjs/errors/index.js +4 -0
- package/dist/mjs/errors/insufficient-funds.error.d.ts +19 -0
- package/dist/mjs/errors/insufficient-funds.error.js +53 -0
- package/dist/mjs/errors/not-found.error.d.ts +3 -0
- package/dist/mjs/errors/not-found.error.js +4 -0
- package/dist/mjs/errors/utils.d.ts +2 -0
- package/dist/mjs/errors/utils.js +22 -0
- package/dist/mjs/index.d.ts +58 -0
- package/dist/mjs/index.js +53 -0
- package/dist/mjs/logger.d.ts +7 -0
- package/dist/mjs/logger.js +7 -0
- package/dist/mjs/models/EtlModel.d.ts +34 -0
- package/dist/mjs/models/EtlModel.js +96 -0
- package/dist/mjs/models/index.d.ts +1 -0
- package/dist/mjs/models/index.js +2 -0
- package/dist/mjs/package.json +1 -0
- package/dist/mjs/polyfills.d.ts +4 -0
- package/dist/mjs/polyfills.js +8 -0
- package/dist/mjs/proto/AmdSevSnp.d.ts +194 -0
- package/dist/mjs/proto/AmdSevSnp.js +348 -0
- package/dist/mjs/proto/Compression.d.ts +43 -0
- package/dist/mjs/proto/Compression.js +125 -0
- package/dist/mjs/proto/Hash.d.ts +37 -0
- package/dist/mjs/proto/Hash.js +98 -0
- package/dist/mjs/proto/Nvtrust.d.ts +116 -0
- package/dist/mjs/proto/Nvtrust.js +153 -0
- package/dist/mjs/proto/OrderReport.d.ts +730 -0
- package/dist/mjs/proto/OrderReport.js +460 -0
- package/dist/mjs/proto/TRI.d.ts +215 -0
- package/dist/mjs/proto/TRI.js +312 -0
- package/dist/mjs/providers/storage/ChunksDownloadDecorator.d.ts +36 -0
- package/dist/mjs/providers/storage/ChunksDownloadDecorator.js +139 -0
- package/dist/mjs/providers/storage/IStorageProvider.d.ts +15 -0
- package/dist/mjs/providers/storage/IStorageProvider.js +2 -0
- package/dist/mjs/providers/storage/S3StorageProvider.d.ts +26 -0
- package/dist/mjs/providers/storage/S3StorageProvider.js +203 -0
- package/dist/mjs/providers/storage/StorageAdapter.d.ts +62 -0
- package/dist/mjs/providers/storage/StorageAdapter.js +270 -0
- package/dist/mjs/providers/storage/StorageContentWriter.d.ts +46 -0
- package/dist/mjs/providers/storage/StorageContentWriter.js +161 -0
- package/dist/mjs/providers/storage/StorageKeyValueAdapter.d.ts +26 -0
- package/dist/mjs/providers/storage/StorageKeyValueAdapter.js +133 -0
- package/dist/mjs/providers/storage/StorageMetadataReader.d.ts +20 -0
- package/dist/mjs/providers/storage/StorageMetadataReader.js +50 -0
- package/dist/mjs/providers/storage/StorjAdapter.d.ts +20 -0
- package/dist/mjs/providers/storage/StorjAdapter.js +54 -0
- package/dist/mjs/providers/storage/StorjCredentialsManager.d.ts +24 -0
- package/dist/mjs/providers/storage/StorjCredentialsManager.js +84 -0
- package/dist/mjs/providers/storage/StorjStorageProvider.d.ts +29 -0
- package/dist/mjs/providers/storage/StorjStorageProvider.js +140 -0
- package/dist/mjs/providers/storage/fs-storage-provider.d.ts +19 -0
- package/dist/mjs/providers/storage/fs-storage-provider.js +132 -0
- package/dist/mjs/providers/storage/getStorageProvider.d.ts +4 -0
- package/dist/mjs/providers/storage/getStorageProvider.js +18 -0
- package/dist/mjs/providers/storage/parseStorageCredentials.d.ts +4 -0
- package/dist/mjs/providers/storage/parseStorageCredentials.js +17 -0
- package/dist/mjs/providers/storage/types.d.ts +29 -0
- package/dist/mjs/providers/storage/types.js +2 -0
- package/dist/mjs/staticModels/Deposits.d.ts +85 -0
- package/dist/mjs/staticModels/Deposits.js +263 -0
- package/dist/mjs/staticModels/Diamond.d.ts +6 -0
- package/dist/mjs/staticModels/Diamond.js +17 -0
- package/dist/mjs/staticModels/ModelPackager.d.ts +18 -0
- package/dist/mjs/staticModels/ModelPackager.js +45 -0
- package/dist/mjs/staticModels/ProviderRewards.d.ts +5 -0
- package/dist/mjs/staticModels/ProviderRewards.js +76 -0
- package/dist/mjs/staticModels/StaticModel.d.ts +6 -0
- package/dist/mjs/staticModels/StaticModel.js +38 -0
- package/dist/mjs/staticModels/Superpro.d.ts +18 -0
- package/dist/mjs/staticModels/Superpro.js +45 -0
- package/dist/mjs/staticModels/SuperproToken.d.ts +113 -0
- package/dist/mjs/staticModels/SuperproToken.js +328 -0
- package/dist/mjs/store.d.ts +17 -0
- package/dist/mjs/store.js +17 -0
- package/dist/mjs/tee/OrderReportService.d.ts +9 -0
- package/dist/mjs/tee/OrderReportService.js +97 -0
- package/dist/mjs/tee/QuoteParser.d.ts +82 -0
- package/dist/mjs/tee/QuoteParser.js +381 -0
- package/dist/mjs/tee/TeeCertificateService.d.ts +20 -0
- package/dist/mjs/tee/TeeCertificateService.js +139 -0
- package/dist/mjs/tee/TeeSignatureVerifier.d.ts +24 -0
- package/dist/mjs/tee/TeeSignatureVerifier.js +111 -0
- package/dist/mjs/tee/errors.d.ts +11 -0
- package/dist/mjs/tee/errors.js +12 -0
- package/dist/mjs/tee/helpers.d.ts +14 -0
- package/dist/mjs/tee/helpers.js +110 -0
- package/dist/mjs/tee/interface.d.ts +63 -0
- package/dist/mjs/tee/interface.js +2 -0
- package/dist/mjs/tee/statuses.d.ts +14 -0
- package/dist/mjs/tee/statuses.js +17 -0
- package/dist/mjs/tee/types.d.ts +126 -0
- package/dist/mjs/tee/types.js +28 -0
- package/dist/mjs/types/Compressor.d.ts +5 -0
- package/dist/mjs/types/Compressor.js +2 -0
- package/dist/mjs/types/Consensus.d.ts +52 -0
- package/dist/mjs/types/Consensus.js +8 -0
- package/dist/mjs/types/DepositInfo.d.ts +6 -0
- package/dist/mjs/types/DepositInfo.js +2 -0
- package/dist/mjs/types/DistributedSecretStorage.d.ts +68 -0
- package/dist/mjs/types/DistributedSecretStorage.js +2 -0
- package/dist/mjs/types/EtlModel.d.ts +2 -0
- package/dist/mjs/types/EtlModel.js +2 -0
- package/dist/mjs/types/Events.d.ts +34 -0
- package/dist/mjs/types/Events.js +2 -0
- package/dist/mjs/types/HardwareInfo.d.ts +10 -0
- package/dist/mjs/types/HardwareInfo.js +2 -0
- package/dist/mjs/types/Marks.d.ts +9 -0
- package/dist/mjs/types/Marks.js +7 -0
- package/dist/mjs/types/Offer.d.ts +76 -0
- package/dist/mjs/types/Offer.js +29 -0
- package/dist/mjs/types/OfferVersion.d.ts +30 -0
- package/dist/mjs/types/OfferVersion.js +6 -0
- package/dist/mjs/types/OptionInfo.d.ts +8 -0
- package/dist/mjs/types/OptionInfo.js +2 -0
- package/dist/mjs/types/Order.d.ts +144 -0
- package/dist/mjs/types/Order.js +91 -0
- package/dist/mjs/types/OrderUsage.d.ts +28 -0
- package/dist/mjs/types/OrderUsage.js +2 -0
- package/dist/mjs/types/Origins.d.ts +6 -0
- package/dist/mjs/types/Origins.js +2 -0
- package/dist/mjs/types/Provider.d.ts +7 -0
- package/dist/mjs/types/Provider.js +2 -0
- package/dist/mjs/types/ProviderRewards.d.ts +5 -0
- package/dist/mjs/types/ProviderRewards.js +2 -0
- package/dist/mjs/types/ResourceLoader.d.ts +28 -0
- package/dist/mjs/types/ResourceLoader.js +2 -0
- package/dist/mjs/types/SlotInfo.d.ts +7 -0
- package/dist/mjs/types/SlotInfo.js +2 -0
- package/dist/mjs/types/SlotUsage.d.ts +11 -0
- package/dist/mjs/types/SlotUsage.js +6 -0
- package/dist/mjs/types/Superpro.d.ts +9 -0
- package/dist/mjs/types/Superpro.js +11 -0
- package/dist/mjs/types/TeeOfferInfo.d.ts +38 -0
- package/dist/mjs/types/TeeOfferInfo.js +2 -0
- package/dist/mjs/types/TeeOfferOption.d.ts +13 -0
- package/dist/mjs/types/TeeOfferOption.js +2 -0
- package/dist/mjs/types/TeeOfferSlot.d.ts +8 -0
- package/dist/mjs/types/TeeOfferSlot.js +2 -0
- package/dist/mjs/types/ValueOfferSlot.d.ts +18 -0
- package/dist/mjs/types/ValueOfferSlot.js +2 -0
- package/dist/mjs/types/Web3.d.ts +30 -0
- package/dist/mjs/types/Web3.js +2 -0
- package/dist/mjs/types/blockchainConnector/StorageAccess.d.ts +8 -0
- package/dist/mjs/types/blockchainConnector/StorageAccess.js +2 -0
- package/dist/mjs/types/index.d.ts +25 -0
- package/dist/mjs/types/index.js +26 -0
- package/dist/mjs/types/storage/StorageAccess.d.ts +7 -0
- package/dist/mjs/types/storage/StorageAccess.js +2 -0
- package/dist/mjs/types/storage/StorageFileAccess.d.ts +5 -0
- package/dist/mjs/types/storage/StorageFileAccess.js +2 -0
- package/dist/mjs/types/storage/StorageObject.d.ts +8 -0
- package/dist/mjs/types/storage/StorageObject.js +2 -0
- package/dist/mjs/utils/CryptoKeysTransformer.d.ts +42 -0
- package/dist/mjs/utils/CryptoKeysTransformer.js +240 -0
- package/dist/mjs/utils/Monitoring.d.ts +11 -0
- package/dist/mjs/utils/Monitoring.js +44 -0
- package/dist/mjs/utils/NonceTracker.d.ts +20 -0
- package/dist/mjs/utils/NonceTracker.js +77 -0
- package/dist/mjs/utils/PubSub.d.ts +9 -0
- package/dist/mjs/utils/PubSub.js +32 -0
- package/dist/mjs/utils/TxManager.d.ts +28 -0
- package/dist/mjs/utils/TxManager.js +278 -0
- package/dist/mjs/utils/cache/index.d.ts +2 -0
- package/dist/mjs/utils/cache/index.js +3 -0
- package/dist/mjs/utils/cache/memory.d.ts +19 -0
- package/dist/mjs/utils/cache/memory.js +61 -0
- package/dist/mjs/utils/cache/memory.spec.d.ts +1 -0
- package/dist/mjs/utils/cache/memory.spec.js +89 -0
- package/dist/mjs/utils/cache/types.d.ts +17 -0
- package/dist/mjs/utils/cache/types.js +2 -0
- package/dist/mjs/utils/compressors/GzipCompressor.d.ts +8 -0
- package/dist/mjs/utils/compressors/GzipCompressor.js +15 -0
- package/dist/mjs/utils/compressors/UncompressedCompressor.d.ts +8 -0
- package/dist/mjs/utils/compressors/UncompressedCompressor.js +13 -0
- package/dist/mjs/utils/compressors/index.d.ts +2 -0
- package/dist/mjs/utils/compressors/index.js +3 -0
- package/dist/mjs/utils/helper.d.ts +87 -0
- package/dist/mjs/utils/helper.js +526 -0
- package/dist/mjs/utils/helpers/calculateObjectHash.d.ts +8 -0
- package/dist/mjs/utils/helpers/calculateObjectHash.js +18 -0
- package/dist/mjs/utils/helpers/getRawRpc.d.ts +2 -0
- package/dist/mjs/utils/helpers/getRawRpc.js +15 -0
- package/dist/mjs/utils/helpers/getStreamChunks.d.ts +9 -0
- package/dist/mjs/utils/helpers/getStreamChunks.js +31 -0
- package/dist/mjs/utils/helpers/index.d.ts +5 -0
- package/dist/mjs/utils/helpers/index.js +6 -0
- package/dist/mjs/utils/helpers/promise.d.ts +2 -0
- package/dist/mjs/utils/helpers/promise.js +5 -0
- package/dist/mjs/utils/helpers/streamToBuffer.d.ts +4 -0
- package/dist/mjs/utils/helpers/streamToBuffer.js +9 -0
- package/dist/mjs/utils/helpers/tryWithInterval.d.ts +13 -0
- package/dist/mjs/utils/helpers/tryWithInterval.js +35 -0
- package/dist/mjs/utils/rent-calculator/index.d.ts +2 -0
- package/dist/mjs/utils/rent-calculator/index.js +3 -0
- package/dist/mjs/utils/rent-calculator/rent-calculator.d.ts +14 -0
- package/dist/mjs/utils/rent-calculator/rent-calculator.js +110 -0
- package/dist/mjs/utils/rent-calculator/types.d.ts +14 -0
- package/dist/mjs/utils/rent-calculator/types.js +2 -0
- package/dist/mjs/utils/resourceLoaders/BaseResourceLoader.d.ts +10 -0
- package/dist/mjs/utils/resourceLoaders/BaseResourceLoader.js +10 -0
- package/dist/mjs/utils/resourceLoaders/StorageProviderLoader.d.ts +18 -0
- package/dist/mjs/utils/resourceLoaders/StorageProviderLoader.js +53 -0
- package/dist/mjs/utils/resourceLoaders/UrlResourceLoader.d.ts +9 -0
- package/dist/mjs/utils/resourceLoaders/UrlResourceLoader.js +44 -0
- package/dist/mjs/utils/resourceLoaders/getResourceLoader.d.ts +5 -0
- package/dist/mjs/utils/resourceLoaders/getResourceLoader.js +11 -0
- package/dist/mjs/utils/resourceLoaders/index.d.ts +1 -0
- package/dist/mjs/utils/resourceLoaders/index.js +2 -0
- package/dist/mjs/utils/schema-utils/index.d.ts +2 -0
- package/dist/mjs/utils/schema-utils/index.js +3 -0
- package/dist/mjs/utils/schema-utils/serializer.d.ts +3 -0
- package/dist/mjs/utils/schema-utils/serializer.js +26 -0
- package/dist/mjs/utils/schema-utils/validator.d.ts +7 -0
- package/dist/mjs/utils/schema-utils/validator.js +45 -0
- package/dist/mjs/utils/tcb.d.ts +2 -0
- package/dist/mjs/utils/tcb.js +9 -0
- package/dist/mjs/utils/tokens/get-tokens-info.d.ts +8 -0
- package/dist/mjs/utils/tokens/get-tokens-info.js +25 -0
- package/dist/mjs/utils/tokens/index.d.ts +1 -0
- package/dist/mjs/utils/tokens/index.js +2 -0
- package/dist/mjs/utils/types.d.ts +13 -0
- package/dist/mjs/utils/types.js +2 -0
- package/package.json +103 -0
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.CertificateGenerator = void 0;
|
|
7
|
+
const assert_1 = __importDefault(require("assert"));
|
|
8
|
+
const crypto_1 = require("crypto");
|
|
9
|
+
const node_forge_1 = __importDefault(require("node-forge"));
|
|
10
|
+
const x509_1 = require("@peculiar/x509");
|
|
11
|
+
const setup_crypto_js_1 = require("./setup-crypto.js");
|
|
12
|
+
const CryptoKeysTransformer_js_1 = require("../utils/CryptoKeysTransformer.js");
|
|
13
|
+
const helper_js_1 = require("../utils/helper.js");
|
|
14
|
+
const MAX_X509_SERIAL = BigInt('0x' + 'F'.repeat(40));
|
|
15
|
+
const ONE_HOUR_MS = 60 * 60 * 1000; // 1 hour in milliseconds
|
|
16
|
+
const principalAttributeMap = {
|
|
17
|
+
commonName: 'CN',
|
|
18
|
+
country: 'C',
|
|
19
|
+
localityName: 'L',
|
|
20
|
+
stateName: 'ST',
|
|
21
|
+
organization: 'O',
|
|
22
|
+
organizationalUnit: 'OU',
|
|
23
|
+
};
|
|
24
|
+
const notAllowedCertificateCustomExtensions = [...Object.values(node_forge_1.default.pki.oids)];
|
|
25
|
+
class CertificateGenerator {
|
|
26
|
+
/**
|
|
27
|
+
* Generates certificate based on the provided parameters.
|
|
28
|
+
* @param params - Parameters for generating the certificate.
|
|
29
|
+
* @returns The generated certificate in PEM format.
|
|
30
|
+
*/
|
|
31
|
+
static async generateCert(params) {
|
|
32
|
+
const ca = Boolean(params.ca);
|
|
33
|
+
const { publicKey: subjectPublicKey, privateKey: signerPrivateKey } = await CertificateGenerator.getCryptoKeys(params);
|
|
34
|
+
const signingAlgorithm = subjectPublicKey.algorithm;
|
|
35
|
+
const extensions = [new x509_1.BasicConstraintsExtension(ca, undefined, true)];
|
|
36
|
+
const extendedKeyUsageItems = [];
|
|
37
|
+
if (signingAlgorithm.namedCurve !== 'K-256' && params.dnsNames?.length) {
|
|
38
|
+
const generalNames = params.dnsNames.map((dnsName) => ({
|
|
39
|
+
type: ((0, helper_js_1.isIpAddress)(dnsName) ? 'ip' : 'dns'),
|
|
40
|
+
value: dnsName,
|
|
41
|
+
}));
|
|
42
|
+
extensions.push(new x509_1.SubjectAlternativeNameExtension(generalNames));
|
|
43
|
+
extendedKeyUsageItems.push(...[x509_1.ExtendedKeyUsage.serverAuth, x509_1.ExtendedKeyUsage.clientAuth]);
|
|
44
|
+
}
|
|
45
|
+
if (params.ocspSigning) {
|
|
46
|
+
extendedKeyUsageItems.push(x509_1.ExtendedKeyUsage.ocspSigning);
|
|
47
|
+
}
|
|
48
|
+
if (params.ocspExtension) {
|
|
49
|
+
const { ocspUrl, issuerCertUrl } = params.ocspExtension;
|
|
50
|
+
extensions.push(new x509_1.AuthorityInfoAccessExtension({
|
|
51
|
+
ocsp: [ocspUrl],
|
|
52
|
+
...(issuerCertUrl ? { caIssuers: [issuerCertUrl] } : {}),
|
|
53
|
+
}));
|
|
54
|
+
}
|
|
55
|
+
if (extendedKeyUsageItems.length) {
|
|
56
|
+
extensions.push(new x509_1.ExtendedKeyUsageExtension(extendedKeyUsageItems, false));
|
|
57
|
+
}
|
|
58
|
+
let keyUsageFlags = x509_1.KeyUsageFlags.digitalSignature | x509_1.KeyUsageFlags.keyEncipherment;
|
|
59
|
+
if (params.ca) {
|
|
60
|
+
keyUsageFlags |= x509_1.KeyUsageFlags.keyCertSign;
|
|
61
|
+
}
|
|
62
|
+
extensions.push(new x509_1.KeyUsagesExtension(keyUsageFlags, true));
|
|
63
|
+
const signerPublicKey = await CryptoKeysTransformer_js_1.CryptoKeysTransformer.cryptoPublicFromCryptoPrivate(signerPrivateKey);
|
|
64
|
+
extensions.push(...[
|
|
65
|
+
await x509_1.AuthorityKeyIdentifierExtension.create(signerPublicKey),
|
|
66
|
+
await x509_1.SubjectKeyIdentifierExtension.create(subjectPublicKey),
|
|
67
|
+
]);
|
|
68
|
+
if (params.customExtensions?.length) {
|
|
69
|
+
const filteredExtensions = params.customExtensions.filter((ext) => !notAllowedCertificateCustomExtensions.includes(ext.oid));
|
|
70
|
+
for (const customExtension of filteredExtensions) {
|
|
71
|
+
if (!customExtension.oid || !customExtension.value) {
|
|
72
|
+
throw new Error('Custom extension OID and value are required');
|
|
73
|
+
}
|
|
74
|
+
extensions.push(new x509_1.Extension(customExtension.oid, false, customExtension.value));
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
const createCertificateParams = {
|
|
78
|
+
serialNumber: CertificateGenerator.generateSerialNumber(),
|
|
79
|
+
issuer: CertificateGenerator.getPrincipalInfo(params.issuer),
|
|
80
|
+
subject: CertificateGenerator.getPrincipalInfo(params.subject),
|
|
81
|
+
notBefore: new Date(Date.now() - ONE_HOUR_MS), //1 hour ago to avoid clock skew issues between servers
|
|
82
|
+
notAfter: params.notAfter,
|
|
83
|
+
publicKey: subjectPublicKey,
|
|
84
|
+
signingKey: signerPrivateKey,
|
|
85
|
+
signingAlgorithm,
|
|
86
|
+
extensions,
|
|
87
|
+
};
|
|
88
|
+
const cert = await x509_1.X509CertificateGenerator.create(createCertificateParams);
|
|
89
|
+
return cert.toString('pem');
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Generates a pair of cryptographic keys based on the specified signature algorithm.
|
|
93
|
+
* @param signatureAlgorithm - The algorithm to use for key generation.
|
|
94
|
+
* @returns A promise that resolves to a CryptoKeyPair containing the public and private keys.
|
|
95
|
+
*/
|
|
96
|
+
static generateKeys(signatureAlgorithm) {
|
|
97
|
+
const algorithm = CertificateGenerator.getAlgorithm(signatureAlgorithm);
|
|
98
|
+
return setup_crypto_js_1.cryptoProvider.subtle.generateKey(algorithm, true, ['sign', 'verify']);
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Generates a Certificate Signing Request (CSR) based on the provided parameters.
|
|
102
|
+
* @param params - Parameters for generating the CSR.
|
|
103
|
+
* @returns The generated CSR in PEM format.
|
|
104
|
+
*/
|
|
105
|
+
static async generateCsr(params) {
|
|
106
|
+
const keys = await CertificateGenerator.getCryptoKeys(params);
|
|
107
|
+
const signingAlgorithm = keys.publicKey.algorithm;
|
|
108
|
+
signingAlgorithm.hash = { name: 'SHA-256' };
|
|
109
|
+
const extensions = [];
|
|
110
|
+
if (signingAlgorithm.namedCurve !== 'K-256' && params.dnsNames?.length) {
|
|
111
|
+
const generalNames = params.dnsNames.map((dnsName) => ({
|
|
112
|
+
type: ((0, helper_js_1.isIpAddress)(dnsName) ? 'ip' : 'dns'),
|
|
113
|
+
value: dnsName,
|
|
114
|
+
}));
|
|
115
|
+
extensions.push(new x509_1.SubjectAlternativeNameExtension(generalNames));
|
|
116
|
+
}
|
|
117
|
+
if (params.customExtensions?.length) {
|
|
118
|
+
for (const customExtension of params.customExtensions) {
|
|
119
|
+
if (!customExtension.oid || !customExtension.value) {
|
|
120
|
+
throw new Error(`Some custom extension missed OID or value`);
|
|
121
|
+
}
|
|
122
|
+
extensions.push(new x509_1.Extension(customExtension.oid, false, customExtension.value));
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const createCsrParams = {
|
|
126
|
+
name: CertificateGenerator.getPrincipalInfo(params.subject),
|
|
127
|
+
keys,
|
|
128
|
+
signingAlgorithm,
|
|
129
|
+
extensions,
|
|
130
|
+
};
|
|
131
|
+
const csr = await x509_1.Pkcs10CertificateRequestGenerator.create(createCsrParams);
|
|
132
|
+
return csr.toString('pem');
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Checks and parses a certificate in PEM format.
|
|
136
|
+
* @param certPem - The certificate in PEM format.
|
|
137
|
+
* @returns An object containing the parsed certificate details.
|
|
138
|
+
*/
|
|
139
|
+
static async checkAndParseCert(certPem) {
|
|
140
|
+
const cert = new x509_1.X509Certificate(certPem);
|
|
141
|
+
if (cert.issuer === cert.subject) {
|
|
142
|
+
const isValid = await cert.verify();
|
|
143
|
+
if (!isValid) {
|
|
144
|
+
throw new Error('Self-signed certificate signature verification failed');
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
const publicKey = await setup_crypto_js_1.cryptoProvider.subtle.importKey('spki', cert.publicKey.rawData, Object.assign(cert.signatureAlgorithm, cert.publicKey.algorithm), true, ['verify']);
|
|
148
|
+
const authorityKeyIdentifierExt = cert.extensions.find((ext) => ext instanceof x509_1.AuthorityKeyIdentifierExtension);
|
|
149
|
+
const authorityKeyIdentifier = authorityKeyIdentifierExt?.keyId;
|
|
150
|
+
const subjectKeyIdentifierExt = cert.extensions.find((ext) => ext instanceof x509_1.SubjectKeyIdentifierExtension);
|
|
151
|
+
const subjectKeyIdentifier = subjectKeyIdentifierExt?.keyId;
|
|
152
|
+
return {
|
|
153
|
+
serialNumberHex: cert.serialNumber,
|
|
154
|
+
publicKey,
|
|
155
|
+
subject: cert.subject,
|
|
156
|
+
issuer: cert.issuer,
|
|
157
|
+
notBefore: cert.notBefore,
|
|
158
|
+
notAfter: cert.notAfter,
|
|
159
|
+
dnsNames: CertificateGenerator.extractDnsNamesFromExtensions(cert.extensions),
|
|
160
|
+
authorityKeyIdentifier,
|
|
161
|
+
subjectKeyIdentifier,
|
|
162
|
+
extensions: cert.extensions
|
|
163
|
+
.filter((ext) => ext.type !== node_forge_1.default.pki.oids['subjectAltName'])
|
|
164
|
+
.map((ext) => ({
|
|
165
|
+
oid: ext.type,
|
|
166
|
+
value: Buffer.from(ext.value),
|
|
167
|
+
})),
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Checks and parses a Certificate Signing Request (CSR) in PEM format.
|
|
172
|
+
* @param csrPem - The CSR in PEM format.
|
|
173
|
+
* @returns An object containing the parsed CSR details.
|
|
174
|
+
*/
|
|
175
|
+
static async checkAndParseCsr(csrPem) {
|
|
176
|
+
const csr = new x509_1.Pkcs10CertificateRequest(csrPem);
|
|
177
|
+
const isValid = await csr.verify();
|
|
178
|
+
if (!isValid) {
|
|
179
|
+
throw new Error('CSR signature verification failed');
|
|
180
|
+
}
|
|
181
|
+
const publicKey = await setup_crypto_js_1.cryptoProvider.subtle.importKey('spki', csr.publicKey.rawData, Object.assign(csr.signatureAlgorithm, csr.publicKey.algorithm), true, ['verify']);
|
|
182
|
+
const parsedCsr = {
|
|
183
|
+
subject: csr.subject,
|
|
184
|
+
publicKey,
|
|
185
|
+
dnsNames: CertificateGenerator.extractDnsNamesFromExtensions(csr.extensions),
|
|
186
|
+
extensions: csr.extensions
|
|
187
|
+
.filter((ext) => ext.type !== node_forge_1.default.pki.oids['subjectAltName'])
|
|
188
|
+
.map((ext) => ({
|
|
189
|
+
oid: ext.type,
|
|
190
|
+
value: Buffer.from(ext.value),
|
|
191
|
+
})),
|
|
192
|
+
};
|
|
193
|
+
return parsedCsr;
|
|
194
|
+
}
|
|
195
|
+
static async getCryptoKeys({ privateKey, publicKey }) {
|
|
196
|
+
const [pubKey, privKey] = await Promise.all([
|
|
197
|
+
typeof publicKey === 'string'
|
|
198
|
+
? CryptoKeysTransformer_js_1.CryptoKeysTransformer.spkiPemToCryptoKey(publicKey)
|
|
199
|
+
: publicKey,
|
|
200
|
+
typeof privateKey === 'string'
|
|
201
|
+
? CryptoKeysTransformer_js_1.CryptoKeysTransformer.pkcs8PemToCryptoKey(privateKey)
|
|
202
|
+
: privateKey,
|
|
203
|
+
]);
|
|
204
|
+
assert_1.default.deepEqual(pubKey.algorithm, privKey.algorithm, 'Both keys must have same algorithm defined');
|
|
205
|
+
return { publicKey: pubKey, privateKey: privKey };
|
|
206
|
+
}
|
|
207
|
+
static generateSerialNumber() {
|
|
208
|
+
const uuid = (0, crypto_1.randomUUID)().replace(/-/g, '');
|
|
209
|
+
let serial = BigInt('0x' + uuid) % MAX_X509_SERIAL;
|
|
210
|
+
// Ensure the serial number is positive in ASN1
|
|
211
|
+
// 89abcdefABCDEF - set of all hex symbols that have 1 as first bit
|
|
212
|
+
const serialHex = serial.toString(16);
|
|
213
|
+
if (serialHex[0] && '89abcdefABCDEF'.includes(serialHex[0])) {
|
|
214
|
+
serial = serial >> 1n;
|
|
215
|
+
}
|
|
216
|
+
return serial.toString(16);
|
|
217
|
+
}
|
|
218
|
+
static getPrincipalInfo(principal) {
|
|
219
|
+
if (typeof principal === 'string') {
|
|
220
|
+
return principal;
|
|
221
|
+
}
|
|
222
|
+
if (!principal.commonName) {
|
|
223
|
+
throw new Error('Common name is required');
|
|
224
|
+
}
|
|
225
|
+
return Object.entries(principal)
|
|
226
|
+
.map(([key, value]) => `${principalAttributeMap[key] || key}=${value}`)
|
|
227
|
+
.join(',');
|
|
228
|
+
}
|
|
229
|
+
static getAlgorithm(signatureAlgorithm) {
|
|
230
|
+
switch (signatureAlgorithm) {
|
|
231
|
+
case 'RSASSA-PKCS1-SHA256':
|
|
232
|
+
return {
|
|
233
|
+
name: 'RSASSA-PKCS1-v1_5',
|
|
234
|
+
hash: 'SHA-256',
|
|
235
|
+
publicExponent: new Uint8Array([1, 0, 1]), // 65537
|
|
236
|
+
modulusLength: 2048,
|
|
237
|
+
};
|
|
238
|
+
case 'ECDSA-P-256-SHA256':
|
|
239
|
+
return {
|
|
240
|
+
name: 'ECDSA',
|
|
241
|
+
namedCurve: 'P-256',
|
|
242
|
+
};
|
|
243
|
+
case 'ECDSA-secp256k1-SHA256':
|
|
244
|
+
return {
|
|
245
|
+
name: 'ECDSA',
|
|
246
|
+
namedCurve: 'K-256',
|
|
247
|
+
};
|
|
248
|
+
default:
|
|
249
|
+
throw new Error(`Unsupported signature algorithm: ${signatureAlgorithm}`);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
static extractDnsNamesFromExtensions(extensions) {
|
|
253
|
+
const subjectAltNameExt = extensions.find((ext) => ext.type === node_forge_1.default.pki.oids['subjectAltName']);
|
|
254
|
+
if (!subjectAltNameExt) {
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
const dnsNames = subjectAltNameExt.names.items.map((item) => item.value);
|
|
258
|
+
return dnsNames;
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
exports.CertificateGenerator = CertificateGenerator;
|
|
262
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NlcnRpZmljYXRlcy9nZW5lcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsb0RBQTRCO0FBQzVCLG1DQUFvQztBQUNwQyw0REFBK0I7QUFDL0IseUNBbUJ3QjtBQVd4Qix1REFBbUQ7QUFDbkQsZ0ZBQTBFO0FBQzFFLGtEQUFpRDtBQUVqRCxNQUFNLGVBQWUsR0FBRyxNQUFNLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUV0RCxNQUFNLFdBQVcsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDLHlCQUF5QjtBQUU3RCxNQUFNLHFCQUFxQixHQUEyQjtJQUNwRCxVQUFVLEVBQUUsSUFBSTtJQUNoQixPQUFPLEVBQUUsR0FBRztJQUNaLFlBQVksRUFBRSxHQUFHO0lBQ2pCLFNBQVMsRUFBRSxJQUFJO0lBQ2YsWUFBWSxFQUFFLEdBQUc7SUFDakIsa0JBQWtCLEVBQUUsSUFBSTtDQUN6QixDQUFDO0FBRUYsTUFBTSxxQ0FBcUMsR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxvQkFBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBRWpGLE1BQWEsb0JBQW9CO0lBQy9COzs7O09BSUc7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxNQUEwQjtRQUNsRCxNQUFNLEVBQUUsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRTlCLE1BQU0sRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLEdBQ2pFLE1BQU0sb0JBQW9CLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25ELE1BQU0sZ0JBQWdCLEdBQUcsZ0JBQWdCLENBQUMsU0FBeUIs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
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import * as pkijs from 'pkijs';
|
|
3
|
+
import { AlgorithmObj, CertWithKeyIdentifiers, ValidateCertChainResult } from './types.js';
|
|
4
|
+
import './setup-crypto.js';
|
|
5
|
+
export declare class CertificatesHelper {
|
|
6
|
+
private static downloadedCertificateCache;
|
|
7
|
+
static derToPem(data: ArrayBuffer, type?: string): string;
|
|
8
|
+
static pemToDer(certPem: string): Uint8Array;
|
|
9
|
+
static splitPemCerts(certs: string): string[];
|
|
10
|
+
static getDomain(certPem: string): string | undefined;
|
|
11
|
+
static getExtensionValue(certParam: string | pkijs.Certificate, oid: string): Buffer | undefined;
|
|
12
|
+
static extractCAFromChain(certsPem: string): {
|
|
13
|
+
certs: string;
|
|
14
|
+
ca: string;
|
|
15
|
+
};
|
|
16
|
+
static getIssuer(certWithKeyIdent: CertWithKeyIdentifiers, potentialIssuersWithKeyIdent: CertWithKeyIdentifiers[]): CertWithKeyIdentifiers | undefined;
|
|
17
|
+
static pemChainToDer(certsPem: string): Uint8Array[];
|
|
18
|
+
static derChainToPem(certsDer: Uint8Array[]): string;
|
|
19
|
+
static downloadCertWithCache(url: string): Promise<Buffer>;
|
|
20
|
+
static buildChain(leaf: pkijs.Certificate | CertWithKeyIdentifiers, potentialIssuers: pkijs.Certificate[] | CertWithKeyIdentifiers[]): CertWithKeyIdentifiers[];
|
|
21
|
+
static sortCertsFromLeafToRoot(certsPem: string | string[] | pkijs.Certificate[] | CertWithKeyIdentifiers[]): CertWithKeyIdentifiers[];
|
|
22
|
+
static getCertPublicKeyAlgorithm(certPem: string): AlgorithmObj;
|
|
23
|
+
static getCsrPublicKeyAlgorithm(csrPem: string): AlgorithmObj;
|
|
24
|
+
static validateCertChain(certsPem: string | string[], caPem: string | string[], options?: {
|
|
25
|
+
offline?: boolean;
|
|
26
|
+
}): Promise<ValidateCertChainResult>;
|
|
27
|
+
static toPkiCerts(certs: string | string[]): pkijs.Certificate[];
|
|
28
|
+
static addKeyIdentifiersToCerts(certs: Array<pkijs.Certificate | CertWithKeyIdentifiers>): CertWithKeyIdentifiers[];
|
|
29
|
+
}
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.CertificatesHelper = void 0;
|
|
30
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
31
|
+
const axios_1 = __importDefault(require("axios"));
|
|
32
|
+
const node_forge_1 = __importDefault(require("node-forge"));
|
|
33
|
+
const pkijs = __importStar(require("pkijs"));
|
|
34
|
+
const x509_1 = require("@peculiar/x509");
|
|
35
|
+
const memory_js_1 = require("../utils/cache/memory.js");
|
|
36
|
+
const ocsp_js_1 = require("./ocsp.js");
|
|
37
|
+
const crl_js_1 = require("./crl.js");
|
|
38
|
+
require("./setup-crypto.js");
|
|
39
|
+
const pki_common_1 = require("@super-protocol/pki-common");
|
|
40
|
+
const oidsForOcspCheck = [
|
|
41
|
+
pki_common_1.OID_CUSTOM_EXTENSION_CHALLENGE_ID,
|
|
42
|
+
pki_common_1.OID_CUSTOM_EXTENSION_CHALLENGE_COMMON_ID,
|
|
43
|
+
pki_common_1.OID_CUSTOM_EXTENSION_NVIDIA_INFO_GPU,
|
|
44
|
+
pki_common_1.OID_CUSTOM_EXTENSION_CHALLENGE_CERTIFICATE_ID,
|
|
45
|
+
];
|
|
46
|
+
class CertificatesHelper {
|
|
47
|
+
static downloadedCertificateCache = (0, memory_js_1.createMemoryCache)();
|
|
48
|
+
static derToPem(data, type = 'CERTIFICATE') {
|
|
49
|
+
return node_forge_1.default.pem.encode({
|
|
50
|
+
contentDomain: null,
|
|
51
|
+
dekInfo: null,
|
|
52
|
+
headers: [],
|
|
53
|
+
procType: null,
|
|
54
|
+
type,
|
|
55
|
+
body: Buffer.from(data).toString('binary'),
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
static pemToDer(certPem) {
|
|
59
|
+
return Buffer.from(node_forge_1.default.pki.pemToDer(certPem).bytes(), 'binary');
|
|
60
|
+
}
|
|
61
|
+
static splitPemCerts(certs) {
|
|
62
|
+
const pemRegex = /(-----BEGIN CERTIFICATE-----[\s\S]*?-----END CERTIFICATE-----)/g;
|
|
63
|
+
return certs.match(pemRegex) || [];
|
|
64
|
+
}
|
|
65
|
+
static getDomain(certPem) {
|
|
66
|
+
const cert = node_forge_1.default.pki.certificateFromPem(certPem);
|
|
67
|
+
return cert.subject.attributes.find((attribute) => attribute.name === 'commonName')
|
|
68
|
+
?.value;
|
|
69
|
+
}
|
|
70
|
+
static getExtensionValue(certParam, oid) {
|
|
71
|
+
const cert = typeof certParam === 'string'
|
|
72
|
+
? pkijs.Certificate.fromBER(CertificatesHelper.pemToDer(certParam))
|
|
73
|
+
: certParam;
|
|
74
|
+
const extension = cert.extensions?.find((ext) => ext.extnID === oid);
|
|
75
|
+
return extension && Buffer.from(extension.extnValue.valueBlock.toBER());
|
|
76
|
+
}
|
|
77
|
+
static extractCAFromChain(certsPem) {
|
|
78
|
+
const certs = CertificatesHelper.toPkiCerts(certsPem);
|
|
79
|
+
const splitCerts = lodash_1.default.partition(certs, (cert) => !cert.issuer.isEqual(cert.subject));
|
|
80
|
+
const toPemChain = (certs) => certs.map((cert) => CertificatesHelper.derToPem(cert.toSchema().toBER())).join('\n');
|
|
81
|
+
return {
|
|
82
|
+
certs: toPemChain(splitCerts[0]),
|
|
83
|
+
ca: toPemChain(splitCerts[1]),
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
static getIssuer(certWithKeyIdent, potentialIssuersWithKeyIdent) {
|
|
87
|
+
return potentialIssuersWithKeyIdent.find((potentialIssuer) => (certWithKeyIdent?.authorityKeyIdentifier && potentialIssuer.subjectKeyIdentifier
|
|
88
|
+
? certWithKeyIdent.authorityKeyIdentifier.isEqual(potentialIssuer.subjectKeyIdentifier)
|
|
89
|
+
: certWithKeyIdent?.cert.issuer.isEqual(potentialIssuer.cert.subject)) &&
|
|
90
|
+
!certWithKeyIdent?.cert.subject.isEqual(certWithKeyIdent?.cert.issuer));
|
|
91
|
+
}
|
|
92
|
+
static pemChainToDer(certsPem) {
|
|
93
|
+
const certs = CertificatesHelper.splitPemCerts(certsPem);
|
|
94
|
+
return certs.map((certPem) => CertificatesHelper.pemToDer(certPem));
|
|
95
|
+
}
|
|
96
|
+
static derChainToPem(certsDer) {
|
|
97
|
+
return certsDer
|
|
98
|
+
.map((cert) => CertificatesHelper.derToPem(cert))
|
|
99
|
+
.join('')
|
|
100
|
+
.trim();
|
|
101
|
+
}
|
|
102
|
+
static async downloadCertWithCache(url) {
|
|
103
|
+
const responseData = await CertificatesHelper.downloadedCertificateCache.wrap(url, async () => {
|
|
104
|
+
const response = await (0, axios_1.default)(url, {
|
|
105
|
+
responseType: 'arraybuffer',
|
|
106
|
+
});
|
|
107
|
+
return response?.data;
|
|
108
|
+
}, {
|
|
109
|
+
ttl: 5 * 60 * 1000, //5 min
|
|
110
|
+
});
|
|
111
|
+
return responseData;
|
|
112
|
+
}
|
|
113
|
+
static buildChain(leaf, potentialIssuers) {
|
|
114
|
+
const chain = CertificatesHelper.addKeyIdentifiersToCerts([leaf]);
|
|
115
|
+
const potentialIssuersWithKeyIdentifiers = CertificatesHelper.addKeyIdentifiersToCerts(potentialIssuers);
|
|
116
|
+
let currentCert = chain[0];
|
|
117
|
+
do {
|
|
118
|
+
currentCert = CertificatesHelper.getIssuer(currentCert, potentialIssuersWithKeyIdentifiers);
|
|
119
|
+
if (currentCert) {
|
|
120
|
+
chain.push(currentCert);
|
|
121
|
+
}
|
|
122
|
+
} while (currentCert);
|
|
123
|
+
return chain;
|
|
124
|
+
}
|
|
125
|
+
static sortCertsFromLeafToRoot(certsPem) {
|
|
126
|
+
const allCerts = typeof certsPem === 'string' || certsPem.every((cert) => typeof cert === 'string')
|
|
127
|
+
? CertificatesHelper.toPkiCerts(certsPem)
|
|
128
|
+
: certsPem;
|
|
129
|
+
const certsWithKeyIdentifiers = CertificatesHelper.addKeyIdentifiersToCerts(allCerts);
|
|
130
|
+
const leafs = certsWithKeyIdentifiers.filter((certToCheck) => !certsWithKeyIdentifiers.some((certsToCheckWith) => certToCheck.subjectKeyIdentifier && certsToCheckWith.authorityKeyIdentifier
|
|
131
|
+
? certToCheck.subjectKeyIdentifier.isEqual(certsToCheckWith.authorityKeyIdentifier)
|
|
132
|
+
: certToCheck.cert.subject.isEqual(certsToCheckWith.cert.issuer)));
|
|
133
|
+
const chains = leafs
|
|
134
|
+
.map((leaf) => CertificatesHelper.buildChain(leaf.cert, allCerts))
|
|
135
|
+
.sort((one, two) => two.length - one.length);
|
|
136
|
+
return chains.flat();
|
|
137
|
+
}
|
|
138
|
+
static getCertPublicKeyAlgorithm(certPem) {
|
|
139
|
+
const cert = new x509_1.X509Certificate(certPem);
|
|
140
|
+
const publicKey = cert.publicKey;
|
|
141
|
+
return publicKey.algorithm;
|
|
142
|
+
}
|
|
143
|
+
static getCsrPublicKeyAlgorithm(csrPem) {
|
|
144
|
+
const csr = new x509_1.Pkcs10CertificateRequest(csrPem);
|
|
145
|
+
const publicKey = csr.publicKey;
|
|
146
|
+
return publicKey.algorithm;
|
|
147
|
+
}
|
|
148
|
+
static async validateCertChain(certsPem, caPem, options = {}) {
|
|
149
|
+
const { offline } = options;
|
|
150
|
+
// reverse() is needed because pkijs expects certificates to be ordered from root to leaf
|
|
151
|
+
const sortedCertsWithKeyIdent = CertificatesHelper.sortCertsFromLeafToRoot(certsPem).reverse();
|
|
152
|
+
const sortedCerts = sortedCertsWithKeyIdent.map((certWithKeyIdent) => certWithKeyIdent.cert);
|
|
153
|
+
const ca = CertificatesHelper.toPkiCerts(caPem);
|
|
154
|
+
try {
|
|
155
|
+
const crls = offline ? [] : await crl_js_1.CRLHelper.getCRLFromCerts(sortedCerts);
|
|
156
|
+
const ocspBaseResponses = offline
|
|
157
|
+
? []
|
|
158
|
+
: await ocsp_js_1.OCSPHelper.getOCSPResponseFromCerts(sortedCertsWithKeyIdent, CertificatesHelper.addKeyIdentifiersToCerts(ca), oidsForOcspCheck);
|
|
159
|
+
const chainEngine = new pkijs.CertificateChainValidationEngine({
|
|
160
|
+
certs: sortedCerts,
|
|
161
|
+
trustedCerts: ca,
|
|
162
|
+
ocsps: ocspBaseResponses,
|
|
163
|
+
crls,
|
|
164
|
+
});
|
|
165
|
+
const verifyResult = await chainEngine.verify();
|
|
166
|
+
if (!verifyResult.result) {
|
|
167
|
+
return {
|
|
168
|
+
isValid: false,
|
|
169
|
+
errorMessage: verifyResult.resultMessage,
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* When verifying a certificate chain, chainEngine.verify() attempts to find a valid
|
|
174
|
+
* certification path using the provided certificates. It may ignore certificates that
|
|
175
|
+
* don't belong to the valid chain.
|
|
176
|
+
*
|
|
177
|
+
* This check ensures that all certificates we initially provided were actually used
|
|
178
|
+
* in the valid certification path that CertificateChainValidationEngine constructed.
|
|
179
|
+
* If any certificate was ignored/not used, we throw an error.
|
|
180
|
+
*/
|
|
181
|
+
const isEachCertVerified = sortedCerts.every((cert) => verifyResult.certificatePath?.find((verifiedCert) => verifiedCert.serialNumber.isEqual(cert.serialNumber)));
|
|
182
|
+
if (!isEachCertVerified) {
|
|
183
|
+
throw new Error('Some of certificates do not belong to chain');
|
|
184
|
+
}
|
|
185
|
+
return {
|
|
186
|
+
isValid: true,
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
catch (err) {
|
|
190
|
+
return {
|
|
191
|
+
isValid: false,
|
|
192
|
+
errorMessage: err.message,
|
|
193
|
+
};
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
static toPkiCerts(certs) {
|
|
197
|
+
const certsArray = Array.isArray(certs) ? certs : CertificatesHelper.splitPemCerts(certs);
|
|
198
|
+
return certsArray.map((certPem) => pkijs.Certificate.fromBER(CertificatesHelper.pemToDer(certPem)));
|
|
199
|
+
}
|
|
200
|
+
static addKeyIdentifiersToCerts(certs) {
|
|
201
|
+
return certs.map((cert) => {
|
|
202
|
+
if ('cert' in cert) {
|
|
203
|
+
return cert;
|
|
204
|
+
}
|
|
205
|
+
const authorityKeyIdentifierExt = cert.extensions?.find((ext) => ext.extnID === node_forge_1.default.pki.oids['authorityKeyIdentifier'])?.parsedValue;
|
|
206
|
+
const subjectKeyIdentifierExt = cert.extensions?.find((ext) => ext.extnID === node_forge_1.default.pki.oids['subjectKeyIdentifier'])?.parsedValue;
|
|
207
|
+
return {
|
|
208
|
+
cert,
|
|
209
|
+
authorityKeyIdentifier: authorityKeyIdentifierExt?.keyIdentifier,
|
|
210
|
+
subjectKeyIdentifier: subjectKeyIdentifierExt,
|
|
211
|
+
};
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
exports.CertificatesHelper = CertificatesHelper;
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NlcnRpZmljYXRlcy9oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxvREFBdUI7QUFDdkIsa0RBQTBCO0FBQzFCLDREQUErQjtBQUMvQiw2Q0FBK0I7QUFDL0IseUNBQTJFO0FBQzNFLHdEQUE2RDtBQUU3RCx1Q0FBdUM7QUFDdkMscUNBQXFDO0FBQ3JDLDZCQUEyQjtBQUMzQiwyREFLb0M7QUFJcEMsTUFBTSxnQkFBZ0IsR0FBRztJQUN2Qiw4Q0FBaUM7SUFDakMscURBQXdDO0lBQ3hDLGlEQUFvQztJQUNwQywwREFBNkM7Q0FDOUMsQ0FBQztBQUVGLE1BQWEsa0JBQWtCO0lBQ3JCLE1BQU0sQ0FBQywwQkFBMEIsR0FBRyxJQUFBLDZCQUFpQixHQUFFLENBQUM7SUFFaEUsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFpQixFQUFFLE9BQWUsYUFBYTtRQUM3RCxPQUFPLG9CQUFLLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQztZQUN0QixhQUFhLEVBQUUsSUFBSTtZQUNuQixPQUFPLEVBQUUsSUFBSTtZQUNiLE9BQU8sRUFBRSxFQUFFO1lBQ1gsUUFBUSxFQUFFLElBQUk7WUFDZCxJQUFJO1lBQ0osSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztTQUMzQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsTUFBTSxDQUFDLFFBQVEsQ0FBQyxPQUFlO1FBQzdCLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxvQkFBSyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVELE1BQU0sQ0FBQyxhQUFhLENBQUMsS0FBYTtRQUNoQyxNQUFNLFFB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
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./helper.js"), exports);
|
|
18
|
+
__exportStar(require("./types.js"), exports);
|
|
19
|
+
__exportStar(require("./serializer.js"), exports);
|
|
20
|
+
__exportStar(require("./generator.js"), exports);
|
|
21
|
+
__exportStar(require("./ocsp.js"), exports);
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY2VydGlmaWNhdGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw4Q0FBNEI7QUFDNUIsNkNBQTJCO0FBQzNCLGtEQUFnQztBQUNoQyxpREFBK0I7QUFDL0IsNENBQTBCIn0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as pkijs from 'pkijs';
|
|
2
|
+
import { CertWithKeyIdentifiers, GenerateOcspResponseParams, ParsedOcspRequest } from '../index.js';
|
|
3
|
+
export declare class OCSPHelper {
|
|
4
|
+
static getOCSPResponseFromCerts(certs: CertWithKeyIdentifiers[], ca: CertWithKeyIdentifiers[], oidsToCheck?: string[]): Promise<pkijs.BasicOCSPResponse[]>;
|
|
5
|
+
static generateOCSPResponse(params: GenerateOcspResponseParams): Promise<ArrayBuffer>;
|
|
6
|
+
static parseOCSPRequest(ocspRequestBinary: ArrayBuffer): ParsedOcspRequest;
|
|
7
|
+
private static canCertSignOCSPResponse;
|
|
8
|
+
private static getOCSPRequestData;
|
|
9
|
+
private static getOCSPResponse;
|
|
10
|
+
private static sendOCSPRequest;
|
|
11
|
+
private static getNonceForRequest;
|
|
12
|
+
private static getNonceFromResponse;
|
|
13
|
+
private static getCertExtensionsToCheck;
|
|
14
|
+
}
|