@digitaldefiance/ecies-lib 2.1.42 → 3.0.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/README.md +153 -3
- package/package.json +3 -3
- package/src/builders/ecies-builder.d.ts +7 -3
- package/src/builders/ecies-builder.d.ts.map +1 -1
- package/src/builders/ecies-builder.js +11 -9
- package/src/builders/ecies-builder.js.map +1 -1
- package/src/builders/member-builder.d.ts +10 -1
- package/src/builders/member-builder.d.ts.map +1 -1
- package/src/builders/member-builder.js +29 -7
- package/src/builders/member-builder.js.map +1 -1
- package/src/enumerations/ecies-error-type.d.ts +11 -1
- package/src/enumerations/ecies-error-type.d.ts.map +1 -1
- package/src/enumerations/ecies-error-type.js +10 -0
- package/src/enumerations/ecies-error-type.js.map +1 -1
- package/src/enumerations/ecies-string-key.d.ts +77 -1
- package/src/enumerations/ecies-string-key.d.ts.map +1 -1
- package/src/enumerations/ecies-string-key.js +77 -0
- package/src/enumerations/ecies-string-key.js.map +1 -1
- package/src/i18n-setup.d.ts.map +1 -1
- package/src/i18n-setup.js +15 -683
- package/src/i18n-setup.js.map +1 -1
- package/src/index.d.ts +12 -0
- package/src/index.d.ts.map +1 -1
- package/src/index.js +15 -1
- package/src/index.js.map +1 -1
- package/src/interfaces/encrypted-chunk.d.ts +55 -0
- package/src/interfaces/encrypted-chunk.d.ts.map +1 -0
- package/src/interfaces/encrypted-chunk.js +15 -0
- package/src/interfaces/encrypted-chunk.js.map +1 -0
- package/src/interfaces/encryption-state.d.ts +18 -0
- package/src/interfaces/encryption-state.d.ts.map +1 -0
- package/src/interfaces/encryption-state.js +5 -0
- package/src/interfaces/encryption-state.js.map +1 -0
- package/src/interfaces/frontend-member-operational.d.ts +12 -1
- package/src/interfaces/frontend-member-operational.d.ts.map +1 -1
- package/src/interfaces/multi-recipient-chunk.d.ts +65 -0
- package/src/interfaces/multi-recipient-chunk.d.ts.map +1 -0
- package/src/interfaces/multi-recipient-chunk.js +25 -0
- package/src/interfaces/multi-recipient-chunk.js.map +1 -0
- package/src/interfaces/stream-config.d.ts +14 -0
- package/src/interfaces/stream-config.d.ts.map +1 -0
- package/src/interfaces/stream-config.js +11 -0
- package/src/interfaces/stream-config.js.map +1 -0
- package/src/interfaces/stream-header.d.ts +29 -0
- package/src/interfaces/stream-header.d.ts.map +1 -0
- package/src/interfaces/stream-header.js +12 -0
- package/src/interfaces/stream-header.js.map +1 -0
- package/src/interfaces/stream-progress.d.ts +33 -0
- package/src/interfaces/stream-progress.d.ts.map +1 -0
- package/src/interfaces/stream-progress.js +3 -0
- package/src/interfaces/stream-progress.js.map +1 -0
- package/src/lib/crypto-container.d.ts.map +1 -1
- package/src/lib/crypto-container.js +2 -1
- package/src/lib/crypto-container.js.map +1 -1
- package/src/member.d.ts +27 -1
- package/src/member.d.ts.map +1 -1
- package/src/member.js +69 -2
- package/src/member.js.map +1 -1
- package/src/services/aes-gcm.d.ts.map +1 -1
- package/src/services/aes-gcm.js +29 -0
- package/src/services/aes-gcm.js.map +1 -1
- package/src/services/chunk-processor.d.ts +31 -0
- package/src/services/chunk-processor.d.ts.map +1 -0
- package/src/services/chunk-processor.js +149 -0
- package/src/services/chunk-processor.js.map +1 -0
- package/src/services/ecies/crypto-core.d.ts.map +1 -1
- package/src/services/ecies/crypto-core.js +23 -8
- package/src/services/ecies/crypto-core.js.map +1 -1
- package/src/services/ecies/service.d.ts +12 -4
- package/src/services/ecies/service.d.ts.map +1 -1
- package/src/services/ecies/service.js +28 -18
- package/src/services/ecies/service.js.map +1 -1
- package/src/services/ecies/single-recipient.d.ts.map +1 -1
- package/src/services/ecies/single-recipient.js +55 -4
- package/src/services/ecies/single-recipient.js.map +1 -1
- package/src/services/encryption-stream.d.ts +69 -0
- package/src/services/encryption-stream.d.ts.map +1 -0
- package/src/services/encryption-stream.js +297 -0
- package/src/services/encryption-stream.js.map +1 -0
- package/src/services/multi-recipient-processor.d.ts +25 -0
- package/src/services/multi-recipient-processor.d.ts.map +1 -0
- package/src/services/multi-recipient-processor.js +238 -0
- package/src/services/multi-recipient-processor.js.map +1 -0
- package/src/services/password-login.js +1 -1
- package/src/services/password-login.js.map +1 -1
- package/src/services/progress-tracker.d.ts +23 -0
- package/src/services/progress-tracker.d.ts.map +1 -0
- package/src/services/progress-tracker.js +98 -0
- package/src/services/progress-tracker.js.map +1 -0
- package/src/services/resumable-encryption.d.ts +19 -0
- package/src/services/resumable-encryption.d.ts.map +1 -0
- package/src/services/resumable-encryption.js +109 -0
- package/src/services/resumable-encryption.js.map +1 -0
- package/src/test-mocks/mock-frontend-member.d.ts +15 -0
- package/src/test-mocks/mock-frontend-member.d.ts.map +1 -1
- package/src/test-mocks/mock-frontend-member.js +58 -0
- package/src/test-mocks/mock-frontend-member.js.map +1 -1
- package/src/translations/de.d.ts +3 -0
- package/src/translations/de.d.ts.map +1 -0
- package/src/translations/de.js +178 -0
- package/src/translations/de.js.map +1 -0
- package/src/translations/en-US.d.ts +3 -0
- package/src/translations/en-US.d.ts.map +1 -0
- package/src/translations/en-US.js +178 -0
- package/src/translations/en-US.js.map +1 -0
- package/src/translations/es.d.ts +3 -0
- package/src/translations/es.d.ts.map +1 -0
- package/src/translations/es.js +178 -0
- package/src/translations/es.js.map +1 -0
- package/src/translations/fr.d.ts +3 -0
- package/src/translations/fr.d.ts.map +1 -0
- package/src/translations/fr.js +178 -0
- package/src/translations/fr.js.map +1 -0
- package/src/translations/ja.d.ts +3 -0
- package/src/translations/ja.d.ts.map +1 -0
- package/src/translations/ja.js +178 -0
- package/src/translations/ja.js.map +1 -0
- package/src/translations/uk.d.ts +3 -0
- package/src/translations/uk.d.ts.map +1 -0
- package/src/translations/uk.js +178 -0
- package/src/translations/uk.js.map +1 -0
- package/src/translations/zh-cn.d.ts +3 -0
- package/src/translations/zh-cn.d.ts.map +1 -0
- package/src/translations/zh-cn.js +178 -0
- package/src/translations/zh-cn.js.map +1 -0
- package/src/utils.d.ts.map +1 -1
- package/src/utils.js +8 -5
- package/src/utils.js.map +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encryption-stream.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/encryption-stream.ts"],"names":[],"mappings":";;;AACA,4CAAyC;AACzC,+DAAmF;AAEnF,+DAAqF;AAIrF,uDAAmD;AACnD,yDAAqD;AACrD,2EAAsE;AAEtE,8CAAqE;AACrE,kDAAiD;AAwBjD;;GAEG;AACH,MAAa,gBAAgB;IAKR;IACA;IACA;IANF,SAAS,CAAiB;IAC1B,uBAAuB,CAA0B;IAElE,YACmB,KAAmB,EACnB,SAAwB,qCAAqB,EAC7C,cAA+B,qBAAS,CAAC,KAAK;QAF9C,UAAK,GAAL,KAAK,CAAc;QACnB,WAAM,GAAN,MAAM,CAAuC;QAC7C,gBAAW,GAAX,WAAW,CAAmC;QAE/D,IAAI,CAAC,SAAS,GAAG,IAAI,gCAAc,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QACxD,IAAI,CAAC,uBAAuB,GAAG,IAAI,mDAAuB,CAAC,KAAK,CAAC,CAAC;IACpE,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,MAAqB;QACrC,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,uCAAuB,CAAC,WAAW,CAAC,CAAC;QACnE,MAAM,IAAI,GAAG,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAEzC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,cAAc,CAAC,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAC3C,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,MAAM,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,KAAK,CAAC,CAAC;QACxD,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,KAAK,CAAC,CAAC;QACvD,iCAAiC;QAEjC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,IAAgB;QAChC,MAAM,MAAM,GAAG,IAAA,+BAAkB,GAAE,CAAC;QACpC,IAAI,IAAI,CAAC,MAAM,GAAG,uCAAuB,CAAC,WAAW,EAAE,CAAC;YACtD,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,kCAAkC,CAAC,CAAC,CAAC;QACzG,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAExD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QACvC,IAAI,KAAK,KAAK,uCAAuB,CAAC,KAAK,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,8BAA8B,CAAC,CAAC,CAAC;QACrG,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QACzC,IAAI,OAAO,KAAK,uCAAuB,CAAC,OAAO,EAAE,CAAC;YAChD,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,+BAA+B,CAAC,CAAC,CAAC;QACtG,CAAC;QAED,OAAO;YACL,KAAK;YACL,OAAO;YACP,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAA4B;YAC3D,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC;YACnC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC;YACtC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;YAChD,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;SAChD,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,CAAC,aAAa,CAClB,MAAiC,EACjC,SAAqB,EACrB,UAAiC,EAAE;QAEnC,MAAM,MAAM,GAAG,IAAA,+BAAkB,GAAE,CAAC;QACpC,+DAA+D;QAC/D,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,EAAE,IAAI,SAAS,CAAC,MAAM,KAAK,EAAE,CAAC,EAAE,CAAC;YACvE,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,mCAAmC,CAAC,CAAC,CAAC;QAC1G,CAAC;QAED,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QAC7D,MAAM,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,IAAI,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC;QAClF,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;QAC9B,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QAEtC,IAAI,MAAM,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,gBAAgB,GAA2B,IAAI,CAAC;QACpD,IAAI,OAAoC,CAAC;QACzC,IAAI,cAAc,GAAG,CAAC,CAAC;QACvB,MAAM,cAAc,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,6BAA6B;QAEvE,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;YAChC,yBAAyB;YACzB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,IAAI,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,gCAAgC,CAAC,EAAE,YAAY,CAAC,CAAC;YAC5H,CAAC;YAED,2DAA2D;YAC3D,IAAI,IAAI,CAAC,MAAM,GAAG,cAAc,EAAE,CAAC;gBACjC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,mCAAmC,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;YACnI,CAAC;YAED,mBAAmB;YACnB,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;YAC9D,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACtB,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YACnC,MAAM,GAAG,SAAS,CAAC;YACnB,cAAc,IAAI,IAAI,CAAC,MAAM,CAAC;YAE9B,mCAAmC;YACnC,IAAI,CAAC,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC3B,OAAO,GAAG,IAAI,kCAAe,EAAE,CAAC;YAClC,CAAC;YAED,0BAA0B;YAC1B,OAAO,MAAM,CAAC,MAAM,IAAI,SAAS,EAAE,CAAC;gBAClC,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;oBACpB,MAAM,IAAI,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;gBAC/D,CAAC;gBAED,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;gBAC7C,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAEjC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CACtD,SAAS,EACT,SAAS,EACT,UAAU,EAAE,EACZ,KAAK,EACL,gBAAgB,CACjB,CAAC;gBAEF,gBAAgB,GAAG,cAAc,CAAC;gBAClC,MAAM,cAAc,CAAC;gBAErB,kBAAkB;gBAClB,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;oBAC1B,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;QAED,uCAAuC;QACvC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,IAAI,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;YAC/D,CAAC;YAED,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CACtD,MAAM,EACN,SAAS,EACT,UAAU,EACV,IAAI,EACJ,gBAAgB,CACjB,CAAC;YAEF,MAAM,cAAc,CAAC;YAErB,wBAAwB;YACxB,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC1B,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC5C,CAAC;QACH,CAAC;aAAM,IAAI,UAAU,KAAK,CAAC,EAAE,CAAC;YAC5B,+BAA+B;YAC/B,OAAO;QACT,CAAC;aAAM,IAAI,gBAAgB,EAAE,CAAC;YAC5B,sCAAsC;YACtC,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC;QACjC,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,CAAC,qBAAqB,CAC1B,MAAiC,EACjC,UAA4D,EAC5D,UAAiC,EAAE;QAEnC,MAAM,MAAM,GAAG,IAAA,+BAAkB,GAAE,CAAC;QACpC,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,wCAAwC,CAAC,CAAC,CAAC;QAC/G,CAAC;QACD,IAAI,UAAU,CAAC,MAAM,GAAG,KAAK,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,kCAAkC,CAAC,CAAC,CAAC;QACzG,CAAC;QAED,qCAAqC;QACrC,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,KAAK,EAAE,IAAI,SAAS,CAAC,SAAS,CAAC,MAAM,KAAK,EAAE,CAAC,EAAE,CAAC;gBACrG,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,4CAA4C,CAAC,CAAC,CAAC;YACnH,CAAC;YACD,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;gBAChD,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,qCAAqC,CAAC,CAAC,CAAC;YAC5G,CAAC;QACH,CAAC;QAED,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QAC7D,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;QAC9B,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QAEtC,gDAAgD;QAChD,MAAM,YAAY,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;QAEhE,IAAI,MAAM,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,OAAoC,CAAC;QACzC,MAAM,cAAc,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,CAAC;QAEzC,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;YAChC,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,IAAI,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;YAC/D,CAAC;YAED,IAAI,IAAI,CAAC,MAAM,GAAG,cAAc,EAAE,CAAC;gBACjC,MAAM,IAAI,KAAK,CAAC,yCAAyC,cAAc,QAAQ,CAAC,CAAC;YACnF,CAAC;YAED,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;YAC9D,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACtB,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YACnC,MAAM,GAAG,SAAS,CAAC;YAEnB,IAAI,CAAC,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC3B,OAAO,GAAG,IAAI,kCAAe,EAAE,CAAC;YAClC,CAAC;YAED,OAAO,MAAM,CAAC,MAAM,IAAI,SAAS,EAAE,CAAC;gBAClC,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;oBACpB,MAAM,IAAI,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;gBAC/D,CAAC;gBAED,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;gBAC7C,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAEjC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,YAAY,CACpE,SAAS,EACT,UAAU,EACV,UAAU,EAAE,EACZ,KAAK,EACL,YAAY,CACb,CAAC;gBAEF,MAAM,cAAc,CAAC;gBAErB,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;oBAC1B,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;QAED,uCAAuC;QACvC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,IAAI,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;YAC/D,CAAC;YAED,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,YAAY,CACpE,MAAM,EACN,UAAU,EACV,UAAU,EACV,IAAI,EACJ,YAAY,CACb,CAAC;YAEF,MAAM,cAAc,CAAC;YAErB,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC1B,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC5C,CAAC;QACH,CAAC;aAAM,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;YAC1B,8DAA8D;YAC9D,uDAAuD;QACzD,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,CAAC,qBAAqB,CAC1B,MAAiC,EACjC,WAAuB,EACvB,UAAsB,EACtB,UAAiC,EAAE;QAEnC,MAAM,MAAM,GAAG,IAAA,+BAAkB,GAAE,CAAC;QACpC,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAC9C,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,0CAA0C,CAAC,CAAC,CAAC;QACjH,CAAC;QACD,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,yCAAyC,CAAC,CAAC,CAAC;QAChH,CAAC;QAED,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;QAC9B,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,IAAI,aAAa,GAAG,CAAC,CAAC;QACtB,IAAI,OAAoC,CAAC;QAEzC,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,GAAG,IAAI,kCAAe,EAAE,CAAC;QAClC,CAAC;QAED,IAAI,KAAK,EAAE,MAAM,SAAS,IAAI,MAAM,EAAE,CAAC;YACrC,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,IAAI,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,gCAAgC,CAAC,EAAE,YAAY,CAAC,CAAC;YAC5H,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,YAAY,CACtE,SAAS,EACT,WAAW,EACX,UAAU,CACX,CAAC;YAEF,IAAI,MAAM,CAAC,UAAU,KAAK,aAAa,EAAE,CAAC;gBACxC,MAAM,IAAI,KAAK,CACb,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,uCAAuC,EAAE,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,CAAC,UAAU,EAAE,CAAC,CACnJ,CAAC;YACJ,CAAC;YAED,aAAa,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC;YAEX,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC1B,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YAC1C,CAAC;YAED,MAAM,MAAM,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3C,IAAI,MAAM,EAAE,CAAC;gBACX,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,CAAC,aAAa,CAClB,MAAiC,EACjC,UAAsB,EACtB,UAAiC,EAAE;QAEnC,MAAM,MAAM,GAAG,IAAA,+BAAkB,GAAE,CAAC;QACpC,uBAAuB;QACvB,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,yCAAyC,CAAC,CAAC,CAAC;QAChH,CAAC;QAED,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;QAC9B,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,IAAI,aAAa,GAAG,CAAC,CAAC;QACtB,IAAI,OAAoC,CAAC;QAEzC,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,GAAG,IAAI,kCAAe,EAAE,CAAC;QAClC,CAAC;QAED,IAAI,KAAK,EAAE,MAAM,SAAS,IAAI,MAAM,EAAE,CAAC;YACrC,yBAAyB;YACzB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,IAAI,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,gCAAgC,CAAC,EAAE,YAAY,CAAC,CAAC;YAC5H,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CACxD,SAAS,EACT,UAAU,CACX,CAAC;YAEF,oBAAoB;YACpB,IAAI,MAAM,CAAC,KAAK,KAAK,aAAa,EAAE,CAAC;gBACnC,MAAM,IAAI,KAAK,CACb,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,6BAAc,CAAC,uCAAuC,EAAE,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAC9I,CAAC;YACJ,CAAC;YAED,aAAa,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC;YAEX,kBAAkB;YAClB,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC1B,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YAC1C,CAAC;YAED,mCAAmC;YACnC,MAAM,MAAM,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3C,IAAI,MAAM,EAAE,CAAC;gBACX,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;CACF;AApYD,4CAoYC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { ECIESService } from './ecies/service';
|
|
2
|
+
import { IMultiRecipientChunk, IMultiRecipientChunkHeader } from '../interfaces/multi-recipient-chunk';
|
|
3
|
+
/**
|
|
4
|
+
* Processes multi-recipient chunks using symmetric encryption
|
|
5
|
+
*/
|
|
6
|
+
export declare class MultiRecipientProcessor {
|
|
7
|
+
private readonly ecies;
|
|
8
|
+
constructor(ecies: ECIESService);
|
|
9
|
+
/**
|
|
10
|
+
* Encrypt chunk for multiple recipients
|
|
11
|
+
*/
|
|
12
|
+
encryptChunk(data: Uint8Array, recipients: Array<{
|
|
13
|
+
id: Uint8Array;
|
|
14
|
+
publicKey: Uint8Array;
|
|
15
|
+
}>, chunkIndex: number, isLast: boolean, symmetricKey: Uint8Array): Promise<IMultiRecipientChunk>;
|
|
16
|
+
/**
|
|
17
|
+
* Decrypt chunk for specific recipient
|
|
18
|
+
*/
|
|
19
|
+
decryptChunk(chunkData: Uint8Array, recipientId: Uint8Array, privateKey: Uint8Array): Promise<{
|
|
20
|
+
data: Uint8Array;
|
|
21
|
+
header: IMultiRecipientChunkHeader;
|
|
22
|
+
}>;
|
|
23
|
+
private arraysEqual;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=multi-recipient-processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-recipient-processor.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/multi-recipient-processor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAG3B,MAAM,qCAAqC,CAAC;AAK7C;;GAEG;AACH,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,YAAY;IAEhD;;OAEG;IACG,YAAY,CAChB,IAAI,EAAE,UAAU,EAChB,UAAU,EAAE,KAAK,CAAC;QAAE,EAAE,EAAE,UAAU,CAAC;QAAC,SAAS,EAAE,UAAU,CAAA;KAAE,CAAC,EAC5D,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,OAAO,EACf,YAAY,EAAE,UAAU,GACvB,OAAO,CAAC,oBAAoB,CAAC;IA8HhC;;OAEG;IACG,YAAY,CAChB,SAAS,EAAE,UAAU,EACrB,WAAW,EAAE,UAAU,EACvB,UAAU,EAAE,UAAU,GACrB,OAAO,CAAC;QAAE,IAAI,EAAE,UAAU,CAAC;QAAC,MAAM,EAAE,0BAA0B,CAAA;KAAE,CAAC;IAwHpE,OAAO,CAAC,WAAW;CAUpB"}
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MultiRecipientProcessor = void 0;
|
|
4
|
+
const multi_recipient_chunk_1 = require("../interfaces/multi-recipient-chunk");
|
|
5
|
+
const crypto_1 = require("crypto");
|
|
6
|
+
const i18n_setup_1 = require("../i18n-setup");
|
|
7
|
+
const enumerations_1 = require("../enumerations");
|
|
8
|
+
/**
|
|
9
|
+
* Processes multi-recipient chunks using symmetric encryption
|
|
10
|
+
*/
|
|
11
|
+
class MultiRecipientProcessor {
|
|
12
|
+
ecies;
|
|
13
|
+
constructor(ecies) {
|
|
14
|
+
this.ecies = ecies;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Encrypt chunk for multiple recipients
|
|
18
|
+
*/
|
|
19
|
+
async encryptChunk(data, recipients, chunkIndex, isLast, symmetricKey) {
|
|
20
|
+
// Validate inputs
|
|
21
|
+
const engine = (0, i18n_setup_1.getEciesI18nEngine)();
|
|
22
|
+
if (recipients.length === 0 || recipients.length > multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.MAX_RECIPIENTS) {
|
|
23
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_InvalidRecipientCountTemplate, { count: recipients.length }));
|
|
24
|
+
}
|
|
25
|
+
if (symmetricKey.length !== 32) {
|
|
26
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_SymmetricKeyMust32Bytes));
|
|
27
|
+
}
|
|
28
|
+
if (chunkIndex < 0 || chunkIndex > 0xFFFFFFFF) {
|
|
29
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_InvalidChunkIndexTemplate, { index: chunkIndex }));
|
|
30
|
+
}
|
|
31
|
+
if (data.length > 0x7FFFFFFF) {
|
|
32
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_DataSizeExceedsMaximumTemplate, { size: data.length }));
|
|
33
|
+
}
|
|
34
|
+
// Check for duplicate recipient IDs
|
|
35
|
+
const seenIds = new Set();
|
|
36
|
+
for (const recipient of recipients) {
|
|
37
|
+
const idStr = Buffer.from(recipient.id).toString('hex');
|
|
38
|
+
if (seenIds.has(idStr)) {
|
|
39
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_DuplicateRecipientId));
|
|
40
|
+
}
|
|
41
|
+
seenIds.add(idStr);
|
|
42
|
+
}
|
|
43
|
+
// Encrypt data with AES-256-GCM
|
|
44
|
+
const iv = (0, crypto_1.randomBytes)(12);
|
|
45
|
+
const cipher = (0, crypto_1.createCipheriv)('aes-256-gcm', symmetricKey, iv);
|
|
46
|
+
const encrypted = Buffer.concat([cipher.update(data), cipher.final()]);
|
|
47
|
+
const authTag = cipher.getAuthTag();
|
|
48
|
+
// Build recipient headers
|
|
49
|
+
const recipientHeaders = [];
|
|
50
|
+
for (const recipient of recipients) {
|
|
51
|
+
if (recipient.id.length !== multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.RECIPIENT_ID_SIZE) {
|
|
52
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_RecipientIdMust32Bytes));
|
|
53
|
+
}
|
|
54
|
+
const encryptedKey = await this.ecies.encryptSimpleOrSingle(false, recipient.publicKey, symmetricKey);
|
|
55
|
+
recipientHeaders.push({
|
|
56
|
+
id: recipient.id,
|
|
57
|
+
keySize: encryptedKey.length,
|
|
58
|
+
encryptedKey,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
// Calculate sizes with overflow check
|
|
62
|
+
let recipientHeadersSize = 0;
|
|
63
|
+
for (const h of recipientHeaders) {
|
|
64
|
+
const headerSize = multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.RECIPIENT_ID_SIZE +
|
|
65
|
+
multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.KEY_SIZE_BYTES + h.keySize;
|
|
66
|
+
if (recipientHeadersSize + headerSize < recipientHeadersSize) {
|
|
67
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_RecipientHeadersSizeOverflow));
|
|
68
|
+
}
|
|
69
|
+
recipientHeadersSize += headerSize;
|
|
70
|
+
}
|
|
71
|
+
const totalSize = multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.HEADER_SIZE +
|
|
72
|
+
recipientHeadersSize +
|
|
73
|
+
12 + // IV
|
|
74
|
+
encrypted.length +
|
|
75
|
+
16; // Auth tag
|
|
76
|
+
// Check for integer overflow (max safe: 2^31 - 1 for Uint8Array)
|
|
77
|
+
if (totalSize > 0x7FFFFFFF || totalSize < 0) {
|
|
78
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_ChunkSizeOverflow));
|
|
79
|
+
}
|
|
80
|
+
// Build chunk
|
|
81
|
+
const chunk = new Uint8Array(totalSize);
|
|
82
|
+
const view = new DataView(chunk.buffer);
|
|
83
|
+
let offset = 0;
|
|
84
|
+
// Write header
|
|
85
|
+
view.setUint32(offset, multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.MAGIC, false);
|
|
86
|
+
offset += 4;
|
|
87
|
+
view.setUint16(offset, multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.VERSION, false);
|
|
88
|
+
offset += 2;
|
|
89
|
+
view.setUint16(offset, recipients.length, false);
|
|
90
|
+
offset += 2;
|
|
91
|
+
view.setUint32(offset, chunkIndex, false);
|
|
92
|
+
offset += 4;
|
|
93
|
+
view.setUint32(offset, data.length, false);
|
|
94
|
+
offset += 4;
|
|
95
|
+
view.setUint32(offset, encrypted.length, false);
|
|
96
|
+
offset += 4;
|
|
97
|
+
view.setUint8(offset, isLast ? multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.FLAG_IS_LAST : 0);
|
|
98
|
+
offset += 1;
|
|
99
|
+
// Padding to 32 bytes
|
|
100
|
+
offset = multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.HEADER_SIZE;
|
|
101
|
+
// Write recipient headers
|
|
102
|
+
for (const header of recipientHeaders) {
|
|
103
|
+
chunk.set(header.id, offset);
|
|
104
|
+
offset += multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.RECIPIENT_ID_SIZE;
|
|
105
|
+
view.setUint16(offset, header.keySize, false);
|
|
106
|
+
offset += multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.KEY_SIZE_BYTES;
|
|
107
|
+
chunk.set(header.encryptedKey, offset);
|
|
108
|
+
offset += header.keySize;
|
|
109
|
+
}
|
|
110
|
+
// Write IV
|
|
111
|
+
chunk.set(iv, offset);
|
|
112
|
+
offset += 12;
|
|
113
|
+
// Write encrypted data
|
|
114
|
+
chunk.set(encrypted, offset);
|
|
115
|
+
offset += encrypted.length;
|
|
116
|
+
// Write auth tag
|
|
117
|
+
chunk.set(authTag, offset);
|
|
118
|
+
return {
|
|
119
|
+
index: chunkIndex,
|
|
120
|
+
data: chunk,
|
|
121
|
+
isLast,
|
|
122
|
+
recipientCount: recipients.length,
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Decrypt chunk for specific recipient
|
|
127
|
+
*/
|
|
128
|
+
async decryptChunk(chunkData, recipientId, privateKey) {
|
|
129
|
+
const engine = (0, i18n_setup_1.getEciesI18nEngine)();
|
|
130
|
+
if (chunkData.length < multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.HEADER_SIZE) {
|
|
131
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_ChunkTooSmall));
|
|
132
|
+
}
|
|
133
|
+
const view = new DataView(chunkData.buffer, chunkData.byteOffset);
|
|
134
|
+
let offset = 0;
|
|
135
|
+
// Parse header
|
|
136
|
+
const magic = view.getUint32(offset, false);
|
|
137
|
+
offset += 4;
|
|
138
|
+
if (magic !== multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.MAGIC) {
|
|
139
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_InvalidChunkMagic));
|
|
140
|
+
}
|
|
141
|
+
const version = view.getUint16(offset, false);
|
|
142
|
+
offset += 2;
|
|
143
|
+
if (version !== multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.VERSION) {
|
|
144
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_UnsupportedVersionTemplate, { version }));
|
|
145
|
+
}
|
|
146
|
+
const recipientCount = view.getUint16(offset, false);
|
|
147
|
+
offset += 2;
|
|
148
|
+
if (recipientCount === 0 || recipientCount > multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.MAX_RECIPIENTS) {
|
|
149
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_InvalidRecipientCountTemplate, { count: recipientCount }));
|
|
150
|
+
}
|
|
151
|
+
const chunkIndex = view.getUint32(offset, false);
|
|
152
|
+
offset += 4;
|
|
153
|
+
const originalSize = view.getUint32(offset, false);
|
|
154
|
+
offset += 4;
|
|
155
|
+
const encryptedSize = view.getUint32(offset, false);
|
|
156
|
+
offset += 4;
|
|
157
|
+
const flags = view.getUint8(offset);
|
|
158
|
+
offset = multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.HEADER_SIZE;
|
|
159
|
+
// Validate encryptedSize against chunk size
|
|
160
|
+
const minChunkSize = multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.HEADER_SIZE + 12 + encryptedSize + 16;
|
|
161
|
+
if (chunkData.length < minChunkSize) {
|
|
162
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_ChunkTooSmallForEncryptedSize));
|
|
163
|
+
}
|
|
164
|
+
// Find recipient header and decrypt symmetric key
|
|
165
|
+
let symmetricKey = null;
|
|
166
|
+
let tempOffset = offset;
|
|
167
|
+
for (let i = 0; i < recipientCount; i++) {
|
|
168
|
+
// Check if we have enough data for recipient ID
|
|
169
|
+
if (tempOffset + multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.RECIPIENT_ID_SIZE > chunkData.length) {
|
|
170
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_ChunkTruncatedRecipientId));
|
|
171
|
+
}
|
|
172
|
+
const id = chunkData.slice(tempOffset, tempOffset + multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.RECIPIENT_ID_SIZE);
|
|
173
|
+
tempOffset += multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.RECIPIENT_ID_SIZE;
|
|
174
|
+
// Check if we have enough data for keySize field
|
|
175
|
+
if (tempOffset + multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.KEY_SIZE_BYTES > chunkData.length) {
|
|
176
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_ChunkTruncatedKeySize));
|
|
177
|
+
}
|
|
178
|
+
const keySize = view.getUint16(tempOffset, false);
|
|
179
|
+
tempOffset += multi_recipient_chunk_1.MULTI_RECIPIENT_CONSTANTS.KEY_SIZE_BYTES;
|
|
180
|
+
// Validate keySize (typical ECIES: 100-400 bytes)
|
|
181
|
+
if (keySize === 0 || keySize > 1000) {
|
|
182
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_InvalidKeySizeTemplate, { size: keySize }));
|
|
183
|
+
}
|
|
184
|
+
// Check if we have enough data for the encrypted key
|
|
185
|
+
if (tempOffset + keySize > chunkData.length) {
|
|
186
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_ChunkTruncatedEncryptedKey));
|
|
187
|
+
}
|
|
188
|
+
const encryptedKey = chunkData.slice(tempOffset, tempOffset + keySize);
|
|
189
|
+
tempOffset += keySize;
|
|
190
|
+
// Check if this is our recipient
|
|
191
|
+
if (this.arraysEqual(id, recipientId)) {
|
|
192
|
+
symmetricKey = await this.ecies.decryptSimpleOrSingleWithHeader(false, privateKey, encryptedKey);
|
|
193
|
+
// Don't break - need to skip all recipient headers
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
if (!symmetricKey) {
|
|
197
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, enumerations_1.EciesStringKey.Error_MultiRecipient_RecipientNotFoundInChunk));
|
|
198
|
+
}
|
|
199
|
+
// Update offset to after all recipient headers
|
|
200
|
+
offset = tempOffset;
|
|
201
|
+
// Read IV
|
|
202
|
+
const iv = chunkData.slice(offset, offset + 12);
|
|
203
|
+
offset += 12;
|
|
204
|
+
// Read encrypted data
|
|
205
|
+
const encrypted = chunkData.slice(offset, offset + encryptedSize);
|
|
206
|
+
offset += encryptedSize;
|
|
207
|
+
// Read auth tag
|
|
208
|
+
const authTag = chunkData.slice(offset, offset + 16);
|
|
209
|
+
// Decrypt
|
|
210
|
+
const decipher = (0, crypto_1.createDecipheriv)('aes-256-gcm', symmetricKey, iv);
|
|
211
|
+
decipher.setAuthTag(authTag);
|
|
212
|
+
const decrypted = Buffer.concat([decipher.update(encrypted), decipher.final()]);
|
|
213
|
+
return {
|
|
214
|
+
data: new Uint8Array(decrypted),
|
|
215
|
+
header: {
|
|
216
|
+
magic,
|
|
217
|
+
version,
|
|
218
|
+
recipientCount,
|
|
219
|
+
chunkIndex,
|
|
220
|
+
originalSize,
|
|
221
|
+
encryptedSize,
|
|
222
|
+
flags,
|
|
223
|
+
},
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
arraysEqual(a, b) {
|
|
227
|
+
if (a.length !== b.length)
|
|
228
|
+
return false;
|
|
229
|
+
// Constant-time comparison to prevent timing attacks
|
|
230
|
+
let diff = 0;
|
|
231
|
+
for (let i = 0; i < a.length; i++) {
|
|
232
|
+
diff |= a[i] ^ b[i];
|
|
233
|
+
}
|
|
234
|
+
return diff === 0;
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
exports.MultiRecipientProcessor = MultiRecipientProcessor;
|
|
238
|
+
//# sourceMappingURL=multi-recipient-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-recipient-processor.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/multi-recipient-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -35,7 +35,7 @@ class PasswordLoginService {
|
|
|
35
35
|
}
|
|
36
36
|
const encryptedPrivateKey = aes_gcm_1.AESGCMService.combineIvTagAndEncryptedData(iv, encrypted, tag);
|
|
37
37
|
// now use the public key to encrypt the mnemonic and store it
|
|
38
|
-
const encryptedMnemonic = await this.eciesService.encrypt(ecies_encryption_type_1.EciesEncryptionTypeEnum.Simple,
|
|
38
|
+
const encryptedMnemonic = await this.eciesService.encrypt(ecies_encryption_type_1.EciesEncryptionTypeEnum.Simple, wallet.getPublicKey(), mnemonic.valueAsUint8Array);
|
|
39
39
|
return {
|
|
40
40
|
salt: derivedKey.salt,
|
|
41
41
|
encryptedPrivateKey: encryptedPrivateKey,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"password-login.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/password-login.ts"],"names":[],"mappings":";;;AAAA,+CAA4C;AAC5C,iFAAgF;AAChF,mEAAmE;AACnE,oDAAgD;AAChD,oCAA4D;AAC5D,uCAA0C;AAG1C,kDAA6E;AAC7E,wDAA2G;AAE3G,4CAAyC;AACzC,8CAAiD;AAGjD,MAAa,oBAAoB;IACZ,YAAY,CAAe;IAC3B,aAAa,CAAgB;IAC7B,WAAW,CAAkB;IACzC,MAAM,CAAU,oBAAoB,GAAG,qBAAqB,CAAC;IAC7D,MAAM,CAAU,cAAc,GAAG,mBAAmB,CAAC;IACrD,MAAM,CAAU,2BAA2B,GAAG,mBAAmB,CAAC;IAClE,MAAM,CAAU,iBAAiB,GAAG,eAAe,CAAC;IAE3D,YAAY,YAA0B,EAAE,aAA4B,EAAE,cAA+B,qBAAS,CAAC,KAAK;QAClH,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAEM,KAAK,CAAC,yBAAyB,CACpC,QAAsB,EACtB,QAAsB,EACtB,UAA6B,kCAAiB,CAAC,gBAAgB;QAO/D,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC;QAEzE,MAAM,UAAU,GACd,MAAM,IAAI,CAAC,aAAa,CAAC,qCAAqC,CAC5D,QAAQ,CAAC,iBAAiB,EAC1B,OAAO,CACR,CAAC;QAEJ,uCAAuC;QACvC,MAAM,eAAe,GAAG,MAAM,CAAC,aAAa,EAAE,CAAC;QAC/C,MAAM,EAAE,SAAS,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,MAAM,uBAAa,CAAC,OAAO,CACxD,eAAe,EACf,UAAU,CAAC,IAAI,EACf,IAAI,CACL,CAAC;QACF,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,MAAM,IAAI,mCAAwB,CAAC,6BAAgB,EAAE,6BAAc,CAAC,qCAAqC,CAAC,CAAC;QAC7G,CAAC;QACD,MAAM,mBAAmB,GAAG,uBAAa,CAAC,4BAA4B,CACpE,EAAE,EACF,SAAS,EACT,GAAG,CACJ,CAAC;QAEF,8DAA8D;QAC9D,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,CACvD,+CAAuB,CAAC,MAAM,EAC9B,
|
|
1
|
+
{"version":3,"file":"password-login.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/password-login.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { IStreamProgress } from '../interfaces/stream-progress';
|
|
2
|
+
/**
|
|
3
|
+
* Tracks progress for streaming operations
|
|
4
|
+
*/
|
|
5
|
+
export declare class ProgressTracker {
|
|
6
|
+
private readonly totalBytes?;
|
|
7
|
+
private startTime;
|
|
8
|
+
private lastUpdateTime;
|
|
9
|
+
private bytesProcessed;
|
|
10
|
+
private chunksProcessed;
|
|
11
|
+
private recentThroughputs;
|
|
12
|
+
private readonly maxThroughputSamples;
|
|
13
|
+
constructor(totalBytes?: number | undefined);
|
|
14
|
+
/**
|
|
15
|
+
* Update progress with new chunk
|
|
16
|
+
*/
|
|
17
|
+
update(chunkBytes: number): IStreamProgress;
|
|
18
|
+
/**
|
|
19
|
+
* Get current progress without update
|
|
20
|
+
*/
|
|
21
|
+
getProgress(): IStreamProgress;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=progress-tracker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress-tracker.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/progress-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAIhE;;GAEG;AACH,qBAAa,eAAe;IAQd,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;IAPxC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,eAAe,CAAa;IACpC,OAAO,CAAC,iBAAiB,CAAgB;IACzC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAK;gBAEb,UAAU,CAAC,EAAE,MAAM,YAAA;IAKhD;;OAEG;IACH,MAAM,CAAC,UAAU,EAAE,MAAM,GAAG,eAAe;IAuD3C;;OAEG;IACH,WAAW,IAAI,eAAe;CAyB/B"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProgressTracker = void 0;
|
|
4
|
+
const i18n_setup_1 = require("../i18n-setup");
|
|
5
|
+
const ecies_string_key_1 = require("../enumerations/ecies-string-key");
|
|
6
|
+
/**
|
|
7
|
+
* Tracks progress for streaming operations
|
|
8
|
+
*/
|
|
9
|
+
class ProgressTracker {
|
|
10
|
+
totalBytes;
|
|
11
|
+
startTime;
|
|
12
|
+
lastUpdateTime;
|
|
13
|
+
bytesProcessed = 0;
|
|
14
|
+
chunksProcessed = 0;
|
|
15
|
+
recentThroughputs = [];
|
|
16
|
+
maxThroughputSamples = 5;
|
|
17
|
+
constructor(totalBytes) {
|
|
18
|
+
this.totalBytes = totalBytes;
|
|
19
|
+
this.startTime = Date.now();
|
|
20
|
+
this.lastUpdateTime = this.startTime;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Update progress with new chunk
|
|
24
|
+
*/
|
|
25
|
+
update(chunkBytes) {
|
|
26
|
+
// Validate input
|
|
27
|
+
if (chunkBytes < 0) {
|
|
28
|
+
const engine = (0, i18n_setup_1.getEciesI18nEngine)();
|
|
29
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Progress_ChunkBytesCannotBeNegative));
|
|
30
|
+
}
|
|
31
|
+
this.bytesProcessed += chunkBytes;
|
|
32
|
+
this.chunksProcessed++;
|
|
33
|
+
const now = Date.now();
|
|
34
|
+
const elapsedTime = Math.max(0, now - this.startTime);
|
|
35
|
+
const timeSinceLastUpdate = Math.max(0, now - this.lastUpdateTime);
|
|
36
|
+
// Calculate instantaneous throughput (use elapsed time if same millisecond)
|
|
37
|
+
const timeWindow = timeSinceLastUpdate > 0 ? timeSinceLastUpdate : Math.max(1, elapsedTime);
|
|
38
|
+
if (chunkBytes > 0 && timeWindow > 0) {
|
|
39
|
+
const instantThroughput = (chunkBytes / timeWindow) * 1000;
|
|
40
|
+
// Guard against unrealistic throughput (>10GB/s)
|
|
41
|
+
if (isFinite(instantThroughput) && instantThroughput < 10 * 1024 * 1024 * 1024) {
|
|
42
|
+
this.recentThroughputs.push(instantThroughput);
|
|
43
|
+
if (this.recentThroughputs.length > this.maxThroughputSamples) {
|
|
44
|
+
this.recentThroughputs.shift();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
this.lastUpdateTime = now;
|
|
49
|
+
// Calculate average throughput
|
|
50
|
+
const throughput = this.recentThroughputs.length > 0
|
|
51
|
+
? this.recentThroughputs.reduce((a, b) => a + b, 0) / this.recentThroughputs.length
|
|
52
|
+
: 0;
|
|
53
|
+
// Calculate ETA (guard against negative)
|
|
54
|
+
let estimatedTimeRemaining;
|
|
55
|
+
if (this.totalBytes && throughput > 0 && this.bytesProcessed < this.totalBytes) {
|
|
56
|
+
const remainingBytes = this.totalBytes - this.bytesProcessed;
|
|
57
|
+
estimatedTimeRemaining = Math.max(0, remainingBytes / throughput);
|
|
58
|
+
}
|
|
59
|
+
return {
|
|
60
|
+
bytesProcessed: this.bytesProcessed,
|
|
61
|
+
totalBytes: this.totalBytes,
|
|
62
|
+
chunksProcessed: this.chunksProcessed,
|
|
63
|
+
percentComplete: this.totalBytes ? Math.min(100, (this.bytesProcessed / this.totalBytes) * 100) : undefined,
|
|
64
|
+
throughputBytesPerSec: throughput,
|
|
65
|
+
throughput, // Alias
|
|
66
|
+
estimatedTimeRemaining,
|
|
67
|
+
startTime: this.startTime,
|
|
68
|
+
elapsedTime,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Get current progress without update
|
|
73
|
+
*/
|
|
74
|
+
getProgress() {
|
|
75
|
+
const elapsedTime = Math.max(0, Date.now() - this.startTime);
|
|
76
|
+
const throughput = this.recentThroughputs.length > 0
|
|
77
|
+
? this.recentThroughputs.reduce((a, b) => a + b, 0) / this.recentThroughputs.length
|
|
78
|
+
: 0;
|
|
79
|
+
let estimatedTimeRemaining;
|
|
80
|
+
if (this.totalBytes && throughput > 0 && this.bytesProcessed < this.totalBytes) {
|
|
81
|
+
const remainingBytes = this.totalBytes - this.bytesProcessed;
|
|
82
|
+
estimatedTimeRemaining = Math.max(0, remainingBytes / throughput);
|
|
83
|
+
}
|
|
84
|
+
return {
|
|
85
|
+
bytesProcessed: this.bytesProcessed,
|
|
86
|
+
totalBytes: this.totalBytes,
|
|
87
|
+
chunksProcessed: this.chunksProcessed,
|
|
88
|
+
percentComplete: this.totalBytes ? Math.min(100, (this.bytesProcessed / this.totalBytes) * 100) : undefined,
|
|
89
|
+
throughputBytesPerSec: throughput,
|
|
90
|
+
throughput, // Alias
|
|
91
|
+
estimatedTimeRemaining,
|
|
92
|
+
startTime: this.startTime,
|
|
93
|
+
elapsedTime,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
exports.ProgressTracker = ProgressTracker;
|
|
98
|
+
//# sourceMappingURL=progress-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress-tracker.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/progress-tracker.ts"],"names":[],"mappings":";;;AACA,8CAAqE;AACrE,uEAAkE;AAElE;;GAEG;AACH,MAAa,eAAe;IAQG;IAPrB,SAAS,CAAS;IAClB,cAAc,CAAS;IACvB,cAAc,GAAW,CAAC,CAAC;IAC3B,eAAe,GAAW,CAAC,CAAC;IAC5B,iBAAiB,GAAa,EAAE,CAAC;IACxB,oBAAoB,GAAG,CAAC,CAAC;IAE1C,YAA6B,UAAmB;QAAnB,eAAU,GAAV,UAAU,CAAS;QAC9C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC;IACvC,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAkB;QACvB,iBAAiB;QACjB,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;YACnB,MAAM,MAAM,GAAG,IAAA,+BAAkB,GAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,6BAAgB,EAAE,iCAAc,CAAC,yCAAyC,CAAC,CAAC,CAAC;QAChH,CAAC;QAED,IAAI,CAAC,cAAc,IAAI,UAAU,CAAC;QAClC,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,mBAAmB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;QAEnE,4EAA4E;QAC5E,MAAM,UAAU,GAAG,mBAAmB,GAAG,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;QAC5F,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;YACrC,MAAM,iBAAiB,GAAG,CAAC,UAAU,GAAG,UAAU,CAAC,GAAG,IAAI,CAAC;YAC3D,iDAAiD;YACjD,IAAI,QAAQ,CAAC,iBAAiB,CAAC,IAAI,iBAAiB,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,EAAE,CAAC;gBAC/E,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;gBAC/C,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBAC9D,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;gBACjC,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC;QAE1B,+BAA+B;QAC/B,MAAM,UAAU,GACd,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC;YAC/B,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM;YACnF,CAAC,CAAC,CAAC,CAAC;QAER,yCAAyC;QACzC,IAAI,sBAA0C,CAAC;QAC/C,IAAI,IAAI,CAAC,UAAU,IAAI,UAAU,GAAG,CAAC,IAAI,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAC/E,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC;YAC7D,sBAAsB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,cAAc,GAAG,UAAU,CAAC,CAAC;QACpE,CAAC;QAED,OAAO;YACL,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC3G,qBAAqB,EAAE,UAAU;YACjC,UAAU,EAAE,QAAQ;YACpB,sBAAsB;YACtB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,WAAW;SACL,CAAC;IACX,CAAC;IAED;;OAEG;IACH,WAAW;QACT,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7D,MAAM,UAAU,GACd,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC;YAC/B,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM;YACnF,CAAC,CAAC,CAAC,CAAC;QAER,IAAI,sBAA0C,CAAC;QAC/C,IAAI,IAAI,CAAC,UAAU,IAAI,UAAU,GAAG,CAAC,IAAI,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAC/E,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC;YAC7D,sBAAsB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,cAAc,GAAG,UAAU,CAAC,CAAC;QACpE,CAAC;QAED,OAAO;YACL,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;YAC3G,qBAAqB,EAAE,UAAU;YACjC,UAAU,EAAE,QAAQ;YACpB,sBAAsB;YACtB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,WAAW;SACL,CAAC;IACX,CAAC;CACF;AAnGD,0CAmGC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { IEncryptionState } from '../interfaces/encryption-state';
|
|
2
|
+
import { IEncryptedChunk } from '../interfaces/encrypted-chunk';
|
|
3
|
+
import { EncryptionStream } from './encryption-stream';
|
|
4
|
+
import { IEncryptStreamOptions } from './encryption-stream';
|
|
5
|
+
export interface IResumableOptions extends IEncryptStreamOptions {
|
|
6
|
+
autoSaveInterval?: number;
|
|
7
|
+
onStateSaved?: (state: IEncryptionState) => void | Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
export declare class ResumableEncryption {
|
|
10
|
+
private readonly stream;
|
|
11
|
+
private state;
|
|
12
|
+
constructor(stream: EncryptionStream, initialState?: IEncryptionState);
|
|
13
|
+
encrypt(source: AsyncIterable<Uint8Array>, publicKey: Uint8Array, options?: IResumableOptions): AsyncGenerator<IEncryptedChunk, void, unknown>;
|
|
14
|
+
saveState(): IEncryptionState;
|
|
15
|
+
private calculateStateHMAC;
|
|
16
|
+
static resume(stream: EncryptionStream, state: IEncryptionState): ResumableEncryption;
|
|
17
|
+
private validateState;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=resumable-encryption.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resumable-encryption.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/resumable-encryption.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAA4B,MAAM,gCAAgC,CAAC;AAC5F,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAO5D,MAAM,WAAW,iBAAkB,SAAQ,qBAAqB;IAC9D,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,gBAAgB,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAClE;AAED,qBAAa,mBAAmB;IAI5B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAHzB,OAAO,CAAC,KAAK,CAAiC;gBAG3B,MAAM,EAAE,gBAAgB,EACzC,YAAY,CAAC,EAAE,gBAAgB;IAQ1B,OAAO,CACZ,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC,EACjC,SAAS,EAAE,UAAU,EACrB,OAAO,GAAE,iBAAsB,GAC9B,cAAc,CAAC,eAAe,EAAE,IAAI,EAAE,OAAO,CAAC;IAkDjD,SAAS,IAAI,gBAAgB;IAW7B,OAAO,CAAC,kBAAkB;IAW1B,MAAM,CAAC,MAAM,CACX,MAAM,EAAE,gBAAgB,EACxB,KAAK,EAAE,gBAAgB,GACtB,mBAAmB;IAItB,OAAO,CAAC,aAAa;CAuBtB"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ResumableEncryption = void 0;
|
|
4
|
+
const encryption_state_1 = require("../interfaces/encryption-state");
|
|
5
|
+
const utils_1 = require("../utils");
|
|
6
|
+
const ecies_encryption_type_1 = require("../enumerations/ecies-encryption-type");
|
|
7
|
+
const i18n_setup_1 = require("../i18n-setup");
|
|
8
|
+
const ecies_string_key_1 = require("../enumerations/ecies-string-key");
|
|
9
|
+
class ResumableEncryption {
|
|
10
|
+
stream;
|
|
11
|
+
state = null;
|
|
12
|
+
constructor(stream, initialState) {
|
|
13
|
+
this.stream = stream;
|
|
14
|
+
if (initialState) {
|
|
15
|
+
this.validateState(initialState);
|
|
16
|
+
this.state = initialState;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
async *encrypt(source, publicKey, options = {}) {
|
|
20
|
+
const engine = (0, i18n_setup_1.getEciesI18nEngine)();
|
|
21
|
+
const autoSaveInterval = options.autoSaveInterval ?? 10;
|
|
22
|
+
if (autoSaveInterval <= 0) {
|
|
23
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_AutoSaveIntervalMustBePositive));
|
|
24
|
+
}
|
|
25
|
+
const publicKeyHex = (0, utils_1.uint8ArrayToHex)(publicKey);
|
|
26
|
+
if (this.state) {
|
|
27
|
+
if (this.state.publicKey !== publicKeyHex) {
|
|
28
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_PublicKeyMismatch));
|
|
29
|
+
}
|
|
30
|
+
if (this.state.chunkSize !== (options.chunkSize ?? 1024 * 1024)) {
|
|
31
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_ChunkSizeMismatch));
|
|
32
|
+
}
|
|
33
|
+
if (this.state.includeChecksums !== (options.includeChecksums ?? false)) {
|
|
34
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_IncludeChecksumsMismatch));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
const startIndex = this.state?.chunkIndex ?? 0;
|
|
38
|
+
let chunkIndex = 0;
|
|
39
|
+
for await (const chunk of this.stream.encryptStream(source, publicKey, options)) {
|
|
40
|
+
if (chunkIndex < startIndex) {
|
|
41
|
+
chunkIndex++;
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
yield chunk;
|
|
45
|
+
this.state = {
|
|
46
|
+
version: encryption_state_1.ENCRYPTION_STATE_VERSION,
|
|
47
|
+
chunkIndex: chunk.index + 1,
|
|
48
|
+
bytesProcessed: (this.state?.bytesProcessed ?? 0) + (chunk.metadata?.originalSize ?? 0),
|
|
49
|
+
publicKey: publicKeyHex,
|
|
50
|
+
encryptionType: ecies_encryption_type_1.EciesEncryptionTypeEnum.Single,
|
|
51
|
+
chunkSize: options.chunkSize ?? 1024 * 1024,
|
|
52
|
+
includeChecksums: options.includeChecksums ?? false,
|
|
53
|
+
timestamp: Date.now(),
|
|
54
|
+
};
|
|
55
|
+
if (options.onStateSaved && (chunk.index + 1) % autoSaveInterval === 0) {
|
|
56
|
+
await options.onStateSaved({ ...this.state });
|
|
57
|
+
}
|
|
58
|
+
chunkIndex++;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
saveState() {
|
|
62
|
+
if (!this.state) {
|
|
63
|
+
const engine = (0, i18n_setup_1.getEciesI18nEngine)();
|
|
64
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_NoStateToSave));
|
|
65
|
+
}
|
|
66
|
+
const state = { ...this.state };
|
|
67
|
+
// Add HMAC for integrity
|
|
68
|
+
state.hmac = this.calculateStateHMAC(state);
|
|
69
|
+
return state;
|
|
70
|
+
}
|
|
71
|
+
calculateStateHMAC(state) {
|
|
72
|
+
const data = `${state.version}|${state.chunkIndex}|${state.bytesProcessed}|${state.publicKey}|${state.chunkSize}|${state.includeChecksums}|${state.timestamp}`;
|
|
73
|
+
const hash = new Uint8Array(32);
|
|
74
|
+
// Simple hash for integrity check (not cryptographic HMAC)
|
|
75
|
+
const bytes = new TextEncoder().encode(data);
|
|
76
|
+
for (let i = 0; i < bytes.length; i++) {
|
|
77
|
+
hash[i % 32] ^= bytes[i];
|
|
78
|
+
}
|
|
79
|
+
return (0, utils_1.uint8ArrayToHex)(hash);
|
|
80
|
+
}
|
|
81
|
+
static resume(stream, state) {
|
|
82
|
+
return new ResumableEncryption(stream, state);
|
|
83
|
+
}
|
|
84
|
+
validateState(state) {
|
|
85
|
+
const engine = (0, i18n_setup_1.getEciesI18nEngine)();
|
|
86
|
+
if (state.version !== encryption_state_1.ENCRYPTION_STATE_VERSION) {
|
|
87
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_UnsupportedStateVersionTemplate, { version: state.version }));
|
|
88
|
+
}
|
|
89
|
+
if (state.chunkIndex < 0) {
|
|
90
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_InvalidChunkIndex));
|
|
91
|
+
}
|
|
92
|
+
const age = Date.now() - state.timestamp;
|
|
93
|
+
if (age > 24 * 60 * 60 * 1000) {
|
|
94
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_StateTooOld));
|
|
95
|
+
}
|
|
96
|
+
if (!state.publicKey || state.publicKey.length === 0) {
|
|
97
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_InvalidPublicKeyInState));
|
|
98
|
+
}
|
|
99
|
+
// Verify HMAC if present
|
|
100
|
+
if (state.hmac) {
|
|
101
|
+
const expectedHMAC = this.calculateStateHMAC(state);
|
|
102
|
+
if (state.hmac !== expectedHMAC) {
|
|
103
|
+
throw new Error(engine.translate(i18n_setup_1.EciesComponentId, ecies_string_key_1.EciesStringKey.Error_Resumable_StateIntegrityCheckFailed));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
exports.ResumableEncryption = ResumableEncryption;
|
|
109
|
+
//# sourceMappingURL=resumable-encryption.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resumable-encryption.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-ecies-lib/src/services/resumable-encryption.ts"],"names":[],"mappings":"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"}
|