@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,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LifecycleValidator - Validates lifecycle state transitions
|
|
3
|
+
*/
|
|
4
|
+
export class LifecycleValidator {
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.config = config;
|
|
7
|
+
}
|
|
8
|
+
async validate(options) {
|
|
9
|
+
const errors = [];
|
|
10
|
+
const warnings = [];
|
|
11
|
+
try {
|
|
12
|
+
// All lifecycle states are compatible with all layers
|
|
13
|
+
// This validator checks for pending operations that might interfere
|
|
14
|
+
// For now, lifecycle is always compatible
|
|
15
|
+
// Future enhancements could check for:
|
|
16
|
+
// - Pending operations on source DID
|
|
17
|
+
// - State machine compatibility
|
|
18
|
+
// - Event history preservation capability
|
|
19
|
+
return {
|
|
20
|
+
valid: errors.length === 0,
|
|
21
|
+
errors,
|
|
22
|
+
warnings,
|
|
23
|
+
estimatedCost: {
|
|
24
|
+
storageCost: 0,
|
|
25
|
+
networkFees: 0,
|
|
26
|
+
totalCost: 0,
|
|
27
|
+
currency: 'sats'
|
|
28
|
+
},
|
|
29
|
+
estimatedDuration: 30
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
errors.push({
|
|
34
|
+
code: 'LIFECYCLE_VALIDATION_ERROR',
|
|
35
|
+
message: 'Error validating lifecycle compatibility',
|
|
36
|
+
details: { error: error instanceof Error ? error.message : String(error) }
|
|
37
|
+
});
|
|
38
|
+
return {
|
|
39
|
+
valid: false,
|
|
40
|
+
errors,
|
|
41
|
+
warnings,
|
|
42
|
+
estimatedCost: {
|
|
43
|
+
storageCost: 0,
|
|
44
|
+
networkFees: 0,
|
|
45
|
+
totalCost: 0,
|
|
46
|
+
currency: 'sats'
|
|
47
|
+
},
|
|
48
|
+
estimatedDuration: 0
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* StorageValidator - Validates storage adapter compatibility
|
|
3
|
+
*/
|
|
4
|
+
import { MigrationOptions, MigrationValidationResult, IValidator } from '../types';
|
|
5
|
+
import { OriginalsConfig } from '../../types';
|
|
6
|
+
export declare class StorageValidator implements IValidator {
|
|
7
|
+
private config;
|
|
8
|
+
constructor(config: OriginalsConfig);
|
|
9
|
+
validate(options: MigrationOptions): Promise<MigrationValidationResult>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* StorageValidator - Validates storage adapter compatibility
|
|
3
|
+
*/
|
|
4
|
+
export class StorageValidator {
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.config = config;
|
|
7
|
+
}
|
|
8
|
+
async validate(options) {
|
|
9
|
+
const errors = [];
|
|
10
|
+
const warnings = [];
|
|
11
|
+
try {
|
|
12
|
+
const storageAdapter = this.config.storageAdapter;
|
|
13
|
+
// Check if storage adapter is available
|
|
14
|
+
if (!storageAdapter) {
|
|
15
|
+
warnings.push({
|
|
16
|
+
code: 'NO_STORAGE_ADAPTER',
|
|
17
|
+
message: 'No storage adapter configured; using memory storage (not persistent)'
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
// Check large file support for partial migrations
|
|
21
|
+
if (options.partialMode) {
|
|
22
|
+
// Verify storage adapter supports chunked uploads
|
|
23
|
+
if (storageAdapter && typeof storageAdapter.putChunk !== 'function') {
|
|
24
|
+
warnings.push({
|
|
25
|
+
code: 'NO_CHUNKED_UPLOAD_SUPPORT',
|
|
26
|
+
message: 'Storage adapter does not support chunked uploads; partial mode may be inefficient'
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
// Estimate storage costs (minimal for webvh, zero for peer/btco)
|
|
31
|
+
const storageCost = options.targetLayer === 'webvh' ? 0.001 : 0;
|
|
32
|
+
return {
|
|
33
|
+
valid: errors.length === 0,
|
|
34
|
+
errors,
|
|
35
|
+
warnings,
|
|
36
|
+
estimatedCost: {
|
|
37
|
+
storageCost,
|
|
38
|
+
networkFees: 0,
|
|
39
|
+
totalCost: storageCost,
|
|
40
|
+
currency: 'sats'
|
|
41
|
+
},
|
|
42
|
+
estimatedDuration: 50
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
errors.push({
|
|
47
|
+
code: 'STORAGE_VALIDATION_ERROR',
|
|
48
|
+
message: 'Error validating storage compatibility',
|
|
49
|
+
details: { error: error instanceof Error ? error.message : String(error) }
|
|
50
|
+
});
|
|
51
|
+
return {
|
|
52
|
+
valid: false,
|
|
53
|
+
errors,
|
|
54
|
+
warnings,
|
|
55
|
+
estimatedCost: {
|
|
56
|
+
storageCost: 0,
|
|
57
|
+
networkFees: 0,
|
|
58
|
+
totalCost: 0,
|
|
59
|
+
currency: 'sats'
|
|
60
|
+
},
|
|
61
|
+
estimatedDuration: 0
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ValidationPipeline - Orchestrates all validation checks before migration
|
|
3
|
+
*/
|
|
4
|
+
import { MigrationOptions, MigrationValidationResult, ValidationError } from '../types';
|
|
5
|
+
import { OriginalsConfig } from '../../types';
|
|
6
|
+
import { DIDManager } from '../../did/DIDManager';
|
|
7
|
+
import { CredentialManager } from '../../vc/CredentialManager';
|
|
8
|
+
import { BitcoinManager } from '../../bitcoin/BitcoinManager';
|
|
9
|
+
export declare class ValidationPipeline {
|
|
10
|
+
private config;
|
|
11
|
+
private didManager;
|
|
12
|
+
private credentialManager;
|
|
13
|
+
private bitcoinManager?;
|
|
14
|
+
private validators;
|
|
15
|
+
constructor(config: OriginalsConfig, didManager: DIDManager, credentialManager: CredentialManager, bitcoinManager?: BitcoinManager | undefined);
|
|
16
|
+
private initializeValidators;
|
|
17
|
+
/**
|
|
18
|
+
* Run all validation checks for a migration
|
|
19
|
+
*/
|
|
20
|
+
validate(options: MigrationOptions): Promise<MigrationValidationResult>;
|
|
21
|
+
/**
|
|
22
|
+
* Validate basic input parameters
|
|
23
|
+
*/
|
|
24
|
+
private validateInput;
|
|
25
|
+
/**
|
|
26
|
+
* Quick validation check (basic only, no async operations)
|
|
27
|
+
*/
|
|
28
|
+
validateQuick(options: MigrationOptions): ValidationError[];
|
|
29
|
+
}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ValidationPipeline - Orchestrates all validation checks before migration
|
|
3
|
+
*/
|
|
4
|
+
import { DIDCompatibilityValidator } from './DIDCompatibilityValidator';
|
|
5
|
+
import { CredentialValidator } from './CredentialValidator';
|
|
6
|
+
import { StorageValidator } from './StorageValidator';
|
|
7
|
+
import { LifecycleValidator } from './LifecycleValidator';
|
|
8
|
+
import { BitcoinValidator } from './BitcoinValidator';
|
|
9
|
+
export class ValidationPipeline {
|
|
10
|
+
constructor(config, didManager, credentialManager, bitcoinManager) {
|
|
11
|
+
this.config = config;
|
|
12
|
+
this.didManager = didManager;
|
|
13
|
+
this.credentialManager = credentialManager;
|
|
14
|
+
this.bitcoinManager = bitcoinManager;
|
|
15
|
+
this.validators = new Map();
|
|
16
|
+
this.initializeValidators();
|
|
17
|
+
}
|
|
18
|
+
initializeValidators() {
|
|
19
|
+
this.validators.set('did', new DIDCompatibilityValidator(this.config, this.didManager));
|
|
20
|
+
this.validators.set('credential', new CredentialValidator(this.config, this.credentialManager));
|
|
21
|
+
this.validators.set('storage', new StorageValidator(this.config));
|
|
22
|
+
this.validators.set('lifecycle', new LifecycleValidator(this.config));
|
|
23
|
+
if (this.bitcoinManager) {
|
|
24
|
+
this.validators.set('bitcoin', new BitcoinValidator(this.config, this.bitcoinManager));
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Run all validation checks for a migration
|
|
29
|
+
*/
|
|
30
|
+
async validate(options) {
|
|
31
|
+
const errors = [];
|
|
32
|
+
const warnings = [];
|
|
33
|
+
let estimatedCost = {
|
|
34
|
+
storageCost: 0,
|
|
35
|
+
networkFees: 0,
|
|
36
|
+
totalCost: 0,
|
|
37
|
+
currency: 'sats'
|
|
38
|
+
};
|
|
39
|
+
let estimatedDuration = 0;
|
|
40
|
+
try {
|
|
41
|
+
// Basic input validation
|
|
42
|
+
const inputErrors = this.validateInput(options);
|
|
43
|
+
if (inputErrors.length > 0) {
|
|
44
|
+
return {
|
|
45
|
+
valid: false,
|
|
46
|
+
errors: inputErrors,
|
|
47
|
+
warnings: [],
|
|
48
|
+
estimatedCost,
|
|
49
|
+
estimatedDuration: 0
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
// Run DID compatibility validation
|
|
53
|
+
const didResult = await this.validators.get('did').validate(options);
|
|
54
|
+
errors.push(...didResult.errors);
|
|
55
|
+
warnings.push(...didResult.warnings);
|
|
56
|
+
estimatedDuration = Math.max(estimatedDuration, didResult.estimatedDuration);
|
|
57
|
+
// Run credential validation if enabled
|
|
58
|
+
if (options.credentialIssuance !== false) {
|
|
59
|
+
const credResult = await this.validators.get('credential').validate(options);
|
|
60
|
+
errors.push(...credResult.errors);
|
|
61
|
+
warnings.push(...credResult.warnings);
|
|
62
|
+
}
|
|
63
|
+
// Run storage validation
|
|
64
|
+
const storageResult = await this.validators.get('storage').validate(options);
|
|
65
|
+
errors.push(...storageResult.errors);
|
|
66
|
+
warnings.push(...storageResult.warnings);
|
|
67
|
+
estimatedCost.storageCost = storageResult.estimatedCost.storageCost;
|
|
68
|
+
// Run lifecycle validation
|
|
69
|
+
const lifecycleResult = await this.validators.get('lifecycle').validate(options);
|
|
70
|
+
errors.push(...lifecycleResult.errors);
|
|
71
|
+
warnings.push(...lifecycleResult.warnings);
|
|
72
|
+
// Run Bitcoin validation for btco migrations
|
|
73
|
+
if (options.targetLayer === 'btco') {
|
|
74
|
+
const bitcoinValidator = this.validators.get('bitcoin');
|
|
75
|
+
if (!bitcoinValidator) {
|
|
76
|
+
errors.push({
|
|
77
|
+
code: 'BITCOIN_VALIDATOR_MISSING',
|
|
78
|
+
message: 'Bitcoin validator required for btco migrations but not configured',
|
|
79
|
+
details: { targetLayer: options.targetLayer }
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
const bitcoinResult = await bitcoinValidator.validate(options);
|
|
84
|
+
errors.push(...bitcoinResult.errors);
|
|
85
|
+
warnings.push(...bitcoinResult.warnings);
|
|
86
|
+
estimatedCost.networkFees = bitcoinResult.estimatedCost.networkFees;
|
|
87
|
+
estimatedDuration = Math.max(estimatedDuration, bitcoinResult.estimatedDuration);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
// Calculate total cost
|
|
91
|
+
estimatedCost.totalCost = estimatedCost.storageCost + estimatedCost.networkFees;
|
|
92
|
+
return {
|
|
93
|
+
valid: errors.length === 0,
|
|
94
|
+
errors,
|
|
95
|
+
warnings,
|
|
96
|
+
estimatedCost,
|
|
97
|
+
estimatedDuration
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
catch (error) {
|
|
101
|
+
errors.push({
|
|
102
|
+
code: 'VALIDATION_PIPELINE_ERROR',
|
|
103
|
+
message: 'Unexpected error during validation',
|
|
104
|
+
details: { error: error instanceof Error ? error.message : String(error) }
|
|
105
|
+
});
|
|
106
|
+
return {
|
|
107
|
+
valid: false,
|
|
108
|
+
errors,
|
|
109
|
+
warnings,
|
|
110
|
+
estimatedCost,
|
|
111
|
+
estimatedDuration
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Validate basic input parameters
|
|
117
|
+
*/
|
|
118
|
+
validateInput(options) {
|
|
119
|
+
const errors = [];
|
|
120
|
+
// Validate source DID
|
|
121
|
+
if (!options.sourceDid || typeof options.sourceDid !== 'string') {
|
|
122
|
+
errors.push({
|
|
123
|
+
code: 'INVALID_SOURCE_DID',
|
|
124
|
+
message: 'Source DID is required and must be a string',
|
|
125
|
+
field: 'sourceDid'
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
// Validate target layer
|
|
129
|
+
if (!options.targetLayer) {
|
|
130
|
+
errors.push({
|
|
131
|
+
code: 'INVALID_TARGET_LAYER',
|
|
132
|
+
message: 'Target layer is required',
|
|
133
|
+
field: 'targetLayer'
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
else if (!['peer', 'webvh', 'btco'].includes(options.targetLayer)) {
|
|
137
|
+
errors.push({
|
|
138
|
+
code: 'INVALID_TARGET_LAYER',
|
|
139
|
+
message: 'Target layer must be one of: peer, webvh, btco',
|
|
140
|
+
field: 'targetLayer',
|
|
141
|
+
details: { received: options.targetLayer }
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
// Validate partial mode options
|
|
145
|
+
if (options.partialMode) {
|
|
146
|
+
if (typeof options.partialMode.chunkSize !== 'number' || options.partialMode.chunkSize <= 0) {
|
|
147
|
+
errors.push({
|
|
148
|
+
code: 'INVALID_CHUNK_SIZE',
|
|
149
|
+
message: 'Chunk size must be a positive number',
|
|
150
|
+
field: 'partialMode.chunkSize'
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
// Validate webvh-specific options
|
|
155
|
+
if (options.targetLayer === 'webvh' && !options.domain) {
|
|
156
|
+
errors.push({
|
|
157
|
+
code: 'DOMAIN_REQUIRED',
|
|
158
|
+
message: 'Domain is required for webvh migrations',
|
|
159
|
+
field: 'domain'
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
// Validate btco-specific options
|
|
163
|
+
if (options.targetLayer === 'btco') {
|
|
164
|
+
if (options.feeRate !== undefined && (typeof options.feeRate !== 'number' || options.feeRate <= 0)) {
|
|
165
|
+
errors.push({
|
|
166
|
+
code: 'INVALID_FEE_RATE',
|
|
167
|
+
message: 'Fee rate must be a positive number',
|
|
168
|
+
field: 'feeRate'
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return errors;
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Quick validation check (basic only, no async operations)
|
|
176
|
+
*/
|
|
177
|
+
validateQuick(options) {
|
|
178
|
+
return this.validateInput(options);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ResourceManager - CRUD operations for immutable, versioned resources.
|
|
3
|
+
*
|
|
4
|
+
* Resources in the Originals SDK are content-addressed and immutable. Each "update"
|
|
5
|
+
* creates a new version with a new content hash, linked to the previous version
|
|
6
|
+
* via previousVersionHash. This creates a verifiable provenance chain.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```typescript
|
|
10
|
+
* const manager = new ResourceManager();
|
|
11
|
+
*
|
|
12
|
+
* // Create a new resource
|
|
13
|
+
* const resource = manager.createResource('Hello, World!', {
|
|
14
|
+
* type: 'text',
|
|
15
|
+
* contentType: 'text/plain'
|
|
16
|
+
* });
|
|
17
|
+
*
|
|
18
|
+
* // Update creates a new version
|
|
19
|
+
* const updatedResource = manager.updateResource(resource, 'Hello, Updated World!', {
|
|
20
|
+
* changes: 'Updated greeting'
|
|
21
|
+
* });
|
|
22
|
+
*
|
|
23
|
+
* // Get version history
|
|
24
|
+
* const history = manager.getResourceHistory(resource.id);
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
import type { Resource, ResourceOptions, ResourceUpdateOptions, ResourceVersionHistory, ResourceManagerConfig, ResourceValidationResult, ResourceType } from './types.js';
|
|
28
|
+
/**
|
|
29
|
+
* ResourceManager provides CRUD operations for immutable, content-addressed resources
|
|
30
|
+
* with versioning support and validation.
|
|
31
|
+
*/
|
|
32
|
+
export declare class ResourceManager {
|
|
33
|
+
private resources;
|
|
34
|
+
private config;
|
|
35
|
+
/**
|
|
36
|
+
* Create a new ResourceManager instance.
|
|
37
|
+
*
|
|
38
|
+
* @param config - Optional configuration for the manager
|
|
39
|
+
*/
|
|
40
|
+
constructor(config?: ResourceManagerConfig);
|
|
41
|
+
/**
|
|
42
|
+
* Create a new resource from content.
|
|
43
|
+
*
|
|
44
|
+
* @param content - The resource content (string for text, Buffer for binary)
|
|
45
|
+
* @param options - Creation options including type and contentType
|
|
46
|
+
* @returns The created Resource
|
|
47
|
+
* @throws Error if content or options are invalid
|
|
48
|
+
*
|
|
49
|
+
* @example
|
|
50
|
+
* ```typescript
|
|
51
|
+
* // Create a text resource
|
|
52
|
+
* const textResource = manager.createResource('# README\nHello', {
|
|
53
|
+
* type: 'text',
|
|
54
|
+
* contentType: 'text/markdown'
|
|
55
|
+
* });
|
|
56
|
+
*
|
|
57
|
+
* // Create a binary resource (image)
|
|
58
|
+
* const imageBuffer = fs.readFileSync('image.png');
|
|
59
|
+
* const imageResource = manager.createResource(imageBuffer, {
|
|
60
|
+
* type: 'image',
|
|
61
|
+
* contentType: 'image/png'
|
|
62
|
+
* });
|
|
63
|
+
* ```
|
|
64
|
+
*/
|
|
65
|
+
createResource(content: Buffer | string, options: ResourceOptions): Resource;
|
|
66
|
+
/**
|
|
67
|
+
* Update a resource by creating a new version.
|
|
68
|
+
* The original resource remains unchanged (immutable versioning).
|
|
69
|
+
*
|
|
70
|
+
* @param resource - The resource to update (or its ID)
|
|
71
|
+
* @param newContent - The new content
|
|
72
|
+
* @param options - Optional update options including change description
|
|
73
|
+
* @returns The new version of the resource
|
|
74
|
+
* @throws Error if resource not found or content unchanged
|
|
75
|
+
*
|
|
76
|
+
* @example
|
|
77
|
+
* ```typescript
|
|
78
|
+
* const v2 = manager.updateResource(originalResource, 'Updated content', {
|
|
79
|
+
* changes: 'Fixed typo in documentation'
|
|
80
|
+
* });
|
|
81
|
+
*
|
|
82
|
+
* console.log(v2.version); // 2
|
|
83
|
+
* console.log(v2.previousVersionHash); // hash of v1
|
|
84
|
+
* ```
|
|
85
|
+
*/
|
|
86
|
+
updateResource(resource: Resource | string, newContent: Buffer | string, options?: ResourceUpdateOptions): Resource;
|
|
87
|
+
/**
|
|
88
|
+
* Get the complete version history for a resource.
|
|
89
|
+
*
|
|
90
|
+
* @param resourceId - The logical resource ID
|
|
91
|
+
* @returns Array of all versions (oldest to newest), or empty array if not found
|
|
92
|
+
*
|
|
93
|
+
* @example
|
|
94
|
+
* ```typescript
|
|
95
|
+
* const history = manager.getResourceHistory('my-resource-id');
|
|
96
|
+
* console.log(`Found ${history.length} versions`);
|
|
97
|
+
* history.forEach((v, i) => console.log(`v${i + 1}: ${v.hash}`));
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
getResourceHistory(resourceId: string): Resource[];
|
|
101
|
+
/**
|
|
102
|
+
* Get detailed version history with metadata.
|
|
103
|
+
*
|
|
104
|
+
* @param resourceId - The logical resource ID
|
|
105
|
+
* @returns ResourceVersionHistory object or null if not found
|
|
106
|
+
*/
|
|
107
|
+
getResourceVersionHistory(resourceId: string): ResourceVersionHistory | null;
|
|
108
|
+
/**
|
|
109
|
+
* Get a specific version of a resource.
|
|
110
|
+
*
|
|
111
|
+
* @param resourceId - The logical resource ID
|
|
112
|
+
* @param version - Version number (1-indexed)
|
|
113
|
+
* @returns The resource at that version, or null if not found
|
|
114
|
+
*/
|
|
115
|
+
getResourceVersion(resourceId: string, version: number): Resource | null;
|
|
116
|
+
/**
|
|
117
|
+
* Get the current (latest) version of a resource.
|
|
118
|
+
*
|
|
119
|
+
* @param resourceId - The logical resource ID
|
|
120
|
+
* @returns The current version, or null if not found
|
|
121
|
+
*/
|
|
122
|
+
getCurrentVersion(resourceId: string): Resource | null;
|
|
123
|
+
/**
|
|
124
|
+
* Get a resource by its content hash.
|
|
125
|
+
*
|
|
126
|
+
* @param hash - The content hash to search for
|
|
127
|
+
* @returns The resource with that hash, or null if not found
|
|
128
|
+
*/
|
|
129
|
+
getResourceByHash(hash: string): Resource | null;
|
|
130
|
+
/**
|
|
131
|
+
* Validate a resource object.
|
|
132
|
+
*
|
|
133
|
+
* @param resource - The resource to validate
|
|
134
|
+
* @returns ValidationResult with valid flag and any errors/warnings
|
|
135
|
+
*
|
|
136
|
+
* @example
|
|
137
|
+
* ```typescript
|
|
138
|
+
* const result = manager.validateResource(resource);
|
|
139
|
+
* if (!result.valid) {
|
|
140
|
+
* console.error('Validation errors:', result.errors);
|
|
141
|
+
* }
|
|
142
|
+
* if (result.warnings.length > 0) {
|
|
143
|
+
* console.warn('Warnings:', result.warnings);
|
|
144
|
+
* }
|
|
145
|
+
* ```
|
|
146
|
+
*/
|
|
147
|
+
validateResource(resource: Resource): ResourceValidationResult;
|
|
148
|
+
/**
|
|
149
|
+
* Verify the integrity of a resource's version chain.
|
|
150
|
+
* Ensures that previousVersionHash references form a valid chain.
|
|
151
|
+
*
|
|
152
|
+
* @param resourceId - The logical resource ID to verify
|
|
153
|
+
* @returns ResourceValidationResult indicating chain integrity
|
|
154
|
+
*/
|
|
155
|
+
verifyVersionChain(resourceId: string): ResourceValidationResult;
|
|
156
|
+
/**
|
|
157
|
+
* Hash content using SHA-256.
|
|
158
|
+
*
|
|
159
|
+
* @param content - Content to hash (string or Buffer)
|
|
160
|
+
* @returns Hex-encoded SHA-256 hash
|
|
161
|
+
*
|
|
162
|
+
* @example
|
|
163
|
+
* ```typescript
|
|
164
|
+
* const hash = manager.hashContent('Hello, World!');
|
|
165
|
+
* console.log(hash); // 64-character hex string
|
|
166
|
+
* ```
|
|
167
|
+
*/
|
|
168
|
+
hashContent(content: Buffer | string): string;
|
|
169
|
+
/**
|
|
170
|
+
* Delete a resource and all its versions.
|
|
171
|
+
*
|
|
172
|
+
* @param resourceId - The resource ID to delete
|
|
173
|
+
* @returns true if deleted, false if not found
|
|
174
|
+
*/
|
|
175
|
+
deleteResource(resourceId: string): boolean;
|
|
176
|
+
/**
|
|
177
|
+
* List all resource IDs managed by this instance.
|
|
178
|
+
*
|
|
179
|
+
* @returns Array of resource IDs
|
|
180
|
+
*/
|
|
181
|
+
listResourceIds(): string[];
|
|
182
|
+
/**
|
|
183
|
+
* Get the total number of resources (unique IDs) managed.
|
|
184
|
+
*
|
|
185
|
+
* @returns Number of resources
|
|
186
|
+
*/
|
|
187
|
+
getResourceCount(): number;
|
|
188
|
+
/**
|
|
189
|
+
* Get the total number of versions across all resources.
|
|
190
|
+
*
|
|
191
|
+
* @returns Total version count
|
|
192
|
+
*/
|
|
193
|
+
getTotalVersionCount(): number;
|
|
194
|
+
/**
|
|
195
|
+
* Import a resource from an existing AssetResource.
|
|
196
|
+
* Useful for loading resources from storage or external sources.
|
|
197
|
+
*
|
|
198
|
+
* @param assetResource - The AssetResource to import
|
|
199
|
+
* @returns The imported Resource
|
|
200
|
+
*/
|
|
201
|
+
importResource(assetResource: Resource): Resource;
|
|
202
|
+
/**
|
|
203
|
+
* Export all resources as an array (for serialization).
|
|
204
|
+
*
|
|
205
|
+
* @returns Array of all resources (all versions)
|
|
206
|
+
*/
|
|
207
|
+
exportResources(): Resource[];
|
|
208
|
+
/**
|
|
209
|
+
* Clear all resources from this manager.
|
|
210
|
+
*/
|
|
211
|
+
clear(): void;
|
|
212
|
+
/**
|
|
213
|
+
* Infer resource type from MIME type.
|
|
214
|
+
*
|
|
215
|
+
* @param contentType - The MIME content type
|
|
216
|
+
* @returns Inferred ResourceType
|
|
217
|
+
*/
|
|
218
|
+
static inferResourceType(contentType: string): ResourceType;
|
|
219
|
+
/**
|
|
220
|
+
* Check if a string is a valid MIME type format.
|
|
221
|
+
*/
|
|
222
|
+
private isValidMimeType;
|
|
223
|
+
/**
|
|
224
|
+
* Convert content to Buffer.
|
|
225
|
+
*/
|
|
226
|
+
private toBuffer;
|
|
227
|
+
/**
|
|
228
|
+
* Check if content is binary (Buffer) rather than text.
|
|
229
|
+
*/
|
|
230
|
+
private isBinaryContent;
|
|
231
|
+
}
|