@originals/sdk 1.8.0 → 1.8.2

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.
Files changed (145) hide show
  1. package/dist/utils/hash.js +1 -0
  2. package/package.json +6 -5
  3. package/src/adapters/FeeOracleMock.ts +9 -0
  4. package/src/adapters/index.ts +5 -0
  5. package/src/adapters/providers/OrdHttpProvider.ts +126 -0
  6. package/src/adapters/providers/OrdMockProvider.ts +101 -0
  7. package/src/adapters/types.ts +66 -0
  8. package/src/bitcoin/BitcoinManager.ts +329 -0
  9. package/src/bitcoin/BroadcastClient.ts +54 -0
  10. package/src/bitcoin/OrdinalsClient.ts +120 -0
  11. package/src/bitcoin/PSBTBuilder.ts +106 -0
  12. package/src/bitcoin/fee-calculation.ts +38 -0
  13. package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
  14. package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
  15. package/src/bitcoin/providers/types.ts +59 -0
  16. package/src/bitcoin/transactions/commit.ts +465 -0
  17. package/src/bitcoin/transactions/index.ts +13 -0
  18. package/src/bitcoin/transfer.ts +43 -0
  19. package/src/bitcoin/utxo-selection.ts +322 -0
  20. package/src/bitcoin/utxo.ts +113 -0
  21. package/src/cel/ExternalReferenceManager.ts +87 -0
  22. package/src/cel/OriginalsCel.ts +460 -0
  23. package/src/cel/algorithms/createEventLog.ts +68 -0
  24. package/src/cel/algorithms/deactivateEventLog.ts +109 -0
  25. package/src/cel/algorithms/index.ts +11 -0
  26. package/src/cel/algorithms/updateEventLog.ts +99 -0
  27. package/src/cel/algorithms/verifyEventLog.ts +306 -0
  28. package/src/cel/algorithms/witnessEvent.ts +87 -0
  29. package/src/cel/cli/create.ts +330 -0
  30. package/src/cel/cli/index.ts +383 -0
  31. package/src/cel/cli/inspect.ts +549 -0
  32. package/src/cel/cli/migrate.ts +473 -0
  33. package/src/cel/cli/verify.ts +249 -0
  34. package/src/cel/hash.ts +71 -0
  35. package/src/cel/index.ts +16 -0
  36. package/src/cel/layers/BtcoCelManager.ts +408 -0
  37. package/src/cel/layers/PeerCelManager.ts +371 -0
  38. package/src/cel/layers/WebVHCelManager.ts +361 -0
  39. package/src/cel/layers/index.ts +27 -0
  40. package/src/cel/serialization/cbor.ts +189 -0
  41. package/src/cel/serialization/index.ts +10 -0
  42. package/src/cel/serialization/json.ts +209 -0
  43. package/src/cel/types.ts +160 -0
  44. package/src/cel/witnesses/BitcoinWitness.ts +184 -0
  45. package/src/cel/witnesses/HttpWitness.ts +241 -0
  46. package/src/cel/witnesses/WitnessService.ts +51 -0
  47. package/src/cel/witnesses/index.ts +11 -0
  48. package/src/contexts/credentials-v1.json +237 -0
  49. package/src/contexts/credentials-v2-examples.json +5 -0
  50. package/src/contexts/credentials-v2.json +340 -0
  51. package/src/contexts/credentials.json +237 -0
  52. package/src/contexts/data-integrity-v2.json +81 -0
  53. package/src/contexts/dids.json +58 -0
  54. package/src/contexts/ed255192020.json +93 -0
  55. package/src/contexts/ordinals-plus.json +23 -0
  56. package/src/contexts/originals.json +22 -0
  57. package/src/core/OriginalsSDK.ts +420 -0
  58. package/src/crypto/Multikey.ts +194 -0
  59. package/src/crypto/Signer.ts +262 -0
  60. package/src/crypto/noble-init.ts +138 -0
  61. package/src/did/BtcoDidResolver.ts +231 -0
  62. package/src/did/DIDManager.ts +705 -0
  63. package/src/did/Ed25519Verifier.ts +68 -0
  64. package/src/did/KeyManager.ts +239 -0
  65. package/src/did/WebVHManager.ts +499 -0
  66. package/src/did/createBtcoDidDocument.ts +60 -0
  67. package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
  68. package/src/events/EventEmitter.ts +222 -0
  69. package/src/events/index.ts +19 -0
  70. package/src/events/types.ts +331 -0
  71. package/src/examples/basic-usage.ts +78 -0
  72. package/src/examples/create-module-original.ts +435 -0
  73. package/src/examples/full-lifecycle-flow.ts +514 -0
  74. package/src/examples/run.ts +60 -0
  75. package/src/index.ts +204 -0
  76. package/src/kinds/KindRegistry.ts +320 -0
  77. package/src/kinds/index.ts +74 -0
  78. package/src/kinds/types.ts +470 -0
  79. package/src/kinds/validators/AgentValidator.ts +257 -0
  80. package/src/kinds/validators/AppValidator.ts +211 -0
  81. package/src/kinds/validators/DatasetValidator.ts +242 -0
  82. package/src/kinds/validators/DocumentValidator.ts +311 -0
  83. package/src/kinds/validators/MediaValidator.ts +269 -0
  84. package/src/kinds/validators/ModuleValidator.ts +225 -0
  85. package/src/kinds/validators/base.ts +276 -0
  86. package/src/kinds/validators/index.ts +12 -0
  87. package/src/lifecycle/BatchOperations.ts +381 -0
  88. package/src/lifecycle/LifecycleManager.ts +2156 -0
  89. package/src/lifecycle/OriginalsAsset.ts +524 -0
  90. package/src/lifecycle/ProvenanceQuery.ts +280 -0
  91. package/src/lifecycle/ResourceVersioning.ts +163 -0
  92. package/src/migration/MigrationManager.ts +587 -0
  93. package/src/migration/audit/AuditLogger.ts +176 -0
  94. package/src/migration/checkpoint/CheckpointManager.ts +112 -0
  95. package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
  96. package/src/migration/index.ts +33 -0
  97. package/src/migration/operations/BaseMigration.ts +126 -0
  98. package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
  99. package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
  100. package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
  101. package/src/migration/rollback/RollbackManager.ts +170 -0
  102. package/src/migration/state/StateMachine.ts +92 -0
  103. package/src/migration/state/StateTracker.ts +156 -0
  104. package/src/migration/types.ts +356 -0
  105. package/src/migration/validation/BitcoinValidator.ts +107 -0
  106. package/src/migration/validation/CredentialValidator.ts +62 -0
  107. package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
  108. package/src/migration/validation/LifecycleValidator.ts +64 -0
  109. package/src/migration/validation/StorageValidator.ts +79 -0
  110. package/src/migration/validation/ValidationPipeline.ts +213 -0
  111. package/src/resources/ResourceManager.ts +655 -0
  112. package/src/resources/index.ts +21 -0
  113. package/src/resources/types.ts +202 -0
  114. package/src/storage/LocalStorageAdapter.ts +64 -0
  115. package/src/storage/MemoryStorageAdapter.ts +29 -0
  116. package/src/storage/StorageAdapter.ts +25 -0
  117. package/src/storage/index.ts +3 -0
  118. package/src/types/bitcoin.ts +98 -0
  119. package/src/types/common.ts +92 -0
  120. package/src/types/credentials.ts +89 -0
  121. package/src/types/did.ts +31 -0
  122. package/src/types/external-shims.d.ts +53 -0
  123. package/src/types/index.ts +7 -0
  124. package/src/types/network.ts +178 -0
  125. package/src/utils/EventLogger.ts +298 -0
  126. package/src/utils/Logger.ts +324 -0
  127. package/src/utils/MetricsCollector.ts +358 -0
  128. package/src/utils/bitcoin-address.ts +132 -0
  129. package/src/utils/cbor.ts +31 -0
  130. package/src/utils/encoding.ts +135 -0
  131. package/src/utils/hash.ts +12 -0
  132. package/src/utils/retry.ts +46 -0
  133. package/src/utils/satoshi-validation.ts +196 -0
  134. package/src/utils/serialization.ts +102 -0
  135. package/src/utils/telemetry.ts +44 -0
  136. package/src/utils/validation.ts +123 -0
  137. package/src/vc/CredentialManager.ts +955 -0
  138. package/src/vc/Issuer.ts +105 -0
  139. package/src/vc/Verifier.ts +54 -0
  140. package/src/vc/cryptosuites/bbs.ts +253 -0
  141. package/src/vc/cryptosuites/bbsSimple.ts +21 -0
  142. package/src/vc/cryptosuites/eddsa.ts +99 -0
  143. package/src/vc/documentLoader.ts +81 -0
  144. package/src/vc/proofs/data-integrity.ts +33 -0
  145. package/src/vc/utils/jsonld.ts +18 -0
@@ -0,0 +1,202 @@
1
+ /**
2
+ * Resource types for the Originals SDK ResourceManager.
3
+ *
4
+ * Resources in the Originals protocol are immutable, content-addressed entities
5
+ * that can be versioned through a linked hash chain.
6
+ */
7
+
8
+ import { AssetResource } from '../types/common';
9
+
10
+ /**
11
+ * Supported resource types for categorization
12
+ */
13
+ export type ResourceType =
14
+ | 'image'
15
+ | 'text'
16
+ | 'code'
17
+ | 'data'
18
+ | 'audio'
19
+ | 'video'
20
+ | 'document'
21
+ | 'binary'
22
+ | 'other';
23
+
24
+ /**
25
+ * Options for creating a new resource
26
+ */
27
+ export interface ResourceOptions {
28
+ /** Logical resource ID (optional - will be generated if not provided) */
29
+ id?: string;
30
+
31
+ /** Resource type category */
32
+ type: ResourceType;
33
+
34
+ /** MIME content type (e.g., 'text/plain', 'image/png') */
35
+ contentType: string;
36
+
37
+ /** Optional URL if resource is externally hosted */
38
+ url?: string;
39
+
40
+ /** Optional description of the resource */
41
+ description?: string;
42
+
43
+ /** Maximum allowed size in bytes (optional, uses default if not specified) */
44
+ maxSize?: number;
45
+ }
46
+
47
+ /**
48
+ * Options for updating an existing resource
49
+ */
50
+ export interface ResourceUpdateOptions {
51
+ /** New content type (optional - inherits from previous version if not specified) */
52
+ contentType?: string;
53
+
54
+ /** Description of changes made in this version */
55
+ changes?: string;
56
+ }
57
+
58
+ /**
59
+ * Result of resource validation
60
+ */
61
+ export interface ResourceValidationResult {
62
+ /** Whether the resource is valid */
63
+ valid: boolean;
64
+
65
+ /** Array of error messages if validation failed */
66
+ errors: string[];
67
+
68
+ /** Array of warning messages (non-fatal issues) */
69
+ warnings: string[];
70
+ }
71
+
72
+ /**
73
+ * A resource with its content and metadata
74
+ */
75
+ export interface Resource extends AssetResource {
76
+ /** The actual content (for in-memory resources) */
77
+ content?: string;
78
+
79
+ /** Binary content as base64-encoded string */
80
+ contentBase64?: string;
81
+
82
+ /** Description of the resource */
83
+ description?: string;
84
+ }
85
+
86
+ /**
87
+ * Complete history of a resource including all versions
88
+ */
89
+ export interface ResourceVersionHistory {
90
+ /** Logical resource ID (stable across all versions) */
91
+ resourceId: string;
92
+
93
+ /** All versions in chronological order (oldest first) */
94
+ versions: Resource[];
95
+
96
+ /** The current (latest) version */
97
+ currentVersion: Resource;
98
+
99
+ /** Total number of versions */
100
+ versionCount: number;
101
+ }
102
+
103
+ /**
104
+ * Configuration for the ResourceManager
105
+ */
106
+ export interface ResourceManagerConfig {
107
+ /** Default maximum resource size in bytes (default: 10MB) */
108
+ defaultMaxSize?: number;
109
+
110
+ /** Whether to store content in memory (default: true) */
111
+ storeContent?: boolean;
112
+
113
+ /** Allowed MIME types (if empty, all types allowed) */
114
+ allowedContentTypes?: string[];
115
+
116
+ /** Whether to enable strict MIME type validation (default: true) */
117
+ strictMimeValidation?: boolean;
118
+ }
119
+
120
+ /**
121
+ * Common MIME types and their resource type mappings
122
+ */
123
+ export const MIME_TYPE_MAP: Record<string, ResourceType> = {
124
+ // Images
125
+ 'image/png': 'image',
126
+ 'image/jpeg': 'image',
127
+ 'image/gif': 'image',
128
+ 'image/webp': 'image',
129
+ 'image/svg+xml': 'image',
130
+ 'image/bmp': 'image',
131
+ 'image/tiff': 'image',
132
+
133
+ // Text
134
+ 'text/plain': 'text',
135
+ 'text/html': 'text',
136
+ 'text/css': 'text',
137
+ 'text/csv': 'text',
138
+ 'text/markdown': 'text',
139
+
140
+ // Code
141
+ 'text/javascript': 'code',
142
+ 'application/javascript': 'code',
143
+ 'text/typescript': 'code',
144
+ 'application/typescript': 'code',
145
+ 'text/x-python': 'code',
146
+ 'application/x-python-code': 'code',
147
+ 'text/x-rust': 'code',
148
+ 'text/x-go': 'code',
149
+ 'text/x-java': 'code',
150
+ 'text/x-c': 'code',
151
+ 'text/x-cpp': 'code',
152
+
153
+ // Data formats
154
+ 'application/json': 'data',
155
+ 'application/xml': 'data',
156
+ 'text/xml': 'data',
157
+ 'application/yaml': 'data',
158
+ 'text/yaml': 'data',
159
+ 'application/toml': 'data',
160
+
161
+ // Documents
162
+ 'application/pdf': 'document',
163
+ 'application/msword': 'document',
164
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document': 'document',
165
+ 'application/vnd.ms-excel': 'document',
166
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet': 'document',
167
+ 'application/vnd.ms-powerpoint': 'document',
168
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation': 'document',
169
+
170
+ // Audio
171
+ 'audio/mpeg': 'audio',
172
+ 'audio/mp3': 'audio',
173
+ 'audio/wav': 'audio',
174
+ 'audio/ogg': 'audio',
175
+ 'audio/webm': 'audio',
176
+ 'audio/flac': 'audio',
177
+
178
+ // Video
179
+ 'video/mp4': 'video',
180
+ 'video/webm': 'video',
181
+ 'video/ogg': 'video',
182
+ 'video/quicktime': 'video',
183
+ 'video/x-msvideo': 'video',
184
+
185
+ // Binary
186
+ 'application/octet-stream': 'binary',
187
+ 'application/zip': 'binary',
188
+ 'application/gzip': 'binary',
189
+ 'application/x-tar': 'binary',
190
+ 'application/wasm': 'binary',
191
+ };
192
+
193
+ /**
194
+ * Default configuration values
195
+ */
196
+ export const DEFAULT_RESOURCE_CONFIG: Required<ResourceManagerConfig> = {
197
+ defaultMaxSize: 10 * 1024 * 1024, // 10MB
198
+ storeContent: true,
199
+ allowedContentTypes: [],
200
+ strictMimeValidation: true,
201
+ };
202
+
@@ -0,0 +1,64 @@
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: unknown) {
46
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-assignment
47
+ const error = e as any;
48
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
49
+ if (error && error.code === 'ENOENT') return null;
50
+ throw e;
51
+ }
52
+ }
53
+
54
+ async exists(domain: string, objectPath: string): Promise<boolean> {
55
+ const fullPath = this.resolvePath(domain, objectPath);
56
+ try {
57
+ await fs.access(fullPath);
58
+ return true;
59
+ } catch {
60
+ return false;
61
+ }
62
+ }
63
+ }
64
+
@@ -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
+ 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 Promise.resolve(`mem://${domain}/${objectPath.replace(/^\/+/, '')}`);
17
+ }
18
+
19
+ getObject(domain: string, objectPath: string): Promise<GetObjectResult | null> {
20
+ const stored = globalStore.get(key(domain, objectPath));
21
+ if (!stored) return Promise.resolve(null);
22
+ return Promise.resolve({ content: stored });
23
+ }
24
+
25
+ exists(domain: string, objectPath: string): Promise<boolean> {
26
+ return Promise.resolve(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,3 @@
1
+ export * from './StorageAdapter';
2
+ export * from './MemoryStorageAdapter';
3
+
@@ -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 Turnkey
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
+
@@ -0,0 +1,89 @@
1
+ import { LayerType } from './common';
2
+
3
+ // Verifiable Credentials types
4
+ export interface VerifiableCredential {
5
+ '@context': string[];
6
+ type: string[];
7
+ id?: string;
8
+ issuer: string | Issuer;
9
+ issuanceDate: string;
10
+ expirationDate?: string;
11
+ credentialSubject: CredentialSubject;
12
+ credentialStatus?: CredentialStatus;
13
+ proof?: Proof | Proof[];
14
+ }
15
+
16
+ export interface Issuer {
17
+ id: string;
18
+ name?: string;
19
+ }
20
+
21
+ export interface CredentialSubject {
22
+ id?: string;
23
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
24
+ [key: string]: any;
25
+ }
26
+
27
+ export interface CredentialStatus {
28
+ id: string;
29
+ type: string;
30
+ }
31
+
32
+ export interface Proof {
33
+ type: string;
34
+ created: string;
35
+ verificationMethod: string;
36
+ proofPurpose: string;
37
+ proofValue: string;
38
+ }
39
+
40
+ export interface VerifiablePresentation {
41
+ '@context': string[];
42
+ type: string[];
43
+ id?: string;
44
+ holder: string;
45
+ verifiableCredential: VerifiableCredential[];
46
+ proof?: Proof | Proof[];
47
+ }
48
+
49
+ export interface ResourceCreatedCredential extends VerifiableCredential {
50
+ credentialSubject: {
51
+ id: string;
52
+ resourceId: string;
53
+ resourceType: string;
54
+ createdAt: string;
55
+ creator: string;
56
+ };
57
+ }
58
+
59
+ export interface ResourceUpdatedCredential extends VerifiableCredential {
60
+ credentialSubject: {
61
+ id: string;
62
+ resourceId: string;
63
+ updatedAt: string;
64
+ updateReason?: string;
65
+ };
66
+ }
67
+
68
+ export interface ResourceMigratedCredential extends VerifiableCredential {
69
+ credentialSubject: {
70
+ id: string;
71
+ resourceId: string;
72
+ fromLayer: LayerType;
73
+ toLayer: LayerType;
74
+ migratedAt: string;
75
+ migrationReason?: string;
76
+ };
77
+ }
78
+
79
+ export interface KeyRecoveryCredential extends VerifiableCredential {
80
+ credentialSubject: {
81
+ id: string; // DID that was recovered
82
+ recoveredAt: string; // ISO 8601 timestamp
83
+ recoveryReason: string; // "key_compromise" or other reason
84
+ previousVerificationMethods: string[]; // IDs of compromised keys
85
+ newVerificationMethod: string; // ID of new key
86
+ };
87
+ }
88
+
89
+
@@ -0,0 +1,31 @@
1
+ // W3C DID Document types
2
+ export interface DIDDocument {
3
+ '@context': string[];
4
+ id: string;
5
+ verificationMethod?: VerificationMethod[];
6
+ authentication?: (string | VerificationMethod)[];
7
+ assertionMethod?: (string | VerificationMethod)[];
8
+ keyAgreement?: (string | VerificationMethod)[];
9
+ capabilityInvocation?: (string | VerificationMethod)[];
10
+ capabilityDelegation?: (string | VerificationMethod)[];
11
+ service?: ServiceEndpoint[];
12
+ controller?: string[];
13
+ alsoKnownAs?: string[];
14
+ }
15
+
16
+ export interface VerificationMethod {
17
+ id: string;
18
+ type: string;
19
+ controller: string;
20
+ publicKeyMultibase: string;
21
+ revoked?: string; // ISO 8601 timestamp when the key was revoked
22
+ compromised?: string; // ISO 8601 timestamp when the key was marked as compromised
23
+ }
24
+
25
+ export interface ServiceEndpoint {
26
+ id: string;
27
+ type: string;
28
+ serviceEndpoint: string | object;
29
+ }
30
+
31
+
@@ -0,0 +1,53 @@
1
+ declare module 'cbor-js' {
2
+ export function encode(value: unknown): ArrayBuffer | Uint8Array;
3
+ export function decode(buffer: ArrayBufferLike): unknown;
4
+ const _default: {
5
+ encode: typeof encode;
6
+ decode: typeof decode;
7
+ };
8
+ export default _default;
9
+ }
10
+
11
+ declare module 'multiformats/bases/base64' {
12
+ export const base64url: {
13
+ encode: (bytes: Uint8Array) => string;
14
+ decode: (s: string) => Uint8Array;
15
+ };
16
+ }
17
+
18
+ declare module 'jsonld';
19
+ declare module 'b58';
20
+ declare module '@aviarytech/did-peer' {
21
+ export interface ServiceEndpoint {
22
+ id: string;
23
+ type: string;
24
+ serviceEndpoint: string | Record<string, unknown>;
25
+ [key: string]: unknown;
26
+ }
27
+
28
+ export interface IDIDDocument {
29
+ '@context'?: string | string[];
30
+ id: string;
31
+ controller?: string | string[];
32
+ verificationMethod?: IDIDDocumentVerificationMethod[];
33
+ authentication?: Array<string | IDIDDocumentVerificationMethod>;
34
+ assertionMethod?: Array<string | IDIDDocumentVerificationMethod>;
35
+ keyAgreement?: Array<string | IDIDDocumentVerificationMethod>;
36
+ capabilityInvocation?: Array<string | IDIDDocumentVerificationMethod>;
37
+ capabilityDelegation?: Array<string | IDIDDocumentVerificationMethod>;
38
+ service?: ServiceEndpoint[];
39
+ [key: string]: unknown;
40
+ }
41
+
42
+ export type IDIDDocumentVerificationMethod = { id?: string; type: string; controller?: string; publicKeyMultibase?: string };
43
+ export function create(numalgo: number, authenticationKeys: IDIDDocumentVerificationMethod[], encryptionKeys?: IDIDDocumentVerificationMethod[], service?: ServiceEndpoint): Promise<string>;
44
+ export function createNumAlgo0(authenticationKey: IDIDDocumentVerificationMethod): Promise<string>;
45
+ export function createNumAlgo2(authenticationKeys: IDIDDocumentVerificationMethod[], encryptionKeys?: IDIDDocumentVerificationMethod[], service?: ServiceEndpoint[]): Promise<string>;
46
+ export function createNumAlgo4(authenticationKeys: IDIDDocumentVerificationMethod[], encryptionKeys?: IDIDDocumentVerificationMethod[], service?: ServiceEndpoint[]): Promise<string>;
47
+ export function resolve(did: string, repository?: Record<string, unknown>): Promise<IDIDDocument>;
48
+ }
49
+
50
+ // Global shims for non-DOM/node test environments
51
+ declare const global: Record<string, unknown> & typeof globalThis;
52
+ declare function setTimeout(handler: (...args: unknown[]) => void, timeout?: number, ...args: unknown[]): number;
53
+