@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,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Maximum number of satoshis in Bitcoin's total supply (21 million BTC)
|
|
3
|
+
* 21,000,000 BTC * 100,000,000 satoshis/BTC = 2,100,000,000,000,000 satoshis
|
|
4
|
+
*/
|
|
5
|
+
export declare const MAX_SATOSHI_SUPPLY = 2100000000000000;
|
|
6
|
+
/**
|
|
7
|
+
* Validation result interface for satoshi number validation
|
|
8
|
+
*/
|
|
9
|
+
export interface SatoshiValidationResult {
|
|
10
|
+
valid: boolean;
|
|
11
|
+
error?: string;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Validates a satoshi number for use in Bitcoin ordinals and did:btco DIDs.
|
|
15
|
+
*
|
|
16
|
+
* @param satoshi - The satoshi identifier to validate (string or number)
|
|
17
|
+
* @returns Validation result with descriptive error if invalid
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```typescript
|
|
21
|
+
* const result = validateSatoshiNumber('123456');
|
|
22
|
+
* if (!result.valid) {
|
|
23
|
+
* throw new Error(result.error);
|
|
24
|
+
* }
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare function validateSatoshiNumber(satoshi: string | number): SatoshiValidationResult;
|
|
28
|
+
/**
|
|
29
|
+
* Parses a satoshi identifier from various formats and validates it.
|
|
30
|
+
*
|
|
31
|
+
* Supported formats:
|
|
32
|
+
* - Plain satoshi number: "123456"
|
|
33
|
+
* - did:btco DID: "did:btco:123456", "did:btco:test:123456", "did:btco:sig:123456"
|
|
34
|
+
* - Ordinal notation: "123456" (same as plain number, for future extensions)
|
|
35
|
+
*
|
|
36
|
+
* @param identifier - The identifier to parse
|
|
37
|
+
* @returns The extracted satoshi number
|
|
38
|
+
* @throws {StructuredError} If the identifier format is invalid or satoshi is invalid
|
|
39
|
+
*
|
|
40
|
+
* @example
|
|
41
|
+
* ```typescript
|
|
42
|
+
* const satoshi = parseSatoshiIdentifier('did:btco:123456');
|
|
43
|
+
* console.log(satoshi); // 123456
|
|
44
|
+
* ```
|
|
45
|
+
*/
|
|
46
|
+
export declare function parseSatoshiIdentifier(identifier: string): number;
|
|
47
|
+
/**
|
|
48
|
+
* Validates a satoshi number and throws an error if invalid.
|
|
49
|
+
* Convenience wrapper around validateSatoshiNumber for code that expects exceptions.
|
|
50
|
+
*
|
|
51
|
+
* @param satoshi - The satoshi identifier to validate
|
|
52
|
+
* @throws {StructuredError} If the satoshi is invalid
|
|
53
|
+
*
|
|
54
|
+
* @example
|
|
55
|
+
* ```typescript
|
|
56
|
+
* assertValidSatoshi('123456'); // OK
|
|
57
|
+
* assertValidSatoshi(''); // throws StructuredError
|
|
58
|
+
* ```
|
|
59
|
+
*/
|
|
60
|
+
export declare function assertValidSatoshi(satoshi: string | number): void;
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { StructuredError } from './telemetry';
|
|
2
|
+
/**
|
|
3
|
+
* Maximum number of satoshis in Bitcoin's total supply (21 million BTC)
|
|
4
|
+
* 21,000,000 BTC * 100,000,000 satoshis/BTC = 2,100,000,000,000,000 satoshis
|
|
5
|
+
*/
|
|
6
|
+
export const MAX_SATOSHI_SUPPLY = 2100000000000000;
|
|
7
|
+
/**
|
|
8
|
+
* Validates a satoshi number for use in Bitcoin ordinals and did:btco DIDs.
|
|
9
|
+
*
|
|
10
|
+
* @param satoshi - The satoshi identifier to validate (string or number)
|
|
11
|
+
* @returns Validation result with descriptive error if invalid
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```typescript
|
|
15
|
+
* const result = validateSatoshiNumber('123456');
|
|
16
|
+
* if (!result.valid) {
|
|
17
|
+
* throw new Error(result.error);
|
|
18
|
+
* }
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
export function validateSatoshiNumber(satoshi) {
|
|
22
|
+
// Check for null, undefined, or empty string
|
|
23
|
+
if (satoshi === null || satoshi === undefined || satoshi === '') {
|
|
24
|
+
return {
|
|
25
|
+
valid: false,
|
|
26
|
+
error: 'Satoshi identifier cannot be null, undefined, or empty string'
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
// Convert to string for validation
|
|
30
|
+
const satoshiStr = String(satoshi).trim();
|
|
31
|
+
// Check for empty string after trimming
|
|
32
|
+
if (satoshiStr === '') {
|
|
33
|
+
return {
|
|
34
|
+
valid: false,
|
|
35
|
+
error: 'Satoshi identifier cannot be empty or whitespace-only string'
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
// Check for numeric format (must be all digits, no decimals, no scientific notation)
|
|
39
|
+
if (!/^[0-9]+$/.test(satoshiStr)) {
|
|
40
|
+
return {
|
|
41
|
+
valid: false,
|
|
42
|
+
error: 'Satoshi identifier must be a non-negative integer (no decimals, no scientific notation, no non-numeric characters)'
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
// Convert to number for range validation
|
|
46
|
+
const satoshiNum = Number(satoshiStr);
|
|
47
|
+
// Check for valid number conversion
|
|
48
|
+
if (!Number.isFinite(satoshiNum)) {
|
|
49
|
+
return {
|
|
50
|
+
valid: false,
|
|
51
|
+
error: 'Satoshi identifier must be a finite number'
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
// Check for decimals (would be truncated by Number())
|
|
55
|
+
if (satoshiNum !== Math.floor(satoshiNum)) {
|
|
56
|
+
return {
|
|
57
|
+
valid: false,
|
|
58
|
+
error: 'Satoshi identifier cannot contain decimal places'
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
// Check for negative numbers
|
|
62
|
+
if (satoshiNum < 0) {
|
|
63
|
+
return {
|
|
64
|
+
valid: false,
|
|
65
|
+
error: 'Satoshi identifier must be non-negative (>= 0)'
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
// Check for maximum supply range
|
|
69
|
+
if (satoshiNum > MAX_SATOSHI_SUPPLY) {
|
|
70
|
+
return {
|
|
71
|
+
valid: false,
|
|
72
|
+
error: `Satoshi identifier must be within Bitcoin's total supply (0 to ${MAX_SATOSHI_SUPPLY.toLocaleString()})`
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
return { valid: true };
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Parses a satoshi identifier from various formats and validates it.
|
|
79
|
+
*
|
|
80
|
+
* Supported formats:
|
|
81
|
+
* - Plain satoshi number: "123456"
|
|
82
|
+
* - did:btco DID: "did:btco:123456", "did:btco:test:123456", "did:btco:sig:123456"
|
|
83
|
+
* - Ordinal notation: "123456" (same as plain number, for future extensions)
|
|
84
|
+
*
|
|
85
|
+
* @param identifier - The identifier to parse
|
|
86
|
+
* @returns The extracted satoshi number
|
|
87
|
+
* @throws {StructuredError} If the identifier format is invalid or satoshi is invalid
|
|
88
|
+
*
|
|
89
|
+
* @example
|
|
90
|
+
* ```typescript
|
|
91
|
+
* const satoshi = parseSatoshiIdentifier('did:btco:123456');
|
|
92
|
+
* console.log(satoshi); // 123456
|
|
93
|
+
* ```
|
|
94
|
+
*/
|
|
95
|
+
export function parseSatoshiIdentifier(identifier) {
|
|
96
|
+
if (!identifier || typeof identifier !== 'string') {
|
|
97
|
+
throw new StructuredError('INVALID_SATOSHI_IDENTIFIER', 'Satoshi identifier must be a non-empty string');
|
|
98
|
+
}
|
|
99
|
+
const trimmed = identifier.trim();
|
|
100
|
+
if (trimmed === '') {
|
|
101
|
+
throw new StructuredError('INVALID_SATOSHI_IDENTIFIER', 'Satoshi identifier cannot be empty or whitespace-only');
|
|
102
|
+
}
|
|
103
|
+
let satoshiStr;
|
|
104
|
+
// Check if it's a did:btco DID
|
|
105
|
+
if (trimmed.startsWith('did:btco:')) {
|
|
106
|
+
const parts = trimmed.split(':');
|
|
107
|
+
// Handle different network prefixes:
|
|
108
|
+
// did:btco:123456 (mainnet)
|
|
109
|
+
// did:btco:test:123456 (testnet)
|
|
110
|
+
// did:btco:sig:123456 (signet)
|
|
111
|
+
if (parts.length === 3) {
|
|
112
|
+
// Mainnet format: did:btco:satoshi
|
|
113
|
+
satoshiStr = parts[2];
|
|
114
|
+
}
|
|
115
|
+
else if (parts.length === 4) {
|
|
116
|
+
// Network-specific format: did:btco:network:satoshi
|
|
117
|
+
const network = parts[2];
|
|
118
|
+
if (network !== 'test' && network !== 'sig') {
|
|
119
|
+
throw new StructuredError('INVALID_SATOSHI_IDENTIFIER', `Invalid did:btco DID format: unsupported network "${network}"`);
|
|
120
|
+
}
|
|
121
|
+
satoshiStr = parts[3];
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
throw new StructuredError('INVALID_SATOSHI_IDENTIFIER', 'Invalid did:btco DID format: expected "did:btco:satoshi" or "did:btco:network:satoshi"');
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
// Assume it's a plain satoshi number
|
|
129
|
+
satoshiStr = trimmed;
|
|
130
|
+
}
|
|
131
|
+
// Validate the extracted satoshi
|
|
132
|
+
const validation = validateSatoshiNumber(satoshiStr);
|
|
133
|
+
if (!validation.valid) {
|
|
134
|
+
throw new StructuredError('INVALID_SATOSHI_IDENTIFIER', validation.error || 'Invalid satoshi identifier');
|
|
135
|
+
}
|
|
136
|
+
return Number(satoshiStr);
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Validates a satoshi number and throws an error if invalid.
|
|
140
|
+
* Convenience wrapper around validateSatoshiNumber for code that expects exceptions.
|
|
141
|
+
*
|
|
142
|
+
* @param satoshi - The satoshi identifier to validate
|
|
143
|
+
* @throws {StructuredError} If the satoshi is invalid
|
|
144
|
+
*
|
|
145
|
+
* @example
|
|
146
|
+
* ```typescript
|
|
147
|
+
* assertValidSatoshi('123456'); // OK
|
|
148
|
+
* assertValidSatoshi(''); // throws StructuredError
|
|
149
|
+
* ```
|
|
150
|
+
*/
|
|
151
|
+
export function assertValidSatoshi(satoshi) {
|
|
152
|
+
const result = validateSatoshiNumber(satoshi);
|
|
153
|
+
if (!result.valid) {
|
|
154
|
+
throw new StructuredError('INVALID_SATOSHI', result.error || 'Invalid satoshi identifier');
|
|
155
|
+
}
|
|
156
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { DIDDocument, VerifiableCredential } from '../types';
|
|
2
|
+
type DocumentLoader = (url: string) => Promise<{
|
|
3
|
+
documentUrl: string;
|
|
4
|
+
document: any;
|
|
5
|
+
contextUrl: string | null;
|
|
6
|
+
}>;
|
|
7
|
+
export declare function serializeDIDDocument(didDoc: DIDDocument): string;
|
|
8
|
+
export declare function deserializeDIDDocument(data: string): DIDDocument;
|
|
9
|
+
export declare function serializeCredential(vc: VerifiableCredential): string;
|
|
10
|
+
export declare function deserializeCredential(data: string): VerifiableCredential;
|
|
11
|
+
export declare function canonicalizeDocument(doc: any, options?: {
|
|
12
|
+
documentLoader?: DocumentLoader;
|
|
13
|
+
}): Promise<string>;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import jsonld from 'jsonld';
|
|
2
|
+
// Import context documents from src/contexts
|
|
3
|
+
import credentialsV1Context from '../contexts/credentials-v1.json';
|
|
4
|
+
import credentialsV2Context from '../contexts/credentials-v2.json';
|
|
5
|
+
import dataIntegrityV2Context from '../contexts/data-integrity-v2.json';
|
|
6
|
+
import didsContext from '../contexts/dids.json';
|
|
7
|
+
import ed255192020Context from '../contexts/ed255192020.json';
|
|
8
|
+
import ordinalsContext from '../contexts/ordinals-plus.json';
|
|
9
|
+
import originalsContext from '../contexts/originals.json';
|
|
10
|
+
// Full context documents for proper canonicalization
|
|
11
|
+
const PRELOADED_CONTEXTS = {
|
|
12
|
+
// W3C and standard contexts
|
|
13
|
+
'https://www.w3.org/2018/credentials/v1': credentialsV1Context,
|
|
14
|
+
'https://www.w3.org/ns/credentials/v2': credentialsV2Context,
|
|
15
|
+
'https://w3id.org/security/data-integrity/v2': dataIntegrityV2Context,
|
|
16
|
+
'https://www.w3.org/ns/did/v1': didsContext,
|
|
17
|
+
'https://w3id.org/security/suites/ed25519-2020/v1': ed255192020Context,
|
|
18
|
+
// Custom contexts
|
|
19
|
+
'https://ordinals.plus/vocab/v1': ordinalsContext,
|
|
20
|
+
// Originals network contexts (all three networks use the same context document)
|
|
21
|
+
'https://originals.build/context': originalsContext, // Legacy
|
|
22
|
+
'https://pichu.originals.build/context': originalsContext, // Production
|
|
23
|
+
'https://cleffa.originals.build/context': originalsContext, // Staging
|
|
24
|
+
'https://magby.originals.build/context': originalsContext, // Development
|
|
25
|
+
};
|
|
26
|
+
const defaultDocumentLoader = async (url) => {
|
|
27
|
+
const preloaded = PRELOADED_CONTEXTS[url];
|
|
28
|
+
if (preloaded) {
|
|
29
|
+
return { documentUrl: url, document: preloaded, contextUrl: null };
|
|
30
|
+
}
|
|
31
|
+
throw new Error(`Document not found in PRELOADED_CONTEXTS: ${url}`);
|
|
32
|
+
};
|
|
33
|
+
export function serializeDIDDocument(didDoc) {
|
|
34
|
+
// Serialize to JSON-LD with proper context
|
|
35
|
+
return JSON.stringify(didDoc, null, 2);
|
|
36
|
+
}
|
|
37
|
+
export function deserializeDIDDocument(data) {
|
|
38
|
+
// Parse from JSON-LD
|
|
39
|
+
try {
|
|
40
|
+
const parsed = JSON.parse(data);
|
|
41
|
+
return parsed;
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
throw new Error('Invalid DID Document JSON');
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
export function serializeCredential(vc) {
|
|
48
|
+
// Serialize VC to JSON-LD
|
|
49
|
+
return JSON.stringify(vc, null, 2);
|
|
50
|
+
}
|
|
51
|
+
export function deserializeCredential(data) {
|
|
52
|
+
// Parse VC from JSON-LD
|
|
53
|
+
try {
|
|
54
|
+
const parsed = JSON.parse(data);
|
|
55
|
+
return parsed;
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
throw new Error('Invalid Verifiable Credential JSON');
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
export async function canonicalizeDocument(doc, options = {}) {
|
|
62
|
+
try {
|
|
63
|
+
return await jsonld.canonize(doc, {
|
|
64
|
+
algorithm: 'URDNA2015',
|
|
65
|
+
format: 'application/n-quads',
|
|
66
|
+
documentLoader: options.documentLoader ?? defaultDocumentLoader,
|
|
67
|
+
useNative: false,
|
|
68
|
+
rdfDirection: 'i18n-datatype',
|
|
69
|
+
safe: false // Disable safe mode to allow custom contexts
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
const message = error?.message ?? String(error);
|
|
74
|
+
throw new Error(`Failed to canonicalize document: ${message}`);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export type TelemetryLevel = 'debug' | 'info' | 'warn' | 'error';
|
|
2
|
+
export interface TelemetryEvent {
|
|
3
|
+
name: string;
|
|
4
|
+
level?: TelemetryLevel;
|
|
5
|
+
attributes?: Record<string, unknown>;
|
|
6
|
+
}
|
|
7
|
+
export interface TelemetryHooks {
|
|
8
|
+
onEvent?: (event: TelemetryEvent) => void;
|
|
9
|
+
onError?: (error: StructuredError) => void;
|
|
10
|
+
}
|
|
11
|
+
export declare class StructuredError extends Error {
|
|
12
|
+
readonly code: string;
|
|
13
|
+
readonly details?: Record<string, unknown>;
|
|
14
|
+
constructor(code: string, message: string, details?: Record<string, unknown>);
|
|
15
|
+
}
|
|
16
|
+
export declare function emitTelemetry(hooks: TelemetryHooks | undefined, event: TelemetryEvent): void;
|
|
17
|
+
export declare function emitError(hooks: TelemetryHooks | undefined, error: StructuredError): void;
|
|
@@ -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,22 @@
|
|
|
1
|
+
import { VerifiableCredential, VerifiablePresentation, CredentialSubject, OriginalsConfig, ExternalSigner } from '../types';
|
|
2
|
+
import { DIDManager } from '../did/DIDManager';
|
|
3
|
+
export declare class CredentialManager {
|
|
4
|
+
private config;
|
|
5
|
+
private didManager?;
|
|
6
|
+
constructor(config: OriginalsConfig, didManager?: DIDManager | undefined);
|
|
7
|
+
createResourceCredential(type: 'ResourceCreated' | 'ResourceUpdated' | 'ResourceMigrated', subject: CredentialSubject, issuer: string): Promise<VerifiableCredential>;
|
|
8
|
+
signCredential(credential: VerifiableCredential, privateKeyMultibase: string, verificationMethod: string): Promise<VerifiableCredential>;
|
|
9
|
+
/**
|
|
10
|
+
* Sign a credential using an external signer (e.g., hardware wallet, Privy)
|
|
11
|
+
* @param credential - The unsigned credential
|
|
12
|
+
* @param signer - External signer implementation
|
|
13
|
+
* @returns Signed verifiable credential
|
|
14
|
+
*/
|
|
15
|
+
signCredentialWithExternalSigner(credential: VerifiableCredential, signer: ExternalSigner): Promise<VerifiableCredential>;
|
|
16
|
+
verifyCredential(credential: VerifiableCredential): Promise<boolean>;
|
|
17
|
+
createPresentation(credentials: VerifiableCredential[], holder: string): Promise<VerifiablePresentation>;
|
|
18
|
+
private generateProofValue;
|
|
19
|
+
private getSigner;
|
|
20
|
+
private resolveVerificationMethodMultibase;
|
|
21
|
+
private decodeMultibase;
|
|
22
|
+
}
|