@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,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LifecycleValidator - Validates lifecycle state transitions
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
MigrationOptions,
|
|
7
|
+
MigrationValidationResult,
|
|
8
|
+
ValidationError,
|
|
9
|
+
ValidationWarning,
|
|
10
|
+
IValidator
|
|
11
|
+
} from '../types';
|
|
12
|
+
import { OriginalsConfig } from '../../types';
|
|
13
|
+
|
|
14
|
+
export class LifecycleValidator implements IValidator {
|
|
15
|
+
constructor(private config: OriginalsConfig) {}
|
|
16
|
+
|
|
17
|
+
async validate(options: MigrationOptions): Promise<MigrationValidationResult> {
|
|
18
|
+
const errors: ValidationError[] = [];
|
|
19
|
+
const warnings: ValidationWarning[] = [];
|
|
20
|
+
|
|
21
|
+
try {
|
|
22
|
+
// All lifecycle states are compatible with all layers
|
|
23
|
+
// This validator checks for pending operations that might interfere
|
|
24
|
+
|
|
25
|
+
// For now, lifecycle is always compatible
|
|
26
|
+
// Future enhancements could check for:
|
|
27
|
+
// - Pending operations on source DID
|
|
28
|
+
// - State machine compatibility
|
|
29
|
+
// - Event history preservation capability
|
|
30
|
+
|
|
31
|
+
return {
|
|
32
|
+
valid: errors.length === 0,
|
|
33
|
+
errors,
|
|
34
|
+
warnings,
|
|
35
|
+
estimatedCost: {
|
|
36
|
+
storageCost: 0,
|
|
37
|
+
networkFees: 0,
|
|
38
|
+
totalCost: 0,
|
|
39
|
+
currency: 'sats'
|
|
40
|
+
},
|
|
41
|
+
estimatedDuration: 30
|
|
42
|
+
};
|
|
43
|
+
} catch (error) {
|
|
44
|
+
errors.push({
|
|
45
|
+
code: 'LIFECYCLE_VALIDATION_ERROR',
|
|
46
|
+
message: 'Error validating lifecycle compatibility',
|
|
47
|
+
details: { error: error instanceof Error ? error.message : String(error) }
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
return {
|
|
51
|
+
valid: false,
|
|
52
|
+
errors,
|
|
53
|
+
warnings,
|
|
54
|
+
estimatedCost: {
|
|
55
|
+
storageCost: 0,
|
|
56
|
+
networkFees: 0,
|
|
57
|
+
totalCost: 0,
|
|
58
|
+
currency: 'sats'
|
|
59
|
+
},
|
|
60
|
+
estimatedDuration: 0
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* StorageValidator - Validates storage adapter compatibility
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
MigrationOptions,
|
|
7
|
+
MigrationValidationResult,
|
|
8
|
+
ValidationError,
|
|
9
|
+
ValidationWarning,
|
|
10
|
+
IValidator
|
|
11
|
+
} from '../types';
|
|
12
|
+
import { OriginalsConfig } from '../../types';
|
|
13
|
+
|
|
14
|
+
export class StorageValidator implements IValidator {
|
|
15
|
+
constructor(private config: OriginalsConfig) {}
|
|
16
|
+
|
|
17
|
+
async validate(options: MigrationOptions): Promise<MigrationValidationResult> {
|
|
18
|
+
const errors: ValidationError[] = [];
|
|
19
|
+
const warnings: ValidationWarning[] = [];
|
|
20
|
+
|
|
21
|
+
try {
|
|
22
|
+
const storageAdapter = (this.config as any).storageAdapter;
|
|
23
|
+
|
|
24
|
+
// Check if storage adapter is available
|
|
25
|
+
if (!storageAdapter) {
|
|
26
|
+
warnings.push({
|
|
27
|
+
code: 'NO_STORAGE_ADAPTER',
|
|
28
|
+
message: 'No storage adapter configured; using memory storage (not persistent)'
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// Check large file support for partial migrations
|
|
33
|
+
if (options.partialMode) {
|
|
34
|
+
// Verify storage adapter supports chunked uploads
|
|
35
|
+
if (storageAdapter && typeof storageAdapter.putChunk !== 'function') {
|
|
36
|
+
warnings.push({
|
|
37
|
+
code: 'NO_CHUNKED_UPLOAD_SUPPORT',
|
|
38
|
+
message: 'Storage adapter does not support chunked uploads; partial mode may be inefficient'
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
// Estimate storage costs (minimal for webvh, zero for peer/btco)
|
|
44
|
+
const storageCost = options.targetLayer === 'webvh' ? 0.001 : 0;
|
|
45
|
+
|
|
46
|
+
return {
|
|
47
|
+
valid: errors.length === 0,
|
|
48
|
+
errors,
|
|
49
|
+
warnings,
|
|
50
|
+
estimatedCost: {
|
|
51
|
+
storageCost,
|
|
52
|
+
networkFees: 0,
|
|
53
|
+
totalCost: storageCost,
|
|
54
|
+
currency: 'sats'
|
|
55
|
+
},
|
|
56
|
+
estimatedDuration: 50
|
|
57
|
+
};
|
|
58
|
+
} catch (error) {
|
|
59
|
+
errors.push({
|
|
60
|
+
code: 'STORAGE_VALIDATION_ERROR',
|
|
61
|
+
message: 'Error validating storage compatibility',
|
|
62
|
+
details: { error: error instanceof Error ? error.message : String(error) }
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
return {
|
|
66
|
+
valid: false,
|
|
67
|
+
errors,
|
|
68
|
+
warnings,
|
|
69
|
+
estimatedCost: {
|
|
70
|
+
storageCost: 0,
|
|
71
|
+
networkFees: 0,
|
|
72
|
+
totalCost: 0,
|
|
73
|
+
currency: 'sats'
|
|
74
|
+
},
|
|
75
|
+
estimatedDuration: 0
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ValidationPipeline - Orchestrates all validation checks before migration
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
MigrationOptions,
|
|
7
|
+
MigrationValidationResult,
|
|
8
|
+
ValidationError,
|
|
9
|
+
ValidationWarning,
|
|
10
|
+
CostEstimate,
|
|
11
|
+
IValidator
|
|
12
|
+
} from '../types';
|
|
13
|
+
import { DIDCompatibilityValidator } from './DIDCompatibilityValidator';
|
|
14
|
+
import { CredentialValidator } from './CredentialValidator';
|
|
15
|
+
import { StorageValidator } from './StorageValidator';
|
|
16
|
+
import { LifecycleValidator } from './LifecycleValidator';
|
|
17
|
+
import { BitcoinValidator } from './BitcoinValidator';
|
|
18
|
+
import { OriginalsConfig } from '../../types';
|
|
19
|
+
import { DIDManager } from '../../did/DIDManager';
|
|
20
|
+
import { CredentialManager } from '../../vc/CredentialManager';
|
|
21
|
+
import { BitcoinManager } from '../../bitcoin/BitcoinManager';
|
|
22
|
+
|
|
23
|
+
export class ValidationPipeline {
|
|
24
|
+
private validators: Map<string, IValidator>;
|
|
25
|
+
|
|
26
|
+
constructor(
|
|
27
|
+
private config: OriginalsConfig,
|
|
28
|
+
private didManager: DIDManager,
|
|
29
|
+
private credentialManager: CredentialManager,
|
|
30
|
+
private bitcoinManager?: BitcoinManager
|
|
31
|
+
) {
|
|
32
|
+
this.validators = new Map();
|
|
33
|
+
this.initializeValidators();
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
private initializeValidators(): void {
|
|
37
|
+
this.validators.set('did', new DIDCompatibilityValidator(this.config, this.didManager));
|
|
38
|
+
this.validators.set('credential', new CredentialValidator(this.config, this.credentialManager));
|
|
39
|
+
this.validators.set('storage', new StorageValidator(this.config));
|
|
40
|
+
this.validators.set('lifecycle', new LifecycleValidator(this.config));
|
|
41
|
+
if (this.bitcoinManager) {
|
|
42
|
+
this.validators.set('bitcoin', new BitcoinValidator(this.config, this.bitcoinManager));
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Run all validation checks for a migration
|
|
48
|
+
*/
|
|
49
|
+
async validate(options: MigrationOptions): Promise<MigrationValidationResult> {
|
|
50
|
+
const errors: ValidationError[] = [];
|
|
51
|
+
const warnings: ValidationWarning[] = [];
|
|
52
|
+
let estimatedCost: CostEstimate = {
|
|
53
|
+
storageCost: 0,
|
|
54
|
+
networkFees: 0,
|
|
55
|
+
totalCost: 0,
|
|
56
|
+
currency: 'sats'
|
|
57
|
+
};
|
|
58
|
+
let estimatedDuration = 0;
|
|
59
|
+
|
|
60
|
+
try {
|
|
61
|
+
// Basic input validation
|
|
62
|
+
const inputErrors = this.validateInput(options);
|
|
63
|
+
if (inputErrors.length > 0) {
|
|
64
|
+
return {
|
|
65
|
+
valid: false,
|
|
66
|
+
errors: inputErrors,
|
|
67
|
+
warnings: [],
|
|
68
|
+
estimatedCost,
|
|
69
|
+
estimatedDuration: 0
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// Run DID compatibility validation
|
|
74
|
+
const didResult = await this.validators.get('did')!.validate(options);
|
|
75
|
+
errors.push(...didResult.errors);
|
|
76
|
+
warnings.push(...didResult.warnings);
|
|
77
|
+
estimatedDuration = Math.max(estimatedDuration, didResult.estimatedDuration);
|
|
78
|
+
|
|
79
|
+
// Run credential validation if enabled
|
|
80
|
+
if (options.credentialIssuance !== false) {
|
|
81
|
+
const credResult = await this.validators.get('credential')!.validate(options);
|
|
82
|
+
errors.push(...credResult.errors);
|
|
83
|
+
warnings.push(...credResult.warnings);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// Run storage validation
|
|
87
|
+
const storageResult = await this.validators.get('storage')!.validate(options);
|
|
88
|
+
errors.push(...storageResult.errors);
|
|
89
|
+
warnings.push(...storageResult.warnings);
|
|
90
|
+
estimatedCost.storageCost = storageResult.estimatedCost.storageCost;
|
|
91
|
+
|
|
92
|
+
// Run lifecycle validation
|
|
93
|
+
const lifecycleResult = await this.validators.get('lifecycle')!.validate(options);
|
|
94
|
+
errors.push(...lifecycleResult.errors);
|
|
95
|
+
warnings.push(...lifecycleResult.warnings);
|
|
96
|
+
|
|
97
|
+
// Run Bitcoin validation for btco migrations
|
|
98
|
+
if (options.targetLayer === 'btco') {
|
|
99
|
+
const bitcoinValidator = this.validators.get('bitcoin');
|
|
100
|
+
if (!bitcoinValidator) {
|
|
101
|
+
errors.push({
|
|
102
|
+
code: 'BITCOIN_VALIDATOR_MISSING',
|
|
103
|
+
message: 'Bitcoin validator required for btco migrations but not configured',
|
|
104
|
+
details: { targetLayer: options.targetLayer }
|
|
105
|
+
});
|
|
106
|
+
} else {
|
|
107
|
+
const bitcoinResult = await bitcoinValidator.validate(options);
|
|
108
|
+
errors.push(...bitcoinResult.errors);
|
|
109
|
+
warnings.push(...bitcoinResult.warnings);
|
|
110
|
+
estimatedCost.networkFees = bitcoinResult.estimatedCost.networkFees;
|
|
111
|
+
estimatedDuration = Math.max(estimatedDuration, bitcoinResult.estimatedDuration);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
// Calculate total cost
|
|
116
|
+
estimatedCost.totalCost = estimatedCost.storageCost + estimatedCost.networkFees;
|
|
117
|
+
|
|
118
|
+
return {
|
|
119
|
+
valid: errors.length === 0,
|
|
120
|
+
errors,
|
|
121
|
+
warnings,
|
|
122
|
+
estimatedCost,
|
|
123
|
+
estimatedDuration
|
|
124
|
+
};
|
|
125
|
+
} catch (error) {
|
|
126
|
+
errors.push({
|
|
127
|
+
code: 'VALIDATION_PIPELINE_ERROR',
|
|
128
|
+
message: 'Unexpected error during validation',
|
|
129
|
+
details: { error: error instanceof Error ? error.message : String(error) }
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
return {
|
|
133
|
+
valid: false,
|
|
134
|
+
errors,
|
|
135
|
+
warnings,
|
|
136
|
+
estimatedCost,
|
|
137
|
+
estimatedDuration
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Validate basic input parameters
|
|
144
|
+
*/
|
|
145
|
+
private validateInput(options: MigrationOptions): ValidationError[] {
|
|
146
|
+
const errors: ValidationError[] = [];
|
|
147
|
+
|
|
148
|
+
// Validate source DID
|
|
149
|
+
if (!options.sourceDid || typeof options.sourceDid !== 'string') {
|
|
150
|
+
errors.push({
|
|
151
|
+
code: 'INVALID_SOURCE_DID',
|
|
152
|
+
message: 'Source DID is required and must be a string',
|
|
153
|
+
field: 'sourceDid'
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
// Validate target layer
|
|
158
|
+
if (!options.targetLayer) {
|
|
159
|
+
errors.push({
|
|
160
|
+
code: 'INVALID_TARGET_LAYER',
|
|
161
|
+
message: 'Target layer is required',
|
|
162
|
+
field: 'targetLayer'
|
|
163
|
+
});
|
|
164
|
+
} else if (!['peer', 'webvh', 'btco'].includes(options.targetLayer)) {
|
|
165
|
+
errors.push({
|
|
166
|
+
code: 'INVALID_TARGET_LAYER',
|
|
167
|
+
message: 'Target layer must be one of: peer, webvh, btco',
|
|
168
|
+
field: 'targetLayer',
|
|
169
|
+
details: { received: options.targetLayer }
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
// Validate partial mode options
|
|
174
|
+
if (options.partialMode) {
|
|
175
|
+
if (typeof options.partialMode.chunkSize !== 'number' || options.partialMode.chunkSize <= 0) {
|
|
176
|
+
errors.push({
|
|
177
|
+
code: 'INVALID_CHUNK_SIZE',
|
|
178
|
+
message: 'Chunk size must be a positive number',
|
|
179
|
+
field: 'partialMode.chunkSize'
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
// Validate webvh-specific options
|
|
185
|
+
if (options.targetLayer === 'webvh' && !options.domain) {
|
|
186
|
+
errors.push({
|
|
187
|
+
code: 'DOMAIN_REQUIRED',
|
|
188
|
+
message: 'Domain is required for webvh migrations',
|
|
189
|
+
field: 'domain'
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
// Validate btco-specific options
|
|
194
|
+
if (options.targetLayer === 'btco') {
|
|
195
|
+
if (options.feeRate !== undefined && (typeof options.feeRate !== 'number' || options.feeRate <= 0)) {
|
|
196
|
+
errors.push({
|
|
197
|
+
code: 'INVALID_FEE_RATE',
|
|
198
|
+
message: 'Fee rate must be a positive number',
|
|
199
|
+
field: 'feeRate'
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
return errors;
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* Quick validation check (basic only, no async operations)
|
|
209
|
+
*/
|
|
210
|
+
validateQuick(options: MigrationOptions): ValidationError[] {
|
|
211
|
+
return this.validateInput(options);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
// Local adapter is optional in this environment; keeping implementation but avoid Node typings
|
|
2
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
3
|
+
// @ts-nocheck
|
|
4
|
+
import * as fs from 'fs/promises';
|
|
5
|
+
import * as path from 'path';
|
|
6
|
+
import { GetObjectResult, LocalStorageAdapterOptions, StorageAdapter } from './StorageAdapter';
|
|
7
|
+
|
|
8
|
+
export class LocalStorageAdapter implements StorageAdapter {
|
|
9
|
+
private baseDir: string;
|
|
10
|
+
private baseUrl?: string;
|
|
11
|
+
|
|
12
|
+
constructor(options: LocalStorageAdapterOptions) {
|
|
13
|
+
this.baseDir = options.baseDir;
|
|
14
|
+
this.baseUrl = options.baseUrl;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
private resolvePath(domain: string, objectPath: string): string {
|
|
18
|
+
const safeDomain = domain.replace(/[^a-zA-Z0-9.-]/g, '_');
|
|
19
|
+
const cleanPath = objectPath.replace(/^\/+/, '');
|
|
20
|
+
return path.join(this.baseDir, safeDomain, cleanPath);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
private toUrl(domain: string, objectPath: string): string {
|
|
24
|
+
const cleanPath = objectPath.replace(/^\/+/, '');
|
|
25
|
+
if (this.baseUrl) {
|
|
26
|
+
const trimmed = this.baseUrl.replace(/\/$/, '');
|
|
27
|
+
return `${trimmed}/${domain}/${cleanPath}`;
|
|
28
|
+
}
|
|
29
|
+
return `file://${this.resolvePath(domain, cleanPath)}`;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
async putObject(domain: string, objectPath: string, content: Uint8Array | string): Promise<string> {
|
|
33
|
+
const fullPath = this.resolvePath(domain, objectPath);
|
|
34
|
+
await fs.mkdir(path.dirname(fullPath), { recursive: true });
|
|
35
|
+
const data = typeof content === 'string' ? Buffer.from(content) : Buffer.from(content);
|
|
36
|
+
await fs.writeFile(fullPath, data);
|
|
37
|
+
return this.toUrl(domain, objectPath);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async getObject(domain: string, objectPath: string): Promise<GetObjectResult | null> {
|
|
41
|
+
const fullPath = this.resolvePath(domain, objectPath);
|
|
42
|
+
try {
|
|
43
|
+
const content = await fs.readFile(fullPath);
|
|
44
|
+
return { content: new Uint8Array(content) };
|
|
45
|
+
} catch (e: any) {
|
|
46
|
+
if (e && e.code === 'ENOENT') return null;
|
|
47
|
+
throw e;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
async exists(domain: string, objectPath: string): Promise<boolean> {
|
|
52
|
+
const fullPath = this.resolvePath(domain, objectPath);
|
|
53
|
+
try {
|
|
54
|
+
await fs.access(fullPath);
|
|
55
|
+
return true;
|
|
56
|
+
} catch {
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { GetObjectResult, StorageAdapter } from './StorageAdapter';
|
|
2
|
+
|
|
3
|
+
type DomainPath = string;
|
|
4
|
+
|
|
5
|
+
const globalStore: Map<DomainPath, Uint8Array> = new Map();
|
|
6
|
+
|
|
7
|
+
function key(domain: string, objectPath: string): string {
|
|
8
|
+
const cleanPath = objectPath.replace(/^\/+/, '');
|
|
9
|
+
return `${domain}::${cleanPath}`;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export class MemoryStorageAdapter implements StorageAdapter {
|
|
13
|
+
async putObject(domain: string, objectPath: string, content: Uint8Array | string): Promise<string> {
|
|
14
|
+
const data = typeof content === 'string' ? new TextEncoder().encode(content) : content;
|
|
15
|
+
globalStore.set(key(domain, objectPath), data);
|
|
16
|
+
return `mem://${domain}/${objectPath.replace(/^\/+/, '')}`;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
async getObject(domain: string, objectPath: string): Promise<GetObjectResult | null> {
|
|
20
|
+
const stored = globalStore.get(key(domain, objectPath));
|
|
21
|
+
if (!stored) return null;
|
|
22
|
+
return { content: stored };
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
async exists(domain: string, objectPath: string): Promise<boolean> {
|
|
26
|
+
return globalStore.has(key(domain, objectPath));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface PutOptions {
|
|
2
|
+
contentType?: string;
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
export interface GetObjectResult {
|
|
6
|
+
content: Uint8Array;
|
|
7
|
+
contentType?: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export interface StorageAdapter {
|
|
11
|
+
// Writes content at a path under a logical domain root and returns a public URL
|
|
12
|
+
putObject(domain: string, path: string, content: Uint8Array | string, options?: PutOptions): Promise<string>;
|
|
13
|
+
|
|
14
|
+
// Reads content from a path under a domain root
|
|
15
|
+
getObject(domain: string, path: string): Promise<GetObjectResult | null>;
|
|
16
|
+
|
|
17
|
+
// Checks whether a path exists
|
|
18
|
+
exists(domain: string, path: string): Promise<boolean>;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface LocalStorageAdapterOptions {
|
|
22
|
+
baseDir: string;
|
|
23
|
+
baseUrl?: string;
|
|
24
|
+
}
|
|
25
|
+
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
// Bitcoin/Ordinals types
|
|
2
|
+
export interface OrdinalsInscription {
|
|
3
|
+
satoshi: string; // Unique satoshi identifier
|
|
4
|
+
inscriptionId: string;
|
|
5
|
+
content: Buffer;
|
|
6
|
+
contentType: string;
|
|
7
|
+
txid: string;
|
|
8
|
+
vout: number;
|
|
9
|
+
blockHeight?: number;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export interface BitcoinTransaction {
|
|
13
|
+
txid: string;
|
|
14
|
+
vin: TransactionInput[];
|
|
15
|
+
vout: TransactionOutput[];
|
|
16
|
+
fee: number;
|
|
17
|
+
blockHeight?: number;
|
|
18
|
+
confirmations?: number;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface TransactionInput {
|
|
22
|
+
txid: string;
|
|
23
|
+
vout: number;
|
|
24
|
+
scriptSig?: string;
|
|
25
|
+
witness?: string[];
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export interface TransactionOutput {
|
|
29
|
+
value: number; // satoshis
|
|
30
|
+
scriptPubKey: string;
|
|
31
|
+
address?: string;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export interface Utxo {
|
|
35
|
+
txid: string;
|
|
36
|
+
vout: number;
|
|
37
|
+
value: number; // satoshis
|
|
38
|
+
scriptPubKey?: string;
|
|
39
|
+
address?: string;
|
|
40
|
+
inscriptions?: string[]; // inscription ids located on this outpoint
|
|
41
|
+
locked?: boolean; // if true, cannot be spent due to wallet locks
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Extended UTXO interface that tracks whether it contains an Ordinals resource (inscription)
|
|
46
|
+
*/
|
|
47
|
+
export interface ResourceUtxo extends Utxo {
|
|
48
|
+
/** True if this UTXO contains an inscription or other Ordinals resource */
|
|
49
|
+
hasResource?: boolean;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Strategy for selecting UTXOs
|
|
54
|
+
*/
|
|
55
|
+
export type UtxoSelectionStrategy = 'minimize_change' | 'minimize_inputs' | 'optimize_size';
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Options for resource-aware UTXO selection
|
|
59
|
+
*/
|
|
60
|
+
export interface ResourceUtxoSelectionOptions {
|
|
61
|
+
/** Required amount in satoshis */
|
|
62
|
+
requiredAmount: number;
|
|
63
|
+
/** Fee rate in satoshis per vbyte */
|
|
64
|
+
feeRate: number;
|
|
65
|
+
/** Allow using UTXOs that contain resources (default: false) */
|
|
66
|
+
allowResourceUtxos?: boolean;
|
|
67
|
+
/** Prefer older UTXOs (default: false) */
|
|
68
|
+
preferOlder?: boolean;
|
|
69
|
+
/** Prefer UTXOs with value closer to required amount (default: false) */
|
|
70
|
+
preferCloserAmount?: boolean;
|
|
71
|
+
/** List of UTXO IDs to avoid using (format: "txid:vout") */
|
|
72
|
+
avoidUtxoIds?: string[];
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Result of resource-aware UTXO selection
|
|
77
|
+
*/
|
|
78
|
+
export interface ResourceUtxoSelectionResult {
|
|
79
|
+
/** Selected UTXOs for the transaction */
|
|
80
|
+
selectedUtxos: ResourceUtxo[];
|
|
81
|
+
/** Total value of selected UTXOs */
|
|
82
|
+
totalSelectedValue: number;
|
|
83
|
+
/** Estimated transaction fee in satoshis */
|
|
84
|
+
estimatedFee: number;
|
|
85
|
+
/** Change amount in satoshis (0 if less than dust) */
|
|
86
|
+
changeAmount: number;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
export const DUST_LIMIT_SATS = 546;
|
|
90
|
+
|
|
91
|
+
export interface KeyPair {
|
|
92
|
+
privateKey: string; // multibase encoded
|
|
93
|
+
publicKey: string; // multibase encoded
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
export type KeyType = 'ES256K' | 'Ed25519' | 'ES256';
|
|
97
|
+
|
|
98
|
+
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { StorageAdapter, FeeOracleAdapter, OrdinalsProvider } from '../adapters';
|
|
2
|
+
import { TelemetryHooks } from '../utils/telemetry';
|
|
3
|
+
import type { LogLevel, LogOutput } from '../utils/Logger';
|
|
4
|
+
import type { EventLoggingConfig } from '../utils/EventLogger';
|
|
5
|
+
import type { WebVHNetworkName } from './network';
|
|
6
|
+
|
|
7
|
+
// Base types for the Originals protocol
|
|
8
|
+
export type LayerType = 'did:peer' | 'did:webvh' | 'did:btco';
|
|
9
|
+
|
|
10
|
+
export interface OriginalsConfig {
|
|
11
|
+
network: 'mainnet' | 'regtest' | 'signet';
|
|
12
|
+
bitcoinRpcUrl?: string;
|
|
13
|
+
defaultKeyType: 'ES256K' | 'Ed25519' | 'ES256';
|
|
14
|
+
keyStore?: KeyStore;
|
|
15
|
+
enableLogging?: boolean;
|
|
16
|
+
// WebVH network selection (defaults to 'pichu' - production)
|
|
17
|
+
webvhNetwork?: WebVHNetworkName;
|
|
18
|
+
// Optional pluggable adapters
|
|
19
|
+
storageAdapter?: StorageAdapter;
|
|
20
|
+
feeOracle?: FeeOracleAdapter;
|
|
21
|
+
ordinalsProvider?: OrdinalsProvider;
|
|
22
|
+
// Optional telemetry hooks
|
|
23
|
+
telemetry?: TelemetryHooks;
|
|
24
|
+
// Enhanced logging configuration
|
|
25
|
+
logging?: {
|
|
26
|
+
level?: LogLevel;
|
|
27
|
+
outputs?: LogOutput[];
|
|
28
|
+
includeTimestamps?: boolean;
|
|
29
|
+
includeContext?: boolean;
|
|
30
|
+
eventLogging?: EventLoggingConfig;
|
|
31
|
+
sanitizeLogs?: boolean; // Remove sensitive data
|
|
32
|
+
};
|
|
33
|
+
// Metrics configuration
|
|
34
|
+
metrics?: {
|
|
35
|
+
enabled?: boolean;
|
|
36
|
+
exportFormat?: 'json' | 'prometheus';
|
|
37
|
+
collectCache?: boolean;
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export interface AssetResource {
|
|
42
|
+
id: string; // Logical resource ID (stable across versions)
|
|
43
|
+
type: string; // 'image', 'text', 'code', 'data', etc.
|
|
44
|
+
url?: string;
|
|
45
|
+
content?: string;
|
|
46
|
+
contentType: string;
|
|
47
|
+
hash: string; // Content hash (unique per version)
|
|
48
|
+
size?: number;
|
|
49
|
+
version?: number; // Version number (default 1)
|
|
50
|
+
previousVersionHash?: string; // Link to previous version (by content hash)
|
|
51
|
+
createdAt?: string; // ISO timestamp of when this version was created
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export interface KeyStore {
|
|
55
|
+
getPrivateKey(verificationMethodId: string): Promise<string | null>;
|
|
56
|
+
setPrivateKey(verificationMethodId: string, privateKey: string): Promise<void>;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* External signer interface for DID operations (compatible with didwebvh-ts)
|
|
61
|
+
* This allows integration with external key management systems like Privy
|
|
62
|
+
*/
|
|
63
|
+
export interface ExternalSigner {
|
|
64
|
+
/**
|
|
65
|
+
* Sign data and return a proof value
|
|
66
|
+
* @param input - The signing input containing document and proof
|
|
67
|
+
* @returns The proof value (typically multibase-encoded signature)
|
|
68
|
+
*/
|
|
69
|
+
sign(input: { document: Record<string, unknown>; proof: Record<string, unknown> }): Promise<{ proofValue: string }>;
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Get the verification method ID for this signer
|
|
73
|
+
* @returns The verification method ID (e.g., "did:key:z6Mk...")
|
|
74
|
+
*/
|
|
75
|
+
getVerificationMethodId(): string;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* External verifier interface for DID operations (compatible with didwebvh-ts)
|
|
80
|
+
*/
|
|
81
|
+
export interface ExternalVerifier {
|
|
82
|
+
/**
|
|
83
|
+
* Verify a signature
|
|
84
|
+
* @param signature - The signature bytes
|
|
85
|
+
* @param message - The message bytes that were signed
|
|
86
|
+
* @param publicKey - The public key bytes
|
|
87
|
+
* @returns True if the signature is valid
|
|
88
|
+
*/
|
|
89
|
+
verify(signature: Uint8Array, message: Uint8Array, publicKey: Uint8Array): Promise<boolean>;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
|