@originals/sdk 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.json +33 -0
- package/.turbo/turbo-build.log +1 -0
- package/.turbo/turbo-test.log +68353 -0
- package/dist/adapters/FeeOracleMock.d.ts +6 -0
- package/dist/adapters/FeeOracleMock.js +8 -0
- package/dist/adapters/index.d.ts +4 -0
- package/dist/adapters/index.js +4 -0
- package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
- package/dist/adapters/providers/OrdHttpProvider.js +110 -0
- package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
- package/dist/adapters/providers/OrdMockProvider.js +75 -0
- package/dist/adapters/types.d.ts +71 -0
- package/dist/adapters/types.js +1 -0
- package/dist/bitcoin/BitcoinManager.d.ts +15 -0
- package/dist/bitcoin/BitcoinManager.js +262 -0
- package/dist/bitcoin/BroadcastClient.d.ts +30 -0
- package/dist/bitcoin/BroadcastClient.js +35 -0
- package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
- package/dist/bitcoin/OrdinalsClient.js +105 -0
- package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
- package/dist/bitcoin/PSBTBuilder.js +80 -0
- package/dist/bitcoin/fee-calculation.d.ts +14 -0
- package/dist/bitcoin/fee-calculation.js +31 -0
- package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
- package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
- package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
- package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
- package/dist/bitcoin/providers/types.d.ts +63 -0
- package/dist/bitcoin/providers/types.js +1 -0
- package/dist/bitcoin/transactions/commit.d.ts +89 -0
- package/dist/bitcoin/transactions/commit.js +311 -0
- package/dist/bitcoin/transactions/index.d.ts +7 -0
- package/dist/bitcoin/transactions/index.js +8 -0
- package/dist/bitcoin/transfer.d.ts +9 -0
- package/dist/bitcoin/transfer.js +26 -0
- package/dist/bitcoin/utxo-selection.d.ts +78 -0
- package/dist/bitcoin/utxo-selection.js +237 -0
- package/dist/bitcoin/utxo.d.ts +26 -0
- package/dist/bitcoin/utxo.js +78 -0
- package/dist/contexts/credentials-v1.json +195 -0
- package/dist/contexts/credentials-v2-examples.json +5 -0
- package/dist/contexts/credentials-v2.json +301 -0
- package/dist/contexts/credentials.json +195 -0
- package/dist/contexts/data-integrity-v2.json +81 -0
- package/dist/contexts/dids.json +57 -0
- package/dist/contexts/ed255192020.json +93 -0
- package/dist/contexts/ordinals-plus.json +23 -0
- package/dist/contexts/originals.json +22 -0
- package/dist/core/OriginalsSDK.d.ts +158 -0
- package/dist/core/OriginalsSDK.js +274 -0
- package/dist/crypto/Multikey.d.ts +30 -0
- package/dist/crypto/Multikey.js +149 -0
- package/dist/crypto/Signer.d.ts +21 -0
- package/dist/crypto/Signer.js +196 -0
- package/dist/crypto/noble-init.d.ts +18 -0
- package/dist/crypto/noble-init.js +106 -0
- package/dist/did/BtcoDidResolver.d.ts +57 -0
- package/dist/did/BtcoDidResolver.js +166 -0
- package/dist/did/DIDManager.d.ts +101 -0
- package/dist/did/DIDManager.js +493 -0
- package/dist/did/Ed25519Verifier.d.ts +30 -0
- package/dist/did/Ed25519Verifier.js +59 -0
- package/dist/did/KeyManager.d.ts +17 -0
- package/dist/did/KeyManager.js +207 -0
- package/dist/did/WebVHManager.d.ts +100 -0
- package/dist/did/WebVHManager.js +304 -0
- package/dist/did/createBtcoDidDocument.d.ts +10 -0
- package/dist/did/createBtcoDidDocument.js +42 -0
- package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
- package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
- package/dist/events/EventEmitter.d.ts +115 -0
- package/dist/events/EventEmitter.js +198 -0
- package/dist/events/index.d.ts +7 -0
- package/dist/events/index.js +6 -0
- package/dist/events/types.d.ts +286 -0
- package/dist/events/types.js +9 -0
- package/dist/examples/basic-usage.d.ts +3 -0
- package/dist/examples/basic-usage.js +62 -0
- package/dist/examples/run.d.ts +1 -0
- package/dist/examples/run.js +4 -0
- package/dist/index.d.ts +39 -0
- package/dist/index.js +47 -0
- package/dist/lifecycle/BatchOperations.d.ts +147 -0
- package/dist/lifecycle/BatchOperations.js +251 -0
- package/dist/lifecycle/LifecycleManager.d.ts +116 -0
- package/dist/lifecycle/LifecycleManager.js +971 -0
- package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
- package/dist/lifecycle/OriginalsAsset.js +380 -0
- package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
- package/dist/lifecycle/ProvenanceQuery.js +220 -0
- package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
- package/dist/lifecycle/ResourceVersioning.js +127 -0
- package/dist/migration/MigrationManager.d.ts +86 -0
- package/dist/migration/MigrationManager.js +412 -0
- package/dist/migration/audit/AuditLogger.d.ts +51 -0
- package/dist/migration/audit/AuditLogger.js +156 -0
- package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
- package/dist/migration/checkpoint/CheckpointManager.js +96 -0
- package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
- package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
- package/dist/migration/index.d.ts +22 -0
- package/dist/migration/index.js +27 -0
- package/dist/migration/operations/BaseMigration.d.ts +48 -0
- package/dist/migration/operations/BaseMigration.js +83 -0
- package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
- package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
- package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
- package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
- package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
- package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
- package/dist/migration/rollback/RollbackManager.d.ts +29 -0
- package/dist/migration/rollback/RollbackManager.js +146 -0
- package/dist/migration/state/StateMachine.d.ts +25 -0
- package/dist/migration/state/StateMachine.js +76 -0
- package/dist/migration/state/StateTracker.d.ts +36 -0
- package/dist/migration/state/StateTracker.js +123 -0
- package/dist/migration/types.d.ts +306 -0
- package/dist/migration/types.js +33 -0
- package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
- package/dist/migration/validation/BitcoinValidator.js +83 -0
- package/dist/migration/validation/CredentialValidator.d.ts +13 -0
- package/dist/migration/validation/CredentialValidator.js +46 -0
- package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
- package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
- package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
- package/dist/migration/validation/LifecycleValidator.js +52 -0
- package/dist/migration/validation/StorageValidator.d.ts +10 -0
- package/dist/migration/validation/StorageValidator.js +65 -0
- package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
- package/dist/migration/validation/ValidationPipeline.js +180 -0
- package/dist/storage/LocalStorageAdapter.d.ts +11 -0
- package/dist/storage/LocalStorageAdapter.js +53 -0
- package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
- package/dist/storage/MemoryStorageAdapter.js +21 -0
- package/dist/storage/StorageAdapter.d.ts +16 -0
- package/dist/storage/StorageAdapter.js +1 -0
- package/dist/storage/index.d.ts +2 -0
- package/dist/storage/index.js +2 -0
- package/dist/types/bitcoin.d.ts +84 -0
- package/dist/types/bitcoin.js +1 -0
- package/dist/types/common.d.ts +82 -0
- package/dist/types/common.js +1 -0
- package/dist/types/credentials.d.ts +75 -0
- package/dist/types/credentials.js +1 -0
- package/dist/types/did.d.ts +26 -0
- package/dist/types/did.js +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.js +5 -0
- package/dist/types/network.d.ts +78 -0
- package/dist/types/network.js +145 -0
- package/dist/utils/EventLogger.d.ts +71 -0
- package/dist/utils/EventLogger.js +232 -0
- package/dist/utils/Logger.d.ts +106 -0
- package/dist/utils/Logger.js +257 -0
- package/dist/utils/MetricsCollector.d.ts +110 -0
- package/dist/utils/MetricsCollector.js +264 -0
- package/dist/utils/bitcoin-address.d.ts +38 -0
- package/dist/utils/bitcoin-address.js +113 -0
- package/dist/utils/cbor.d.ts +2 -0
- package/dist/utils/cbor.js +9 -0
- package/dist/utils/encoding.d.ts +37 -0
- package/dist/utils/encoding.js +120 -0
- package/dist/utils/hash.d.ts +1 -0
- package/dist/utils/hash.js +5 -0
- package/dist/utils/retry.d.ts +10 -0
- package/dist/utils/retry.js +35 -0
- package/dist/utils/satoshi-validation.d.ts +60 -0
- package/dist/utils/satoshi-validation.js +156 -0
- package/dist/utils/serialization.d.ts +14 -0
- package/dist/utils/serialization.js +76 -0
- package/dist/utils/telemetry.d.ts +17 -0
- package/dist/utils/telemetry.js +24 -0
- package/dist/utils/validation.d.ts +5 -0
- package/dist/utils/validation.js +98 -0
- package/dist/vc/CredentialManager.d.ts +22 -0
- package/dist/vc/CredentialManager.js +227 -0
- package/dist/vc/Issuer.d.ts +27 -0
- package/dist/vc/Issuer.js +70 -0
- package/dist/vc/Verifier.d.ts +16 -0
- package/dist/vc/Verifier.js +50 -0
- package/dist/vc/cryptosuites/bbs.d.ts +44 -0
- package/dist/vc/cryptosuites/bbs.js +213 -0
- package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
- package/dist/vc/cryptosuites/bbsSimple.js +12 -0
- package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
- package/dist/vc/cryptosuites/eddsa.js +81 -0
- package/dist/vc/documentLoader.d.ts +16 -0
- package/dist/vc/documentLoader.js +59 -0
- package/dist/vc/proofs/data-integrity.d.ts +21 -0
- package/dist/vc/proofs/data-integrity.js +15 -0
- package/dist/vc/utils/jsonld.d.ts +2 -0
- package/dist/vc/utils/jsonld.js +15 -0
- package/package.json +79 -0
- package/src/adapters/FeeOracleMock.ts +9 -0
- package/src/adapters/index.ts +5 -0
- package/src/adapters/providers/OrdHttpProvider.ts +126 -0
- package/src/adapters/providers/OrdMockProvider.ts +101 -0
- package/src/adapters/types.ts +66 -0
- package/src/bitcoin/BitcoinManager.ts +330 -0
- package/src/bitcoin/BroadcastClient.ts +54 -0
- package/src/bitcoin/OrdinalsClient.ts +119 -0
- package/src/bitcoin/PSBTBuilder.ts +106 -0
- package/src/bitcoin/fee-calculation.ts +38 -0
- package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
- package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
- package/src/bitcoin/providers/types.ts +59 -0
- package/src/bitcoin/transactions/commit.ts +465 -0
- package/src/bitcoin/transactions/index.ts +13 -0
- package/src/bitcoin/transfer.ts +43 -0
- package/src/bitcoin/utxo-selection.ts +322 -0
- package/src/bitcoin/utxo.ts +113 -0
- package/src/contexts/credentials-v1.json +237 -0
- package/src/contexts/credentials-v2-examples.json +5 -0
- package/src/contexts/credentials-v2.json +340 -0
- package/src/contexts/credentials.json +237 -0
- package/src/contexts/data-integrity-v2.json +81 -0
- package/src/contexts/dids.json +58 -0
- package/src/contexts/ed255192020.json +93 -0
- package/src/contexts/ordinals-plus.json +23 -0
- package/src/contexts/originals.json +22 -0
- package/src/core/OriginalsSDK.ts +416 -0
- package/src/crypto/Multikey.ts +194 -0
- package/src/crypto/Signer.ts +254 -0
- package/src/crypto/noble-init.ts +121 -0
- package/src/did/BtcoDidResolver.ts +227 -0
- package/src/did/DIDManager.ts +694 -0
- package/src/did/Ed25519Verifier.ts +68 -0
- package/src/did/KeyManager.ts +236 -0
- package/src/did/WebVHManager.ts +489 -0
- package/src/did/createBtcoDidDocument.ts +59 -0
- package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
- package/src/events/EventEmitter.ts +222 -0
- package/src/events/index.ts +19 -0
- package/src/events/types.ts +331 -0
- package/src/examples/basic-usage.ts +78 -0
- package/src/examples/run.ts +5 -0
- package/src/index.ts +84 -0
- package/src/lifecycle/BatchOperations.ts +373 -0
- package/src/lifecycle/LifecycleManager.ts +1218 -0
- package/src/lifecycle/OriginalsAsset.ts +524 -0
- package/src/lifecycle/ProvenanceQuery.ts +280 -0
- package/src/lifecycle/ResourceVersioning.ts +163 -0
- package/src/migration/MigrationManager.ts +527 -0
- package/src/migration/audit/AuditLogger.ts +176 -0
- package/src/migration/checkpoint/CheckpointManager.ts +112 -0
- package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
- package/src/migration/index.ts +33 -0
- package/src/migration/operations/BaseMigration.ts +126 -0
- package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
- package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
- package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
- package/src/migration/rollback/RollbackManager.ts +170 -0
- package/src/migration/state/StateMachine.ts +92 -0
- package/src/migration/state/StateTracker.ts +156 -0
- package/src/migration/types.ts +344 -0
- package/src/migration/validation/BitcoinValidator.ts +107 -0
- package/src/migration/validation/CredentialValidator.ts +62 -0
- package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
- package/src/migration/validation/LifecycleValidator.ts +64 -0
- package/src/migration/validation/StorageValidator.ts +79 -0
- package/src/migration/validation/ValidationPipeline.ts +213 -0
- package/src/storage/LocalStorageAdapter.ts +61 -0
- package/src/storage/MemoryStorageAdapter.ts +29 -0
- package/src/storage/StorageAdapter.ts +25 -0
- package/src/storage/index.ts +3 -0
- package/src/types/bitcoin.ts +98 -0
- package/src/types/common.ts +92 -0
- package/src/types/credentials.ts +88 -0
- package/src/types/did.ts +31 -0
- package/src/types/external-shims.d.ts +53 -0
- package/src/types/index.ts +7 -0
- package/src/types/network.ts +175 -0
- package/src/utils/EventLogger.ts +298 -0
- package/src/utils/Logger.ts +322 -0
- package/src/utils/MetricsCollector.ts +358 -0
- package/src/utils/bitcoin-address.ts +130 -0
- package/src/utils/cbor.ts +12 -0
- package/src/utils/encoding.ts +127 -0
- package/src/utils/hash.ts +6 -0
- package/src/utils/retry.ts +46 -0
- package/src/utils/satoshi-validation.ts +196 -0
- package/src/utils/serialization.ts +96 -0
- package/src/utils/telemetry.ts +40 -0
- package/src/utils/validation.ts +119 -0
- package/src/vc/CredentialManager.ts +273 -0
- package/src/vc/Issuer.ts +100 -0
- package/src/vc/Verifier.ts +47 -0
- package/src/vc/cryptosuites/bbs.ts +253 -0
- package/src/vc/cryptosuites/bbsSimple.ts +21 -0
- package/src/vc/cryptosuites/eddsa.ts +99 -0
- package/src/vc/documentLoader.ts +67 -0
- package/src/vc/proofs/data-integrity.ts +33 -0
- package/src/vc/utils/jsonld.ts +18 -0
- package/test/logs/did_webvh_QmQsRNhXxPSCSeLjpbKYcNMZj8b1kBQAoC6cZmkFAgmpHt_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmSQkpD58qxcqMWHYcEmDUn3wk7hHvJwzYTrZmhh6zjPQ8_example_com_users_alice123_profile.jsonl +1 -0
- package/test/logs/did_webvh_QmTMda6VW3cUPdKk5Yc3onnv1vdgEumvWWdP2noAYFSjeG_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmTkb8KnCYcsnKKDCY4eUQuKQdKJLrCinvhw13v3zETxpE_example_com_users_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmTn9FdCfpXFDrxHH52pwB4iNrDFVvNDjJ5FQTcDbmM3Fg_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUCQUi1xjtJjnSQ1XJZgKqcWgErx1v7E2dz4DAPraAyJP_example_com_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmUENQJCDKBJVRS5BkL6zjaUvcRjkb9xHmy7foCgRjmv3W_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUPdGyjYBEnQ3aQUkmqyyBKTyjvCP5RZQGiaEDeTtf6dc_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUoHTuHMWzQM29ZFrE9VLtMxkZ5u869yqee8LwcCLN39M_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUrnms8G65ggVKsr9oQeWrLUBuGChwQPPb2LCFvaoNxaw_example_com_users_alice.jsonl +1 -0
- package/test/logs/did_webvh_QmUwiw3eSXdHG1hPvoAGu3cuK5jF4aXRYDLBAjPXfv1qzb_example_com_level1_level2.jsonl +1 -0
- package/test/logs/did_webvh_QmW7bzKh6yFEKNAtmVsrPGvvsMHTUQdzJSNsTZkbuGFpbj_example_com_secret.jsonl +1 -0
- package/test/logs/did_webvh_QmXbFTFBBJ8zpjdz9WE1DNN44A2wprFmdvAubjSffeyoAG_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmXyVXFPCTffGb2mTUFDeMCsScjnpLWkyUkVkB6q6QoeBf_example_com_C_Windows_System32.jsonl +1 -0
- package/test/logs/did_webvh_QmZK9B81gxZtvo5fYHYKDtKt8zZfZZPhmCMhbujBJuRRzE_example_com_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmbNLCVSdXSVLrwFBvCBQPAabjtRb1SGHjkGVyw3QUbfBL_example_com_users_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmbeaicmGW3Q7Yzbqmftc8a9jLBngokveb5A2KVKfVGZRb_example_com_my_org_user_name_test_123.jsonl +1 -0
- package/test/logs/did_webvh_Qmdv7c7AjUreUfoKyvkN2UpAWTozxKsv99srQetPJMJEnp_example_com_users_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmeioWY3uypYLkYpCXe9eCYnn4xBVruP9C1d79azMrTEHG_example_com.jsonl +1 -0
- package/test/logs/did_webvh_Qmf4QH5dsA6Ecr5HJ6KaJL9uJRyY8RxrQdqoRCM25DzvPi_example_com_users_alice.jsonl +1 -0
- package/tests/__mocks__/bbs-signatures.js +17 -0
- package/tests/__mocks__/mf-base58.js +24 -0
- package/tests/e2e/README.md +97 -0
- package/tests/e2e/example.spec.ts +78 -0
- package/tests/fixtures/did-documents.ts +247 -0
- package/tests/index.test.ts +21 -0
- package/tests/integration/BatchOperations.test.ts +531 -0
- package/tests/integration/CompleteLifecycle.e2e.test.ts +735 -0
- package/tests/integration/CredentialManager.test.ts +42 -0
- package/tests/integration/DIDManager.test.ts +41 -0
- package/tests/integration/DidPeerToWebVhFlow.test.ts +351 -0
- package/tests/integration/Events.test.ts +435 -0
- package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +25 -0
- package/tests/integration/LifecycleManager.test.ts +21 -0
- package/tests/integration/MultikeyFlow.test.ts +52 -0
- package/tests/integration/TelemetryIntegration.test.ts +395 -0
- package/tests/integration/WebVhPublish.test.ts +48 -0
- package/tests/integration/migration/peer-to-webvh.test.ts +172 -0
- package/tests/manual/test-commit-creation.ts +323 -0
- package/tests/mocks/MockKeyStore.ts +38 -0
- package/tests/mocks/adapters/MemoryStorageAdapter.ts +24 -0
- package/tests/mocks/adapters/MockFeeOracle.ts +11 -0
- package/tests/mocks/adapters/MockOrdinalsProvider.ts +76 -0
- package/tests/mocks/adapters/OrdMockProvider.test.ts +176 -0
- package/tests/mocks/adapters/index.ts +6 -0
- package/tests/performance/BatchOperations.perf.test.ts +403 -0
- package/tests/performance/logging.perf.test.ts +336 -0
- package/tests/sdk.test.ts +43 -0
- package/tests/security/bitcoin-penetration-tests.test.ts +622 -0
- package/tests/setup.bun.ts +69 -0
- package/tests/setup.jest.ts +23 -0
- package/tests/stress/batch-operations-stress.test.ts +571 -0
- package/tests/unit/adapters/FeeOracleMock.test.ts +40 -0
- package/tests/unit/bitcoin/BitcoinManager.test.ts +293 -0
- package/tests/unit/bitcoin/BroadcastClient.test.ts +52 -0
- package/tests/unit/bitcoin/OrdNodeProvider.test.ts +53 -0
- package/tests/unit/bitcoin/OrdinalsClient.test.ts +381 -0
- package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +102 -0
- package/tests/unit/bitcoin/PSBTBuilder.test.ts +84 -0
- package/tests/unit/bitcoin/fee-calculation.test.ts +261 -0
- package/tests/unit/bitcoin/transactions/commit.test.ts +649 -0
- package/tests/unit/bitcoin/transfer.test.ts +31 -0
- package/tests/unit/bitcoin/utxo-selection-new.test.ts +502 -0
- package/tests/unit/bitcoin/utxo.more.test.ts +39 -0
- package/tests/unit/bitcoin/utxo.selection.test.ts +38 -0
- package/tests/unit/core/OriginalsSDK.test.ts +152 -0
- package/tests/unit/crypto/Multikey.test.ts +206 -0
- package/tests/unit/crypto/Signer.test.ts +408 -0
- package/tests/unit/did/BtcoDidResolver.test.ts +611 -0
- package/tests/unit/did/DIDManager.more.test.ts +43 -0
- package/tests/unit/did/DIDManager.test.ts +185 -0
- package/tests/unit/did/Ed25519Verifier.test.ts +160 -0
- package/tests/unit/did/KeyManager.test.ts +452 -0
- package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +45 -0
- package/tests/unit/did/WebVHManager.test.ts +435 -0
- package/tests/unit/did/createBtcoDidDocument.test.ts +67 -0
- package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +159 -0
- package/tests/unit/events/EventEmitter.test.ts +407 -0
- package/tests/unit/lifecycle/BatchOperations.test.ts +527 -0
- package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +312 -0
- package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +18 -0
- package/tests/unit/lifecycle/LifecycleManager.test.ts +213 -0
- package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +30 -0
- package/tests/unit/lifecycle/OriginalsAsset.test.ts +176 -0
- package/tests/unit/lifecycle/ProvenanceQuery.test.ts +577 -0
- package/tests/unit/lifecycle/ResourceVersioning.test.ts +651 -0
- package/tests/unit/storage/MemoryStorageAdapter.test.ts +93 -0
- package/tests/unit/types/network.test.ts +255 -0
- package/tests/unit/utils/EventIntegration.test.ts +384 -0
- package/tests/unit/utils/Logger.test.ts +473 -0
- package/tests/unit/utils/MetricsCollector.test.ts +358 -0
- package/tests/unit/utils/bitcoin-address.test.ts +250 -0
- package/tests/unit/utils/cbor.test.ts +35 -0
- package/tests/unit/utils/encoding.test.ts +318 -0
- package/tests/unit/utils/hash.test.ts +12 -0
- package/tests/unit/utils/retry.test.ts +100 -0
- package/tests/unit/utils/satoshi-validation.test.ts +354 -0
- package/tests/unit/utils/serialization.test.ts +124 -0
- package/tests/unit/utils/telemetry.test.ts +52 -0
- package/tests/unit/utils/validation.test.ts +141 -0
- package/tests/unit/vc/CredentialManager.test.ts +487 -0
- package/tests/unit/vc/Issuer.test.ts +107 -0
- package/tests/unit/vc/Verifier.test.ts +525 -0
- package/tests/unit/vc/bbs.test.ts +282 -0
- package/tests/unit/vc/cryptosuites/eddsa.test.ts +398 -0
- package/tests/unit/vc/documentLoader.test.ts +121 -0
- package/tests/unit/vc/proofs/data-integrity.test.ts +24 -0
- package/tsconfig.json +32 -0
- package/tsconfig.test.json +15 -0
- package/tsconfig.tsbuildinfo +1 -0
|
@@ -0,0 +1,525 @@
|
|
|
1
|
+
import { describe, test, expect, beforeAll, afterEach, afterAll, beforeEach } from 'bun:test';
|
|
2
|
+
import { Verifier } from '../../../src/vc/Verifier';
|
|
3
|
+
import { Issuer } from '../../../src/vc/Issuer';
|
|
4
|
+
import * as ed25519 from '@noble/ed25519';
|
|
5
|
+
import { multikey } from '../../../src/crypto/Multikey';
|
|
6
|
+
import { registerVerificationMethod, verificationMethodRegistry } from '../../../src/vc/documentLoader';
|
|
7
|
+
import { DIDManager } from '../../../src/did/DIDManager';
|
|
8
|
+
|
|
9
|
+
describe('diwings Verifier', () => {
|
|
10
|
+
const didManager = new DIDManager({} as any);
|
|
11
|
+
const did = 'did:peer:issuer1';
|
|
12
|
+
const sk = new Uint8Array(32).map((_, i) => (i + 1) & 0xff);
|
|
13
|
+
const pk = ed25519.getPublicKey(sk);
|
|
14
|
+
const vm = {
|
|
15
|
+
id: `${did}#keys-1`,
|
|
16
|
+
controller: did,
|
|
17
|
+
type: 'Multikey',
|
|
18
|
+
publicKeyMultibase: multikey.encodePublicKey(pk, 'Ed25519'),
|
|
19
|
+
secretKeyMultibase: multikey.encodePrivateKey(sk, 'Ed25519')
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
registerVerificationMethod(vm);
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
test('verifies a credential (v2)', async () => {
|
|
27
|
+
const issuer = new Issuer(didManager, vm);
|
|
28
|
+
const vc = await issuer.issueCredential(
|
|
29
|
+
{
|
|
30
|
+
type: ['VerifiableCredential', 'Test'],
|
|
31
|
+
issuer: did,
|
|
32
|
+
issuanceDate: new Date().toISOString(),
|
|
33
|
+
credentialSubject: { id: 'did:peer:subject1' }
|
|
34
|
+
} as any,
|
|
35
|
+
{ proofPurpose: 'assertionMethod' }
|
|
36
|
+
);
|
|
37
|
+
const verifier = new Verifier(didManager);
|
|
38
|
+
const res = await verifier.verifyCredential(vc);
|
|
39
|
+
expect(res.verified).toBe(true);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
test('verifies a presentation (v2) with nested credential', async () => {
|
|
43
|
+
const issuer = new Issuer(didManager, vm);
|
|
44
|
+
const vc = await issuer.issueCredential(
|
|
45
|
+
{
|
|
46
|
+
type: ['VerifiableCredential', 'Nested'],
|
|
47
|
+
issuer: did,
|
|
48
|
+
issuanceDate: new Date().toISOString(),
|
|
49
|
+
credentialSubject: { id: 'did:peer:subject2' }
|
|
50
|
+
} as any,
|
|
51
|
+
{ proofPurpose: 'assertionMethod' }
|
|
52
|
+
);
|
|
53
|
+
const vp = await issuer.issuePresentation(
|
|
54
|
+
{
|
|
55
|
+
type: ['VerifiablePresentation'],
|
|
56
|
+
holder: did,
|
|
57
|
+
verifiableCredential: [vc]
|
|
58
|
+
} as any,
|
|
59
|
+
{ proofPurpose: 'authentication' }
|
|
60
|
+
);
|
|
61
|
+
const verifier = new Verifier(didManager);
|
|
62
|
+
const res = await verifier.verifyPresentation(vp);
|
|
63
|
+
expect(res.verified).toBe(true);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
test('fails when proof missing', async () => {
|
|
67
|
+
const verifier = new Verifier(didManager);
|
|
68
|
+
const badVc: any = {
|
|
69
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
70
|
+
type: ['VerifiableCredential']
|
|
71
|
+
};
|
|
72
|
+
const res = await verifier.verifyCredential(badVc);
|
|
73
|
+
expect(res.verified).toBe(false);
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
/** Inlined from Verifier.array-context-and-proof.part.ts */
|
|
78
|
+
|
|
79
|
+
describe('Verifier array handling branches', () => {
|
|
80
|
+
const dm = new DIDManager({} as any);
|
|
81
|
+
const verifier = new Verifier(dm);
|
|
82
|
+
|
|
83
|
+
test('verifyCredential with array proof and array contexts', async () => {
|
|
84
|
+
const vc: any = {
|
|
85
|
+
'@context': ['https://www.w3.org/2018/credentials/v1', 'https://w3id.org/security/data-integrity/v2'],
|
|
86
|
+
type: ['VerifiableCredential'],
|
|
87
|
+
proof: [{ cryptosuite: 'data-integrity' }]
|
|
88
|
+
};
|
|
89
|
+
const res = await verifier.verifyCredential(vc, {
|
|
90
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
91
|
+
});
|
|
92
|
+
expect(res.verified).toBe(false);
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
test('verifyPresentation with array proof and array contexts', async () => {
|
|
96
|
+
const vp: any = {
|
|
97
|
+
'@context': ['https://www.w3.org/2018/credentials/v1', 'https://w3id.org/security/data-integrity/v2'],
|
|
98
|
+
type: ['VerifiablePresentation'],
|
|
99
|
+
proof: [{ cryptosuite: 'data-integrity' }]
|
|
100
|
+
};
|
|
101
|
+
const res = await verifier.verifyPresentation(vp, {
|
|
102
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
103
|
+
});
|
|
104
|
+
expect(res.verified).toBe(false);
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
/** Inlined from Verifier.branches-more.part.ts */
|
|
110
|
+
|
|
111
|
+
describe('Verifier additional error branches', () => {
|
|
112
|
+
const dm = new DIDManager({} as any);
|
|
113
|
+
const verifier = new Verifier(dm);
|
|
114
|
+
|
|
115
|
+
test('verifyCredential invalid input missing type', async () => {
|
|
116
|
+
const res = await verifier.verifyCredential({ '@context': ['x'], proof: {} } as any);
|
|
117
|
+
expect(res.verified).toBe(false);
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
test('verifyPresentation invalid input missing type', async () => {
|
|
121
|
+
const res = await verifier.verifyPresentation({ '@context': ['x'], proof: {} } as any);
|
|
122
|
+
expect(res.verified).toBe(false);
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
/** Inlined from Verifier.context-string.part.ts */
|
|
130
|
+
|
|
131
|
+
describe('Verifier with string @context branches', () => {
|
|
132
|
+
const dm = new DIDManager({} as any);
|
|
133
|
+
const did = 'did:peer:stringctx';
|
|
134
|
+
const sk = new Uint8Array(32).map((_, i) => (i + 7) & 0xff);
|
|
135
|
+
const pk = ed25519.getPublicKey(sk);
|
|
136
|
+
const vm = {
|
|
137
|
+
id: `${did}#keys-1`,
|
|
138
|
+
controller: did,
|
|
139
|
+
type: 'Multikey',
|
|
140
|
+
publicKeyMultibase: multikey.encodePublicKey(pk, 'Ed25519'),
|
|
141
|
+
secretKeyMultibase: multikey.encodePrivateKey(sk, 'Ed25519')
|
|
142
|
+
};
|
|
143
|
+
|
|
144
|
+
beforeEach(() => registerVerificationMethod(vm));
|
|
145
|
+
|
|
146
|
+
test('verifyCredential accepts string @context', async () => {
|
|
147
|
+
const issuer = new Issuer(dm, vm);
|
|
148
|
+
const vc = await issuer.issueCredential({ id: 'urn:x', type: ['VerifiableCredential'], issuer: did, issuanceDate: new Date().toISOString(), credentialSubject: {} } as any, { proofPurpose: 'assertionMethod' });
|
|
149
|
+
(vc as any)['@context'] = 'https://www.w3.org/ns/credentials/v2';
|
|
150
|
+
const verifier = new Verifier(dm);
|
|
151
|
+
const res = await verifier.verifyCredential(vc as any);
|
|
152
|
+
expect(typeof res.verified).toBe('boolean');
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
test('verifyPresentation accepts string @context and no nested VCs', async () => {
|
|
156
|
+
const issuer = new Issuer(dm, vm);
|
|
157
|
+
const vp = await issuer.issuePresentation({ holder: did } as any, { proofPurpose: 'authentication' });
|
|
158
|
+
(vp as any)['@context'] = 'https://www.w3.org/ns/credentials/v2';
|
|
159
|
+
const verifier = new Verifier(dm);
|
|
160
|
+
const res = await verifier.verifyPresentation(vp as any);
|
|
161
|
+
expect(typeof res.verified).toBe('boolean');
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
|
|
166
|
+
|
|
167
|
+
|
|
168
|
+
/** Inlined from Verifier.default-loader.part.ts */
|
|
169
|
+
|
|
170
|
+
describe('Verifier with default document loader (no options)', () => {
|
|
171
|
+
const dm = new DIDManager({} as any);
|
|
172
|
+
const verifier = new Verifier(dm);
|
|
173
|
+
|
|
174
|
+
test('verifyCredential uses default loader with v2 contexts', async () => {
|
|
175
|
+
const vc: any = {
|
|
176
|
+
'@context': ['https://www.w3.org/ns/credentials/v2', 'https://w3id.org/security/data-integrity/v2'],
|
|
177
|
+
type: ['VerifiableCredential'],
|
|
178
|
+
proof: { cryptosuite: 'data-integrity' }
|
|
179
|
+
};
|
|
180
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
181
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
182
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: false, errors: ['x'] });
|
|
183
|
+
const res = await verifier.verifyCredential(vc);
|
|
184
|
+
expect(res.verified).toBe(false);
|
|
185
|
+
expect(res.errors[0]).toBe('x');
|
|
186
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
test('verifyPresentation uses default loader with v2 contexts', async () => {
|
|
190
|
+
const vp: any = {
|
|
191
|
+
'@context': ['https://www.w3.org/ns/credentials/v2', 'https://w3id.org/security/data-integrity/v2'],
|
|
192
|
+
type: ['VerifiablePresentation'],
|
|
193
|
+
proof: { cryptosuite: 'data-integrity' }
|
|
194
|
+
};
|
|
195
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
196
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
197
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: true, errors: [] });
|
|
198
|
+
const res = await verifier.verifyPresentation(vp);
|
|
199
|
+
expect(res.verified).toBe(true);
|
|
200
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
201
|
+
});
|
|
202
|
+
});
|
|
203
|
+
|
|
204
|
+
|
|
205
|
+
/** Inlined from Verifier.dimock.part.ts */
|
|
206
|
+
describe('Verifier with mocked DataIntegrityProofManager', () => {
|
|
207
|
+
afterEach(() => {
|
|
208
|
+
// Bun doesn't require resetModules
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
test('verifyCredential success branch (verified=true)', async () => {
|
|
212
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
213
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
214
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: true });
|
|
215
|
+
const { Verifier } = await import('../../../src/vc/Verifier');
|
|
216
|
+
const { DIDManager } = await import('../../../src/did/DIDManager');
|
|
217
|
+
const verifier = new Verifier(new DIDManager({} as any));
|
|
218
|
+
const res = await verifier.verifyCredential({ '@context': ['https://www.w3.org/ns/credentials/v2'], type: ['VerifiableCredential'], proof: {} } as any, {
|
|
219
|
+
documentLoader: async () => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: '', contextUrl: null })
|
|
220
|
+
});
|
|
221
|
+
expect(res.verified).toBe(true);
|
|
222
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
test('verifyPresentation failure branch (no errors provided -> default)', async () => {
|
|
226
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
227
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
228
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: false });
|
|
229
|
+
const { Verifier } = await import('../../../src/vc/Verifier');
|
|
230
|
+
const { DIDManager } = await import('../../../src/did/DIDManager');
|
|
231
|
+
const verifier = new Verifier(new DIDManager({} as any));
|
|
232
|
+
const res = await verifier.verifyPresentation({ '@context': ['https://www.w3.org/ns/credentials/v2'], type: ['VerifiablePresentation'], proof: {} } as any, {
|
|
233
|
+
documentLoader: async () => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: '', contextUrl: null })
|
|
234
|
+
});
|
|
235
|
+
expect(res.verified).toBe(false);
|
|
236
|
+
expect(res.errors[0]).toBe('Verification failed');
|
|
237
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
|
|
241
|
+
|
|
242
|
+
|
|
243
|
+
|
|
244
|
+
/** Inlined from Verifier.errors.part.ts */
|
|
245
|
+
|
|
246
|
+
describe('Verifier error branches', () => {
|
|
247
|
+
const dm = new DIDManager({} as any);
|
|
248
|
+
const verifier = new Verifier(dm);
|
|
249
|
+
|
|
250
|
+
test('verifyCredential catches loader error', async () => {
|
|
251
|
+
const res = await verifier.verifyCredential({ '@context': ['bad'], type: ['VerifiableCredential'], proof: {} } as any, {
|
|
252
|
+
documentLoader: async () => { throw new Error('loader boom'); }
|
|
253
|
+
});
|
|
254
|
+
expect(res.verified).toBe(false);
|
|
255
|
+
expect(res.errors[0]).toContain('loader boom');
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
test('verifyPresentation catches nested VC failure', async () => {
|
|
259
|
+
const vp: any = {
|
|
260
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
261
|
+
type: ['VerifiablePresentation'],
|
|
262
|
+
verifiableCredential: [{ '@context': ['https://www.w3.org/2018/credentials/v1'], type: ['VerifiableCredential'] }],
|
|
263
|
+
proof: {}
|
|
264
|
+
};
|
|
265
|
+
const res = await verifier.verifyPresentation(vp, { documentLoader: async () => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: '', contextUrl: null }) });
|
|
266
|
+
expect(res.verified).toBe(false);
|
|
267
|
+
});
|
|
268
|
+
|
|
269
|
+
test('verifyPresentation returns nested vc error early', async () => {
|
|
270
|
+
const vp: any = {
|
|
271
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
272
|
+
type: ['VerifiablePresentation'],
|
|
273
|
+
verifiableCredential: [{ '@context': ['https://www.w3.org/2018/credentials/v1'], type: ['VerifiableCredential'], proof: {} }],
|
|
274
|
+
proof: {}
|
|
275
|
+
};
|
|
276
|
+
const res = await verifier.verifyPresentation(vp, { documentLoader: async () => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: '', contextUrl: null }) });
|
|
277
|
+
expect(res.verified).toBe(false);
|
|
278
|
+
});
|
|
279
|
+
|
|
280
|
+
test('verifyPresentation catches loader error', async () => {
|
|
281
|
+
const vp: any = {
|
|
282
|
+
'@context': ['bad'],
|
|
283
|
+
type: ['VerifiablePresentation'],
|
|
284
|
+
proof: {}
|
|
285
|
+
};
|
|
286
|
+
const res = await verifier.verifyPresentation(vp, { documentLoader: async () => { throw new Error('vp loader boom'); } });
|
|
287
|
+
expect(res.verified).toBe(false);
|
|
288
|
+
expect(res.errors[0]).toContain('vp loader boom');
|
|
289
|
+
});
|
|
290
|
+
|
|
291
|
+
test('verifyCredential returns Verification failed when proof manager returns false', async () => {
|
|
292
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
293
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
294
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: false, errors: undefined });
|
|
295
|
+
const { Verifier } = await import('../../../src/vc/Verifier');
|
|
296
|
+
const { DIDManager } = await import('../../../src/did/DIDManager');
|
|
297
|
+
const localVerifier = new Verifier(new DIDManager({} as any));
|
|
298
|
+
const res = await localVerifier.verifyCredential({ '@context': ['https://www.w3.org/2018/credentials/v1'], type: ['VerifiableCredential'], proof: { cryptosuite: 'eddsa-rdfc-2022' } } as any, { documentLoader: async () => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: '', contextUrl: null }) });
|
|
299
|
+
expect(res.verified).toBe(false);
|
|
300
|
+
expect(res.errors[0]).toBe('Verification failed');
|
|
301
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
302
|
+
});
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
|
|
306
|
+
|
|
307
|
+
|
|
308
|
+
/** Inlined from Verifier.more-branches2.part.ts */
|
|
309
|
+
|
|
310
|
+
describe('Verifier branches for string context and single proof', () => {
|
|
311
|
+
const dm = new DIDManager({} as any);
|
|
312
|
+
const verifier = new Verifier(dm);
|
|
313
|
+
|
|
314
|
+
test('verifyCredential with string context runs loader loop with one item', async () => {
|
|
315
|
+
const vc: any = {
|
|
316
|
+
'@context': 'https://www.w3.org/2018/credentials/v1',
|
|
317
|
+
type: ['VerifiableCredential'],
|
|
318
|
+
proof: { cryptosuite: 'data-integrity' }
|
|
319
|
+
};
|
|
320
|
+
const res = await verifier.verifyCredential(vc, {
|
|
321
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
322
|
+
});
|
|
323
|
+
expect(res.verified).toBe(false);
|
|
324
|
+
});
|
|
325
|
+
|
|
326
|
+
test('verifyPresentation with string context runs loader loop with one item', async () => {
|
|
327
|
+
const vp: any = {
|
|
328
|
+
'@context': 'https://www.w3.org/2018/credentials/v1',
|
|
329
|
+
type: ['VerifiablePresentation'],
|
|
330
|
+
proof: { cryptosuite: 'data-integrity' }
|
|
331
|
+
};
|
|
332
|
+
const res = await verifier.verifyPresentation(vp, {
|
|
333
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
334
|
+
});
|
|
335
|
+
expect(res.verified).toBe(false);
|
|
336
|
+
});
|
|
337
|
+
});
|
|
338
|
+
|
|
339
|
+
|
|
340
|
+
/** Inlined from Verifier.more.part.ts */
|
|
341
|
+
|
|
342
|
+
describe('Verifier branches', () => {
|
|
343
|
+
const dm = new DIDManager({} as any);
|
|
344
|
+
const verifier = new Verifier(dm);
|
|
345
|
+
|
|
346
|
+
test('verifyCredential returns error on invalid vc', async () => {
|
|
347
|
+
const res = await verifier.verifyCredential({} as any);
|
|
348
|
+
expect(res.verified).toBe(false);
|
|
349
|
+
});
|
|
350
|
+
|
|
351
|
+
test('verifyPresentation returns error on invalid vp', async () => {
|
|
352
|
+
const res = await verifier.verifyPresentation({} as any);
|
|
353
|
+
expect(res.verified).toBe(false);
|
|
354
|
+
});
|
|
355
|
+
|
|
356
|
+
test('verifyPresentation missing proof triggers error', async () => {
|
|
357
|
+
const res = await verifier.verifyPresentation({ '@context': ['https://www.w3.org/2018/credentials/v1'], type: ['VerifiablePresentation'] } as any);
|
|
358
|
+
expect(res.verified).toBe(false);
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
test('verifyCredential unknown error message fallback', async () => {
|
|
362
|
+
const dm2 = new DIDManager({} as any);
|
|
363
|
+
const v2: any = new Verifier(dm2);
|
|
364
|
+
const orig = (require('../../../src/vc/proofs/data-integrity').DataIntegrityProofManager as any).verifyProof;
|
|
365
|
+
(require('../../../src/vc/proofs/data-integrity').DataIntegrityProofManager as any).verifyProof = async () => { throw { not: 'error' }; };
|
|
366
|
+
const res = await v2.verifyCredential({ '@context': ['https://www.w3.org/2018/credentials/v1'], type: ['VerifiableCredential'], proof: {} } as any, { documentLoader: async () => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: '', contextUrl: null }) });
|
|
367
|
+
expect(res.verified).toBe(false);
|
|
368
|
+
;(require('../../../src/vc/proofs/data-integrity').DataIntegrityProofManager as any).verifyProof = orig;
|
|
369
|
+
});
|
|
370
|
+
});
|
|
371
|
+
|
|
372
|
+
|
|
373
|
+
|
|
374
|
+
|
|
375
|
+
/** Inlined from Verifier.proofarray.part.ts */
|
|
376
|
+
|
|
377
|
+
describe('Verifier handles array proofs', () => {
|
|
378
|
+
test('verifyCredential with proof array handled (takes first element)', async () => {
|
|
379
|
+
const dm = new DIDManager({} as any);
|
|
380
|
+
const sk = new Uint8Array(32).fill(7);
|
|
381
|
+
const pk = new Uint8Array(32).fill(8);
|
|
382
|
+
const vm = {
|
|
383
|
+
id: 'did:ex:arr#key-1',
|
|
384
|
+
controller: 'did:ex:arr',
|
|
385
|
+
publicKeyMultibase: multikey.encodePublicKey(pk, 'Ed25519'),
|
|
386
|
+
secretKeyMultibase: multikey.encodePrivateKey(sk, 'Ed25519')
|
|
387
|
+
};
|
|
388
|
+
const issuer = new Issuer(dm, vm);
|
|
389
|
+
registerVerificationMethod({ id: vm.id, type: 'Multikey', controller: vm.controller, publicKeyMultibase: vm.publicKeyMultibase });
|
|
390
|
+
const unsigned: any = { id: 'urn:cred:arr', type: ['VerifiableCredential', 'Test'], issuer: vm.controller, issuanceDate: new Date().toISOString(), credentialSubject: {} };
|
|
391
|
+
const vc = await issuer.issueCredential(unsigned, { proofPurpose: 'assertionMethod' });
|
|
392
|
+
(vc as any).proof = [vc.proof as any];
|
|
393
|
+
const verifier = new Verifier(dm);
|
|
394
|
+
const res = await verifier.verifyCredential(vc as any);
|
|
395
|
+
// Current verifier takes first element, but our generated array fails canonically under eddsa
|
|
396
|
+
// Ensure the function handles array shape and returns a structured result
|
|
397
|
+
expect(typeof res.verified).toBe('boolean');
|
|
398
|
+
expect(Array.isArray(res.errors)).toBe(true);
|
|
399
|
+
});
|
|
400
|
+
});
|
|
401
|
+
|
|
402
|
+
|
|
403
|
+
|
|
404
|
+
|
|
405
|
+
/** Inlined from Verifier.proofarray.presentation.part.ts */
|
|
406
|
+
|
|
407
|
+
describe('Verifier handles presentation proof array', () => {
|
|
408
|
+
test('verifyPresentation with proof array handled (takes first element)', async () => {
|
|
409
|
+
const dm = new DIDManager({} as any);
|
|
410
|
+
const sk = new Uint8Array(32).fill(7);
|
|
411
|
+
const pk = new Uint8Array(32).fill(8);
|
|
412
|
+
const vm = {
|
|
413
|
+
id: 'did:ex:arr#key-1',
|
|
414
|
+
controller: 'did:ex:arr',
|
|
415
|
+
publicKeyMultibase: multikey.encodePublicKey(pk, 'Ed25519'),
|
|
416
|
+
secretKeyMultibase: multikey.encodePrivateKey(sk, 'Ed25519')
|
|
417
|
+
};
|
|
418
|
+
const issuer = new Issuer(dm, vm);
|
|
419
|
+
const vp = await issuer.issuePresentation({ holder: vm.controller } as any, { proofPurpose: 'authentication' });
|
|
420
|
+
(vp as any).proof = [ (vp as any).proof ];
|
|
421
|
+
const verifier = new Verifier(dm);
|
|
422
|
+
const res = await verifier.verifyPresentation(vp as any);
|
|
423
|
+
expect(typeof res.verified).toBe('boolean');
|
|
424
|
+
});
|
|
425
|
+
});
|
|
426
|
+
|
|
427
|
+
|
|
428
|
+
|
|
429
|
+
|
|
430
|
+
/** Inlined from Verifier.success.part.ts */
|
|
431
|
+
|
|
432
|
+
describe('Verifier success branches', () => {
|
|
433
|
+
const dm = new DIDManager({} as any);
|
|
434
|
+
const verifier = new Verifier(dm);
|
|
435
|
+
|
|
436
|
+
test('verifyCredential returns verified=true when proof manager passes', async () => {
|
|
437
|
+
const vc: any = {
|
|
438
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
439
|
+
type: ['VerifiableCredential'],
|
|
440
|
+
proof: { cryptosuite: 'eddsa-rdfc-2022' }
|
|
441
|
+
};
|
|
442
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
443
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
444
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: true, errors: [] });
|
|
445
|
+
const { Verifier } = await import('../../../src/vc/Verifier');
|
|
446
|
+
const { DIDManager } = await import('../../../src/did/DIDManager');
|
|
447
|
+
const localVerifier = new Verifier(new DIDManager({} as any));
|
|
448
|
+
const res = await localVerifier.verifyCredential(vc, {
|
|
449
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
450
|
+
});
|
|
451
|
+
expect(res.verified).toBe(true);
|
|
452
|
+
expect(res.errors).toEqual([]);
|
|
453
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
454
|
+
});
|
|
455
|
+
|
|
456
|
+
test('verifyPresentation returns verified=true, with and without nested VC', async () => {
|
|
457
|
+
const mod = require('../../../src/vc/proofs/data-integrity');
|
|
458
|
+
const orig = mod.DataIntegrityProofManager.verifyProof;
|
|
459
|
+
mod.DataIntegrityProofManager.verifyProof = async () => ({ verified: true, errors: [] });
|
|
460
|
+
|
|
461
|
+
// without nested VC
|
|
462
|
+
const vp1: any = {
|
|
463
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
464
|
+
type: ['VerifiablePresentation'],
|
|
465
|
+
proof: { cryptosuite: 'eddsa-rdfc-2022' }
|
|
466
|
+
};
|
|
467
|
+
const { Verifier } = await import('../../../src/vc/Verifier');
|
|
468
|
+
const { DIDManager } = await import('../../../src/did/DIDManager');
|
|
469
|
+
const localVerifier = new Verifier(new DIDManager({} as any));
|
|
470
|
+
const res1 = await localVerifier.verifyPresentation(vp1, {
|
|
471
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
472
|
+
});
|
|
473
|
+
expect(res1.verified).toBe(true);
|
|
474
|
+
|
|
475
|
+
// with nested VC
|
|
476
|
+
const vp2: any = {
|
|
477
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
478
|
+
type: ['VerifiablePresentation'],
|
|
479
|
+
verifiableCredential: [
|
|
480
|
+
{ '@context': ['https://www.w3.org/2018/credentials/v1'], type: ['VerifiableCredential'], proof: { cryptosuite: 'eddsa-rdfc-2022' } }
|
|
481
|
+
],
|
|
482
|
+
proof: { cryptosuite: 'eddsa-rdfc-2022' }
|
|
483
|
+
};
|
|
484
|
+
const res2 = await localVerifier.verifyPresentation(vp2, {
|
|
485
|
+
documentLoader: async (iri: string) => ({ document: { '@context': { '@version': 1.1 } }, documentUrl: iri, contextUrl: null })
|
|
486
|
+
});
|
|
487
|
+
expect(res2.verified).toBe(true);
|
|
488
|
+
|
|
489
|
+
mod.DataIntegrityProofManager.verifyProof = orig;
|
|
490
|
+
});
|
|
491
|
+
});
|
|
492
|
+
|
|
493
|
+
|
|
494
|
+
/** Inlined from Verifier.unknown-error-branches.part.ts */
|
|
495
|
+
|
|
496
|
+
describe('Verifier unknown-error fallback branches', () => {
|
|
497
|
+
const dm = new DIDManager({} as any);
|
|
498
|
+
const verifier = new Verifier(dm);
|
|
499
|
+
|
|
500
|
+
test('verifyCredential returns Unknown error when non-Error thrown', async () => {
|
|
501
|
+
const vc: any = {
|
|
502
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
503
|
+
type: ['VerifiableCredential'],
|
|
504
|
+
proof: { cryptosuite: 'data-integrity' }
|
|
505
|
+
};
|
|
506
|
+
const res = await verifier.verifyCredential(vc, {
|
|
507
|
+
documentLoader: async () => { throw 123 as any; }
|
|
508
|
+
});
|
|
509
|
+
expect(res.verified).toBe(false);
|
|
510
|
+
expect(res.errors[0]).toBe('Unknown error in verifyCredential');
|
|
511
|
+
});
|
|
512
|
+
|
|
513
|
+
test('verifyPresentation returns Unknown error when non-Error thrown', async () => {
|
|
514
|
+
const vp: any = {
|
|
515
|
+
'@context': ['https://www.w3.org/2018/credentials/v1'],
|
|
516
|
+
type: ['VerifiablePresentation'],
|
|
517
|
+
proof: { cryptosuite: 'data-integrity' }
|
|
518
|
+
};
|
|
519
|
+
const res = await verifier.verifyPresentation(vp, {
|
|
520
|
+
documentLoader: async () => { throw 456 as any; }
|
|
521
|
+
});
|
|
522
|
+
expect(res.verified).toBe(false);
|
|
523
|
+
expect(res.errors[0]).toBe('Unknown error in verifyPresentation');
|
|
524
|
+
});
|
|
525
|
+
});
|