@originals/sdk 1.4.2 → 1.4.3
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/package.json +4 -1
- package/.eslintrc.json +0 -33
- package/src/adapters/FeeOracleMock.ts +0 -9
- package/src/adapters/index.ts +0 -5
- 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/fee-calculation.ts +0 -38
- 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/transactions/index.ts +0 -13
- 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/index.ts +0 -74
- 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/kinds/validators/index.ts +0 -12
- 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/index.ts +0 -33
- 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/index.ts +0 -21
- 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/storage/index.ts +0 -3
- 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/index.ts +0 -7
- 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
|
@@ -1,435 +0,0 @@
|
|
|
1
|
-
import { describe, test, expect, beforeEach } from 'bun:test';
|
|
2
|
-
import { OriginalsSDK } from '../../src/core/OriginalsSDK';
|
|
3
|
-
import { OriginalsAsset } from '../../src/lifecycle/OriginalsAsset';
|
|
4
|
-
import type { AssetResource, OriginalsConfig } from '../../src/types';
|
|
5
|
-
import type {
|
|
6
|
-
AssetCreatedEvent,
|
|
7
|
-
AssetMigratedEvent,
|
|
8
|
-
AssetTransferredEvent,
|
|
9
|
-
ResourcePublishedEvent,
|
|
10
|
-
CredentialIssuedEvent
|
|
11
|
-
} from '../../src/events/types';
|
|
12
|
-
import { MockKeyStore } from '../mocks/MockKeyStore';
|
|
13
|
-
import { MemoryStorageAdapter } from '../../src/storage/MemoryStorageAdapter';
|
|
14
|
-
import { OrdMockProvider } from '../../src/adapters/providers/OrdMockProvider';
|
|
15
|
-
import { KeyManager } from '../../src/did/KeyManager';
|
|
16
|
-
|
|
17
|
-
// Helper to create a valid hash
|
|
18
|
-
function makeHash(prefix: string): string {
|
|
19
|
-
// Create a valid hex string by converting prefix to hex and padding with zeros
|
|
20
|
-
const hexPrefix = Buffer.from(prefix).toString('hex');
|
|
21
|
-
return hexPrefix.padEnd(64, '0');
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
// Storage adapter bridge
|
|
25
|
-
class StorageAdapterBridge {
|
|
26
|
-
constructor(private memoryAdapter: MemoryStorageAdapter) {}
|
|
27
|
-
|
|
28
|
-
async put(objectKey: string, data: Buffer | string, options?: { contentType?: string }): Promise<string> {
|
|
29
|
-
const firstSlash = objectKey.indexOf('/');
|
|
30
|
-
const domain = firstSlash >= 0 ? objectKey.substring(0, firstSlash) : objectKey;
|
|
31
|
-
const path = firstSlash >= 0 ? objectKey.substring(firstSlash + 1) : '';
|
|
32
|
-
const content = typeof data === 'string' ? Buffer.from(data) : data;
|
|
33
|
-
return await this.memoryAdapter.putObject(domain, path, new Uint8Array(content));
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
async get(objectKey: string): Promise<{ content: Buffer; contentType: string } | null> {
|
|
37
|
-
const firstSlash = objectKey.indexOf('/');
|
|
38
|
-
const domain = firstSlash >= 0 ? objectKey.substring(0, firstSlash) : objectKey;
|
|
39
|
-
const path = firstSlash >= 0 ? objectKey.substring(firstSlash + 1) : '';
|
|
40
|
-
const result = await this.memoryAdapter.getObject(domain, path);
|
|
41
|
-
if (!result) return null;
|
|
42
|
-
return {
|
|
43
|
-
content: Buffer.from(result.content),
|
|
44
|
-
contentType: result.contentType || 'application/octet-stream'
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
async delete(objectKey: string): Promise<boolean> {
|
|
49
|
-
return false;
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
describe('Integration: Event System', () => {
|
|
54
|
-
let sdk: OriginalsSDK;
|
|
55
|
-
let keyStore: MockKeyStore;
|
|
56
|
-
|
|
57
|
-
beforeEach(async () => {
|
|
58
|
-
keyStore = new MockKeyStore();
|
|
59
|
-
const storageAdapter = new StorageAdapterBridge(new MemoryStorageAdapter());
|
|
60
|
-
|
|
61
|
-
const config: OriginalsConfig = {
|
|
62
|
-
network: 'regtest',
|
|
63
|
-
defaultKeyType: 'Ed25519', // Use Ed25519 for did:webvh compatibility
|
|
64
|
-
enableLogging: false,
|
|
65
|
-
keyStore: keyStore,
|
|
66
|
-
storageAdapter: storageAdapter as any,
|
|
67
|
-
ordinalsProvider: new OrdMockProvider()
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
sdk = new OriginalsSDK(config, keyStore);
|
|
71
|
-
|
|
72
|
-
// Set up publisher DID keys for credential signing
|
|
73
|
-
const keyManager = new KeyManager();
|
|
74
|
-
const publisherKey = await keyManager.generateKeyPair('Ed25519');
|
|
75
|
-
await keyStore.setPrivateKey('did:webvh:example.com:user#key-0', publisherKey.privateKey);
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
describe('asset:created event', () => {
|
|
79
|
-
test('should emit asset:created event when asset is created', async () => {
|
|
80
|
-
const resources: AssetResource[] = [
|
|
81
|
-
{
|
|
82
|
-
id: 'resource-1',
|
|
83
|
-
type: 'text',
|
|
84
|
-
contentType: 'text/plain',
|
|
85
|
-
hash: makeHash('deadbeef'),
|
|
86
|
-
content: 'Hello, World!'
|
|
87
|
-
}
|
|
88
|
-
];
|
|
89
|
-
|
|
90
|
-
let eventReceived = false;
|
|
91
|
-
let capturedEvent: AssetCreatedEvent | null = null;
|
|
92
|
-
|
|
93
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
94
|
-
|
|
95
|
-
// Subscribe after creation to test event was emitted
|
|
96
|
-
asset.on('asset:created', (event) => {
|
|
97
|
-
eventReceived = true;
|
|
98
|
-
capturedEvent = event;
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
// Create another asset to trigger event
|
|
102
|
-
const asset2 = await sdk.lifecycle.createAsset(resources);
|
|
103
|
-
|
|
104
|
-
asset2.on('asset:created', (event) => {
|
|
105
|
-
eventReceived = true;
|
|
106
|
-
capturedEvent = event;
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
// Wait a bit for async emission
|
|
110
|
-
await new Promise(resolve => setTimeout(resolve, 10));
|
|
111
|
-
|
|
112
|
-
// Events should have been emitted during creation
|
|
113
|
-
expect(asset.id).toMatch(/^did:peer:/);
|
|
114
|
-
expect(asset.currentLayer).toBe('did:peer');
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
test('should include correct data in asset:created event', async () => {
|
|
118
|
-
const resources: AssetResource[] = [
|
|
119
|
-
{
|
|
120
|
-
id: 'resource-1',
|
|
121
|
-
type: 'text',
|
|
122
|
-
contentType: 'text/plain',
|
|
123
|
-
hash: makeHash('abc123'),
|
|
124
|
-
content: 'Test'
|
|
125
|
-
},
|
|
126
|
-
{
|
|
127
|
-
id: 'resource-2',
|
|
128
|
-
type: 'image',
|
|
129
|
-
contentType: 'image/png',
|
|
130
|
-
hash: makeHash('def456'),
|
|
131
|
-
content: 'Image data'
|
|
132
|
-
}
|
|
133
|
-
];
|
|
134
|
-
|
|
135
|
-
let capturedEvent: AssetCreatedEvent | null = null;
|
|
136
|
-
|
|
137
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
138
|
-
|
|
139
|
-
// The event was emitted during creation, verify asset state
|
|
140
|
-
expect(asset.id).toMatch(/^did:peer:/);
|
|
141
|
-
expect(asset.currentLayer).toBe('did:peer');
|
|
142
|
-
expect(asset.resources).toHaveLength(2);
|
|
143
|
-
});
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
describe('asset:migrated event', () => {
|
|
147
|
-
test('should emit asset:migrated event when migrating to webvh', async () => {
|
|
148
|
-
const resources: AssetResource[] = [
|
|
149
|
-
{
|
|
150
|
-
id: 'resource-1',
|
|
151
|
-
type: 'text',
|
|
152
|
-
contentType: 'text/plain',
|
|
153
|
-
hash: makeHash('migrate'),
|
|
154
|
-
content: 'Migrate test'
|
|
155
|
-
}
|
|
156
|
-
];
|
|
157
|
-
|
|
158
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
159
|
-
|
|
160
|
-
let eventReceived = false;
|
|
161
|
-
let capturedEvent: AssetMigratedEvent | null = null;
|
|
162
|
-
|
|
163
|
-
asset.on('asset:migrated', (event) => {
|
|
164
|
-
eventReceived = true;
|
|
165
|
-
capturedEvent = event;
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
169
|
-
|
|
170
|
-
expect(eventReceived).toBe(true);
|
|
171
|
-
expect(capturedEvent).not.toBeNull();
|
|
172
|
-
expect(capturedEvent?.type).toBe('asset:migrated');
|
|
173
|
-
expect(capturedEvent?.asset.fromLayer).toBe('did:peer');
|
|
174
|
-
expect(capturedEvent?.asset.toLayer).toBe('did:webvh');
|
|
175
|
-
expect(capturedEvent?.asset.id).toBe(asset.id);
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
test('should emit asset:migrated event when migrating to btco', async () => {
|
|
179
|
-
const resources: AssetResource[] = [
|
|
180
|
-
{
|
|
181
|
-
id: 'resource-1',
|
|
182
|
-
type: 'text',
|
|
183
|
-
contentType: 'text/plain',
|
|
184
|
-
hash: makeHash('btco'),
|
|
185
|
-
content: 'Bitcoin test'
|
|
186
|
-
}
|
|
187
|
-
];
|
|
188
|
-
|
|
189
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
190
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
191
|
-
|
|
192
|
-
let eventReceived = false;
|
|
193
|
-
let capturedEvent: AssetMigratedEvent | null = null;
|
|
194
|
-
|
|
195
|
-
asset.on('asset:migrated', (event) => {
|
|
196
|
-
eventReceived = true;
|
|
197
|
-
capturedEvent = event;
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
201
|
-
|
|
202
|
-
expect(eventReceived).toBe(true);
|
|
203
|
-
expect(capturedEvent).not.toBeNull();
|
|
204
|
-
expect(capturedEvent?.type).toBe('asset:migrated');
|
|
205
|
-
expect(capturedEvent?.asset.fromLayer).toBe('did:webvh');
|
|
206
|
-
expect(capturedEvent?.asset.toLayer).toBe('did:btco');
|
|
207
|
-
expect(capturedEvent?.details).toBeDefined();
|
|
208
|
-
expect(capturedEvent?.details?.inscriptionId).toBeDefined();
|
|
209
|
-
});
|
|
210
|
-
});
|
|
211
|
-
|
|
212
|
-
describe('asset:transferred event', () => {
|
|
213
|
-
test('should emit asset:transferred event', async () => {
|
|
214
|
-
const resources: AssetResource[] = [
|
|
215
|
-
{
|
|
216
|
-
id: 'resource-1',
|
|
217
|
-
type: 'text',
|
|
218
|
-
contentType: 'text/plain',
|
|
219
|
-
hash: makeHash('transfer'),
|
|
220
|
-
content: 'Transfer test'
|
|
221
|
-
}
|
|
222
|
-
];
|
|
223
|
-
|
|
224
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
225
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
226
|
-
await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
227
|
-
|
|
228
|
-
let eventReceived = false;
|
|
229
|
-
let capturedEvent: AssetTransferredEvent | null = null;
|
|
230
|
-
|
|
231
|
-
asset.on('asset:transferred', (event) => {
|
|
232
|
-
eventReceived = true;
|
|
233
|
-
capturedEvent = event;
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
const recipientAddress = 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx';
|
|
237
|
-
await sdk.lifecycle.transferOwnership(asset, recipientAddress);
|
|
238
|
-
|
|
239
|
-
expect(eventReceived).toBe(true);
|
|
240
|
-
expect(capturedEvent).not.toBeNull();
|
|
241
|
-
expect(capturedEvent?.type).toBe('asset:transferred');
|
|
242
|
-
expect(capturedEvent?.to).toBe(recipientAddress);
|
|
243
|
-
expect(capturedEvent?.transactionId).toBeDefined();
|
|
244
|
-
});
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
describe('resource:published event', () => {
|
|
248
|
-
test('should emit resource:published event for each resource', async () => {
|
|
249
|
-
const resources: AssetResource[] = [
|
|
250
|
-
{
|
|
251
|
-
id: 'resource-1',
|
|
252
|
-
type: 'text',
|
|
253
|
-
contentType: 'text/plain',
|
|
254
|
-
hash: makeHash('pub1'),
|
|
255
|
-
content: 'Resource 1'
|
|
256
|
-
},
|
|
257
|
-
{
|
|
258
|
-
id: 'resource-2',
|
|
259
|
-
type: 'text',
|
|
260
|
-
contentType: 'text/plain',
|
|
261
|
-
hash: makeHash('pub2'),
|
|
262
|
-
content: 'Resource 2'
|
|
263
|
-
}
|
|
264
|
-
];
|
|
265
|
-
|
|
266
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
267
|
-
|
|
268
|
-
const publishedEvents: ResourcePublishedEvent[] = [];
|
|
269
|
-
|
|
270
|
-
asset.on('resource:published', (event) => {
|
|
271
|
-
publishedEvents.push(event);
|
|
272
|
-
});
|
|
273
|
-
|
|
274
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
275
|
-
|
|
276
|
-
expect(publishedEvents).toHaveLength(2);
|
|
277
|
-
expect(publishedEvents[0].type).toBe('resource:published');
|
|
278
|
-
expect(publishedEvents[0].resource.id).toBe('resource-1');
|
|
279
|
-
expect(publishedEvents[0].domain).toBe('example.com');
|
|
280
|
-
expect(publishedEvents[1].resource.id).toBe('resource-2');
|
|
281
|
-
});
|
|
282
|
-
});
|
|
283
|
-
|
|
284
|
-
describe('credential:issued event', () => {
|
|
285
|
-
test('should emit credential:issued event during publishToWeb', async () => {
|
|
286
|
-
const resources: AssetResource[] = [
|
|
287
|
-
{
|
|
288
|
-
id: 'resource-1',
|
|
289
|
-
type: 'text',
|
|
290
|
-
contentType: 'text/plain',
|
|
291
|
-
hash: makeHash('cred'),
|
|
292
|
-
content: 'Credential test'
|
|
293
|
-
}
|
|
294
|
-
];
|
|
295
|
-
|
|
296
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
297
|
-
|
|
298
|
-
let eventReceived = false;
|
|
299
|
-
let capturedEvent: CredentialIssuedEvent | null = null;
|
|
300
|
-
|
|
301
|
-
asset.on('credential:issued', (event) => {
|
|
302
|
-
eventReceived = true;
|
|
303
|
-
capturedEvent = event;
|
|
304
|
-
});
|
|
305
|
-
|
|
306
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
307
|
-
|
|
308
|
-
expect(eventReceived).toBe(true);
|
|
309
|
-
expect(capturedEvent).not.toBeNull();
|
|
310
|
-
expect(capturedEvent?.type).toBe('credential:issued');
|
|
311
|
-
expect(capturedEvent?.credential.type).toContain('VerifiableCredential');
|
|
312
|
-
});
|
|
313
|
-
});
|
|
314
|
-
|
|
315
|
-
describe('complete lifecycle with all events', () => {
|
|
316
|
-
test('should emit all events in correct order during complete lifecycle', async () => {
|
|
317
|
-
const resources: AssetResource[] = [
|
|
318
|
-
{
|
|
319
|
-
id: 'resource-1',
|
|
320
|
-
type: 'text',
|
|
321
|
-
contentType: 'text/plain',
|
|
322
|
-
hash: makeHash('complete'),
|
|
323
|
-
content: 'Complete lifecycle'
|
|
324
|
-
}
|
|
325
|
-
];
|
|
326
|
-
|
|
327
|
-
const eventLog: string[] = [];
|
|
328
|
-
|
|
329
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
330
|
-
|
|
331
|
-
// Subscribe to all events
|
|
332
|
-
asset.on('asset:created', () => eventLog.push('created'));
|
|
333
|
-
asset.on('asset:migrated', (event) => eventLog.push(`migrated:${event.asset.toLayer}`));
|
|
334
|
-
asset.on('asset:transferred', () => eventLog.push('transferred'));
|
|
335
|
-
asset.on('resource:published', () => eventLog.push('resource:published'));
|
|
336
|
-
asset.on('credential:issued', () => eventLog.push('credential:issued'));
|
|
337
|
-
|
|
338
|
-
// Execute full lifecycle
|
|
339
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
340
|
-
await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
341
|
-
await sdk.lifecycle.transferOwnership(asset, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx');
|
|
342
|
-
|
|
343
|
-
// Verify events were emitted
|
|
344
|
-
expect(eventLog).toContain('resource:published');
|
|
345
|
-
expect(eventLog).toContain('migrated:did:webvh');
|
|
346
|
-
expect(eventLog).toContain('migrated:did:btco');
|
|
347
|
-
expect(eventLog).toContain('transferred');
|
|
348
|
-
});
|
|
349
|
-
});
|
|
350
|
-
|
|
351
|
-
describe('event handler cleanup', () => {
|
|
352
|
-
test('should properly unsubscribe handlers', async () => {
|
|
353
|
-
const resources: AssetResource[] = [
|
|
354
|
-
{
|
|
355
|
-
id: 'resource-1',
|
|
356
|
-
type: 'text',
|
|
357
|
-
contentType: 'text/plain',
|
|
358
|
-
hash: makeHash('cleanup'),
|
|
359
|
-
content: 'Cleanup test'
|
|
360
|
-
}
|
|
361
|
-
];
|
|
362
|
-
|
|
363
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
364
|
-
|
|
365
|
-
let callCount = 0;
|
|
366
|
-
const unsubscribe = asset.on('asset:migrated', () => {
|
|
367
|
-
callCount++;
|
|
368
|
-
});
|
|
369
|
-
|
|
370
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
371
|
-
expect(callCount).toBe(1);
|
|
372
|
-
|
|
373
|
-
unsubscribe();
|
|
374
|
-
|
|
375
|
-
await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
376
|
-
expect(callCount).toBe(1); // Should not increment after unsubscribe
|
|
377
|
-
});
|
|
378
|
-
|
|
379
|
-
test('should support once() for single emission', async () => {
|
|
380
|
-
const resources: AssetResource[] = [
|
|
381
|
-
{
|
|
382
|
-
id: 'resource-1',
|
|
383
|
-
type: 'text',
|
|
384
|
-
contentType: 'text/plain',
|
|
385
|
-
hash: makeHash('once'),
|
|
386
|
-
content: 'Once test'
|
|
387
|
-
}
|
|
388
|
-
];
|
|
389
|
-
|
|
390
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
391
|
-
|
|
392
|
-
let callCount = 0;
|
|
393
|
-
asset.once('asset:migrated', () => {
|
|
394
|
-
callCount++;
|
|
395
|
-
});
|
|
396
|
-
|
|
397
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
398
|
-
expect(callCount).toBe(1);
|
|
399
|
-
|
|
400
|
-
await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
401
|
-
expect(callCount).toBe(1); // Should not increment on second migration
|
|
402
|
-
});
|
|
403
|
-
});
|
|
404
|
-
|
|
405
|
-
describe('event timing', () => {
|
|
406
|
-
test('should emit events with valid timestamps', async () => {
|
|
407
|
-
const resources: AssetResource[] = [
|
|
408
|
-
{
|
|
409
|
-
id: 'resource-1',
|
|
410
|
-
type: 'text',
|
|
411
|
-
contentType: 'text/plain',
|
|
412
|
-
hash: makeHash('timing'),
|
|
413
|
-
content: 'Timing test'
|
|
414
|
-
}
|
|
415
|
-
];
|
|
416
|
-
|
|
417
|
-
const asset = await sdk.lifecycle.createAsset(resources);
|
|
418
|
-
|
|
419
|
-
let eventTimestamp: string | null = null;
|
|
420
|
-
const beforeTime = Date.now();
|
|
421
|
-
|
|
422
|
-
asset.on('asset:migrated', (event) => {
|
|
423
|
-
eventTimestamp = event.timestamp;
|
|
424
|
-
});
|
|
425
|
-
|
|
426
|
-
await sdk.lifecycle.publishToWeb(asset, 'example.com');
|
|
427
|
-
const afterTime = Date.now();
|
|
428
|
-
|
|
429
|
-
expect(eventTimestamp).not.toBeNull();
|
|
430
|
-
const eventTime = new Date(eventTimestamp!).getTime();
|
|
431
|
-
expect(eventTime).toBeGreaterThanOrEqual(beforeTime);
|
|
432
|
-
expect(eventTime).toBeLessThanOrEqual(afterTime);
|
|
433
|
-
});
|
|
434
|
-
});
|
|
435
|
-
});
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
/* istanbul ignore file */
|
|
2
|
-
import { describe, test, expect } from 'bun:test';
|
|
3
|
-
import { OriginalsSDK, OriginalsAsset } from '../../src';
|
|
4
|
-
import { MockOrdinalsProvider } from '../mocks/adapters';
|
|
5
|
-
|
|
6
|
-
describe('Integration: Lifecycle.transferOwnership for did:btco', () => {
|
|
7
|
-
const provider = new MockOrdinalsProvider();
|
|
8
|
-
const sdk = OriginalsSDK.create({ network: 'regtest', bitcoinRpcUrl: 'http://ord', ordinalsProvider: provider } as any);
|
|
9
|
-
|
|
10
|
-
test('returns txid and records provenance transfer', async () => {
|
|
11
|
-
const asset = new OriginalsAsset(
|
|
12
|
-
[{ id: 'res1', type: 'text', contentType: 'text/plain', hash: 'dead' }],
|
|
13
|
-
{ '@context': ['https://www.w3.org/ns/did/v1'], id: 'did:btco:123' } as any,
|
|
14
|
-
[]
|
|
15
|
-
);
|
|
16
|
-
|
|
17
|
-
const tx = await sdk.lifecycle.transferOwnership(asset, 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx');
|
|
18
|
-
expect(typeof tx.txid).toBe('string');
|
|
19
|
-
const prov = asset.getProvenance();
|
|
20
|
-
expect(prov.transfers.length).toBe(1);
|
|
21
|
-
expect(prov.transfers[0].to).toBe('tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx');
|
|
22
|
-
expect(prov.transfers[0].transactionId).toBe(tx.txid);
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
/** Canonical test aggregator created by combine-tests script. */
|
|
2
|
-
|
|
3
|
-
/** Inlined from LifecycleManager.btco.integration.part.ts */
|
|
4
|
-
import { describe, test, expect } from 'bun:test';
|
|
5
|
-
import { OriginalsSDK } from '../../src';
|
|
6
|
-
import { MockOrdinalsProvider } from '../mocks/adapters';
|
|
7
|
-
|
|
8
|
-
describe('Integration: Lifecycle inscribe updates provenance and btco layer', () => {
|
|
9
|
-
test('provenance updated and layer becomes did:btco', async () => {
|
|
10
|
-
const provider = new MockOrdinalsProvider();
|
|
11
|
-
const sdk = OriginalsSDK.create({ network: 'regtest', bitcoinRpcUrl: 'http://ord', ordinalsProvider: provider } as any);
|
|
12
|
-
const asset = await sdk.lifecycle.createAsset([
|
|
13
|
-
{ id: 'res1', type: 'text', contentType: 'text/plain', hash: 'deadbeef' }
|
|
14
|
-
]);
|
|
15
|
-
const updated = await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
16
|
-
expect(updated.currentLayer).toBe('did:btco');
|
|
17
|
-
const prov = (updated as any).getProvenance();
|
|
18
|
-
const latest = prov.migrations[prov.migrations.length - 1];
|
|
19
|
-
expect(latest.transactionId).toEqual(expect.any(String));
|
|
20
|
-
});
|
|
21
|
-
});
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { describe, test, expect, beforeEach, afterEach, spyOn } from 'bun:test';
|
|
2
|
-
import { KeyManager } from '../../src/did/KeyManager';
|
|
3
|
-
import { createBtcoDidDocument } from '../../src/did/createBtcoDidDocument';
|
|
4
|
-
import { multikey } from '../../src/crypto/Multikey';
|
|
5
|
-
import { DIDManager } from '../../src/did/DIDManager';
|
|
6
|
-
import { Issuer } from '../../src/vc/Issuer';
|
|
7
|
-
import { Verifier } from '../../src/vc/Verifier';
|
|
8
|
-
import { registerVerificationMethod, verificationMethodRegistry } from '../../src/vc/documentLoader';
|
|
9
|
-
|
|
10
|
-
describe('Multikey end-to-end pipeline', () => {
|
|
11
|
-
beforeEach(() => {
|
|
12
|
-
verificationMethodRegistry.clear();
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
afterEach(() => {
|
|
16
|
-
verificationMethodRegistry.clear();
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
test('generates keys, embeds DID, issues and verifies credential', async () => {
|
|
20
|
-
const km = new KeyManager();
|
|
21
|
-
const keyPair = await km.generateKeyPair('Ed25519');
|
|
22
|
-
const decoded = multikey.decodePublicKey(keyPair.publicKey);
|
|
23
|
-
const didDoc = createBtcoDidDocument(123, 'mainnet', {
|
|
24
|
-
publicKey: decoded.key,
|
|
25
|
-
keyType: decoded.type
|
|
26
|
-
});
|
|
27
|
-
const vm = didDoc.verificationMethod?.[0];
|
|
28
|
-
if (!vm) {
|
|
29
|
-
throw new Error('Missing verification method');
|
|
30
|
-
}
|
|
31
|
-
registerVerificationMethod(vm);
|
|
32
|
-
|
|
33
|
-
const didManager = new DIDManager({ network: 'mainnet', defaultKeyType: 'Ed25519' } as any);
|
|
34
|
-
const resolveSpy = spyOn(didManager, 'resolveDID').mockResolvedValue(didDoc);
|
|
35
|
-
|
|
36
|
-
const issuer = new Issuer(didManager, { ...vm, secretKeyMultibase: keyPair.privateKey });
|
|
37
|
-
const unsigned: any = {
|
|
38
|
-
id: 'urn:cred:example',
|
|
39
|
-
type: ['VerifiableCredential'],
|
|
40
|
-
issuer: didDoc.id,
|
|
41
|
-
issuanceDate: new Date().toISOString(),
|
|
42
|
-
credentialSubject: { id: 'did:example:subject' }
|
|
43
|
-
};
|
|
44
|
-
const vc = await issuer.issueCredential(unsigned, { proofPurpose: 'assertionMethod' });
|
|
45
|
-
|
|
46
|
-
const verifier = new Verifier(didManager);
|
|
47
|
-
const res = await verifier.verifyCredential(vc);
|
|
48
|
-
expect(res.verified).toBe(true);
|
|
49
|
-
|
|
50
|
-
resolveSpy.mockRestore();
|
|
51
|
-
});
|
|
52
|
-
});
|