@enbox/dwn-sdk-js 0.0.6 → 0.0.7
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/dist/browser.mjs +8 -8
- package/dist/browser.mjs.map +4 -4
- package/dist/esm/generated/precompiled-validators.js +1 -2
- package/dist/esm/generated/precompiled-validators.js.map +1 -1
- package/dist/esm/src/core/abstract-message.js +4 -0
- package/dist/esm/src/core/abstract-message.js.map +1 -1
- package/dist/esm/src/core/auth.js +22 -33
- package/dist/esm/src/core/auth.js.map +1 -1
- package/dist/esm/src/core/dwn-constant.js +7 -7
- package/dist/esm/src/core/dwn-constant.js.map +1 -1
- package/dist/esm/src/core/dwn-error.js +1 -0
- package/dist/esm/src/core/dwn-error.js.map +1 -1
- package/dist/esm/src/core/grant-authorization.js +37 -52
- package/dist/esm/src/core/grant-authorization.js.map +1 -1
- package/dist/esm/src/core/message.js +85 -116
- package/dist/esm/src/core/message.js.map +1 -1
- package/dist/esm/src/core/messages-grant-authorization.js +63 -78
- package/dist/esm/src/core/messages-grant-authorization.js.map +1 -1
- package/dist/esm/src/core/protocol-authorization-action.js +266 -0
- package/dist/esm/src/core/protocol-authorization-action.js.map +1 -0
- package/dist/esm/src/core/protocol-authorization-validation.js +254 -0
- package/dist/esm/src/core/protocol-authorization-validation.js.map +1 -0
- package/dist/esm/src/core/protocol-authorization.js +122 -740
- package/dist/esm/src/core/protocol-authorization.js.map +1 -1
- package/dist/esm/src/core/protocols-grant-authorization.js +24 -38
- package/dist/esm/src/core/protocols-grant-authorization.js.map +1 -1
- package/dist/esm/src/core/record-chain.js +64 -0
- package/dist/esm/src/core/record-chain.js.map +1 -0
- package/dist/esm/src/core/records-grant-authorization.js +55 -72
- package/dist/esm/src/core/records-grant-authorization.js.map +1 -1
- package/dist/esm/src/core/resumable-task-manager.js +50 -65
- package/dist/esm/src/core/resumable-task-manager.js.map +1 -1
- package/dist/esm/src/core/tenant-gate.js +2 -13
- package/dist/esm/src/core/tenant-gate.js.map +1 -1
- package/dist/esm/src/dwn.js +69 -86
- package/dist/esm/src/dwn.js.map +1 -1
- package/dist/esm/src/event-stream/event-emitter-stream.js +17 -31
- package/dist/esm/src/event-stream/event-emitter-stream.js.map +1 -1
- package/dist/esm/src/handlers/messages-read.js +67 -77
- package/dist/esm/src/handlers/messages-read.js.map +1 -1
- package/dist/esm/src/handlers/messages-subscribe.js +51 -61
- package/dist/esm/src/handlers/messages-subscribe.js.map +1 -1
- package/dist/esm/src/handlers/messages-sync.js +75 -85
- package/dist/esm/src/handlers/messages-sync.js.map +1 -1
- package/dist/esm/src/handlers/protocols-configure.js +135 -155
- package/dist/esm/src/handlers/protocols-configure.js.map +1 -1
- package/dist/esm/src/handlers/protocols-query.js +52 -51
- package/dist/esm/src/handlers/protocols-query.js.map +1 -1
- package/dist/esm/src/handlers/records-count.js +96 -82
- package/dist/esm/src/handlers/records-count.js.map +1 -1
- package/dist/esm/src/handlers/records-delete.js +78 -88
- package/dist/esm/src/handlers/records-delete.js.map +1 -1
- package/dist/esm/src/handlers/records-query.js +116 -101
- package/dist/esm/src/handlers/records-query.js.map +1 -1
- package/dist/esm/src/handlers/records-read.js +124 -131
- package/dist/esm/src/handlers/records-read.js.map +1 -1
- package/dist/esm/src/handlers/records-subscribe.js +150 -103
- package/dist/esm/src/handlers/records-subscribe.js.map +1 -1
- package/dist/esm/src/handlers/records-write.js +250 -259
- package/dist/esm/src/handlers/records-write.js.map +1 -1
- package/dist/esm/src/interfaces/messages-read.js +24 -32
- package/dist/esm/src/interfaces/messages-read.js.map +1 -1
- package/dist/esm/src/interfaces/messages-subscribe.js +27 -41
- package/dist/esm/src/interfaces/messages-subscribe.js.map +1 -1
- package/dist/esm/src/interfaces/messages-sync.js +26 -40
- package/dist/esm/src/interfaces/messages-sync.js.map +1 -1
- package/dist/esm/src/interfaces/protocols-configure.js +63 -63
- package/dist/esm/src/interfaces/protocols-configure.js.map +1 -1
- package/dist/esm/src/interfaces/protocols-query.js +55 -68
- package/dist/esm/src/interfaces/protocols-query.js.map +1 -1
- package/dist/esm/src/interfaces/records-count.js +50 -66
- package/dist/esm/src/interfaces/records-count.js.map +1 -1
- package/dist/esm/src/interfaces/records-delete.js +45 -55
- package/dist/esm/src/interfaces/records-delete.js.map +1 -1
- package/dist/esm/src/interfaces/records-query.js +60 -76
- package/dist/esm/src/interfaces/records-query.js.map +1 -1
- package/dist/esm/src/interfaces/records-read.js +51 -67
- package/dist/esm/src/interfaces/records-read.js.map +1 -1
- package/dist/esm/src/interfaces/records-subscribe.js +52 -68
- package/dist/esm/src/interfaces/records-subscribe.js.map +1 -1
- package/dist/esm/src/interfaces/records-write-query.js +102 -0
- package/dist/esm/src/interfaces/records-write-query.js.map +1 -0
- package/dist/esm/src/interfaces/records-write-signing.js +92 -0
- package/dist/esm/src/interfaces/records-write-signing.js.map +1 -0
- package/dist/esm/src/interfaces/records-write.js +407 -602
- package/dist/esm/src/interfaces/records-write.js.map +1 -1
- package/dist/esm/src/jose/algorithms/signing/ed25519.js +10 -19
- package/dist/esm/src/jose/algorithms/signing/ed25519.js.map +1 -1
- package/dist/esm/src/jose/jws/general/builder.js +23 -35
- package/dist/esm/src/jose/jws/general/builder.js.map +1 -1
- package/dist/esm/src/jose/jws/general/verifier.js +56 -69
- package/dist/esm/src/jose/jws/general/verifier.js.map +1 -1
- package/dist/esm/src/protocols/permission-grant.js +44 -15
- package/dist/esm/src/protocols/permission-grant.js.map +1 -1
- package/dist/esm/src/protocols/permission-request.js +29 -15
- package/dist/esm/src/protocols/permission-request.js.map +1 -1
- package/dist/esm/src/protocols/permissions.js +216 -226
- package/dist/esm/src/protocols/permissions.js.map +1 -1
- package/dist/esm/src/smt/smt-store-level.js +42 -64
- package/dist/esm/src/smt/smt-store-level.js.map +1 -1
- package/dist/esm/src/smt/smt-store-memory.js +19 -45
- package/dist/esm/src/smt/smt-store-memory.js.map +1 -1
- package/dist/esm/src/smt/smt-utils.js +28 -45
- package/dist/esm/src/smt/smt-utils.js.map +1 -1
- package/dist/esm/src/smt/sparse-merkle-tree.js +426 -471
- package/dist/esm/src/smt/sparse-merkle-tree.js.map +1 -1
- package/dist/esm/src/state-index/state-index-level.js +115 -150
- package/dist/esm/src/state-index/state-index-level.js.map +1 -1
- package/dist/esm/src/store/blockstore-level.js +54 -156
- package/dist/esm/src/store/blockstore-level.js.map +1 -1
- package/dist/esm/src/store/blockstore-mock.js +48 -153
- package/dist/esm/src/store/blockstore-mock.js.map +1 -1
- package/dist/esm/src/store/data-store-level.js +59 -99
- package/dist/esm/src/store/data-store-level.js.map +1 -1
- package/dist/esm/src/store/index-level-compound.js +246 -0
- package/dist/esm/src/store/index-level-compound.js.map +1 -0
- package/dist/esm/src/store/index-level.js +295 -713
- package/dist/esm/src/store/index-level.js.map +1 -1
- package/dist/esm/src/store/level-wrapper.js +143 -244
- package/dist/esm/src/store/level-wrapper.js.map +1 -1
- package/dist/esm/src/store/message-store-level.js +71 -94
- package/dist/esm/src/store/message-store-level.js.map +1 -1
- package/dist/esm/src/store/resumable-task-store-level.js +62 -101
- package/dist/esm/src/store/resumable-task-store-level.js.map +1 -1
- package/dist/esm/src/store/storage-controller.js +129 -144
- package/dist/esm/src/store/storage-controller.js.map +1 -1
- package/dist/esm/src/utils/abort.js +8 -19
- package/dist/esm/src/utils/abort.js.map +1 -1
- package/dist/esm/src/utils/array.js +15 -49
- package/dist/esm/src/utils/array.js.map +1 -1
- package/dist/esm/src/utils/cid.js +29 -77
- package/dist/esm/src/utils/cid.js.map +1 -1
- package/dist/esm/src/utils/data-stream.js +37 -65
- package/dist/esm/src/utils/data-stream.js.map +1 -1
- package/dist/esm/src/utils/encryption.js +136 -162
- package/dist/esm/src/utils/encryption.js.map +1 -1
- package/dist/esm/src/utils/filter.js +1 -12
- package/dist/esm/src/utils/filter.js.map +1 -1
- package/dist/esm/src/utils/hd-key.js +45 -63
- package/dist/esm/src/utils/hd-key.js.map +1 -1
- package/dist/esm/src/utils/jws.js +9 -20
- package/dist/esm/src/utils/jws.js.map +1 -1
- package/dist/esm/src/utils/memory-cache.js +12 -23
- package/dist/esm/src/utils/memory-cache.js.map +1 -1
- package/dist/esm/src/utils/messages.js +9 -3
- package/dist/esm/src/utils/messages.js.map +1 -1
- package/dist/esm/src/utils/private-key-signer.js +9 -17
- package/dist/esm/src/utils/private-key-signer.js.map +1 -1
- package/dist/esm/src/utils/protocols.js +62 -70
- package/dist/esm/src/utils/protocols.js.map +1 -1
- package/dist/esm/src/utils/records.js +100 -125
- package/dist/esm/src/utils/records.js.map +1 -1
- package/dist/esm/src/utils/secp256k1.js +60 -96
- package/dist/esm/src/utils/secp256k1.js.map +1 -1
- package/dist/esm/src/utils/secp256r1.js +54 -71
- package/dist/esm/src/utils/secp256r1.js.map +1 -1
- package/dist/esm/src/utils/time.js +5 -18
- package/dist/esm/src/utils/time.js.map +1 -1
- package/dist/esm/src/utils/url.js +3 -3
- package/dist/esm/src/utils/url.js.map +1 -1
- package/dist/esm/tests/core/auth.spec.js +3 -12
- package/dist/esm/tests/core/auth.spec.js.map +1 -1
- package/dist/esm/tests/core/message.spec.js +50 -59
- package/dist/esm/tests/core/message.spec.js.map +1 -1
- package/dist/esm/tests/core/protocol-authorization.spec.js +9 -18
- package/dist/esm/tests/core/protocol-authorization.spec.js.map +1 -1
- package/dist/esm/tests/dwn.spec.js +45 -58
- package/dist/esm/tests/dwn.spec.js.map +1 -1
- package/dist/esm/tests/event-stream/event-emitter-stream.spec.js +24 -33
- package/dist/esm/tests/event-stream/event-emitter-stream.spec.js.map +1 -1
- package/dist/esm/tests/event-stream/event-stream.spec.js +46 -55
- package/dist/esm/tests/event-stream/event-stream.spec.js.map +1 -1
- package/dist/esm/tests/features/author-delegated-grant.spec.js +326 -343
- package/dist/esm/tests/features/author-delegated-grant.spec.js.map +1 -1
- package/dist/esm/tests/features/owner-delegated-grant.spec.js +153 -169
- package/dist/esm/tests/features/owner-delegated-grant.spec.js.map +1 -1
- package/dist/esm/tests/features/owner-signature.spec.js +67 -78
- package/dist/esm/tests/features/owner-signature.spec.js.map +1 -1
- package/dist/esm/tests/features/permissions.spec.js +446 -181
- package/dist/esm/tests/features/permissions.spec.js.map +1 -1
- package/dist/esm/tests/features/protocol-composition.spec.js +346 -356
- package/dist/esm/tests/features/protocol-composition.spec.js.map +1 -1
- package/dist/esm/tests/features/protocol-create-action.spec.js +42 -51
- package/dist/esm/tests/features/protocol-create-action.spec.js.map +1 -1
- package/dist/esm/tests/features/protocol-delete-action.spec.js +94 -103
- package/dist/esm/tests/features/protocol-delete-action.spec.js.map +1 -1
- package/dist/esm/tests/features/protocol-update-action.spec.js +105 -114
- package/dist/esm/tests/features/protocol-update-action.spec.js.map +1 -1
- package/dist/esm/tests/features/records-prune.spec.js +175 -191
- package/dist/esm/tests/features/records-prune.spec.js.map +1 -1
- package/dist/esm/tests/features/records-tags.spec.js +441 -460
- package/dist/esm/tests/features/records-tags.spec.js.map +1 -1
- package/dist/esm/tests/features/resumable-tasks.spec.js +82 -91
- package/dist/esm/tests/features/resumable-tasks.spec.js.map +1 -1
- package/dist/esm/tests/handlers/messages-read.spec.js +206 -207
- package/dist/esm/tests/handlers/messages-read.spec.js.map +1 -1
- package/dist/esm/tests/handlers/messages-subscribe.spec.js +145 -154
- package/dist/esm/tests/handlers/messages-subscribe.spec.js.map +1 -1
- package/dist/esm/tests/handlers/messages-sync.spec.js +174 -183
- package/dist/esm/tests/handlers/messages-sync.spec.js.map +1 -1
- package/dist/esm/tests/handlers/protocols-configure.spec.js +244 -238
- package/dist/esm/tests/handlers/protocols-configure.spec.js.map +1 -1
- package/dist/esm/tests/handlers/protocols-query.spec.js +156 -169
- package/dist/esm/tests/handlers/protocols-query.spec.js.map +1 -1
- package/dist/esm/tests/handlers/records-count.spec.js +93 -102
- package/dist/esm/tests/handlers/records-count.spec.js.map +1 -1
- package/dist/esm/tests/handlers/records-delete.spec.js +252 -264
- package/dist/esm/tests/handlers/records-delete.spec.js.map +1 -1
- package/dist/esm/tests/handlers/records-query.spec.js +917 -988
- package/dist/esm/tests/handlers/records-query.spec.js.map +1 -1
- package/dist/esm/tests/handlers/records-read.spec.js +549 -564
- package/dist/esm/tests/handlers/records-read.spec.js.map +1 -1
- package/dist/esm/tests/handlers/records-subscribe.spec.js +269 -278
- package/dist/esm/tests/handlers/records-subscribe.spec.js.map +1 -1
- package/dist/esm/tests/handlers/records-write.spec.js +1057 -1082
- package/dist/esm/tests/handlers/records-write.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/messages-get.spec.js +39 -48
- package/dist/esm/tests/interfaces/messages-get.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/messages-subscribe.spec.js +4 -13
- package/dist/esm/tests/interfaces/messages-subscribe.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/protocols-configure.spec.js +212 -88
- package/dist/esm/tests/interfaces/protocols-configure.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/protocols-query.spec.js +8 -17
- package/dist/esm/tests/interfaces/protocols-query.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/records-delete.spec.js +8 -17
- package/dist/esm/tests/interfaces/records-delete.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/records-query.spec.js +20 -29
- package/dist/esm/tests/interfaces/records-query.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/records-read.spec.js +42 -51
- package/dist/esm/tests/interfaces/records-read.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/records-subscribe.spec.js +16 -25
- package/dist/esm/tests/interfaces/records-subscribe.spec.js.map +1 -1
- package/dist/esm/tests/interfaces/records-write.spec.js +152 -165
- package/dist/esm/tests/interfaces/records-write.spec.js.map +1 -1
- package/dist/esm/tests/jose/jws/general.spec.js +36 -45
- package/dist/esm/tests/jose/jws/general.spec.js.map +1 -1
- package/dist/esm/tests/protocols/permission-grant.spec.js +44 -50
- package/dist/esm/tests/protocols/permission-grant.spec.js.map +1 -1
- package/dist/esm/tests/protocols/permission-request.spec.js +23 -32
- package/dist/esm/tests/protocols/permission-request.spec.js.map +1 -1
- package/dist/esm/tests/protocols/permissions.spec.js +49 -55
- package/dist/esm/tests/protocols/permissions.spec.js.map +1 -1
- package/dist/esm/tests/scenarios/aggregator.spec.js +124 -135
- package/dist/esm/tests/scenarios/aggregator.spec.js.map +1 -1
- package/dist/esm/tests/scenarios/deleted-record.spec.js +23 -32
- package/dist/esm/tests/scenarios/deleted-record.spec.js.map +1 -1
- package/dist/esm/tests/scenarios/end-to-end-tests.spec.js +52 -61
- package/dist/esm/tests/scenarios/end-to-end-tests.spec.js.map +1 -1
- package/dist/esm/tests/scenarios/nested-roles.spec.js +63 -73
- package/dist/esm/tests/scenarios/nested-roles.spec.js.map +1 -1
- package/dist/esm/tests/scenarios/subscriptions.spec.js +377 -333
- package/dist/esm/tests/scenarios/subscriptions.spec.js.map +1 -1
- package/dist/esm/tests/smt/smt-store-level.spec.js +76 -87
- package/dist/esm/tests/smt/smt-store-level.spec.js.map +1 -1
- package/dist/esm/tests/smt/sparse-merkle-tree.spec.js +344 -353
- package/dist/esm/tests/smt/sparse-merkle-tree.spec.js.map +1 -1
- package/dist/esm/tests/state-index/state-index-level.spec.js +117 -126
- package/dist/esm/tests/state-index/state-index-level.spec.js.map +1 -1
- package/dist/esm/tests/store/blockstore-level.spec.js +44 -99
- package/dist/esm/tests/store/blockstore-level.spec.js.map +1 -1
- package/dist/esm/tests/store/blockstore-mock.spec.js +40 -120
- package/dist/esm/tests/store/blockstore-mock.spec.js.map +1 -1
- package/dist/esm/tests/store/data-store-level.spec.js +86 -95
- package/dist/esm/tests/store/data-store-level.spec.js.map +1 -1
- package/dist/esm/tests/store/index-level.spec.js +404 -414
- package/dist/esm/tests/store/index-level.spec.js.map +1 -1
- package/dist/esm/tests/store/message-store-level.spec.js +13 -22
- package/dist/esm/tests/store/message-store-level.spec.js.map +1 -1
- package/dist/esm/tests/store/message-store.spec.js +229 -238
- package/dist/esm/tests/store/message-store.spec.js.map +1 -1
- package/dist/esm/tests/test-event-stream.js +3 -3
- package/dist/esm/tests/test-event-stream.js.map +1 -1
- package/dist/esm/tests/test-stores.js +16 -13
- package/dist/esm/tests/test-stores.js.map +1 -1
- package/dist/esm/tests/test-suite.js +2 -11
- package/dist/esm/tests/test-suite.js.map +1 -1
- package/dist/esm/tests/utils/cid.spec.js +24 -33
- package/dist/esm/tests/utils/cid.spec.js.map +1 -1
- package/dist/esm/tests/utils/data-stream.spec.js +48 -57
- package/dist/esm/tests/utils/data-stream.spec.js.map +1 -1
- package/dist/esm/tests/utils/encryption-callbacks.spec.js +45 -54
- package/dist/esm/tests/utils/encryption-callbacks.spec.js.map +1 -1
- package/dist/esm/tests/utils/encryption.spec.js +229 -82
- package/dist/esm/tests/utils/encryption.spec.js.map +1 -1
- package/dist/esm/tests/utils/filters.spec.js +46 -55
- package/dist/esm/tests/utils/filters.spec.js.map +1 -1
- package/dist/esm/tests/utils/hd-key.spec.js +10 -19
- package/dist/esm/tests/utils/hd-key.spec.js.map +1 -1
- package/dist/esm/tests/utils/jws.spec.js +3 -12
- package/dist/esm/tests/utils/jws.spec.js.map +1 -1
- package/dist/esm/tests/utils/memory-cache.spec.js +9 -18
- package/dist/esm/tests/utils/memory-cache.spec.js.map +1 -1
- package/dist/esm/tests/utils/messages.spec.js +6 -15
- package/dist/esm/tests/utils/messages.spec.js.map +1 -1
- package/dist/esm/tests/utils/poller.js +22 -33
- package/dist/esm/tests/utils/poller.js.map +1 -1
- package/dist/esm/tests/utils/private-key-signer.spec.js +15 -24
- package/dist/esm/tests/utils/private-key-signer.spec.js.map +1 -1
- package/dist/esm/tests/utils/records.spec.js +10 -19
- package/dist/esm/tests/utils/records.spec.js.map +1 -1
- package/dist/esm/tests/utils/secp256k1.spec.js +16 -25
- package/dist/esm/tests/utils/secp256k1.spec.js.map +1 -1
- package/dist/esm/tests/utils/secp256r1.spec.js +18 -27
- package/dist/esm/tests/utils/secp256r1.spec.js.map +1 -1
- package/dist/esm/tests/utils/test-data-generator.js +414 -468
- package/dist/esm/tests/utils/test-data-generator.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/definitions.spec.js +2 -11
- package/dist/esm/tests/validation/json-schemas/definitions.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/jwk/general-jwk.spec.js +4 -13
- package/dist/esm/tests/validation/json-schemas/jwk/general-jwk.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/jwk/public-jwk.spec.js +8 -17
- package/dist/esm/tests/validation/json-schemas/jwk/public-jwk.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/jwk-verification-method.spec.js +3 -12
- package/dist/esm/tests/validation/json-schemas/jwk-verification-method.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/protocols/protocols-configure.spec.js +4 -13
- package/dist/esm/tests/validation/json-schemas/protocols/protocols-configure.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/records/records-query.spec.js +2 -11
- package/dist/esm/tests/validation/json-schemas/records/records-query.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/records/records-read.spec.js +2 -11
- package/dist/esm/tests/validation/json-schemas/records/records-read.spec.js.map +1 -1
- package/dist/esm/tests/validation/json-schemas/records/records-write.spec.js +7 -16
- package/dist/esm/tests/validation/json-schemas/records/records-write.spec.js.map +1 -1
- package/dist/types/src/core/protocol-authorization-action.d.ts +42 -0
- package/dist/types/src/core/protocol-authorization-action.d.ts.map +1 -0
- package/dist/types/src/core/protocol-authorization-validation.d.ts +60 -0
- package/dist/types/src/core/protocol-authorization-validation.d.ts.map +1 -0
- package/dist/types/src/core/protocol-authorization.d.ts +10 -100
- package/dist/types/src/core/protocol-authorization.d.ts.map +1 -1
- package/dist/types/src/core/record-chain.d.ts +24 -0
- package/dist/types/src/core/record-chain.d.ts.map +1 -0
- package/dist/types/src/handlers/records-write.d.ts +2 -1
- package/dist/types/src/handlers/records-write.d.ts.map +1 -1
- package/dist/types/src/interfaces/protocols-configure.d.ts.map +1 -1
- package/dist/types/src/interfaces/records-write-query.d.ts +33 -0
- package/dist/types/src/interfaces/records-write-query.d.ts.map +1 -0
- package/dist/types/src/interfaces/records-write-signing.d.ts +35 -0
- package/dist/types/src/interfaces/records-write-signing.d.ts.map +1 -0
- package/dist/types/src/interfaces/records-write.d.ts +10 -44
- package/dist/types/src/interfaces/records-write.d.ts.map +1 -1
- package/dist/types/src/store/index-level-compound.d.ts +70 -0
- package/dist/types/src/store/index-level-compound.d.ts.map +1 -0
- package/dist/types/src/store/index-level.d.ts +0 -58
- package/dist/types/src/store/index-level.d.ts.map +1 -1
- package/dist/types/src/utils/protocols.d.ts +5 -0
- package/dist/types/src/utils/protocols.d.ts.map +1 -1
- package/dist/types/tests/features/permissions.spec.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/core/protocol-authorization-action.ts +377 -0
- package/src/core/protocol-authorization-validation.ts +391 -0
- package/src/core/protocol-authorization.ts +60 -849
- package/src/core/record-chain.ts +99 -0
- package/src/handlers/records-read.ts +1 -1
- package/src/handlers/records-write.ts +37 -21
- package/src/interfaces/protocols-configure.ts +33 -5
- package/src/interfaces/records-write-query.ts +139 -0
- package/src/interfaces/records-write-signing.ts +143 -0
- package/src/interfaces/records-write.ts +49 -221
- package/src/store/index-level-compound.ts +324 -0
- package/src/store/index-level.ts +24 -306
- package/src/utils/protocols.ts +8 -0
- package/src/utils/records.ts +1 -1
|
@@ -1,12 +1,3 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
import { p256, secp256r1 } from '@noble/curves/p256';
|
|
11
2
|
import { Encoder } from './encoder.js';
|
|
12
3
|
import { sha256 } from 'multiformats/hashes/sha2';
|
|
@@ -29,33 +20,31 @@ export class Secp256r1 {
|
|
|
29
20
|
/**
|
|
30
21
|
* Converts a public key in bytes into a JWK.
|
|
31
22
|
*/
|
|
32
|
-
static publicKeyToJwk(publicKeyBytes) {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
return publicJwk;
|
|
58
|
-
});
|
|
23
|
+
static async publicKeyToJwk(publicKeyBytes) {
|
|
24
|
+
// ensure public key is in uncompressed format so we can convert it into both x and y value
|
|
25
|
+
let uncompressedPublicKeyBytes;
|
|
26
|
+
if (publicKeyBytes.byteLength === 33) {
|
|
27
|
+
// this means given key is compressed
|
|
28
|
+
const curvePoints = p256.ProjectivePoint.fromHex(publicKeyBytes);
|
|
29
|
+
uncompressedPublicKeyBytes = curvePoints.toRawBytes(false); // isCompressed = false
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
uncompressedPublicKeyBytes = publicKeyBytes;
|
|
33
|
+
}
|
|
34
|
+
// the first byte is a header that indicates whether the key is uncompressed (0x04 if uncompressed), we can safely ignore
|
|
35
|
+
// bytes 1 - 32 represent X
|
|
36
|
+
// bytes 33 - 64 represent Y
|
|
37
|
+
// skip the first byte because it's used as a header to indicate whether the key is uncompressed
|
|
38
|
+
const x = Encoder.bytesToBase64Url(uncompressedPublicKeyBytes.subarray(1, 33));
|
|
39
|
+
const y = Encoder.bytesToBase64Url(uncompressedPublicKeyBytes.subarray(33, 65));
|
|
40
|
+
const publicJwk = {
|
|
41
|
+
alg: 'ES256',
|
|
42
|
+
kty: 'EC',
|
|
43
|
+
crv: 'P-256',
|
|
44
|
+
x,
|
|
45
|
+
y,
|
|
46
|
+
};
|
|
47
|
+
return publicJwk;
|
|
59
48
|
}
|
|
60
49
|
/**
|
|
61
50
|
* Creates a private key in raw bytes from the given SECP256R1 JWK.
|
|
@@ -68,51 +57,45 @@ export class Secp256r1 {
|
|
|
68
57
|
* Signs the provided content using the provided JWK.
|
|
69
58
|
* Signature that is outputted is JWS format, not DER.
|
|
70
59
|
*/
|
|
71
|
-
static sign(content, privateJwk) {
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
return Promise.resolve(p256.sign(hashedContent, privateKeyBytes).toCompactRawBytes());
|
|
77
|
-
});
|
|
60
|
+
static async sign(content, privateJwk) {
|
|
61
|
+
Secp256r1.validateKey(privateJwk);
|
|
62
|
+
const hashedContent = await sha256.encode(content);
|
|
63
|
+
const privateKeyBytes = Secp256r1.privateJwkToBytes(privateJwk);
|
|
64
|
+
return Promise.resolve(p256.sign(hashedContent, privateKeyBytes).toCompactRawBytes());
|
|
78
65
|
}
|
|
79
66
|
/**
|
|
80
67
|
* Verifies a signature against the provided payload hash and public key.
|
|
81
68
|
* @param signature - the signature to verify. Can be in either DER or compact format. If using Oracle Cloud KMS, keys will be DER formatted.
|
|
82
69
|
* @returns a boolean indicating whether the signature is valid.
|
|
83
70
|
*/
|
|
84
|
-
static verify(content, signature, publicJwk) {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
return p256.verify(sig, hashedContent, keyBytes);
|
|
102
|
-
});
|
|
71
|
+
static async verify(content, signature, publicJwk) {
|
|
72
|
+
Secp256r1.validateKey(publicJwk);
|
|
73
|
+
// handle DER vs compact signature formats
|
|
74
|
+
let sig;
|
|
75
|
+
if (signature.length === 64) {
|
|
76
|
+
sig = p256.Signature.fromCompact(signature);
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
sig = p256.Signature.fromDER(signature);
|
|
80
|
+
}
|
|
81
|
+
const hashedContent = await sha256.encode(content);
|
|
82
|
+
const ecJwk = publicJwk;
|
|
83
|
+
const keyBytes = p256.ProjectivePoint.fromAffine({
|
|
84
|
+
x: Secp256r1.bytesToBigInt(Encoder.base64UrlToBytes(ecJwk.x)),
|
|
85
|
+
y: Secp256r1.bytesToBigInt(Encoder.base64UrlToBytes(ecJwk.y)),
|
|
86
|
+
}).toRawBytes(false);
|
|
87
|
+
return p256.verify(sig, hashedContent, keyBytes);
|
|
103
88
|
}
|
|
104
89
|
/**
|
|
105
90
|
* Generates a random key pair in JWK format.
|
|
106
91
|
*/
|
|
107
|
-
static generateKeyPair() {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
return { publicJwk, privateJwk };
|
|
115
|
-
});
|
|
92
|
+
static async generateKeyPair() {
|
|
93
|
+
const privateKeyBytes = p256.utils.randomPrivateKey();
|
|
94
|
+
const publicKeyBytes = secp256r1.getPublicKey(privateKeyBytes, false); // `false` = uncompressed
|
|
95
|
+
const d = Encoder.bytesToBase64Url(privateKeyBytes);
|
|
96
|
+
const publicJwk = await Secp256r1.publicKeyToJwk(publicKeyBytes);
|
|
97
|
+
const privateJwk = { ...publicJwk, d };
|
|
98
|
+
return { publicJwk, privateJwk };
|
|
116
99
|
}
|
|
117
100
|
static bytesToBigInt(b) {
|
|
118
101
|
return BigInt(`0x` + u8a.toString(b, 'base16'));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"secp256r1.js","sourceRoot":"","sources":["../../../../src/utils/secp256r1.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"secp256r1.js","sourceRoot":"","sources":["../../../../src/utils/secp256r1.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,3 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
import { Temporal } from '@js-temporal/polyfill';
|
|
11
2
|
import { DwnError, DwnErrorCode } from '../core/dwn-error.js';
|
|
12
3
|
/**
|
|
@@ -18,19 +9,15 @@ export class Time {
|
|
|
18
9
|
* @param durationInMillisecond the desired amount of sleep time
|
|
19
10
|
* @returns when the provided duration has passed
|
|
20
11
|
*/
|
|
21
|
-
static sleep(durationInMillisecond) {
|
|
22
|
-
return
|
|
23
|
-
return new Promise(resolve => setTimeout(resolve, durationInMillisecond));
|
|
24
|
-
});
|
|
12
|
+
static async sleep(durationInMillisecond) {
|
|
13
|
+
return new Promise(resolve => setTimeout(resolve, durationInMillisecond));
|
|
25
14
|
}
|
|
26
15
|
/**
|
|
27
16
|
* We must sleep for at least 2ms to avoid timestamp collisions during testing.
|
|
28
17
|
* https://github.com/enboxorg/enbox/issues/481
|
|
29
18
|
*/
|
|
30
|
-
static minimalSleep() {
|
|
31
|
-
|
|
32
|
-
yield Time.sleep(2);
|
|
33
|
-
});
|
|
19
|
+
static async minimalSleep() {
|
|
20
|
+
await Time.sleep(2);
|
|
34
21
|
}
|
|
35
22
|
/**
|
|
36
23
|
* Returns an UTC ISO-8601 timestamp with microsecond precision accepted by DWN.
|
|
@@ -77,7 +64,7 @@ export class Time {
|
|
|
77
64
|
try {
|
|
78
65
|
Temporal.Instant.from(timestamp);
|
|
79
66
|
}
|
|
80
|
-
catch
|
|
67
|
+
catch {
|
|
81
68
|
throw new DwnError(DwnErrorCode.TimestampInvalid, `Invalid timestamp: ${timestamp}`);
|
|
82
69
|
}
|
|
83
70
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"time.js","sourceRoot":"","sources":["../../../../src/utils/time.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"time.js","sourceRoot":"","sources":["../../../../src/utils/time.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAE9D;;GAEG;AACH,MAAM,OAAO,IAAI;IACf;;;;OAIG;IACI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,qBAA6B;QACrD,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,KAAK,CAAC,YAAY;QAC9B,MAAM,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,mBAAmB;QAC/B,OAAO,QAAQ,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,cAAc,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,eAAe,CAAC,OAE7B;QACC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC;QACrF,OAAO,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC;YACjC,QAAQ,EAAE,KAAK;YACf,IAAI;YACJ,KAAK;YACL,GAAG;YACH,IAAI;YACJ,MAAM;YACN,MAAM;YACN,WAAW;YACX,WAAW;SACZ,CAAC,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,cAAc,EAAE,CAAC,CAAC;IAC5D,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,qBAAqB,CAAC,MAA2B,EAAE,SAAkB;QACjF,MAAM,gBAAgB,GAAG,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QAC/F,MAAM,cAAc,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtD,MAAM,aAAa,GAAG,gBAAgB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC3D,OAAO,aAAa,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,cAAc,EAAE,CAAC,CAAC;IAClE,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,iBAAiB,CAAC,SAAiB;QAC/C,IAAI,CAAC;YACH,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACnC,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,QAAQ,CAAC,YAAY,CAAC,gBAAgB,EAAE,sBAAsB,SAAS,EAAE,CAAC,CAAC;QACvF,CAAC;IACH,CAAC;CACF"}
|
|
@@ -4,7 +4,7 @@ export function validateProtocolUrlNormalized(url) {
|
|
|
4
4
|
try {
|
|
5
5
|
normalized = normalizeProtocolUrl(url);
|
|
6
6
|
}
|
|
7
|
-
catch
|
|
7
|
+
catch {
|
|
8
8
|
normalized = undefined;
|
|
9
9
|
}
|
|
10
10
|
if (url !== normalized) {
|
|
@@ -21,7 +21,7 @@ export function validateSchemaUrlNormalized(url) {
|
|
|
21
21
|
try {
|
|
22
22
|
normalized = normalizeSchemaUrl(url);
|
|
23
23
|
}
|
|
24
|
-
catch
|
|
24
|
+
catch {
|
|
25
25
|
normalized = undefined;
|
|
26
26
|
}
|
|
27
27
|
if (url !== normalized) {
|
|
@@ -47,7 +47,7 @@ function normalizeUrl(url) {
|
|
|
47
47
|
result.hash = '';
|
|
48
48
|
return removeTrailingSlash(result.href);
|
|
49
49
|
}
|
|
50
|
-
catch
|
|
50
|
+
catch {
|
|
51
51
|
throw new DwnError(DwnErrorCode.UrlProtocolNotNormalizable, 'Could not normalize protocol URI');
|
|
52
52
|
}
|
|
53
53
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"url.js","sourceRoot":"","sources":["../../../../src/utils/url.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAE9D,MAAM,UAAU,6BAA6B,CAAC,GAAW;IACvD,IAAI,UAA8B,CAAC;IACnC,IAAI,CAAC;QACH,UAAU,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAAC,
|
|
1
|
+
{"version":3,"file":"url.js","sourceRoot":"","sources":["../../../../src/utils/url.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAE9D,MAAM,UAAU,6BAA6B,CAAC,GAAW;IACvD,IAAI,UAA8B,CAAC;IACnC,IAAI,CAAC;QACH,UAAU,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAAC,MAAM,CAAC;QACP,UAAU,GAAG,SAAS,CAAC;IACzB,CAAC;IAED,IAAI,GAAG,KAAK,UAAU,EAAE,CAAC;QACvB,MAAM,IAAI,QAAQ,CAAC,YAAY,CAAC,wBAAwB,EAAE,gBAAgB,GAAG,sBAAsB,CAAC,CAAC;IACvG,CAAC;AACH,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,GAAW;IAC9C,gEAAgE;IAChE,0DAA0D;IAC1D,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,2BAA2B,CAAC,GAAW;IACrD,IAAI,UAA8B,CAAC;IACnC,IAAI,CAAC;QACH,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAC;IACvC,CAAC;IAAC,MAAM,CAAC;QACP,UAAU,GAAG,SAAS,CAAC;IACzB,CAAC;IAED,IAAI,GAAG,KAAK,UAAU,EAAE,CAAC;QACvB,MAAM,IAAI,QAAQ,CAAC,YAAY,CAAC,sBAAsB,EAAE,cAAc,GAAG,sBAAsB,CAAC,CAAC;IACnG,CAAC;AACH,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,GAAW;IAC5C,8DAA8D;IAC9D,0DAA0D;IAC1D,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC;AAC3B,CAAC;AAED,SAAS,YAAY,CAAC,GAAW;IAC/B,IAAI,OAAe,CAAC;IACpB,IAAI,wBAAwB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACvC,OAAO,GAAG,GAAG,CAAC;IAChB,CAAC;SAAM,CAAC;QACN,OAAO,GAAG,UAAU,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC;QAChC,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC;QACnB,MAAM,CAAC,IAAI,GAAG,EAAE,CAAC;QACjB,OAAO,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAAC,MAAM,CAAC;QACP,MAAM,IAAI,QAAQ,CAAC,YAAY,CAAC,0BAA0B,EAAE,kCAAkC,CAAC,CAAC;IAClG,CAAC;AACH,CAAC;AAED,SAAS,mBAAmB,CAAC,GAAW;IACtC,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACtB,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;SAAM,CAAC;QACN,OAAO,GAAG,CAAC;IACb,CAAC;AACH,CAAC"}
|
|
@@ -1,22 +1,13 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
import { authenticate } from '../../src/core/auth.js';
|
|
11
2
|
import { DwnErrorCode } from '../../src/core/dwn-error.js';
|
|
12
3
|
import { describe, expect, it } from 'bun:test';
|
|
13
4
|
import { DidDht, UniversalResolver } from '@enbox/dids';
|
|
14
5
|
describe('Auth', () => {
|
|
15
6
|
describe('authenticate()', () => {
|
|
16
|
-
it('should throw if given JWS is `undefined`', () =>
|
|
7
|
+
it('should throw if given JWS is `undefined`', async () => {
|
|
17
8
|
const jws = undefined;
|
|
18
|
-
|
|
19
|
-
})
|
|
9
|
+
await expect(authenticate(jws, new UniversalResolver({ didResolvers: [DidDht] }))).rejects.toThrow(DwnErrorCode.AuthenticateJwsMissing);
|
|
10
|
+
});
|
|
20
11
|
});
|
|
21
12
|
});
|
|
22
13
|
//# sourceMappingURL=auth.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.spec.js","sourceRoot":"","sources":["../../../../tests/core/auth.spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth.spec.js","sourceRoot":"","sources":["../../../../tests/core/auth.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAExD,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE;IACpB,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;YACxD,MAAM,GAAG,GAAG,SAAS,CAAC;YACtB,MAAM,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,IAAI,iBAAiB,CAAC,EAAE,YAAY,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,sBAAsB,CAAC,CAAC;QAC1I,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,12 +1,3 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
import { Jws } from '../../src/utils/jws.js';
|
|
11
2
|
import { Message } from '../../src/core/message.js';
|
|
12
3
|
import { PermissionsProtocol } from '../../src/protocols/permissions.js';
|
|
@@ -18,24 +9,24 @@ import { describe, expect, it } from 'bun:test';
|
|
|
18
9
|
import { DwnInterfaceName, DwnMethodName } from '../../src/enums/dwn-interface-method.js';
|
|
19
10
|
describe('Message', () => {
|
|
20
11
|
describe('getAuthor()', () => {
|
|
21
|
-
it('should return the author of a message', () =>
|
|
22
|
-
const bob =
|
|
12
|
+
it('should return the author of a message', async () => {
|
|
13
|
+
const bob = await TestDataGenerator.generatePersona();
|
|
23
14
|
// create a record message
|
|
24
|
-
const { message: recordsWriteMessage } =
|
|
15
|
+
const { message: recordsWriteMessage } = await TestDataGenerator.generateRecordsWrite({ author: bob });
|
|
25
16
|
const recordsWriteAuthor = Message.getAuthor(recordsWriteMessage);
|
|
26
17
|
expect(recordsWriteAuthor).toBe(bob.did);
|
|
27
18
|
// create a delete message
|
|
28
|
-
const { message: recordsDeleteMessage } =
|
|
19
|
+
const { message: recordsDeleteMessage } = await TestDataGenerator.generateRecordsDelete({ author: bob });
|
|
29
20
|
const recordsDeleteAuthor = Message.getAuthor(recordsDeleteMessage);
|
|
30
21
|
expect(recordsDeleteAuthor).toBe(bob.did);
|
|
31
22
|
// create a protocol configure message
|
|
32
|
-
const { message: protocolsConfigureMessage } =
|
|
23
|
+
const { message: protocolsConfigureMessage } = await TestDataGenerator.generateProtocolsConfigure({ author: bob });
|
|
33
24
|
const protocolsConfigureAuthor = Message.getAuthor(protocolsConfigureMessage);
|
|
34
25
|
expect(protocolsConfigureAuthor).toBe(bob.did);
|
|
35
|
-
})
|
|
36
|
-
it('should get the author of a delegated message', () =>
|
|
37
|
-
const alice =
|
|
38
|
-
const deviceX =
|
|
26
|
+
});
|
|
27
|
+
it('should get the author of a delegated message', async () => {
|
|
28
|
+
const alice = await TestDataGenerator.generatePersona();
|
|
29
|
+
const deviceX = await TestDataGenerator.generatePersona();
|
|
39
30
|
// create a delegation scope from alice to deviceX for writing records in a protocol
|
|
40
31
|
const scope = {
|
|
41
32
|
interface: DwnInterfaceName.Records,
|
|
@@ -43,7 +34,7 @@ describe('Message', () => {
|
|
|
43
34
|
protocol: 'https://example.com/protocol/test',
|
|
44
35
|
};
|
|
45
36
|
// create the delegated grant message
|
|
46
|
-
const bobGrant =
|
|
37
|
+
const bobGrant = await PermissionsProtocol.createGrant({
|
|
47
38
|
delegated: true,
|
|
48
39
|
dateExpires: Time.createOffsetTimestamp({ seconds: 100 }),
|
|
49
40
|
grantedTo: deviceX.did,
|
|
@@ -52,7 +43,7 @@ describe('Message', () => {
|
|
|
52
43
|
});
|
|
53
44
|
// create a record message using the grant
|
|
54
45
|
const writeData = TestDataGenerator.randomBytes(32);
|
|
55
|
-
const { message } =
|
|
46
|
+
const { message } = await RecordsWrite.create({
|
|
56
47
|
signer: Jws.createSigner(deviceX),
|
|
57
48
|
delegatedGrant: bobGrant.dataEncodedMessage,
|
|
58
49
|
protocol: 'https://example.com/protocol/test',
|
|
@@ -66,81 +57,81 @@ describe('Message', () => {
|
|
|
66
57
|
// expect message signer to be deviceX
|
|
67
58
|
const signer = Message.getSigner(message);
|
|
68
59
|
expect(signer).toBe(deviceX.did);
|
|
69
|
-
})
|
|
70
|
-
it('returns undefined for an unsigned message', () =>
|
|
71
|
-
const { message } =
|
|
60
|
+
});
|
|
61
|
+
it('returns undefined for an unsigned message', async () => {
|
|
62
|
+
const { message } = await RecordsRead.create({
|
|
72
63
|
filter: {
|
|
73
|
-
recordId:
|
|
64
|
+
recordId: await TestDataGenerator.randomCborSha256Cid()
|
|
74
65
|
}
|
|
75
66
|
});
|
|
76
67
|
const author = Message.getAuthor(message);
|
|
77
68
|
expect(author).toBeUndefined();
|
|
78
|
-
})
|
|
69
|
+
});
|
|
79
70
|
});
|
|
80
71
|
describe('getSigner()', () => {
|
|
81
|
-
it('should return `undefined` if message is not signed', () =>
|
|
82
|
-
const recordsRead =
|
|
72
|
+
it('should return `undefined` if message is not signed', async () => {
|
|
73
|
+
const recordsRead = await RecordsRead.create({
|
|
83
74
|
filter: {
|
|
84
|
-
recordId:
|
|
75
|
+
recordId: await TestDataGenerator.randomCborSha256Cid()
|
|
85
76
|
}
|
|
86
77
|
});
|
|
87
78
|
const author = Message.getSigner(recordsRead.message);
|
|
88
79
|
expect(author).toBeUndefined();
|
|
89
|
-
})
|
|
80
|
+
});
|
|
90
81
|
});
|
|
91
82
|
describe('toJSON()', () => {
|
|
92
|
-
it('should return the message passed in to the constructor', () =>
|
|
83
|
+
it('should return the message passed in to the constructor', async () => {
|
|
93
84
|
// create a message without `authorization`
|
|
94
|
-
const { message } =
|
|
85
|
+
const { message } = await RecordsRead.create({
|
|
95
86
|
filter: {
|
|
96
|
-
recordId:
|
|
87
|
+
recordId: await TestDataGenerator.randomCborSha256Cid()
|
|
97
88
|
}
|
|
98
89
|
});
|
|
99
90
|
// NOTE: parse() calls constructor internally
|
|
100
|
-
const recordsRead =
|
|
91
|
+
const recordsRead = await RecordsRead.parse(message);
|
|
101
92
|
expect(recordsRead.toJSON()).toBe(message);
|
|
102
|
-
})
|
|
93
|
+
});
|
|
103
94
|
});
|
|
104
95
|
describe('compareMessageTimestamp', () => {
|
|
105
|
-
it('should return 0 if age is same', () =>
|
|
96
|
+
it('should return 0 if age is same', async () => {
|
|
106
97
|
const dateModified = Time.getCurrentTimestamp();
|
|
107
|
-
const a = (
|
|
98
|
+
const a = (await TestDataGenerator.generateRecordsWrite({ messageTimestamp: dateModified })).message;
|
|
108
99
|
const b = JSON.parse(JSON.stringify(a)); // create a deep copy of `a`
|
|
109
|
-
const compareResult =
|
|
100
|
+
const compareResult = await Message.compareMessageTimestamp(a, b);
|
|
110
101
|
expect(compareResult).toBe(0);
|
|
111
|
-
})
|
|
102
|
+
});
|
|
112
103
|
});
|
|
113
104
|
describe('getNewestMessage', () => {
|
|
114
|
-
it('should return the newest message', () =>
|
|
115
|
-
const a = (
|
|
116
|
-
|
|
117
|
-
const b = (
|
|
118
|
-
|
|
119
|
-
const c = (
|
|
120
|
-
const newestMessage =
|
|
105
|
+
it('should return the newest message', async () => {
|
|
106
|
+
const a = (await TestDataGenerator.generateRecordsWrite()).message;
|
|
107
|
+
await Time.minimalSleep();
|
|
108
|
+
const b = (await TestDataGenerator.generateRecordsWrite()).message;
|
|
109
|
+
await Time.minimalSleep();
|
|
110
|
+
const c = (await TestDataGenerator.generateRecordsWrite()).message; // c is the newest since its created last
|
|
111
|
+
const newestMessage = await Message.getNewestMessage([b, c, a]);
|
|
121
112
|
expect(newestMessage.recordId).toBe(c.recordId);
|
|
122
|
-
})
|
|
113
|
+
});
|
|
123
114
|
});
|
|
124
115
|
describe('getOldestMessage', () => {
|
|
125
|
-
it('should return the newest message', () =>
|
|
126
|
-
const a = (
|
|
127
|
-
|
|
128
|
-
const b = (
|
|
129
|
-
|
|
130
|
-
const c = (
|
|
131
|
-
const newestMessage =
|
|
116
|
+
it('should return the newest message', async () => {
|
|
117
|
+
const a = (await TestDataGenerator.generateRecordsWrite()).message;
|
|
118
|
+
await Time.minimalSleep();
|
|
119
|
+
const b = (await TestDataGenerator.generateRecordsWrite()).message;
|
|
120
|
+
await Time.minimalSleep();
|
|
121
|
+
const c = (await TestDataGenerator.generateRecordsWrite()).message; // c is the newest since its created last
|
|
122
|
+
const newestMessage = await Message.getOldestMessage([b, c, a]);
|
|
132
123
|
expect(newestMessage.recordId).toBe(a.recordId);
|
|
133
|
-
})
|
|
124
|
+
});
|
|
134
125
|
});
|
|
135
126
|
describe('getCid()', () => {
|
|
136
|
-
it('encodedData does not have an effect on getCid()', () =>
|
|
137
|
-
const { message } =
|
|
138
|
-
const cid1 =
|
|
127
|
+
it('encodedData does not have an effect on getCid()', async () => {
|
|
128
|
+
const { message } = await TestDataGenerator.generateRecordsWrite();
|
|
129
|
+
const cid1 = await Message.getCid(message);
|
|
139
130
|
const messageWithData = message;
|
|
140
131
|
messageWithData.encodedData = TestDataGenerator.randomString(25);
|
|
141
|
-
const cid2 =
|
|
132
|
+
const cid2 = await Message.getCid(messageWithData);
|
|
142
133
|
expect(cid1).toBe(cid2);
|
|
143
|
-
})
|
|
134
|
+
});
|
|
144
135
|
});
|
|
145
136
|
});
|
|
146
137
|
//# sourceMappingURL=message.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"message.spec.js","sourceRoot":"","sources":["../../../../tests/core/message.spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"message.spec.js","sourceRoot":"","sources":["../../../../tests/core/message.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,3 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
import { DwnErrorCode } from '../../src/core/dwn-error.js';
|
|
11
2
|
import { MessageStoreLevel } from '../../src/index.js';
|
|
12
3
|
import { ProtocolAuthorization } from '../../src/core/protocol-authorization.js';
|
|
@@ -18,21 +9,21 @@ describe('ProtocolAuthorization', () => {
|
|
|
18
9
|
sinon.restore();
|
|
19
10
|
});
|
|
20
11
|
describe('authorizeWrite()', () => {
|
|
21
|
-
it('should throw if message references non-existent parent', () =>
|
|
22
|
-
const alice =
|
|
23
|
-
const { recordsWrite } =
|
|
12
|
+
it('should throw if message references non-existent parent', async () => {
|
|
13
|
+
const alice = await TestDataGenerator.generateDidKeyPersona();
|
|
14
|
+
const { recordsWrite } = await TestDataGenerator.generateRecordsWrite({
|
|
24
15
|
author: alice,
|
|
25
16
|
parentContextId: 'nonExistentParent',
|
|
26
17
|
});
|
|
27
18
|
// stub the message store
|
|
28
19
|
const messageStoreStub = sinon.createStubInstance(MessageStoreLevel);
|
|
29
20
|
messageStoreStub.query.resolves({ messages: [] }); // simulate parent not in message store
|
|
30
|
-
|
|
31
|
-
})
|
|
21
|
+
await expect(ProtocolAuthorization.authorizeWrite(alice.did, recordsWrite, messageStoreStub)).rejects.toThrow(DwnErrorCode.ProtocolAuthorizationParentNotFoundConstructingRecordChain);
|
|
22
|
+
});
|
|
32
23
|
});
|
|
33
24
|
describe('getActionsSeekingARuleMatch()', () => {
|
|
34
|
-
it('should return empty array if unknown message method type is given', () =>
|
|
35
|
-
const alice =
|
|
25
|
+
it('should return empty array if unknown message method type is given', async () => {
|
|
26
|
+
const alice = await TestDataGenerator.generateDidKeyPersona();
|
|
36
27
|
const deliberatelyCraftedInvalidMessage = {
|
|
37
28
|
message: {
|
|
38
29
|
descriptor: {
|
|
@@ -41,8 +32,8 @@ describe('ProtocolAuthorization', () => {
|
|
|
41
32
|
}
|
|
42
33
|
};
|
|
43
34
|
const messageStoreStub = sinon.createStubInstance(MessageStoreLevel);
|
|
44
|
-
expect(
|
|
45
|
-
})
|
|
35
|
+
expect(await ProtocolAuthorization['getActionsSeekingARuleMatch'](alice.did, deliberatelyCraftedInvalidMessage, messageStoreStub)).toHaveLength(0);
|
|
36
|
+
});
|
|
46
37
|
});
|
|
47
38
|
});
|
|
48
39
|
//# sourceMappingURL=protocol-authorization.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"protocol-authorization.spec.js","sourceRoot":"","sources":["../../../../tests/core/protocol-authorization.spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"protocol-authorization.spec.js","sourceRoot":"","sources":["../../../../tests/core/protocol-authorization.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AACjF,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAE5D,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,UAAU,CAAC,GAAG,EAAE;QACd,KAAK,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAChC,EAAE,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;YACtE,MAAM,KAAK,GAAG,MAAM,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;YAE9D,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,iBAAiB,CAAC,oBAAoB,CAAC;gBACpE,MAAM,EAAY,KAAK;gBACvB,eAAe,EAAG,mBAAmB;aACtC,CAAC,CAAC;YAEH,yBAAyB;YACzB,MAAM,gBAAgB,GAAG,KAAK,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;YACrE,gBAAgB,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,uCAAuC;YAE1F,MAAM,MAAM,CAAC,qBAAqB,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,EAAE,YAAY,EAAE,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAC3G,YAAY,CAAC,0DAA0D,CACxE,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;QAC7C,EAAE,CAAC,mEAAmE,EAAE,KAAK,IAAI,EAAE;YACjF,MAAM,KAAK,GAAG,MAAM,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;YAE9D,MAAM,iCAAiC,GAAG;gBACxC,OAAO,EAAE;oBACP,UAAU,EAAE;wBACV,MAAM,EAAE,gBAAgB;qBACzB;iBACF;aACK,CAAC;YAET,MAAM,gBAAgB,GAAG,KAAK,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;YACrE,MAAM,CAAC,MAAM,qBAAqB,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,iCAAiC,EAAE,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACrJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|