@originals/sdk 1.4.2 → 1.4.5
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/adapters/FeeOracleMock.d.ts +6 -0
- package/dist/adapters/FeeOracleMock.js +8 -0
- package/{src/adapters/index.ts → dist/adapters/index.d.ts} +0 -1
- 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/{src/bitcoin/fee-calculation.ts → dist/bitcoin/fee-calculation.js} +5 -12
- 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/{src/bitcoin/transactions/index.ts → dist/bitcoin/transactions/index.js} +1 -6
- 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 +312 -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/create-module-original.d.ts +32 -0
- package/dist/examples/create-module-original.js +376 -0
- package/dist/examples/full-lifecycle-flow.d.ts +56 -0
- package/dist/examples/full-lifecycle-flow.js +419 -0
- package/dist/examples/run.d.ts +12 -0
- package/dist/examples/run.js +51 -0
- package/dist/index.d.ts +43 -0
- package/dist/index.js +52 -0
- package/dist/kinds/KindRegistry.d.ts +76 -0
- package/dist/kinds/KindRegistry.js +216 -0
- package/dist/kinds/index.d.ts +33 -0
- package/{src/kinds/index.ts → dist/kinds/index.js} +6 -44
- package/dist/kinds/types.d.ts +363 -0
- package/dist/kinds/types.js +25 -0
- package/dist/kinds/validators/AgentValidator.d.ts +14 -0
- package/dist/kinds/validators/AgentValidator.js +155 -0
- package/dist/kinds/validators/AppValidator.d.ts +14 -0
- package/dist/kinds/validators/AppValidator.js +135 -0
- package/dist/kinds/validators/DatasetValidator.d.ts +14 -0
- package/dist/kinds/validators/DatasetValidator.js +148 -0
- package/dist/kinds/validators/DocumentValidator.d.ts +14 -0
- package/dist/kinds/validators/DocumentValidator.js +180 -0
- package/dist/kinds/validators/MediaValidator.d.ts +14 -0
- package/dist/kinds/validators/MediaValidator.js +172 -0
- package/dist/kinds/validators/ModuleValidator.d.ts +14 -0
- package/dist/kinds/validators/ModuleValidator.js +140 -0
- package/dist/kinds/validators/base.d.ts +96 -0
- package/dist/kinds/validators/base.js +218 -0
- package/{src/kinds/validators/index.ts → dist/kinds/validators/index.d.ts} +0 -2
- package/dist/kinds/validators/index.js +10 -0
- package/dist/lifecycle/BatchOperations.d.ts +147 -0
- package/dist/lifecycle/BatchOperations.js +251 -0
- package/dist/lifecycle/LifecycleManager.d.ts +362 -0
- package/dist/lifecycle/LifecycleManager.js +1692 -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/{src/migration/index.ts → dist/migration/index.js} +0 -6
- 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/resources/ResourceManager.d.ts +231 -0
- package/dist/resources/ResourceManager.js +573 -0
- package/{src/resources/index.ts → dist/resources/index.d.ts} +3 -13
- package/dist/resources/index.js +10 -0
- package/dist/resources/types.d.ts +93 -0
- package/dist/resources/types.js +80 -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/{src/storage/index.ts → dist/storage/index.d.ts} +0 -1
- 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/{src/types/index.ts → dist/types/index.d.ts} +0 -2
- 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 +329 -0
- package/dist/vc/CredentialManager.js +615 -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 +5 -1
- package/.eslintrc.json +0 -33
- package/src/adapters/FeeOracleMock.ts +0 -9
- package/src/adapters/providers/OrdHttpProvider.ts +0 -126
- package/src/adapters/providers/OrdMockProvider.ts +0 -101
- package/src/adapters/types.ts +0 -66
- package/src/bitcoin/BitcoinManager.ts +0 -330
- package/src/bitcoin/BroadcastClient.ts +0 -54
- package/src/bitcoin/OrdinalsClient.ts +0 -119
- package/src/bitcoin/PSBTBuilder.ts +0 -106
- package/src/bitcoin/providers/OrdNodeProvider.ts +0 -92
- package/src/bitcoin/providers/OrdinalsProvider.ts +0 -56
- package/src/bitcoin/providers/types.ts +0 -59
- package/src/bitcoin/transactions/commit.ts +0 -465
- package/src/bitcoin/transfer.ts +0 -43
- package/src/bitcoin/utxo-selection.ts +0 -322
- package/src/bitcoin/utxo.ts +0 -113
- package/src/contexts/credentials-v1.json +0 -237
- package/src/contexts/credentials-v2-examples.json +0 -5
- package/src/contexts/credentials-v2.json +0 -340
- package/src/contexts/credentials.json +0 -237
- package/src/contexts/data-integrity-v2.json +0 -81
- package/src/contexts/dids.json +0 -58
- package/src/contexts/ed255192020.json +0 -93
- package/src/contexts/ordinals-plus.json +0 -23
- package/src/contexts/originals.json +0 -22
- package/src/core/OriginalsSDK.ts +0 -416
- package/src/crypto/Multikey.ts +0 -194
- package/src/crypto/Signer.ts +0 -254
- package/src/crypto/noble-init.ts +0 -121
- package/src/did/BtcoDidResolver.ts +0 -227
- package/src/did/DIDManager.ts +0 -694
- package/src/did/Ed25519Verifier.ts +0 -68
- package/src/did/KeyManager.ts +0 -236
- package/src/did/WebVHManager.ts +0 -498
- package/src/did/createBtcoDidDocument.ts +0 -59
- package/src/did/providers/OrdinalsClientProviderAdapter.ts +0 -68
- package/src/events/EventEmitter.ts +0 -222
- package/src/events/index.ts +0 -19
- package/src/events/types.ts +0 -331
- package/src/examples/basic-usage.ts +0 -78
- package/src/examples/create-module-original.ts +0 -435
- package/src/examples/full-lifecycle-flow.ts +0 -514
- package/src/examples/run.ts +0 -60
- package/src/index.ts +0 -150
- package/src/kinds/KindRegistry.ts +0 -290
- package/src/kinds/types.ts +0 -470
- package/src/kinds/validators/AgentValidator.ts +0 -257
- package/src/kinds/validators/AppValidator.ts +0 -211
- package/src/kinds/validators/DatasetValidator.ts +0 -242
- package/src/kinds/validators/DocumentValidator.ts +0 -311
- package/src/kinds/validators/MediaValidator.ts +0 -269
- package/src/kinds/validators/ModuleValidator.ts +0 -225
- package/src/kinds/validators/base.ts +0 -276
- package/src/lifecycle/BatchOperations.ts +0 -373
- package/src/lifecycle/LifecycleManager.ts +0 -2126
- package/src/lifecycle/OriginalsAsset.ts +0 -524
- package/src/lifecycle/ProvenanceQuery.ts +0 -280
- package/src/lifecycle/ResourceVersioning.ts +0 -163
- package/src/migration/MigrationManager.ts +0 -527
- package/src/migration/audit/AuditLogger.ts +0 -176
- package/src/migration/checkpoint/CheckpointManager.ts +0 -112
- package/src/migration/checkpoint/CheckpointStorage.ts +0 -101
- package/src/migration/operations/BaseMigration.ts +0 -126
- package/src/migration/operations/PeerToBtcoMigration.ts +0 -105
- package/src/migration/operations/PeerToWebvhMigration.ts +0 -62
- package/src/migration/operations/WebvhToBtcoMigration.ts +0 -105
- package/src/migration/rollback/RollbackManager.ts +0 -170
- package/src/migration/state/StateMachine.ts +0 -92
- package/src/migration/state/StateTracker.ts +0 -156
- package/src/migration/types.ts +0 -344
- package/src/migration/validation/BitcoinValidator.ts +0 -107
- package/src/migration/validation/CredentialValidator.ts +0 -62
- package/src/migration/validation/DIDCompatibilityValidator.ts +0 -151
- package/src/migration/validation/LifecycleValidator.ts +0 -64
- package/src/migration/validation/StorageValidator.ts +0 -79
- package/src/migration/validation/ValidationPipeline.ts +0 -213
- package/src/resources/ResourceManager.ts +0 -655
- package/src/resources/types.ts +0 -202
- package/src/storage/LocalStorageAdapter.ts +0 -61
- package/src/storage/MemoryStorageAdapter.ts +0 -29
- package/src/storage/StorageAdapter.ts +0 -25
- package/src/types/bitcoin.ts +0 -98
- package/src/types/common.ts +0 -92
- package/src/types/credentials.ts +0 -88
- package/src/types/did.ts +0 -31
- package/src/types/external-shims.d.ts +0 -53
- package/src/types/network.ts +0 -175
- package/src/utils/EventLogger.ts +0 -298
- package/src/utils/Logger.ts +0 -322
- package/src/utils/MetricsCollector.ts +0 -358
- package/src/utils/bitcoin-address.ts +0 -130
- package/src/utils/cbor.ts +0 -12
- package/src/utils/encoding.ts +0 -127
- package/src/utils/hash.ts +0 -6
- package/src/utils/retry.ts +0 -46
- package/src/utils/satoshi-validation.ts +0 -196
- package/src/utils/serialization.ts +0 -96
- package/src/utils/telemetry.ts +0 -40
- package/src/utils/validation.ts +0 -119
- package/src/vc/CredentialManager.ts +0 -918
- package/src/vc/Issuer.ts +0 -100
- package/src/vc/Verifier.ts +0 -47
- package/src/vc/cryptosuites/bbs.ts +0 -253
- package/src/vc/cryptosuites/bbsSimple.ts +0 -21
- package/src/vc/cryptosuites/eddsa.ts +0 -99
- package/src/vc/documentLoader.ts +0 -67
- package/src/vc/proofs/data-integrity.ts +0 -33
- package/src/vc/utils/jsonld.ts +0 -18
- package/tests/__mocks__/bbs-signatures.js +0 -17
- package/tests/__mocks__/mf-base58.js +0 -24
- package/tests/fixtures/did-documents.ts +0 -247
- package/tests/index.test.ts +0 -21
- package/tests/integration/BatchOperations.test.ts +0 -531
- package/tests/integration/CompleteLifecycle.e2e.test.ts +0 -735
- package/tests/integration/CredentialManager.test.ts +0 -42
- package/tests/integration/DIDManager.test.ts +0 -41
- package/tests/integration/DidPeerToWebVhFlow.test.ts +0 -351
- package/tests/integration/Events.test.ts +0 -435
- package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +0 -25
- package/tests/integration/LifecycleManager.test.ts +0 -21
- package/tests/integration/MultikeyFlow.test.ts +0 -52
- package/tests/integration/TelemetryIntegration.test.ts +0 -395
- package/tests/integration/WebVhPublish.test.ts +0 -48
- package/tests/integration/createTypedOriginal.test.ts +0 -379
- package/tests/integration/migration/peer-to-webvh.test.ts +0 -172
- package/tests/manual/test-commit-creation.ts +0 -323
- package/tests/mocks/MockKeyStore.ts +0 -38
- package/tests/mocks/adapters/MemoryStorageAdapter.ts +0 -24
- package/tests/mocks/adapters/MockFeeOracle.ts +0 -11
- package/tests/mocks/adapters/MockOrdinalsProvider.ts +0 -76
- package/tests/mocks/adapters/OrdMockProvider.test.ts +0 -176
- package/tests/mocks/adapters/index.ts +0 -6
- package/tests/performance/BatchOperations.perf.test.ts +0 -403
- package/tests/performance/logging.perf.test.ts +0 -336
- package/tests/sdk.test.ts +0 -43
- package/tests/security/bitcoin-penetration-tests.test.ts +0 -622
- package/tests/setup.bun.ts +0 -69
- package/tests/setup.jest.ts +0 -23
- package/tests/stress/batch-operations-stress.test.ts +0 -571
- package/tests/unit/adapters/FeeOracleMock.test.ts +0 -40
- package/tests/unit/bitcoin/BitcoinManager.test.ts +0 -293
- package/tests/unit/bitcoin/BroadcastClient.test.ts +0 -52
- package/tests/unit/bitcoin/OrdNodeProvider.test.ts +0 -53
- package/tests/unit/bitcoin/OrdinalsClient.test.ts +0 -381
- package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +0 -102
- package/tests/unit/bitcoin/PSBTBuilder.test.ts +0 -84
- package/tests/unit/bitcoin/fee-calculation.test.ts +0 -261
- package/tests/unit/bitcoin/transactions/commit.test.ts +0 -649
- package/tests/unit/bitcoin/transfer.test.ts +0 -31
- package/tests/unit/bitcoin/utxo-selection-new.test.ts +0 -502
- package/tests/unit/bitcoin/utxo.more.test.ts +0 -39
- package/tests/unit/bitcoin/utxo.selection.test.ts +0 -38
- package/tests/unit/core/OriginalsSDK.test.ts +0 -152
- package/tests/unit/crypto/Multikey.test.ts +0 -206
- package/tests/unit/crypto/Signer.test.ts +0 -408
- package/tests/unit/did/BtcoDidResolver.test.ts +0 -611
- package/tests/unit/did/DIDManager.more.test.ts +0 -43
- package/tests/unit/did/DIDManager.test.ts +0 -185
- package/tests/unit/did/Ed25519Verifier.test.ts +0 -160
- package/tests/unit/did/KeyManager.test.ts +0 -452
- package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +0 -45
- package/tests/unit/did/WebVHManager.test.ts +0 -435
- package/tests/unit/did/createBtcoDidDocument.test.ts +0 -67
- package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +0 -159
- package/tests/unit/events/EventEmitter.test.ts +0 -407
- package/tests/unit/kinds/KindRegistry.test.ts +0 -329
- package/tests/unit/kinds/types.test.ts +0 -409
- package/tests/unit/kinds/validators.test.ts +0 -651
- package/tests/unit/lifecycle/BatchOperations.test.ts +0 -527
- package/tests/unit/lifecycle/LifecycleManager.cleanapi.test.ts +0 -441
- package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +0 -312
- package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +0 -18
- package/tests/unit/lifecycle/LifecycleManager.test.ts +0 -213
- package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +0 -30
- package/tests/unit/lifecycle/OriginalsAsset.test.ts +0 -176
- package/tests/unit/lifecycle/ProvenanceQuery.test.ts +0 -577
- package/tests/unit/lifecycle/ResourceVersioning.test.ts +0 -651
- package/tests/unit/resources/ResourceManager.test.ts +0 -740
- package/tests/unit/storage/MemoryStorageAdapter.test.ts +0 -93
- package/tests/unit/types/network.test.ts +0 -255
- package/tests/unit/utils/EventIntegration.test.ts +0 -384
- package/tests/unit/utils/Logger.test.ts +0 -473
- package/tests/unit/utils/MetricsCollector.test.ts +0 -358
- package/tests/unit/utils/bitcoin-address.test.ts +0 -250
- package/tests/unit/utils/cbor.test.ts +0 -35
- package/tests/unit/utils/encoding.test.ts +0 -318
- package/tests/unit/utils/hash.test.ts +0 -12
- package/tests/unit/utils/retry.test.ts +0 -100
- package/tests/unit/utils/satoshi-validation.test.ts +0 -354
- package/tests/unit/utils/serialization.test.ts +0 -124
- package/tests/unit/utils/telemetry.test.ts +0 -52
- package/tests/unit/utils/validation.test.ts +0 -141
- package/tests/unit/vc/CredentialManager.helpers.test.ts +0 -527
- package/tests/unit/vc/CredentialManager.test.ts +0 -487
- package/tests/unit/vc/Issuer.test.ts +0 -107
- package/tests/unit/vc/Verifier.test.ts +0 -525
- package/tests/unit/vc/bbs.test.ts +0 -282
- package/tests/unit/vc/cryptosuites/eddsa.test.ts +0 -398
- package/tests/unit/vc/documentLoader.test.ts +0 -121
- package/tests/unit/vc/proofs/data-integrity.test.ts +0 -24
- package/tsconfig.json +0 -31
- package/tsconfig.test.json +0 -15
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export class StructuredError extends Error {
|
|
2
|
+
constructor(code, message, details) {
|
|
3
|
+
super(message);
|
|
4
|
+
this.name = 'StructuredError';
|
|
5
|
+
this.code = code;
|
|
6
|
+
this.details = details;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
export function emitTelemetry(hooks, event) {
|
|
10
|
+
if (hooks && typeof hooks.onEvent === 'function') {
|
|
11
|
+
try {
|
|
12
|
+
hooks.onEvent({ level: 'info', ...event });
|
|
13
|
+
}
|
|
14
|
+
catch (_) { }
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
export function emitError(hooks, error) {
|
|
18
|
+
if (hooks && typeof hooks.onError === 'function') {
|
|
19
|
+
try {
|
|
20
|
+
hooks.onError(error);
|
|
21
|
+
}
|
|
22
|
+
catch (_) { }
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { DIDDocument, VerifiableCredential } from '../types';
|
|
2
|
+
export declare function validateDID(did: string): boolean;
|
|
3
|
+
export declare function validateCredential(vc: VerifiableCredential): boolean;
|
|
4
|
+
export declare function validateDIDDocument(didDoc: DIDDocument): boolean;
|
|
5
|
+
export declare function hashResource(content: Uint8Array): string;
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { sha256 } from '@noble/hashes/sha2.js';
|
|
2
|
+
import { bytesToHex } from '@noble/hashes/utils.js';
|
|
3
|
+
export function validateDID(did) {
|
|
4
|
+
// Validate DID format according to W3C DID spec
|
|
5
|
+
const didRegex = /^did:([a-z0-9]+):(.*)/;
|
|
6
|
+
if (!didRegex.test(did)) {
|
|
7
|
+
return false;
|
|
8
|
+
}
|
|
9
|
+
const match = did.match(didRegex);
|
|
10
|
+
if (!match) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
const method = match[1];
|
|
14
|
+
// Validate supported methods
|
|
15
|
+
const supportedMethods = ['peer', 'webvh', 'btco'];
|
|
16
|
+
if (!supportedMethods.includes(method)) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
return true;
|
|
20
|
+
}
|
|
21
|
+
export function validateCredential(vc) {
|
|
22
|
+
// Validate VC structure according to W3C VC spec
|
|
23
|
+
if (!vc['@context'] || !Array.isArray(vc['@context'])) {
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
// Require VC v1 context presence
|
|
27
|
+
const contextValues = vc['@context'];
|
|
28
|
+
const hasVcV1 = contextValues.includes('https://www.w3.org/2018/credentials/v1');
|
|
29
|
+
if (!hasVcV1) {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
if (!vc.type || !Array.isArray(vc.type)) {
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
if (!vc.type.includes('VerifiableCredential')) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
if (!vc.issuer || (!vc.issuanceDate)) {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
// issuer must be a DID string or an object with DID id
|
|
42
|
+
const issuerIsValidDid = (iss) => {
|
|
43
|
+
if (typeof iss === 'string')
|
|
44
|
+
return validateDID(iss);
|
|
45
|
+
if (iss && typeof iss.id === 'string')
|
|
46
|
+
return validateDID(iss.id);
|
|
47
|
+
return false;
|
|
48
|
+
};
|
|
49
|
+
if (!issuerIsValidDid(vc.issuer)) {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
// issuanceDate should be a valid ISO timestamp
|
|
53
|
+
if (typeof vc.issuanceDate !== 'string' || Number.isNaN(Date.parse(vc.issuanceDate))) {
|
|
54
|
+
return false;
|
|
55
|
+
}
|
|
56
|
+
if (!vc.credentialSubject) {
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
export function validateDIDDocument(didDoc) {
|
|
62
|
+
// Validate DID Document structure
|
|
63
|
+
if (!didDoc['@context'] || !Array.isArray(didDoc['@context'])) {
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
if (!didDoc.id || !validateDID(didDoc.id)) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
// Validate verification methods
|
|
70
|
+
if (didDoc.verificationMethod) {
|
|
71
|
+
for (const vm of didDoc.verificationMethod) {
|
|
72
|
+
if (!vm.id || !vm.type || !vm.controller || !vm.publicKeyMultibase) {
|
|
73
|
+
return false;
|
|
74
|
+
}
|
|
75
|
+
// controller should be a valid DID
|
|
76
|
+
if (typeof vm.controller !== 'string' || !validateDID(vm.controller)) {
|
|
77
|
+
return false;
|
|
78
|
+
}
|
|
79
|
+
// multibase key presence: require base58-btc multibase indicator 'z'
|
|
80
|
+
if (typeof vm.publicKeyMultibase !== 'string' || !vm.publicKeyMultibase.startsWith('z')) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
// If controller array present on the DID Document, validate entries are DIDs
|
|
86
|
+
if (Array.isArray(didDoc.controller)) {
|
|
87
|
+
const ctrls = didDoc.controller;
|
|
88
|
+
if (!ctrls.every((c) => typeof c === 'string' && validateDID(c))) {
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return true;
|
|
93
|
+
}
|
|
94
|
+
export function hashResource(content) {
|
|
95
|
+
// Generate SHA-256 hash
|
|
96
|
+
const hash = sha256(content);
|
|
97
|
+
return bytesToHex(hash);
|
|
98
|
+
}
|
|
@@ -0,0 +1,329 @@
|
|
|
1
|
+
import { VerifiableCredential, VerifiablePresentation, CredentialSubject, OriginalsConfig, ExternalSigner, LayerType, AssetResource } from '../types';
|
|
2
|
+
import { DIDManager } from '../did/DIDManager';
|
|
3
|
+
/**
|
|
4
|
+
* Subject data for a ResourceCreated credential
|
|
5
|
+
*/
|
|
6
|
+
export interface ResourceCreatedSubject {
|
|
7
|
+
/** ID of the subject (typically the resource DID or asset DID) */
|
|
8
|
+
id: string;
|
|
9
|
+
/** Resource identifier */
|
|
10
|
+
resourceId: string;
|
|
11
|
+
/** Resource type (e.g., 'code', 'text', 'image') */
|
|
12
|
+
resourceType: string;
|
|
13
|
+
/** Content hash of the resource */
|
|
14
|
+
contentHash: string;
|
|
15
|
+
/** MIME content type */
|
|
16
|
+
contentType: string;
|
|
17
|
+
/** Creator DID */
|
|
18
|
+
creator: string;
|
|
19
|
+
/** Creation timestamp */
|
|
20
|
+
createdAt: string;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Subject data for a ResourceUpdated credential
|
|
24
|
+
*/
|
|
25
|
+
export interface ResourceUpdatedSubject {
|
|
26
|
+
/** ID of the subject (typically the asset DID) */
|
|
27
|
+
id: string;
|
|
28
|
+
/** Resource identifier */
|
|
29
|
+
resourceId: string;
|
|
30
|
+
/** Previous content hash */
|
|
31
|
+
previousHash: string;
|
|
32
|
+
/** New content hash */
|
|
33
|
+
newHash: string;
|
|
34
|
+
/** Previous version number */
|
|
35
|
+
fromVersion: number;
|
|
36
|
+
/** New version number */
|
|
37
|
+
toVersion: number;
|
|
38
|
+
/** Update timestamp */
|
|
39
|
+
updatedAt: string;
|
|
40
|
+
/** Optional description of changes */
|
|
41
|
+
updateReason?: string;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Subject data for a MigrationCompleted credential
|
|
45
|
+
*/
|
|
46
|
+
export interface MigrationSubject {
|
|
47
|
+
/** ID of the subject (typically the asset DID) */
|
|
48
|
+
id: string;
|
|
49
|
+
/** Source DID (before migration) */
|
|
50
|
+
sourceDid: string;
|
|
51
|
+
/** Target DID (after migration) */
|
|
52
|
+
targetDid?: string;
|
|
53
|
+
/** Layer migrated from */
|
|
54
|
+
fromLayer: LayerType;
|
|
55
|
+
/** Layer migrated to */
|
|
56
|
+
toLayer: LayerType;
|
|
57
|
+
/** Migration timestamp */
|
|
58
|
+
migratedAt: string;
|
|
59
|
+
/** Transaction ID (for Bitcoin migrations) */
|
|
60
|
+
transactionId?: string;
|
|
61
|
+
/** Inscription ID (for Bitcoin migrations) */
|
|
62
|
+
inscriptionId?: string;
|
|
63
|
+
/** Satoshi number (for Bitcoin migrations) */
|
|
64
|
+
satoshi?: string;
|
|
65
|
+
/** Optional reason for migration */
|
|
66
|
+
migrationReason?: string;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Subject data for an OwnershipTransferred credential
|
|
70
|
+
*/
|
|
71
|
+
export interface OwnershipSubject {
|
|
72
|
+
/** ID of the subject (typically the asset DID) */
|
|
73
|
+
id: string;
|
|
74
|
+
/** Previous owner DID or address */
|
|
75
|
+
previousOwner: string;
|
|
76
|
+
/** New owner DID or address */
|
|
77
|
+
newOwner: string;
|
|
78
|
+
/** Transfer timestamp */
|
|
79
|
+
transferredAt: string;
|
|
80
|
+
/** Transaction ID for the transfer */
|
|
81
|
+
transactionId: string;
|
|
82
|
+
/** Satoshi number of the inscription */
|
|
83
|
+
satoshi?: string;
|
|
84
|
+
/** Optional transfer reason or notes */
|
|
85
|
+
transferReason?: string;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Options for creating credentials with chaining
|
|
89
|
+
*/
|
|
90
|
+
export interface CredentialChainOptions {
|
|
91
|
+
/** Previous credential ID to chain from */
|
|
92
|
+
previousCredentialId?: string;
|
|
93
|
+
/** Hash of the previous credential for verification */
|
|
94
|
+
previousCredentialHash?: string;
|
|
95
|
+
/** Optional expiration date */
|
|
96
|
+
expirationDate?: string;
|
|
97
|
+
/** Optional credential status information */
|
|
98
|
+
credentialStatus?: {
|
|
99
|
+
id: string;
|
|
100
|
+
type: string;
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Options for BBS+ selective disclosure
|
|
105
|
+
*/
|
|
106
|
+
export interface SelectiveDisclosureOptions {
|
|
107
|
+
/** JSON Pointer paths to fields that must always be disclosed */
|
|
108
|
+
mandatoryPointers: string[];
|
|
109
|
+
/** JSON Pointer paths to fields the holder can selectively disclose */
|
|
110
|
+
selectivePointers?: string[];
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Result of creating a derived proof with selective disclosure
|
|
114
|
+
*/
|
|
115
|
+
export interface DerivedProofResult {
|
|
116
|
+
/** The credential with derived proof */
|
|
117
|
+
credential: VerifiableCredential;
|
|
118
|
+
/** Fields that were disclosed */
|
|
119
|
+
disclosedFields: string[];
|
|
120
|
+
/** Fields that were hidden */
|
|
121
|
+
hiddenFields: string[];
|
|
122
|
+
}
|
|
123
|
+
export declare class CredentialManager {
|
|
124
|
+
private config;
|
|
125
|
+
private didManager?;
|
|
126
|
+
constructor(config: OriginalsConfig, didManager?: DIDManager | undefined);
|
|
127
|
+
createResourceCredential(type: 'ResourceCreated' | 'ResourceUpdated' | 'ResourceMigrated', subject: CredentialSubject, issuer: string): Promise<VerifiableCredential>;
|
|
128
|
+
signCredential(credential: VerifiableCredential, privateKeyMultibase: string, verificationMethod: string): Promise<VerifiableCredential>;
|
|
129
|
+
/**
|
|
130
|
+
* Sign a credential using an external signer (e.g., hardware wallet, Turnkey)
|
|
131
|
+
* @param credential - The unsigned credential
|
|
132
|
+
* @param signer - External signer implementation
|
|
133
|
+
* @returns Signed verifiable credential
|
|
134
|
+
*/
|
|
135
|
+
signCredentialWithExternalSigner(credential: VerifiableCredential, signer: ExternalSigner): Promise<VerifiableCredential>;
|
|
136
|
+
verifyCredential(credential: VerifiableCredential): Promise<boolean>;
|
|
137
|
+
createPresentation(credentials: VerifiableCredential[], holder: string): Promise<VerifiablePresentation>;
|
|
138
|
+
private generateProofValue;
|
|
139
|
+
private getSigner;
|
|
140
|
+
private resolveVerificationMethodMultibase;
|
|
141
|
+
private decodeMultibase;
|
|
142
|
+
/**
|
|
143
|
+
* Issue a ResourceCreated credential for a newly created resource
|
|
144
|
+
*
|
|
145
|
+
* @param resource - The created resource
|
|
146
|
+
* @param assetDid - The DID of the asset containing the resource
|
|
147
|
+
* @param creatorDid - The DID of the creator
|
|
148
|
+
* @param chainOptions - Optional chaining options for linking to previous credentials
|
|
149
|
+
* @returns Unsigned verifiable credential
|
|
150
|
+
*
|
|
151
|
+
* @example
|
|
152
|
+
* ```typescript
|
|
153
|
+
* const credential = await credentialManager.issueResourceCredential(
|
|
154
|
+
* resource,
|
|
155
|
+
* 'did:peer:abc...',
|
|
156
|
+
* 'did:peer:creator...'
|
|
157
|
+
* );
|
|
158
|
+
* // Sign the credential with your key
|
|
159
|
+
* const signed = await credentialManager.signCredential(credential, privateKey, vmId);
|
|
160
|
+
* ```
|
|
161
|
+
*/
|
|
162
|
+
issueResourceCredential(resource: AssetResource, assetDid: string, creatorDid: string, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
|
|
163
|
+
/**
|
|
164
|
+
* Issue a ResourceUpdated credential for a resource version update
|
|
165
|
+
*
|
|
166
|
+
* @param resourceId - The logical resource ID
|
|
167
|
+
* @param assetDid - The DID of the asset
|
|
168
|
+
* @param previousHash - Hash of the previous version
|
|
169
|
+
* @param newHash - Hash of the new version
|
|
170
|
+
* @param fromVersion - Previous version number
|
|
171
|
+
* @param toVersion - New version number
|
|
172
|
+
* @param updaterDid - DID of the entity performing the update
|
|
173
|
+
* @param updateReason - Optional reason for the update
|
|
174
|
+
* @param chainOptions - Optional chaining options
|
|
175
|
+
* @returns Unsigned verifiable credential
|
|
176
|
+
*
|
|
177
|
+
* @example
|
|
178
|
+
* ```typescript
|
|
179
|
+
* const credential = await credentialManager.issueResourceUpdateCredential(
|
|
180
|
+
* 'main.js',
|
|
181
|
+
* 'did:webvh:example.com:asset',
|
|
182
|
+
* 'abc123...',
|
|
183
|
+
* 'def456...',
|
|
184
|
+
* 1,
|
|
185
|
+
* 2,
|
|
186
|
+
* 'did:webvh:example.com:user',
|
|
187
|
+
* 'Bug fix'
|
|
188
|
+
* );
|
|
189
|
+
* ```
|
|
190
|
+
*/
|
|
191
|
+
issueResourceUpdateCredential(resourceId: string, assetDid: string, previousHash: string, newHash: string, fromVersion: number, toVersion: number, updaterDid: string, updateReason?: string, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
|
|
192
|
+
/**
|
|
193
|
+
* Issue a MigrationCompleted credential for layer migrations
|
|
194
|
+
*
|
|
195
|
+
* Records the migration of an asset between Originals layers (peer -> webvh -> btco).
|
|
196
|
+
*
|
|
197
|
+
* @param sourceDid - The source DID (before migration)
|
|
198
|
+
* @param targetDid - The target DID (after migration, if different)
|
|
199
|
+
* @param fromLayer - The source layer
|
|
200
|
+
* @param toLayer - The target layer
|
|
201
|
+
* @param issuerDid - The DID issuing this credential
|
|
202
|
+
* @param details - Optional migration details (transactionId, inscriptionId, satoshi)
|
|
203
|
+
* @param chainOptions - Optional chaining options
|
|
204
|
+
* @returns Unsigned verifiable credential
|
|
205
|
+
*
|
|
206
|
+
* @example
|
|
207
|
+
* ```typescript
|
|
208
|
+
* const credential = await credentialManager.issueMigrationCredential(
|
|
209
|
+
* 'did:peer:abc...',
|
|
210
|
+
* 'did:webvh:example.com:asset',
|
|
211
|
+
* 'did:peer',
|
|
212
|
+
* 'did:webvh',
|
|
213
|
+
* 'did:webvh:example.com:publisher'
|
|
214
|
+
* );
|
|
215
|
+
* ```
|
|
216
|
+
*/
|
|
217
|
+
issueMigrationCredential(sourceDid: string, targetDid: string | undefined, fromLayer: LayerType, toLayer: LayerType, issuerDid: string, details?: {
|
|
218
|
+
transactionId?: string;
|
|
219
|
+
inscriptionId?: string;
|
|
220
|
+
satoshi?: string;
|
|
221
|
+
migrationReason?: string;
|
|
222
|
+
}, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
|
|
223
|
+
/**
|
|
224
|
+
* Issue an OwnershipTransferred credential for Bitcoin-anchored asset transfers
|
|
225
|
+
*
|
|
226
|
+
* Records the transfer of ownership of a did:btco asset to a new owner.
|
|
227
|
+
*
|
|
228
|
+
* @param assetDid - The DID of the asset being transferred
|
|
229
|
+
* @param previousOwner - The previous owner (DID or Bitcoin address)
|
|
230
|
+
* @param newOwner - The new owner (Bitcoin address)
|
|
231
|
+
* @param transactionId - The Bitcoin transaction ID
|
|
232
|
+
* @param issuerDid - The DID issuing this credential
|
|
233
|
+
* @param details - Optional additional details
|
|
234
|
+
* @param chainOptions - Optional chaining options
|
|
235
|
+
* @returns Unsigned verifiable credential
|
|
236
|
+
*
|
|
237
|
+
* @example
|
|
238
|
+
* ```typescript
|
|
239
|
+
* const credential = await credentialManager.issueOwnershipCredential(
|
|
240
|
+
* 'did:btco:12345',
|
|
241
|
+
* 'bc1q...oldowner',
|
|
242
|
+
* 'bc1q...newowner',
|
|
243
|
+
* 'abc123...txid',
|
|
244
|
+
* 'did:btco:12345'
|
|
245
|
+
* );
|
|
246
|
+
* ```
|
|
247
|
+
*/
|
|
248
|
+
issueOwnershipCredential(assetDid: string, previousOwner: string, newOwner: string, transactionId: string, issuerDid: string, details?: {
|
|
249
|
+
satoshi?: string;
|
|
250
|
+
transferReason?: string;
|
|
251
|
+
}, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
|
|
252
|
+
/**
|
|
253
|
+
* Create a credential with optional chaining to a previous credential
|
|
254
|
+
*
|
|
255
|
+
* Credential chaining creates a verifiable provenance chain by linking
|
|
256
|
+
* credentials together through their IDs and hashes.
|
|
257
|
+
*
|
|
258
|
+
* @param type - The credential type
|
|
259
|
+
* @param subject - The credential subject
|
|
260
|
+
* @param issuer - The issuer DID
|
|
261
|
+
* @param chainOptions - Optional chaining options
|
|
262
|
+
* @returns Unsigned verifiable credential with chain metadata
|
|
263
|
+
*/
|
|
264
|
+
private createCredentialWithChain;
|
|
265
|
+
/**
|
|
266
|
+
* Generate a unique credential ID
|
|
267
|
+
*/
|
|
268
|
+
private generateCredentialId;
|
|
269
|
+
/**
|
|
270
|
+
* Compute the hash of a credential for chaining purposes
|
|
271
|
+
*
|
|
272
|
+
* @param credential - The credential to hash
|
|
273
|
+
* @returns SHA-256 hash of the canonicalized credential
|
|
274
|
+
*/
|
|
275
|
+
computeCredentialHash(credential: VerifiableCredential): Promise<string>;
|
|
276
|
+
/**
|
|
277
|
+
* Verify a credential chain by checking all previous credential links
|
|
278
|
+
*
|
|
279
|
+
* @param credentials - Array of credentials in chain order (oldest first)
|
|
280
|
+
* @returns Verification result with chain integrity status
|
|
281
|
+
*/
|
|
282
|
+
verifyCredentialChain(credentials: VerifiableCredential[]): Promise<{
|
|
283
|
+
valid: boolean;
|
|
284
|
+
errors: string[];
|
|
285
|
+
chainLength: number;
|
|
286
|
+
}>;
|
|
287
|
+
/**
|
|
288
|
+
* Prepare a credential for BBS+ selective disclosure
|
|
289
|
+
*
|
|
290
|
+
* This creates a base proof that can later be derived into a proof
|
|
291
|
+
* that selectively discloses only certain fields.
|
|
292
|
+
*
|
|
293
|
+
* Note: This requires BBS+ keys and is primarily used for privacy-preserving
|
|
294
|
+
* credential presentations.
|
|
295
|
+
*
|
|
296
|
+
* @param credential - The credential to prepare
|
|
297
|
+
* @param options - Selective disclosure options
|
|
298
|
+
* @returns The credential with BBS+ base proof metadata
|
|
299
|
+
*/
|
|
300
|
+
prepareSelectiveDisclosure(credential: VerifiableCredential, options: SelectiveDisclosureOptions): Promise<{
|
|
301
|
+
credential: VerifiableCredential;
|
|
302
|
+
mandatoryPointers: string[];
|
|
303
|
+
selectivePointers: string[];
|
|
304
|
+
}>;
|
|
305
|
+
/**
|
|
306
|
+
* Create a derived proof with selective disclosure
|
|
307
|
+
*
|
|
308
|
+
* Given a credential with a BBS+ base proof, creates a derived proof
|
|
309
|
+
* that only reveals the specified fields.
|
|
310
|
+
*
|
|
311
|
+
* @param credential - The credential with BBS+ base proof
|
|
312
|
+
* @param fieldsToDisclose - JSON Pointer paths to disclose
|
|
313
|
+
* @param presentationHeader - Optional presentation-specific data
|
|
314
|
+
* @returns The credential with derived proof
|
|
315
|
+
*/
|
|
316
|
+
deriveSelectiveProof(credential: VerifiableCredential, fieldsToDisclose: string[], presentationHeader?: Uint8Array): Promise<DerivedProofResult>;
|
|
317
|
+
/**
|
|
318
|
+
* Extract all field paths from a credential as JSON Pointers
|
|
319
|
+
*/
|
|
320
|
+
private extractFieldPaths;
|
|
321
|
+
/**
|
|
322
|
+
* Get field value from credential using JSON Pointer
|
|
323
|
+
*
|
|
324
|
+
* @param credential - The credential to read from
|
|
325
|
+
* @param pointer - JSON Pointer path (e.g., /credentialSubject/name)
|
|
326
|
+
* @returns The value at the pointer path, or undefined if not found
|
|
327
|
+
*/
|
|
328
|
+
getFieldByPointer(credential: VerifiableCredential, pointer: string): any;
|
|
329
|
+
}
|