@brightchain/brightchain-lib 0.9.0 → 0.10.0
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/package.json +1 -1
- package/src/browser.d.ts +1 -1
- package/src/browser.d.ts.map +1 -1
- package/src/browser.js +2 -2
- package/src/browser.js.map +1 -1
- package/src/lib/blockMetadata.d.ts.map +1 -1
- package/src/lib/blockMetadata.js +1 -1
- package/src/lib/blockMetadata.js.map +1 -1
- package/src/lib/blocks/cbl.js +3 -3
- package/src/lib/blocks/cbl.js.map +1 -1
- package/src/lib/blocks/cblBase.d.ts +4 -4
- package/src/lib/blocks/cblBase.d.ts.map +1 -1
- package/src/lib/blocks/cblBase.js +27 -18
- package/src/lib/blocks/cblBase.js.map +1 -1
- package/src/lib/blocks/encrypted.d.ts +34 -5
- package/src/lib/blocks/encrypted.d.ts.map +1 -1
- package/src/lib/blocks/encrypted.js +78 -20
- package/src/lib/blocks/encrypted.js.map +1 -1
- package/src/lib/blocks/encryptedBlockFactory.js +2 -2
- package/src/lib/blocks/encryptedBlockFactory.js.map +1 -1
- package/src/lib/blocks/ephemeral.d.ts +35 -9
- package/src/lib/blocks/ephemeral.d.ts.map +1 -1
- package/src/lib/blocks/ephemeral.js +57 -35
- package/src/lib/blocks/ephemeral.js.map +1 -1
- package/src/lib/blocks/extendedCbl.d.ts +1 -1
- package/src/lib/blocks/extendedCbl.d.ts.map +1 -1
- package/src/lib/blocks/extendedCbl.js +7 -7
- package/src/lib/blocks/extendedCbl.js.map +1 -1
- package/src/lib/blocks/handle.js +2 -2
- package/src/lib/blocks/handle.js.map +1 -1
- package/src/lib/blocks/handleTuple.js +2 -2
- package/src/lib/blocks/handleTuple.js.map +1 -1
- package/src/lib/blocks/random.d.ts +2 -1
- package/src/lib/blocks/random.d.ts.map +1 -1
- package/src/lib/blocks/random.js +7 -4
- package/src/lib/blocks/random.js.map +1 -1
- package/src/lib/blocks/rawData.d.ts +3 -1
- package/src/lib/blocks/rawData.d.ts.map +1 -1
- package/src/lib/blocks/rawData.js +26 -5
- package/src/lib/blocks/rawData.js.map +1 -1
- package/src/lib/blocks/whitened.d.ts +2 -1
- package/src/lib/blocks/whitened.d.ts.map +1 -1
- package/src/lib/blocks/whitened.js +7 -5
- package/src/lib/blocks/whitened.js.map +1 -1
- package/src/lib/config/constants.d.ts +2 -0
- package/src/lib/config/constants.d.ts.map +1 -0
- package/src/lib/config/constants.js +5 -0
- package/src/lib/config/constants.js.map +1 -0
- package/src/lib/cpus/index.d.ts +2 -3
- package/src/lib/cpus/index.d.ts.map +1 -1
- package/src/lib/cpus/index.js +5 -0
- package/src/lib/cpus/index.js.map +1 -1
- package/src/lib/cpus/instructionFactory.d.ts +56 -0
- package/src/lib/cpus/instructionFactory.d.ts.map +1 -0
- package/src/lib/cpus/instructionFactory.js +190 -0
- package/src/lib/cpus/instructionFactory.js.map +1 -0
- package/src/lib/cpus/instructionTables.d.ts +14 -12
- package/src/lib/cpus/instructionTables.d.ts.map +1 -1
- package/src/lib/cpus/instructionTables.js +17 -147
- package/src/lib/cpus/instructionTables.js.map +1 -1
- package/src/lib/cpus/riscvCpu.d.ts +51 -0
- package/src/lib/cpus/riscvCpu.d.ts.map +1 -0
- package/src/lib/cpus/riscvCpu.js +131 -0
- package/src/lib/cpus/riscvCpu.js.map +1 -0
- package/src/lib/documents/base/document.d.ts +1 -1
- package/src/lib/documents/base/document.d.ts.map +1 -1
- package/src/lib/documents/member/index.d.ts +2 -0
- package/src/lib/documents/member/index.d.ts.map +1 -1
- package/src/lib/documents/member/index.js +2 -0
- package/src/lib/documents/member/index.js.map +1 -1
- package/src/lib/documents/member/memberDocument.d.ts.map +1 -1
- package/src/lib/documents/member/memberDocument.js +3 -1
- package/src/lib/documents/member/memberDocument.js.map +1 -1
- package/src/lib/documents/member/memberHydration.d.ts.map +1 -1
- package/src/lib/documents/member/memberHydration.js +3 -15
- package/src/lib/documents/member/memberHydration.js.map +1 -1
- package/src/lib/documents/member/memberOperational.d.ts.map +1 -1
- package/src/lib/documents/member/memberOperational.js.map +1 -1
- package/src/lib/documents/member/memberProfileDocument.d.ts +138 -0
- package/src/lib/documents/member/memberProfileDocument.d.ts.map +1 -0
- package/src/lib/documents/member/memberProfileDocument.js +326 -0
- package/src/lib/documents/member/memberProfileDocument.js.map +1 -0
- package/src/lib/documents/member/memberProfileHydration.d.ts +12 -0
- package/src/lib/documents/member/memberProfileHydration.d.ts.map +1 -0
- package/src/lib/documents/member/memberProfileHydration.js +143 -0
- package/src/lib/documents/member/memberProfileHydration.js.map +1 -0
- package/src/lib/documents/quorumDocument.d.ts +3 -14
- package/src/lib/documents/quorumDocument.d.ts.map +1 -1
- package/src/lib/documents/quorumDocument.js +4 -2
- package/src/lib/documents/quorumDocument.js.map +1 -1
- package/src/lib/encryptedBlockMetadata.d.ts +3 -2
- package/src/lib/encryptedBlockMetadata.d.ts.map +1 -1
- package/src/lib/encryptedBlockMetadata.js +3 -2
- package/src/lib/encryptedBlockMetadata.js.map +1 -1
- package/src/lib/ephemeralBlockMetadata.d.ts +4 -2
- package/src/lib/ephemeralBlockMetadata.d.ts.map +1 -1
- package/src/lib/ephemeralBlockMetadata.js +9 -8
- package/src/lib/ephemeralBlockMetadata.js.map +1 -1
- package/src/lib/errors/block/blockCapacity.d.ts.map +1 -1
- package/src/lib/errors/block/blockCapacity.js.map +1 -1
- package/src/lib/errors/block/blockError.d.ts.map +1 -1
- package/src/lib/errors/block/blockError.js.map +1 -1
- package/src/lib/errors/block/cannotDecrypt.d.ts.map +1 -1
- package/src/lib/errors/block/cannotDecrypt.js.map +1 -1
- package/src/lib/errors/block/cannotEncrypt.d.ts.map +1 -1
- package/src/lib/errors/block/cannotEncrypt.js.map +1 -1
- package/src/lib/errors/bufferError.d.ts.map +1 -1
- package/src/lib/errors/bufferError.js.map +1 -1
- package/src/lib/errors/cblError.d.ts +1 -1
- package/src/lib/errors/cblError.d.ts.map +1 -1
- package/src/lib/errors/cblError.js +1 -1
- package/src/lib/errors/cblError.js.map +1 -1
- package/src/lib/errors/document.d.ts +1 -1
- package/src/lib/errors/document.d.ts.map +1 -1
- package/src/lib/errors/document.js +1 -1
- package/src/lib/errors/document.js.map +1 -1
- package/src/lib/errors/eciesError.d.ts +1 -1
- package/src/lib/errors/eciesError.d.ts.map +1 -1
- package/src/lib/errors/eciesError.js +1 -1
- package/src/lib/errors/eciesError.js.map +1 -1
- package/src/lib/errors/extendedCblError.d.ts +1 -1
- package/src/lib/errors/extendedCblError.d.ts.map +1 -1
- package/src/lib/errors/extendedCblError.js +1 -1
- package/src/lib/errors/extendedCblError.js.map +1 -1
- package/src/lib/errors/fecError.d.ts +1 -1
- package/src/lib/errors/fecError.d.ts.map +1 -1
- package/src/lib/errors/fecError.js +1 -1
- package/src/lib/errors/fecError.js.map +1 -1
- package/src/lib/errors/handleTupleError.d.ts +1 -1
- package/src/lib/errors/handleTupleError.d.ts.map +1 -1
- package/src/lib/errors/handleTupleError.js +1 -1
- package/src/lib/errors/handleTupleError.js.map +1 -1
- package/src/lib/errors/isolatedKeyError.d.ts +1 -1
- package/src/lib/errors/isolatedKeyError.d.ts.map +1 -1
- package/src/lib/errors/isolatedKeyError.js +1 -1
- package/src/lib/errors/isolatedKeyError.js.map +1 -1
- package/src/lib/errors/memberError.d.ts +1 -1
- package/src/lib/errors/memberError.d.ts.map +1 -1
- package/src/lib/errors/memberError.js +1 -1
- package/src/lib/errors/memberError.js.map +1 -1
- package/src/lib/errors/memoryTupleError.d.ts +1 -1
- package/src/lib/errors/memoryTupleError.d.ts.map +1 -1
- package/src/lib/errors/memoryTupleError.js +1 -1
- package/src/lib/errors/memoryTupleError.js.map +1 -1
- package/src/lib/errors/multiEncryptedError.d.ts +1 -1
- package/src/lib/errors/multiEncryptedError.d.ts.map +1 -1
- package/src/lib/errors/multiEncryptedError.js +1 -1
- package/src/lib/errors/multiEncryptedError.js.map +1 -1
- package/src/lib/errors/quorumError.d.ts +1 -1
- package/src/lib/errors/quorumError.d.ts.map +1 -1
- package/src/lib/errors/quorumError.js +1 -1
- package/src/lib/errors/quorumError.js.map +1 -1
- package/src/lib/errors/sealingError.d.ts +1 -1
- package/src/lib/errors/sealingError.d.ts.map +1 -1
- package/src/lib/errors/sealingError.js +1 -1
- package/src/lib/errors/sealingError.js.map +1 -1
- package/src/lib/errors/secureStorage.d.ts +1 -1
- package/src/lib/errors/secureStorage.d.ts.map +1 -1
- package/src/lib/errors/secureStorage.js +1 -1
- package/src/lib/errors/secureStorage.js.map +1 -1
- package/src/lib/errors/storeError.d.ts +1 -1
- package/src/lib/errors/storeError.d.ts.map +1 -1
- package/src/lib/errors/storeError.js +1 -1
- package/src/lib/errors/storeError.js.map +1 -1
- package/src/lib/errors/streamError.d.ts +1 -1
- package/src/lib/errors/streamError.d.ts.map +1 -1
- package/src/lib/errors/streamError.js +1 -1
- package/src/lib/errors/streamError.js.map +1 -1
- package/src/lib/errors/tupleError.d.ts.map +1 -1
- package/src/lib/errors/tupleError.js.map +1 -1
- package/src/lib/factories/blockFactory.d.ts +23 -0
- package/src/lib/factories/blockFactory.d.ts.map +1 -0
- package/src/lib/factories/blockFactory.js +43 -0
- package/src/lib/factories/blockFactory.js.map +1 -0
- package/src/lib/index.d.ts +5 -0
- package/src/lib/index.d.ts.map +1 -1
- package/src/lib/index.js +8 -0
- package/src/lib/index.js.map +1 -1
- package/src/lib/init.d.ts.map +1 -1
- package/src/lib/init.js +5 -5
- package/src/lib/init.js.map +1 -1
- package/src/lib/interfaces/blockCapacity.d.ts +8 -0
- package/src/lib/interfaces/blockCapacity.d.ts.map +1 -1
- package/src/lib/interfaces/blocks/encrypted.d.ts +1 -1
- package/src/lib/interfaces/blocks/encrypted.d.ts.map +1 -1
- package/src/lib/interfaces/blocks/ephemeral.d.ts +4 -7
- package/src/lib/interfaces/blocks/ephemeral.d.ts.map +1 -1
- package/src/lib/interfaces/blocks/metadata/index.d.ts +0 -1
- package/src/lib/interfaces/blocks/metadata/index.d.ts.map +1 -1
- package/src/lib/interfaces/document/quorumDocument.d.ts +15 -0
- package/src/lib/interfaces/document/quorumDocument.d.ts.map +1 -0
- package/src/lib/interfaces/document/quorumDocument.js +3 -0
- package/src/lib/interfaces/document/quorumDocument.js.map +1 -0
- package/src/lib/interfaces/member/memberData.d.ts +2 -0
- package/src/lib/interfaces/member/memberData.d.ts.map +1 -1
- package/src/lib/interfaces/member/profileStorage.d.ts +77 -0
- package/src/lib/interfaces/member/profileStorage.d.ts.map +1 -0
- package/src/lib/interfaces/member/profileStorage.js +3 -0
- package/src/lib/interfaces/member/profileStorage.js.map +1 -0
- package/src/lib/interfaces/serviceProvider.interface.d.ts +9 -7
- package/src/lib/interfaces/serviceProvider.interface.d.ts.map +1 -1
- package/src/lib/interfaces/services/cblServices.d.ts +1 -1
- package/src/lib/interfaces/services/cblServices.d.ts.map +1 -1
- package/src/lib/interfaces/services/ephemeralBlockServices.d.ts +15 -0
- package/src/lib/interfaces/services/ephemeralBlockServices.d.ts.map +1 -0
- package/src/lib/interfaces/services/ephemeralBlockServices.js +3 -0
- package/src/lib/interfaces/services/ephemeralBlockServices.js.map +1 -0
- package/src/lib/logging/blockLogger.d.ts +6 -0
- package/src/lib/logging/blockLogger.d.ts.map +1 -1
- package/src/lib/logging/blockLogger.js +15 -1
- package/src/lib/logging/blockLogger.js.map +1 -1
- package/src/lib/logging/structuredLogger.d.ts +42 -0
- package/src/lib/logging/structuredLogger.d.ts.map +1 -0
- package/src/lib/logging/structuredLogger.js +93 -0
- package/src/lib/logging/structuredLogger.js.map +1 -0
- package/src/lib/primeTupleGeneratorStream.d.ts.map +1 -1
- package/src/lib/primeTupleGeneratorStream.js +4 -2
- package/src/lib/primeTupleGeneratorStream.js.map +1 -1
- package/src/lib/quorum.d.ts.map +1 -1
- package/src/lib/quorum.js +2 -1
- package/src/lib/quorum.js.map +1 -1
- package/src/lib/quorumDataRecord.d.ts +1 -1
- package/src/lib/quorumDataRecord.d.ts.map +1 -1
- package/src/lib/quorumDataRecord.js +3 -3
- package/src/lib/quorumDataRecord.js.map +1 -1
- package/src/lib/schemas/quorumDocument.d.ts +1 -1
- package/src/lib/schemas/quorumDocument.d.ts.map +1 -1
- package/src/lib/schemas/quorumDocument.js.map +1 -1
- package/src/lib/security/dosProtection.d.ts +13 -0
- package/src/lib/security/dosProtection.d.ts.map +1 -0
- package/src/lib/security/dosProtection.js +29 -0
- package/src/lib/security/dosProtection.js.map +1 -0
- package/src/lib/security/dosProtectionValidator.d.ts +27 -0
- package/src/lib/security/dosProtectionValidator.d.ts.map +1 -0
- package/src/lib/security/dosProtectionValidator.js +60 -0
- package/src/lib/security/dosProtectionValidator.js.map +1 -0
- package/src/lib/security/index.d.ts +12 -0
- package/src/lib/security/index.d.ts.map +1 -0
- package/src/lib/security/index.js +15 -0
- package/src/lib/security/index.js.map +1 -0
- package/src/lib/security/rateLimitTypes.d.ts +20 -0
- package/src/lib/security/rateLimitTypes.d.ts.map +1 -0
- package/src/lib/security/rateLimitTypes.js +15 -0
- package/src/lib/security/rateLimitTypes.js.map +1 -0
- package/src/lib/security/rateLimiter.d.ts +29 -0
- package/src/lib/security/rateLimiter.d.ts.map +1 -0
- package/src/lib/security/rateLimiter.js +107 -0
- package/src/lib/security/rateLimiter.js.map +1 -0
- package/src/lib/security/securityAuditLogger.d.ts +59 -0
- package/src/lib/security/securityAuditLogger.d.ts.map +1 -0
- package/src/lib/security/securityAuditLogger.js +120 -0
- package/src/lib/security/securityAuditLogger.js.map +1 -0
- package/src/lib/security/securityEvent.d.ts +45 -0
- package/src/lib/security/securityEvent.d.ts.map +1 -0
- package/src/lib/security/securityEvent.js +44 -0
- package/src/lib/security/securityEvent.js.map +1 -0
- package/src/lib/services/blockFormatService.d.ts +0 -15
- package/src/lib/services/blockFormatService.d.ts.map +1 -1
- package/src/lib/services/blockFormatService.js +2 -32
- package/src/lib/services/blockFormatService.js.map +1 -1
- package/src/lib/services/blockService.d.ts.map +1 -1
- package/src/lib/services/blockService.js +15 -15
- package/src/lib/services/blockService.js.map +1 -1
- package/src/lib/services/cblService.d.ts +3 -2
- package/src/lib/services/cblService.d.ts.map +1 -1
- package/src/lib/services/cblService.js +16 -16
- package/src/lib/services/cblService.js.map +1 -1
- package/src/lib/services/globalServiceProvider.d.ts +4 -0
- package/src/lib/services/globalServiceProvider.d.ts.map +1 -0
- package/src/lib/services/globalServiceProvider.js +26 -0
- package/src/lib/services/globalServiceProvider.js.map +1 -0
- package/src/lib/services/member/memberCblService.d.ts.map +1 -1
- package/src/lib/services/member/memberCblService.js.map +1 -1
- package/src/lib/services/memberStore.d.ts +8 -0
- package/src/lib/services/memberStore.d.ts.map +1 -1
- package/src/lib/services/memberStore.js +91 -54
- package/src/lib/services/memberStore.js.map +1 -1
- package/src/lib/services/sealing.service.d.ts +1 -1
- package/src/lib/services/sealing.service.d.ts.map +1 -1
- package/src/lib/services/sealing.service.js +4 -14
- package/src/lib/services/sealing.service.js.map +1 -1
- package/src/lib/services/service.provider.d.ts +2 -0
- package/src/lib/services/service.provider.d.ts.map +1 -1
- package/src/lib/services/service.provider.js +6 -3
- package/src/lib/services/service.provider.js.map +1 -1
- package/src/lib/services/serviceLocator.d.ts.map +1 -1
- package/src/lib/services/serviceLocator.js +2 -0
- package/src/lib/services/serviceLocator.js.map +1 -1
- package/src/lib/services/tuple.service.js +4 -4
- package/src/lib/services/tuple.service.js.map +1 -1
- package/src/lib/sharedTypes.d.ts +1 -22
- package/src/lib/sharedTypes.d.ts.map +1 -1
- package/src/lib/sharedTypes.js.map +1 -1
- package/src/lib/strings/englishUs.d.ts.map +1 -1
- package/src/lib/strings/englishUs.js.map +1 -1
- package/src/lib/types/schema.d.ts +38 -0
- package/src/lib/types/schema.d.ts.map +1 -0
- package/src/lib/types/schema.js +7 -0
- package/src/lib/types/schema.js.map +1 -0
- package/src/lib/utils/constantTime.d.ts +16 -101
- package/src/lib/utils/constantTime.d.ts.map +1 -1
- package/src/lib/utils/constantTime.js +43 -156
- package/src/lib/utils/constantTime.js.map +1 -1
- package/src/lib/utils/constantTimeXor.d.ts.map +1 -1
- package/src/lib/utils/constantTimeXor.js.map +1 -1
- package/src/lib/utils/typeGuards.d.ts.map +1 -1
- package/src/lib/utils/typeGuards.js +1 -1
- package/src/lib/utils/typeGuards.js.map +1 -1
- package/src/lib/cpus/instructions.d.ts +0 -35
- package/src/lib/cpus/instructions.d.ts.map +0 -1
- package/src/lib/cpus/instructions.js +0 -285
- package/src/lib/cpus/instructions.js.map +0 -1
- package/src/lib/cpus/mach-o.d.ts +0 -7
- package/src/lib/cpus/mach-o.d.ts.map +0 -1
- package/src/lib/cpus/mach-o.js +0 -99
- package/src/lib/cpus/mach-o.js.map +0 -1
- package/src/lib/cpus/x86Cpu.d.ts +0 -21
- package/src/lib/cpus/x86Cpu.d.ts.map +0 -1
- package/src/lib/cpus/x86Cpu.js +0 -89
- package/src/lib/cpus/x86Cpu.js.map +0 -1
|
@@ -6,10 +6,10 @@ const browserConfig_1 = require("./browserConfig");
|
|
|
6
6
|
const init_1 = require("./init");
|
|
7
7
|
const checksum_service_1 = require("./services/checksum.service");
|
|
8
8
|
class QuorumDataRecord {
|
|
9
|
-
constructor(creator, memberIDs, sharesRequired, encryptedData, encryptedSharesByMemberId, checksum, signature, id, dateCreated, dateUpdated,
|
|
9
|
+
constructor(creator, memberIDs, sharesRequired, encryptedData, encryptedSharesByMemberId, enhancedProvider, checksum, signature, id, dateCreated, dateUpdated, eciesService) {
|
|
10
10
|
this.checksumService = new checksum_service_1.ChecksumService();
|
|
11
11
|
this.eciesService = (0, browserConfig_1.createECIESService)();
|
|
12
|
-
this.enhancedProvider = enhancedProvider
|
|
12
|
+
this.enhancedProvider = enhancedProvider;
|
|
13
13
|
this.eciesService = eciesService ?? (0, browserConfig_1.createECIESService)();
|
|
14
14
|
if (id !== undefined) {
|
|
15
15
|
this.id = id;
|
|
@@ -80,7 +80,7 @@ class QuorumDataRecord {
|
|
|
80
80
|
Object.keys(dto.encryptedSharesByMemberId).forEach((k) => {
|
|
81
81
|
encryptedSharesByMemberId.set(k, (0, ecies_lib_1.hexToUint8Array)(dto.encryptedSharesByMemberId[k]));
|
|
82
82
|
});
|
|
83
|
-
return new QuorumDataRecord(fetchMember(enhancedProviderToUse.fromBytes((0, ecies_lib_1.hexToUint8Array)(dto.creatorId))), dto.memberIDs.map((id) => enhancedProviderToUse.fromBytes((0, ecies_lib_1.hexToUint8Array)(id))), dto.sharesRequired, (0, ecies_lib_1.hexToUint8Array)(dto.encryptedData), encryptedSharesByMemberId, checksumService.hexStringToChecksum(dto.checksum), eciesServiceToUse.signatureStringToSignatureBuffer(dto.signature), enhancedProviderToUse.fromBytes((0, ecies_lib_1.hexToUint8Array)(dto.id)), dto.dateCreated, dto.dateUpdated);
|
|
83
|
+
return new QuorumDataRecord(fetchMember(enhancedProviderToUse.fromBytes((0, ecies_lib_1.hexToUint8Array)(dto.creatorId))), dto.memberIDs.map((id) => enhancedProviderToUse.fromBytes((0, ecies_lib_1.hexToUint8Array)(id))), dto.sharesRequired, (0, ecies_lib_1.hexToUint8Array)(dto.encryptedData), encryptedSharesByMemberId, enhancedProviderToUse, checksumService.hexStringToChecksum(dto.checksum), eciesServiceToUse.signatureStringToSignatureBuffer(dto.signature), enhancedProviderToUse.fromBytes((0, ecies_lib_1.hexToUint8Array)(dto.id)), dto.dateCreated, dto.dateUpdated, eciesServiceToUse);
|
|
84
84
|
}
|
|
85
85
|
toJson() {
|
|
86
86
|
return JSON.stringify(this.toDto());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"quorumDataRecord.js","sourceRoot":"","sources":["../../../../brightchain-lib/src/lib/quorumDataRecord.ts"],"names":[],"mappings":";;;AAAA,0DAWoC;AACpC,mDAAqD;AACrD,iCAAkD;AAElD,kEAA8D;AAG9D,MAAa,gBAAgB;IAmB3B,YACE,OAAoB,EACpB,SAAgB,EAChB,cAAsB,EACtB,aAAyB,EACzB,yBAAwD,EACxD,QAAmB,EACnB,SAA+B,EAC/B,EAAQ,EACR,WAAkB,EAClB,WAAkB,EAClB,
|
|
1
|
+
{"version":3,"file":"quorumDataRecord.js","sourceRoot":"","sources":["../../../../brightchain-lib/src/lib/quorumDataRecord.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Member, PlatformID } from '@digitaldefiance/ecies-lib';
|
|
2
|
-
import { IQuorumDocument } from '../
|
|
2
|
+
import type { IQuorumDocument } from '../interfaces/document/quorumDocument';
|
|
3
3
|
import { SchemaDefinition } from '../sharedTypes';
|
|
4
4
|
export declare class QuorumDocumentSchema<TID extends PlatformID = Uint8Array> {
|
|
5
5
|
isString(value: unknown): boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"quorumDocument.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/schemas/quorumDocument.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,MAAM,EAEN,UAAU,EAGX,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"quorumDocument.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/schemas/quorumDocument.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,MAAM,EAEN,UAAU,EAGX,MAAM,4BAA4B,CAAC;AAKpC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AAG7E,OAAO,EAAE,gBAAgB,EAAmB,MAAM,gBAAgB,CAAC;AAGnE,qBAAa,oBAAoB,CAAC,GAAG,SAAS,UAAU,GAAG,UAAU;IAC5D,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO;IAGjC,mBAAmB,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO;IAQ5C,WAAW,CAAC,QAAQ,EAAE,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC;IAwBvC,MAAM,EAAE,gBAAgB,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAiFnD;CACH"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"quorumDocument.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/schemas/quorumDocument.ts"],"names":[],"mappings":";;;AAAA,0DAOoC;AACpC,qDAAyD;AACzD,gDAAoD;
|
|
1
|
+
{"version":3,"file":"quorumDocument.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/schemas/quorumDocument.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DoS protection limits
|
|
3
|
+
*/
|
|
4
|
+
export interface DosLimits {
|
|
5
|
+
maxInputSize: number;
|
|
6
|
+
maxOperationTime: number;
|
|
7
|
+
maxMemoryUsage: number;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Default DoS protection limits
|
|
11
|
+
*/
|
|
12
|
+
export declare const DEFAULT_DOS_LIMITS: Record<string, DosLimits>;
|
|
13
|
+
//# sourceMappingURL=dosProtection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dosProtection.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/dosProtection.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED;;GAEG;AACH,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAqBxD,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_DOS_LIMITS = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Default DoS protection limits
|
|
6
|
+
*/
|
|
7
|
+
exports.DEFAULT_DOS_LIMITS = {
|
|
8
|
+
blockCreation: {
|
|
9
|
+
maxInputSize: 10 * 1024 * 1024, // 10MB
|
|
10
|
+
maxOperationTime: 5000, // 5 seconds
|
|
11
|
+
maxMemoryUsage: 50 * 1024 * 1024, // 50MB
|
|
12
|
+
},
|
|
13
|
+
encryption: {
|
|
14
|
+
maxInputSize: 5 * 1024 * 1024, // 5MB
|
|
15
|
+
maxOperationTime: 3000, // 3 seconds
|
|
16
|
+
maxMemoryUsage: 25 * 1024 * 1024, // 25MB
|
|
17
|
+
},
|
|
18
|
+
decryption: {
|
|
19
|
+
maxInputSize: 5 * 1024 * 1024, // 5MB
|
|
20
|
+
maxOperationTime: 3000, // 3 seconds
|
|
21
|
+
maxMemoryUsage: 25 * 1024 * 1024, // 25MB
|
|
22
|
+
},
|
|
23
|
+
signatureValidation: {
|
|
24
|
+
maxInputSize: 1024 * 1024, // 1MB
|
|
25
|
+
maxOperationTime: 1000, // 1 second
|
|
26
|
+
maxMemoryUsage: 10 * 1024 * 1024, // 10MB
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=dosProtection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dosProtection.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/dosProtection.ts"],"names":[],"mappings":";;;AASA;;GAEG;AACU,QAAA,kBAAkB,GAA8B;IAC3D,aAAa,EAAE;QACb,YAAY,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,OAAO;QACvC,gBAAgB,EAAE,IAAI,EAAE,YAAY;QACpC,cAAc,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,OAAO;KAC1C;IACD,UAAU,EAAE;QACV,YAAY,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,EAAE,MAAM;QACrC,gBAAgB,EAAE,IAAI,EAAE,YAAY;QACpC,cAAc,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,OAAO;KAC1C;IACD,UAAU,EAAE;QACV,YAAY,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,EAAE,MAAM;QACrC,gBAAgB,EAAE,IAAI,EAAE,YAAY;QACpC,cAAc,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,OAAO;KAC1C;IACD,mBAAmB,EAAE;QACnB,YAAY,EAAE,IAAI,GAAG,IAAI,EAAE,MAAM;QACjC,gBAAgB,EAAE,IAAI,EAAE,WAAW;QACnC,cAAc,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,OAAO;KAC1C;CACF,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { DosLimits } from './dosProtection';
|
|
2
|
+
/**
|
|
3
|
+
* DoS protection validator
|
|
4
|
+
*/
|
|
5
|
+
export declare class DosProtectionValidator {
|
|
6
|
+
private static instance;
|
|
7
|
+
private limits;
|
|
8
|
+
private constructor();
|
|
9
|
+
static getInstance(): DosProtectionValidator;
|
|
10
|
+
/**
|
|
11
|
+
* Validate input size
|
|
12
|
+
*/
|
|
13
|
+
validateInputSize(operation: string, size: number, identifier?: string): void;
|
|
14
|
+
/**
|
|
15
|
+
* Create timeout promise for operation
|
|
16
|
+
*/
|
|
17
|
+
withTimeout<T>(operation: string, promise: Promise<T>, identifier?: string): Promise<T>;
|
|
18
|
+
/**
|
|
19
|
+
* Set custom limits for an operation
|
|
20
|
+
*/
|
|
21
|
+
setLimits(operation: string, limits: DosLimits): void;
|
|
22
|
+
/**
|
|
23
|
+
* Get limits for an operation
|
|
24
|
+
*/
|
|
25
|
+
getLimits(operation: string): DosLimits;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=dosProtectionValidator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dosProtectionValidator.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/dosProtectionValidator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAIhE;;GAEG;AACH,qBAAa,sBAAsB;IACjC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAyB;IAChD,OAAO,CAAC,MAAM,CAAgC;IAE9C,OAAO;WAMO,WAAW,IAAI,sBAAsB;IAOnD;;OAEG;IACI,iBAAiB,CACtB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,EACZ,UAAU,CAAC,EAAE,MAAM,GAClB,IAAI;IAiBP;;OAEG;IACI,WAAW,CAAC,CAAC,EAClB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,EACnB,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,CAAC,CAAC;IAsBb;;OAEG;IACI,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,IAAI;IAI5D;;OAEG;IACI,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS;CAG/C"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DosProtectionValidator = void 0;
|
|
4
|
+
const dosProtection_1 = require("./dosProtection");
|
|
5
|
+
const securityAuditLogger_1 = require("./securityAuditLogger");
|
|
6
|
+
const securityEvent_1 = require("./securityEvent");
|
|
7
|
+
/**
|
|
8
|
+
* DoS protection validator
|
|
9
|
+
*/
|
|
10
|
+
class DosProtectionValidator {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.limits = new Map();
|
|
13
|
+
Object.entries(dosProtection_1.DEFAULT_DOS_LIMITS).forEach(([operation, limits]) => {
|
|
14
|
+
this.limits.set(operation, limits);
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
static getInstance() {
|
|
18
|
+
if (!DosProtectionValidator.instance) {
|
|
19
|
+
DosProtectionValidator.instance = new DosProtectionValidator();
|
|
20
|
+
}
|
|
21
|
+
return DosProtectionValidator.instance;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Validate input size
|
|
25
|
+
*/
|
|
26
|
+
validateInputSize(operation, size, identifier) {
|
|
27
|
+
const limits = this.limits.get(operation) || dosProtection_1.DEFAULT_DOS_LIMITS['blockCreation'];
|
|
28
|
+
if (size > limits.maxInputSize) {
|
|
29
|
+
securityAuditLogger_1.SecurityAuditLogger.getInstance().log(securityEvent_1.SecurityEventType.InvalidInput, securityEvent_1.SecurityEventSeverity.Warning, `Input size ${size} exceeds limit ${limits.maxInputSize} for ${operation}`, { operation, identifier, size, limit: limits.maxInputSize });
|
|
30
|
+
throw new Error(`Input size ${size} exceeds maximum allowed ${limits.maxInputSize} bytes`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Create timeout promise for operation
|
|
35
|
+
*/
|
|
36
|
+
withTimeout(operation, promise, identifier) {
|
|
37
|
+
const limits = this.limits.get(operation) || dosProtection_1.DEFAULT_DOS_LIMITS['blockCreation'];
|
|
38
|
+
return Promise.race([
|
|
39
|
+
promise,
|
|
40
|
+
new Promise((_, reject) => setTimeout(() => {
|
|
41
|
+
securityAuditLogger_1.SecurityAuditLogger.getInstance().log(securityEvent_1.SecurityEventType.SuspiciousActivity, securityEvent_1.SecurityEventSeverity.Warning, `Operation ${operation} exceeded timeout ${limits.maxOperationTime}ms`, { operation, identifier, timeout: limits.maxOperationTime });
|
|
42
|
+
reject(new Error(`Operation timeout after ${limits.maxOperationTime}ms`));
|
|
43
|
+
}, limits.maxOperationTime)),
|
|
44
|
+
]);
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Set custom limits for an operation
|
|
48
|
+
*/
|
|
49
|
+
setLimits(operation, limits) {
|
|
50
|
+
this.limits.set(operation, limits);
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Get limits for an operation
|
|
54
|
+
*/
|
|
55
|
+
getLimits(operation) {
|
|
56
|
+
return this.limits.get(operation) || dosProtection_1.DEFAULT_DOS_LIMITS['blockCreation'];
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.DosProtectionValidator = DosProtectionValidator;
|
|
60
|
+
//# sourceMappingURL=dosProtectionValidator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dosProtectionValidator.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/dosProtectionValidator.ts"],"names":[],"mappings":";;;AAAA,mDAAgE;AAChE,+DAA4D;AAC5D,mDAA2E;AAE3E;;GAEG;AACH,MAAa,sBAAsB;IAIjC;QAFQ,WAAM,GAAG,IAAI,GAAG,EAAqB,CAAC;QAG5C,MAAM,CAAC,OAAO,CAAC,kCAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,EAAE,MAAM,CAAC,EAAE,EAAE;YACjE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,WAAW;QACvB,IAAI,CAAC,sBAAsB,CAAC,QAAQ,EAAE,CAAC;YACrC,sBAAsB,CAAC,QAAQ,GAAG,IAAI,sBAAsB,EAAE,CAAC;QACjE,CAAC;QACD,OAAO,sBAAsB,CAAC,QAAQ,CAAC;IACzC,CAAC;IAED;;OAEG;IACI,iBAAiB,CACtB,SAAiB,EACjB,IAAY,EACZ,UAAmB;QAEnB,MAAM,MAAM,GACV,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,kCAAkB,CAAC,eAAe,CAAC,CAAC;QAEpE,IAAI,IAAI,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YAC/B,yCAAmB,CAAC,WAAW,EAAE,CAAC,GAAG,CACnC,iCAAiB,CAAC,YAAY,EAC9B,qCAAqB,CAAC,OAAO,EAC7B,cAAc,IAAI,kBAAkB,MAAM,CAAC,YAAY,QAAQ,SAAS,EAAE,EAC1E,EAAE,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,CAAC,YAAY,EAAE,CAC5D,CAAC;YACF,MAAM,IAAI,KAAK,CACb,cAAc,IAAI,4BAA4B,MAAM,CAAC,YAAY,QAAQ,CAC1E,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACI,WAAW,CAChB,SAAiB,EACjB,OAAmB,EACnB,UAAmB;QAEnB,MAAM,MAAM,GACV,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,kCAAkB,CAAC,eAAe,CAAC,CAAC;QAEpE,OAAO,OAAO,CAAC,IAAI,CAAC;YAClB,OAAO;YACP,IAAI,OAAO,CAAI,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,CAC3B,UAAU,CAAC,GAAG,EAAE;gBACd,yCAAmB,CAAC,WAAW,EAAE,CAAC,GAAG,CACnC,iCAAiB,CAAC,kBAAkB,EACpC,qCAAqB,CAAC,OAAO,EAC7B,aAAa,SAAS,qBAAqB,MAAM,CAAC,gBAAgB,IAAI,EACtE,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,CAAC,gBAAgB,EAAE,CAC5D,CAAC;gBACF,MAAM,CACJ,IAAI,KAAK,CAAC,2BAA2B,MAAM,CAAC,gBAAgB,IAAI,CAAC,CAClE,CAAC;YACJ,CAAC,EAAE,MAAM,CAAC,gBAAgB,CAAC,CAC5B;SACF,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,SAAS,CAAC,SAAiB,EAAE,MAAiB;QACnD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IACrC,CAAC;IAED;;OAEG;IACI,SAAS,CAAC,SAAiB;QAChC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,kCAAkB,CAAC,eAAe,CAAC,CAAC;IAC3E,CAAC;CACF;AAnFD,wDAmFC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Security module exports
|
|
3
|
+
*
|
|
4
|
+
* @module security
|
|
5
|
+
*/
|
|
6
|
+
export * from './dosProtection';
|
|
7
|
+
export * from './dosProtectionValidator';
|
|
8
|
+
export * from './rateLimiter';
|
|
9
|
+
export * from './rateLimitTypes';
|
|
10
|
+
export * from './securityAuditLogger';
|
|
11
|
+
export * from './securityEvent';
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,kBAAkB,CAAC;AACjC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Security module exports
|
|
4
|
+
*
|
|
5
|
+
* @module security
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
const tslib_1 = require("tslib");
|
|
9
|
+
tslib_1.__exportStar(require("./dosProtection"), exports);
|
|
10
|
+
tslib_1.__exportStar(require("./dosProtectionValidator"), exports);
|
|
11
|
+
tslib_1.__exportStar(require("./rateLimiter"), exports);
|
|
12
|
+
tslib_1.__exportStar(require("./rateLimitTypes"), exports);
|
|
13
|
+
tslib_1.__exportStar(require("./securityAuditLogger"), exports);
|
|
14
|
+
tslib_1.__exportStar(require("./securityEvent"), exports);
|
|
15
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/index.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAEH,0DAAgC;AAChC,mEAAyC;AACzC,wDAA8B;AAC9B,2DAAiC;AACjC,gEAAsC;AACtC,0DAAgC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rate limit configuration for different operations
|
|
3
|
+
*/
|
|
4
|
+
export interface RateLimitConfig {
|
|
5
|
+
maxRequests: number;
|
|
6
|
+
windowMs: number;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Rate limit result
|
|
10
|
+
*/
|
|
11
|
+
export interface RateLimitResult {
|
|
12
|
+
allowed: boolean;
|
|
13
|
+
remaining: number;
|
|
14
|
+
resetTime: number;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Default rate limits for operations
|
|
18
|
+
*/
|
|
19
|
+
export declare const DEFAULT_RATE_LIMITS: Record<string, RateLimitConfig>;
|
|
20
|
+
//# sourceMappingURL=rateLimitTypes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateLimitTypes.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/rateLimitTypes.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAO/D,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_RATE_LIMITS = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Default rate limits for operations
|
|
6
|
+
*/
|
|
7
|
+
exports.DEFAULT_RATE_LIMITS = {
|
|
8
|
+
blockCreation: { maxRequests: 100, windowMs: 60000 }, // 100 per minute
|
|
9
|
+
signatureValidation: { maxRequests: 1000, windowMs: 60000 }, // 1000 per minute
|
|
10
|
+
encryption: { maxRequests: 50, windowMs: 60000 }, // 50 per minute
|
|
11
|
+
decryption: { maxRequests: 50, windowMs: 60000 }, // 50 per minute
|
|
12
|
+
storeRead: { maxRequests: 500, windowMs: 60000 }, // 500 per minute
|
|
13
|
+
storeWrite: { maxRequests: 200, windowMs: 60000 }, // 200 per minute
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=rateLimitTypes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateLimitTypes.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/rateLimitTypes.ts"],"names":[],"mappings":";;;AAiBA;;GAEG;AACU,QAAA,mBAAmB,GAAoC;IAClE,aAAa,EAAE,EAAE,WAAW,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,iBAAiB;IACvE,mBAAmB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,kBAAkB;IAC/E,UAAU,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,gBAAgB;IAClE,UAAU,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,gBAAgB;IAClE,SAAS,EAAE,EAAE,WAAW,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,iBAAiB;IACnE,UAAU,EAAE,EAAE,WAAW,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,iBAAiB;CACrE,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { RateLimitConfig, RateLimitResult } from './rateLimitTypes';
|
|
2
|
+
/**
|
|
3
|
+
* Rate limiter using token bucket algorithm
|
|
4
|
+
*/
|
|
5
|
+
export declare class RateLimiter {
|
|
6
|
+
private static instance;
|
|
7
|
+
private buckets;
|
|
8
|
+
private configs;
|
|
9
|
+
private constructor();
|
|
10
|
+
static getInstance(): RateLimiter;
|
|
11
|
+
/**
|
|
12
|
+
* Set rate limit configuration for an operation
|
|
13
|
+
*/
|
|
14
|
+
setLimit(operation: string, config: RateLimitConfig): void;
|
|
15
|
+
/**
|
|
16
|
+
* Check if operation is allowed
|
|
17
|
+
*/
|
|
18
|
+
checkLimit(operation: string, identifier?: string): RateLimitResult;
|
|
19
|
+
/**
|
|
20
|
+
* Reset rate limit for an operation
|
|
21
|
+
*/
|
|
22
|
+
reset(operation: string, identifier?: string): void;
|
|
23
|
+
/**
|
|
24
|
+
* Clear all rate limits
|
|
25
|
+
*/
|
|
26
|
+
clear(): void;
|
|
27
|
+
private getBucket;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=rateLimiter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateLimiter.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/rateLimiter.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,eAAe,EACf,eAAe,EAChB,MAAM,kBAAkB,CAAC;AAgD1B;;GAEG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAc;IACrC,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,OAAO,CAAsC;IAErD,OAAO;WAOO,WAAW,IAAI,WAAW;IAOxC;;OAEG;IACI,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,GAAG,IAAI;IAKjE;;OAEG;IACI,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,eAAe;IAoB1E;;OAEG;IACI,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI;IAK1D;;OAEG;IACI,KAAK,IAAI,IAAI;IAIpB,OAAO,CAAC,SAAS;CAWlB"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RateLimiter = void 0;
|
|
4
|
+
const rateLimitTypes_1 = require("./rateLimitTypes");
|
|
5
|
+
const securityAuditLogger_1 = require("./securityAuditLogger");
|
|
6
|
+
const securityEvent_1 = require("./securityEvent");
|
|
7
|
+
/**
|
|
8
|
+
* Token bucket for rate limiting
|
|
9
|
+
*/
|
|
10
|
+
class TokenBucket {
|
|
11
|
+
constructor(maxTokens, refillRate) {
|
|
12
|
+
this.maxTokens = maxTokens;
|
|
13
|
+
this.refillRate = refillRate;
|
|
14
|
+
this.tokens = maxTokens;
|
|
15
|
+
this.lastRefill = Date.now();
|
|
16
|
+
}
|
|
17
|
+
consume() {
|
|
18
|
+
this.refill();
|
|
19
|
+
if (this.tokens >= 1) {
|
|
20
|
+
this.tokens -= 1;
|
|
21
|
+
return true;
|
|
22
|
+
}
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
remaining() {
|
|
26
|
+
this.refill();
|
|
27
|
+
return Math.floor(this.tokens);
|
|
28
|
+
}
|
|
29
|
+
resetTime() {
|
|
30
|
+
const tokensNeeded = 1 - this.tokens;
|
|
31
|
+
if (tokensNeeded <= 0)
|
|
32
|
+
return 0;
|
|
33
|
+
return Date.now() + tokensNeeded * this.refillRate;
|
|
34
|
+
}
|
|
35
|
+
refill() {
|
|
36
|
+
const now = Date.now();
|
|
37
|
+
const elapsed = now - this.lastRefill;
|
|
38
|
+
const tokensToAdd = elapsed / this.refillRate;
|
|
39
|
+
this.tokens = Math.min(this.maxTokens, this.tokens + tokensToAdd);
|
|
40
|
+
this.lastRefill = now;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Rate limiter using token bucket algorithm
|
|
45
|
+
*/
|
|
46
|
+
class RateLimiter {
|
|
47
|
+
constructor() {
|
|
48
|
+
this.buckets = new Map();
|
|
49
|
+
this.configs = new Map();
|
|
50
|
+
// Initialize with default configs
|
|
51
|
+
Object.entries(rateLimitTypes_1.DEFAULT_RATE_LIMITS).forEach(([operation, config]) => {
|
|
52
|
+
this.configs.set(operation, config);
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
static getInstance() {
|
|
56
|
+
if (!RateLimiter.instance) {
|
|
57
|
+
RateLimiter.instance = new RateLimiter();
|
|
58
|
+
}
|
|
59
|
+
return RateLimiter.instance;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Set rate limit configuration for an operation
|
|
63
|
+
*/
|
|
64
|
+
setLimit(operation, config) {
|
|
65
|
+
this.configs.set(operation, config);
|
|
66
|
+
this.buckets.delete(operation); // Reset bucket
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Check if operation is allowed
|
|
70
|
+
*/
|
|
71
|
+
checkLimit(operation, identifier) {
|
|
72
|
+
const key = identifier ? `${operation}:${identifier}` : operation;
|
|
73
|
+
const bucket = this.getBucket(key, operation);
|
|
74
|
+
const allowed = bucket.consume();
|
|
75
|
+
const remaining = bucket.remaining();
|
|
76
|
+
const resetTime = bucket.resetTime();
|
|
77
|
+
if (!allowed) {
|
|
78
|
+
securityAuditLogger_1.SecurityAuditLogger.getInstance().log(securityEvent_1.SecurityEventType.RateLimitExceeded, securityEvent_1.SecurityEventSeverity.Warning, `Rate limit exceeded for ${operation}`, { operation, identifier });
|
|
79
|
+
}
|
|
80
|
+
return { allowed, remaining, resetTime };
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Reset rate limit for an operation
|
|
84
|
+
*/
|
|
85
|
+
reset(operation, identifier) {
|
|
86
|
+
const key = identifier ? `${operation}:${identifier}` : operation;
|
|
87
|
+
this.buckets.delete(key);
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Clear all rate limits
|
|
91
|
+
*/
|
|
92
|
+
clear() {
|
|
93
|
+
this.buckets.clear();
|
|
94
|
+
}
|
|
95
|
+
getBucket(key, operation) {
|
|
96
|
+
let bucket = this.buckets.get(key);
|
|
97
|
+
if (!bucket) {
|
|
98
|
+
const config = this.configs.get(operation) || rateLimitTypes_1.DEFAULT_RATE_LIMITS['blockCreation'];
|
|
99
|
+
const refillRate = config.windowMs / config.maxRequests;
|
|
100
|
+
bucket = new TokenBucket(config.maxRequests, refillRate);
|
|
101
|
+
this.buckets.set(key, bucket);
|
|
102
|
+
}
|
|
103
|
+
return bucket;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
exports.RateLimiter = RateLimiter;
|
|
107
|
+
//# sourceMappingURL=rateLimiter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateLimiter.js","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/rateLimiter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { SecurityEvent, SecurityEventSeverity, SecurityEventType } from './securityEvent';
|
|
2
|
+
/**
|
|
3
|
+
* Security audit logger for tracking security-relevant events
|
|
4
|
+
*/
|
|
5
|
+
export declare class SecurityAuditLogger {
|
|
6
|
+
private static instance;
|
|
7
|
+
private events;
|
|
8
|
+
private maxEvents;
|
|
9
|
+
private _silent;
|
|
10
|
+
private constructor();
|
|
11
|
+
static getInstance(): SecurityAuditLogger;
|
|
12
|
+
/**
|
|
13
|
+
* Enable or disable console output (useful for tests)
|
|
14
|
+
*/
|
|
15
|
+
set silent(value: boolean);
|
|
16
|
+
get silent(): boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Log a security event
|
|
19
|
+
*/
|
|
20
|
+
log(type: SecurityEventType, severity: SecurityEventSeverity, message: string, metadata?: {
|
|
21
|
+
correlationId?: string;
|
|
22
|
+
userId?: string;
|
|
23
|
+
blockId?: string;
|
|
24
|
+
[key: string]: unknown;
|
|
25
|
+
}): void;
|
|
26
|
+
/**
|
|
27
|
+
* Log signature validation success
|
|
28
|
+
*/
|
|
29
|
+
logSignatureValidation(success: boolean, blockId?: string, userId?: string): void;
|
|
30
|
+
/**
|
|
31
|
+
* Log block creation
|
|
32
|
+
*/
|
|
33
|
+
logBlockCreated(blockId: string, userId?: string): void;
|
|
34
|
+
/**
|
|
35
|
+
* Log encryption operation
|
|
36
|
+
*/
|
|
37
|
+
logEncryption(blockId: string, recipientCount?: number): void;
|
|
38
|
+
/**
|
|
39
|
+
* Log decryption operation
|
|
40
|
+
*/
|
|
41
|
+
logDecryption(success: boolean, blockId: string, userId?: string): void;
|
|
42
|
+
/**
|
|
43
|
+
* Log access denied
|
|
44
|
+
*/
|
|
45
|
+
logAccessDenied(resource: string, userId?: string): void;
|
|
46
|
+
/**
|
|
47
|
+
* Get recent events
|
|
48
|
+
*/
|
|
49
|
+
getEvents(limit?: number): SecurityEvent[];
|
|
50
|
+
/**
|
|
51
|
+
* Clear all events
|
|
52
|
+
*/
|
|
53
|
+
clear(): void;
|
|
54
|
+
/**
|
|
55
|
+
* Output event to console
|
|
56
|
+
*/
|
|
57
|
+
private outputEvent;
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=securityAuditLogger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"securityAuditLogger.d.ts","sourceRoot":"","sources":["../../../../../brightchain-lib/src/lib/security/securityAuditLogger.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,qBAAqB,EACrB,iBAAiB,EAClB,MAAM,iBAAiB,CAAC;AAEzB;;GAEG;AACH,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAsB;IAC7C,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,OAAO,CAAS;IAExB,OAAO;WAEO,WAAW,IAAI,mBAAmB;IAOhD;;OAEG;IACH,IAAW,MAAM,CAAC,KAAK,EAAE,OAAO,EAE/B;IAED,IAAW,MAAM,IAAI,OAAO,CAE3B;IAED;;OAEG;IACI,GAAG,CACR,IAAI,EAAE,iBAAiB,EACvB,QAAQ,EAAE,qBAAqB,EAC/B,OAAO,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE;QACT,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;KACxB,GACA,IAAI;IAuBP;;OAEG;IACI,sBAAsB,CAC3B,OAAO,EAAE,OAAO,EAChB,OAAO,CAAC,EAAE,MAAM,EAChB,MAAM,CAAC,EAAE,MAAM,GACd,IAAI;IAWP;;OAEG;IACI,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAS9D;;OAEG;IACI,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI;IASpE;;OAEG;IACI,aAAa,CAClB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,MAAM,GACd,IAAI;IAWP;;OAEG;IACI,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAS/D;;OAEG;IACI,SAAS,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,aAAa,EAAE;IAIjD;;OAEG;IACI,KAAK,IAAI,IAAI;IAIpB;;OAEG;IACH,OAAO,CAAC,WAAW;CAmBpB"}
|