@originals/sdk 1.4.3 → 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.
Files changed (222) hide show
  1. package/dist/adapters/FeeOracleMock.d.ts +6 -0
  2. package/dist/adapters/FeeOracleMock.js +8 -0
  3. package/dist/adapters/index.d.ts +4 -0
  4. package/dist/adapters/index.js +4 -0
  5. package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
  6. package/dist/adapters/providers/OrdHttpProvider.js +110 -0
  7. package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
  8. package/dist/adapters/providers/OrdMockProvider.js +75 -0
  9. package/dist/adapters/types.d.ts +71 -0
  10. package/dist/adapters/types.js +1 -0
  11. package/dist/bitcoin/BitcoinManager.d.ts +15 -0
  12. package/dist/bitcoin/BitcoinManager.js +262 -0
  13. package/dist/bitcoin/BroadcastClient.d.ts +30 -0
  14. package/dist/bitcoin/BroadcastClient.js +35 -0
  15. package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
  16. package/dist/bitcoin/OrdinalsClient.js +105 -0
  17. package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
  18. package/dist/bitcoin/PSBTBuilder.js +80 -0
  19. package/dist/bitcoin/fee-calculation.d.ts +14 -0
  20. package/dist/bitcoin/fee-calculation.js +31 -0
  21. package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
  22. package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
  23. package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
  24. package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
  25. package/dist/bitcoin/providers/types.d.ts +63 -0
  26. package/dist/bitcoin/providers/types.js +1 -0
  27. package/dist/bitcoin/transactions/commit.d.ts +89 -0
  28. package/dist/bitcoin/transactions/commit.js +311 -0
  29. package/dist/bitcoin/transactions/index.d.ts +7 -0
  30. package/dist/bitcoin/transactions/index.js +8 -0
  31. package/dist/bitcoin/transfer.d.ts +9 -0
  32. package/dist/bitcoin/transfer.js +26 -0
  33. package/dist/bitcoin/utxo-selection.d.ts +78 -0
  34. package/dist/bitcoin/utxo-selection.js +237 -0
  35. package/dist/bitcoin/utxo.d.ts +26 -0
  36. package/dist/bitcoin/utxo.js +78 -0
  37. package/dist/contexts/credentials-v1.json +195 -0
  38. package/dist/contexts/credentials-v2-examples.json +5 -0
  39. package/dist/contexts/credentials-v2.json +301 -0
  40. package/dist/contexts/credentials.json +195 -0
  41. package/dist/contexts/data-integrity-v2.json +81 -0
  42. package/dist/contexts/dids.json +57 -0
  43. package/dist/contexts/ed255192020.json +93 -0
  44. package/dist/contexts/ordinals-plus.json +23 -0
  45. package/dist/contexts/originals.json +22 -0
  46. package/dist/core/OriginalsSDK.d.ts +158 -0
  47. package/dist/core/OriginalsSDK.js +274 -0
  48. package/dist/crypto/Multikey.d.ts +30 -0
  49. package/dist/crypto/Multikey.js +149 -0
  50. package/dist/crypto/Signer.d.ts +21 -0
  51. package/dist/crypto/Signer.js +196 -0
  52. package/dist/crypto/noble-init.d.ts +18 -0
  53. package/dist/crypto/noble-init.js +106 -0
  54. package/dist/did/BtcoDidResolver.d.ts +57 -0
  55. package/dist/did/BtcoDidResolver.js +166 -0
  56. package/dist/did/DIDManager.d.ts +101 -0
  57. package/dist/did/DIDManager.js +493 -0
  58. package/dist/did/Ed25519Verifier.d.ts +30 -0
  59. package/dist/did/Ed25519Verifier.js +59 -0
  60. package/dist/did/KeyManager.d.ts +17 -0
  61. package/dist/did/KeyManager.js +207 -0
  62. package/dist/did/WebVHManager.d.ts +100 -0
  63. package/dist/did/WebVHManager.js +312 -0
  64. package/dist/did/createBtcoDidDocument.d.ts +10 -0
  65. package/dist/did/createBtcoDidDocument.js +42 -0
  66. package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
  67. package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
  68. package/dist/events/EventEmitter.d.ts +115 -0
  69. package/dist/events/EventEmitter.js +198 -0
  70. package/dist/events/index.d.ts +7 -0
  71. package/dist/events/index.js +6 -0
  72. package/dist/events/types.d.ts +286 -0
  73. package/dist/events/types.js +9 -0
  74. package/dist/examples/basic-usage.d.ts +3 -0
  75. package/dist/examples/basic-usage.js +62 -0
  76. package/dist/examples/create-module-original.d.ts +32 -0
  77. package/dist/examples/create-module-original.js +376 -0
  78. package/dist/examples/full-lifecycle-flow.d.ts +56 -0
  79. package/dist/examples/full-lifecycle-flow.js +419 -0
  80. package/dist/examples/run.d.ts +12 -0
  81. package/dist/examples/run.js +51 -0
  82. package/dist/index.d.ts +43 -0
  83. package/dist/index.js +52 -0
  84. package/dist/kinds/KindRegistry.d.ts +76 -0
  85. package/dist/kinds/KindRegistry.js +216 -0
  86. package/dist/kinds/index.d.ts +33 -0
  87. package/dist/kinds/index.js +36 -0
  88. package/dist/kinds/types.d.ts +363 -0
  89. package/dist/kinds/types.js +25 -0
  90. package/dist/kinds/validators/AgentValidator.d.ts +14 -0
  91. package/dist/kinds/validators/AgentValidator.js +155 -0
  92. package/dist/kinds/validators/AppValidator.d.ts +14 -0
  93. package/dist/kinds/validators/AppValidator.js +135 -0
  94. package/dist/kinds/validators/DatasetValidator.d.ts +14 -0
  95. package/dist/kinds/validators/DatasetValidator.js +148 -0
  96. package/dist/kinds/validators/DocumentValidator.d.ts +14 -0
  97. package/dist/kinds/validators/DocumentValidator.js +180 -0
  98. package/dist/kinds/validators/MediaValidator.d.ts +14 -0
  99. package/dist/kinds/validators/MediaValidator.js +172 -0
  100. package/dist/kinds/validators/ModuleValidator.d.ts +14 -0
  101. package/dist/kinds/validators/ModuleValidator.js +140 -0
  102. package/dist/kinds/validators/base.d.ts +96 -0
  103. package/dist/kinds/validators/base.js +218 -0
  104. package/dist/kinds/validators/index.d.ts +10 -0
  105. package/dist/kinds/validators/index.js +10 -0
  106. package/dist/lifecycle/BatchOperations.d.ts +147 -0
  107. package/dist/lifecycle/BatchOperations.js +251 -0
  108. package/dist/lifecycle/LifecycleManager.d.ts +362 -0
  109. package/dist/lifecycle/LifecycleManager.js +1692 -0
  110. package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
  111. package/dist/lifecycle/OriginalsAsset.js +380 -0
  112. package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
  113. package/dist/lifecycle/ProvenanceQuery.js +220 -0
  114. package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
  115. package/dist/lifecycle/ResourceVersioning.js +127 -0
  116. package/dist/migration/MigrationManager.d.ts +86 -0
  117. package/dist/migration/MigrationManager.js +412 -0
  118. package/dist/migration/audit/AuditLogger.d.ts +51 -0
  119. package/dist/migration/audit/AuditLogger.js +156 -0
  120. package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
  121. package/dist/migration/checkpoint/CheckpointManager.js +96 -0
  122. package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
  123. package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
  124. package/dist/migration/index.d.ts +22 -0
  125. package/dist/migration/index.js +27 -0
  126. package/dist/migration/operations/BaseMigration.d.ts +48 -0
  127. package/dist/migration/operations/BaseMigration.js +83 -0
  128. package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
  129. package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
  130. package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
  131. package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
  132. package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
  133. package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
  134. package/dist/migration/rollback/RollbackManager.d.ts +29 -0
  135. package/dist/migration/rollback/RollbackManager.js +146 -0
  136. package/dist/migration/state/StateMachine.d.ts +25 -0
  137. package/dist/migration/state/StateMachine.js +76 -0
  138. package/dist/migration/state/StateTracker.d.ts +36 -0
  139. package/dist/migration/state/StateTracker.js +123 -0
  140. package/dist/migration/types.d.ts +306 -0
  141. package/dist/migration/types.js +33 -0
  142. package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
  143. package/dist/migration/validation/BitcoinValidator.js +83 -0
  144. package/dist/migration/validation/CredentialValidator.d.ts +13 -0
  145. package/dist/migration/validation/CredentialValidator.js +46 -0
  146. package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
  147. package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
  148. package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
  149. package/dist/migration/validation/LifecycleValidator.js +52 -0
  150. package/dist/migration/validation/StorageValidator.d.ts +10 -0
  151. package/dist/migration/validation/StorageValidator.js +65 -0
  152. package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
  153. package/dist/migration/validation/ValidationPipeline.js +180 -0
  154. package/dist/resources/ResourceManager.d.ts +231 -0
  155. package/dist/resources/ResourceManager.js +573 -0
  156. package/dist/resources/index.d.ts +11 -0
  157. package/dist/resources/index.js +10 -0
  158. package/dist/resources/types.d.ts +93 -0
  159. package/dist/resources/types.js +80 -0
  160. package/dist/storage/LocalStorageAdapter.d.ts +11 -0
  161. package/dist/storage/LocalStorageAdapter.js +53 -0
  162. package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
  163. package/dist/storage/MemoryStorageAdapter.js +21 -0
  164. package/dist/storage/StorageAdapter.d.ts +16 -0
  165. package/dist/storage/StorageAdapter.js +1 -0
  166. package/dist/storage/index.d.ts +2 -0
  167. package/dist/storage/index.js +2 -0
  168. package/dist/types/bitcoin.d.ts +84 -0
  169. package/dist/types/bitcoin.js +1 -0
  170. package/dist/types/common.d.ts +82 -0
  171. package/dist/types/common.js +1 -0
  172. package/dist/types/credentials.d.ts +75 -0
  173. package/dist/types/credentials.js +1 -0
  174. package/dist/types/did.d.ts +26 -0
  175. package/dist/types/did.js +1 -0
  176. package/dist/types/index.d.ts +5 -0
  177. package/dist/types/index.js +5 -0
  178. package/dist/types/network.d.ts +78 -0
  179. package/dist/types/network.js +145 -0
  180. package/dist/utils/EventLogger.d.ts +71 -0
  181. package/dist/utils/EventLogger.js +232 -0
  182. package/dist/utils/Logger.d.ts +106 -0
  183. package/dist/utils/Logger.js +257 -0
  184. package/dist/utils/MetricsCollector.d.ts +110 -0
  185. package/dist/utils/MetricsCollector.js +264 -0
  186. package/dist/utils/bitcoin-address.d.ts +38 -0
  187. package/dist/utils/bitcoin-address.js +113 -0
  188. package/dist/utils/cbor.d.ts +2 -0
  189. package/dist/utils/cbor.js +9 -0
  190. package/dist/utils/encoding.d.ts +37 -0
  191. package/dist/utils/encoding.js +120 -0
  192. package/dist/utils/hash.d.ts +1 -0
  193. package/dist/utils/hash.js +5 -0
  194. package/dist/utils/retry.d.ts +10 -0
  195. package/dist/utils/retry.js +35 -0
  196. package/dist/utils/satoshi-validation.d.ts +60 -0
  197. package/dist/utils/satoshi-validation.js +156 -0
  198. package/dist/utils/serialization.d.ts +14 -0
  199. package/dist/utils/serialization.js +76 -0
  200. package/dist/utils/telemetry.d.ts +17 -0
  201. package/dist/utils/telemetry.js +24 -0
  202. package/dist/utils/validation.d.ts +5 -0
  203. package/dist/utils/validation.js +98 -0
  204. package/dist/vc/CredentialManager.d.ts +329 -0
  205. package/dist/vc/CredentialManager.js +615 -0
  206. package/dist/vc/Issuer.d.ts +27 -0
  207. package/dist/vc/Issuer.js +70 -0
  208. package/dist/vc/Verifier.d.ts +16 -0
  209. package/dist/vc/Verifier.js +50 -0
  210. package/dist/vc/cryptosuites/bbs.d.ts +44 -0
  211. package/dist/vc/cryptosuites/bbs.js +213 -0
  212. package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
  213. package/dist/vc/cryptosuites/bbsSimple.js +12 -0
  214. package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
  215. package/dist/vc/cryptosuites/eddsa.js +81 -0
  216. package/dist/vc/documentLoader.d.ts +16 -0
  217. package/dist/vc/documentLoader.js +59 -0
  218. package/dist/vc/proofs/data-integrity.d.ts +21 -0
  219. package/dist/vc/proofs/data-integrity.js +15 -0
  220. package/dist/vc/utils/jsonld.d.ts +2 -0
  221. package/dist/vc/utils/jsonld.js +15 -0
  222. package/package.json +2 -1
@@ -0,0 +1,80 @@
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
+ * Common MIME types and their resource type mappings
9
+ */
10
+ export const MIME_TYPE_MAP = {
11
+ // Images
12
+ 'image/png': 'image',
13
+ 'image/jpeg': 'image',
14
+ 'image/gif': 'image',
15
+ 'image/webp': 'image',
16
+ 'image/svg+xml': 'image',
17
+ 'image/bmp': 'image',
18
+ 'image/tiff': 'image',
19
+ // Text
20
+ 'text/plain': 'text',
21
+ 'text/html': 'text',
22
+ 'text/css': 'text',
23
+ 'text/csv': 'text',
24
+ 'text/markdown': 'text',
25
+ // Code
26
+ 'text/javascript': 'code',
27
+ 'application/javascript': 'code',
28
+ 'text/typescript': 'code',
29
+ 'application/typescript': 'code',
30
+ 'text/x-python': 'code',
31
+ 'application/x-python-code': 'code',
32
+ 'text/x-rust': 'code',
33
+ 'text/x-go': 'code',
34
+ 'text/x-java': 'code',
35
+ 'text/x-c': 'code',
36
+ 'text/x-cpp': 'code',
37
+ // Data formats
38
+ 'application/json': 'data',
39
+ 'application/xml': 'data',
40
+ 'text/xml': 'data',
41
+ 'application/yaml': 'data',
42
+ 'text/yaml': 'data',
43
+ 'application/toml': 'data',
44
+ // Documents
45
+ 'application/pdf': 'document',
46
+ 'application/msword': 'document',
47
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document': 'document',
48
+ 'application/vnd.ms-excel': 'document',
49
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet': 'document',
50
+ 'application/vnd.ms-powerpoint': 'document',
51
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation': 'document',
52
+ // Audio
53
+ 'audio/mpeg': 'audio',
54
+ 'audio/mp3': 'audio',
55
+ 'audio/wav': 'audio',
56
+ 'audio/ogg': 'audio',
57
+ 'audio/webm': 'audio',
58
+ 'audio/flac': 'audio',
59
+ // Video
60
+ 'video/mp4': 'video',
61
+ 'video/webm': 'video',
62
+ 'video/ogg': 'video',
63
+ 'video/quicktime': 'video',
64
+ 'video/x-msvideo': 'video',
65
+ // Binary
66
+ 'application/octet-stream': 'binary',
67
+ 'application/zip': 'binary',
68
+ 'application/gzip': 'binary',
69
+ 'application/x-tar': 'binary',
70
+ 'application/wasm': 'binary',
71
+ };
72
+ /**
73
+ * Default configuration values
74
+ */
75
+ export const DEFAULT_RESOURCE_CONFIG = {
76
+ defaultMaxSize: 10 * 1024 * 1024, // 10MB
77
+ storeContent: true,
78
+ allowedContentTypes: [],
79
+ strictMimeValidation: true,
80
+ };
@@ -0,0 +1,11 @@
1
+ import { GetObjectResult, LocalStorageAdapterOptions, StorageAdapter } from './StorageAdapter';
2
+ export declare class LocalStorageAdapter implements StorageAdapter {
3
+ private baseDir;
4
+ private baseUrl?;
5
+ constructor(options: LocalStorageAdapterOptions);
6
+ private resolvePath;
7
+ private toUrl;
8
+ putObject(domain: string, objectPath: string, content: Uint8Array | string): Promise<string>;
9
+ getObject(domain: string, objectPath: string): Promise<GetObjectResult | null>;
10
+ exists(domain: string, objectPath: string): Promise<boolean>;
11
+ }
@@ -0,0 +1,53 @@
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
+ export class LocalStorageAdapter {
7
+ constructor(options) {
8
+ this.baseDir = options.baseDir;
9
+ this.baseUrl = options.baseUrl;
10
+ }
11
+ resolvePath(domain, objectPath) {
12
+ const safeDomain = domain.replace(/[^a-zA-Z0-9.-]/g, '_');
13
+ const cleanPath = objectPath.replace(/^\/+/, '');
14
+ return path.join(this.baseDir, safeDomain, cleanPath);
15
+ }
16
+ toUrl(domain, objectPath) {
17
+ const cleanPath = objectPath.replace(/^\/+/, '');
18
+ if (this.baseUrl) {
19
+ const trimmed = this.baseUrl.replace(/\/$/, '');
20
+ return `${trimmed}/${domain}/${cleanPath}`;
21
+ }
22
+ return `file://${this.resolvePath(domain, cleanPath)}`;
23
+ }
24
+ async putObject(domain, objectPath, content) {
25
+ const fullPath = this.resolvePath(domain, objectPath);
26
+ await fs.mkdir(path.dirname(fullPath), { recursive: true });
27
+ const data = typeof content === 'string' ? Buffer.from(content) : Buffer.from(content);
28
+ await fs.writeFile(fullPath, data);
29
+ return this.toUrl(domain, objectPath);
30
+ }
31
+ async getObject(domain, objectPath) {
32
+ const fullPath = this.resolvePath(domain, objectPath);
33
+ try {
34
+ const content = await fs.readFile(fullPath);
35
+ return { content: new Uint8Array(content) };
36
+ }
37
+ catch (e) {
38
+ if (e && e.code === 'ENOENT')
39
+ return null;
40
+ throw e;
41
+ }
42
+ }
43
+ async exists(domain, objectPath) {
44
+ const fullPath = this.resolvePath(domain, objectPath);
45
+ try {
46
+ await fs.access(fullPath);
47
+ return true;
48
+ }
49
+ catch {
50
+ return false;
51
+ }
52
+ }
53
+ }
@@ -0,0 +1,6 @@
1
+ import { GetObjectResult, StorageAdapter } from './StorageAdapter';
2
+ export declare class MemoryStorageAdapter implements StorageAdapter {
3
+ putObject(domain: string, objectPath: string, content: Uint8Array | string): Promise<string>;
4
+ getObject(domain: string, objectPath: string): Promise<GetObjectResult | null>;
5
+ exists(domain: string, objectPath: string): Promise<boolean>;
6
+ }
@@ -0,0 +1,21 @@
1
+ const globalStore = new Map();
2
+ function key(domain, objectPath) {
3
+ const cleanPath = objectPath.replace(/^\/+/, '');
4
+ return `${domain}::${cleanPath}`;
5
+ }
6
+ export class MemoryStorageAdapter {
7
+ async putObject(domain, objectPath, content) {
8
+ const data = typeof content === 'string' ? new TextEncoder().encode(content) : content;
9
+ globalStore.set(key(domain, objectPath), data);
10
+ return `mem://${domain}/${objectPath.replace(/^\/+/, '')}`;
11
+ }
12
+ async getObject(domain, objectPath) {
13
+ const stored = globalStore.get(key(domain, objectPath));
14
+ if (!stored)
15
+ return null;
16
+ return { content: stored };
17
+ }
18
+ async exists(domain, objectPath) {
19
+ return globalStore.has(key(domain, objectPath));
20
+ }
21
+ }
@@ -0,0 +1,16 @@
1
+ export interface PutOptions {
2
+ contentType?: string;
3
+ }
4
+ export interface GetObjectResult {
5
+ content: Uint8Array;
6
+ contentType?: string;
7
+ }
8
+ export interface StorageAdapter {
9
+ putObject(domain: string, path: string, content: Uint8Array | string, options?: PutOptions): Promise<string>;
10
+ getObject(domain: string, path: string): Promise<GetObjectResult | null>;
11
+ exists(domain: string, path: string): Promise<boolean>;
12
+ }
13
+ export interface LocalStorageAdapterOptions {
14
+ baseDir: string;
15
+ baseUrl?: string;
16
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,2 @@
1
+ export * from './StorageAdapter';
2
+ export * from './MemoryStorageAdapter';
@@ -0,0 +1,2 @@
1
+ export * from './StorageAdapter';
2
+ export * from './MemoryStorageAdapter';
@@ -0,0 +1,84 @@
1
+ export interface OrdinalsInscription {
2
+ satoshi: string;
3
+ inscriptionId: string;
4
+ content: Buffer;
5
+ contentType: string;
6
+ txid: string;
7
+ vout: number;
8
+ blockHeight?: number;
9
+ }
10
+ export interface BitcoinTransaction {
11
+ txid: string;
12
+ vin: TransactionInput[];
13
+ vout: TransactionOutput[];
14
+ fee: number;
15
+ blockHeight?: number;
16
+ confirmations?: number;
17
+ }
18
+ export interface TransactionInput {
19
+ txid: string;
20
+ vout: number;
21
+ scriptSig?: string;
22
+ witness?: string[];
23
+ }
24
+ export interface TransactionOutput {
25
+ value: number;
26
+ scriptPubKey: string;
27
+ address?: string;
28
+ }
29
+ export interface Utxo {
30
+ txid: string;
31
+ vout: number;
32
+ value: number;
33
+ scriptPubKey?: string;
34
+ address?: string;
35
+ inscriptions?: string[];
36
+ locked?: boolean;
37
+ }
38
+ /**
39
+ * Extended UTXO interface that tracks whether it contains an Ordinals resource (inscription)
40
+ */
41
+ export interface ResourceUtxo extends Utxo {
42
+ /** True if this UTXO contains an inscription or other Ordinals resource */
43
+ hasResource?: boolean;
44
+ }
45
+ /**
46
+ * Strategy for selecting UTXOs
47
+ */
48
+ export type UtxoSelectionStrategy = 'minimize_change' | 'minimize_inputs' | 'optimize_size';
49
+ /**
50
+ * Options for resource-aware UTXO selection
51
+ */
52
+ export interface ResourceUtxoSelectionOptions {
53
+ /** Required amount in satoshis */
54
+ requiredAmount: number;
55
+ /** Fee rate in satoshis per vbyte */
56
+ feeRate: number;
57
+ /** Allow using UTXOs that contain resources (default: false) */
58
+ allowResourceUtxos?: boolean;
59
+ /** Prefer older UTXOs (default: false) */
60
+ preferOlder?: boolean;
61
+ /** Prefer UTXOs with value closer to required amount (default: false) */
62
+ preferCloserAmount?: boolean;
63
+ /** List of UTXO IDs to avoid using (format: "txid:vout") */
64
+ avoidUtxoIds?: string[];
65
+ }
66
+ /**
67
+ * Result of resource-aware UTXO selection
68
+ */
69
+ export interface ResourceUtxoSelectionResult {
70
+ /** Selected UTXOs for the transaction */
71
+ selectedUtxos: ResourceUtxo[];
72
+ /** Total value of selected UTXOs */
73
+ totalSelectedValue: number;
74
+ /** Estimated transaction fee in satoshis */
75
+ estimatedFee: number;
76
+ /** Change amount in satoshis (0 if less than dust) */
77
+ changeAmount: number;
78
+ }
79
+ export declare const DUST_LIMIT_SATS = 546;
80
+ export interface KeyPair {
81
+ privateKey: string;
82
+ publicKey: string;
83
+ }
84
+ export type KeyType = 'ES256K' | 'Ed25519' | 'ES256';
@@ -0,0 +1 @@
1
+ export const DUST_LIMIT_SATS = 546;
@@ -0,0 +1,82 @@
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
+ export type LayerType = 'did:peer' | 'did:webvh' | 'did:btco';
7
+ export interface OriginalsConfig {
8
+ network: 'mainnet' | 'regtest' | 'signet';
9
+ bitcoinRpcUrl?: string;
10
+ defaultKeyType: 'ES256K' | 'Ed25519' | 'ES256';
11
+ keyStore?: KeyStore;
12
+ enableLogging?: boolean;
13
+ webvhNetwork?: WebVHNetworkName;
14
+ storageAdapter?: StorageAdapter;
15
+ feeOracle?: FeeOracleAdapter;
16
+ ordinalsProvider?: OrdinalsProvider;
17
+ telemetry?: TelemetryHooks;
18
+ logging?: {
19
+ level?: LogLevel;
20
+ outputs?: LogOutput[];
21
+ includeTimestamps?: boolean;
22
+ includeContext?: boolean;
23
+ eventLogging?: EventLoggingConfig;
24
+ sanitizeLogs?: boolean;
25
+ };
26
+ metrics?: {
27
+ enabled?: boolean;
28
+ exportFormat?: 'json' | 'prometheus';
29
+ collectCache?: boolean;
30
+ };
31
+ }
32
+ export interface AssetResource {
33
+ id: string;
34
+ type: string;
35
+ url?: string;
36
+ content?: string;
37
+ contentType: string;
38
+ hash: string;
39
+ size?: number;
40
+ version?: number;
41
+ previousVersionHash?: string;
42
+ createdAt?: string;
43
+ }
44
+ export interface KeyStore {
45
+ getPrivateKey(verificationMethodId: string): Promise<string | null>;
46
+ setPrivateKey(verificationMethodId: string, privateKey: string): Promise<void>;
47
+ }
48
+ /**
49
+ * External signer interface for DID operations (compatible with didwebvh-ts)
50
+ * This allows integration with external key management systems like Turnkey
51
+ */
52
+ export interface ExternalSigner {
53
+ /**
54
+ * Sign data and return a proof value
55
+ * @param input - The signing input containing document and proof
56
+ * @returns The proof value (typically multibase-encoded signature)
57
+ */
58
+ sign(input: {
59
+ document: Record<string, unknown>;
60
+ proof: Record<string, unknown>;
61
+ }): Promise<{
62
+ proofValue: string;
63
+ }>;
64
+ /**
65
+ * Get the verification method ID for this signer
66
+ * @returns The verification method ID (e.g., "did:key:z6Mk...")
67
+ */
68
+ getVerificationMethodId(): string;
69
+ }
70
+ /**
71
+ * External verifier interface for DID operations (compatible with didwebvh-ts)
72
+ */
73
+ export interface ExternalVerifier {
74
+ /**
75
+ * Verify a signature
76
+ * @param signature - The signature bytes
77
+ * @param message - The message bytes that were signed
78
+ * @param publicKey - The public key bytes
79
+ * @returns True if the signature is valid
80
+ */
81
+ verify(signature: Uint8Array, message: Uint8Array, publicKey: Uint8Array): Promise<boolean>;
82
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,75 @@
1
+ import { LayerType } from './common';
2
+ export interface VerifiableCredential {
3
+ '@context': string[];
4
+ type: string[];
5
+ id?: string;
6
+ issuer: string | Issuer;
7
+ issuanceDate: string;
8
+ expirationDate?: string;
9
+ credentialSubject: CredentialSubject;
10
+ credentialStatus?: CredentialStatus;
11
+ proof?: Proof | Proof[];
12
+ }
13
+ export interface Issuer {
14
+ id: string;
15
+ name?: string;
16
+ }
17
+ export interface CredentialSubject {
18
+ id?: string;
19
+ [key: string]: any;
20
+ }
21
+ export interface CredentialStatus {
22
+ id: string;
23
+ type: string;
24
+ }
25
+ export interface Proof {
26
+ type: string;
27
+ created: string;
28
+ verificationMethod: string;
29
+ proofPurpose: string;
30
+ proofValue: string;
31
+ }
32
+ export interface VerifiablePresentation {
33
+ '@context': string[];
34
+ type: string[];
35
+ id?: string;
36
+ holder: string;
37
+ verifiableCredential: VerifiableCredential[];
38
+ proof?: Proof | Proof[];
39
+ }
40
+ export interface ResourceCreatedCredential extends VerifiableCredential {
41
+ credentialSubject: {
42
+ id: string;
43
+ resourceId: string;
44
+ resourceType: string;
45
+ createdAt: string;
46
+ creator: string;
47
+ };
48
+ }
49
+ export interface ResourceUpdatedCredential extends VerifiableCredential {
50
+ credentialSubject: {
51
+ id: string;
52
+ resourceId: string;
53
+ updatedAt: string;
54
+ updateReason?: string;
55
+ };
56
+ }
57
+ export interface ResourceMigratedCredential extends VerifiableCredential {
58
+ credentialSubject: {
59
+ id: string;
60
+ resourceId: string;
61
+ fromLayer: LayerType;
62
+ toLayer: LayerType;
63
+ migratedAt: string;
64
+ migrationReason?: string;
65
+ };
66
+ }
67
+ export interface KeyRecoveryCredential extends VerifiableCredential {
68
+ credentialSubject: {
69
+ id: string;
70
+ recoveredAt: string;
71
+ recoveryReason: string;
72
+ previousVerificationMethods: string[];
73
+ newVerificationMethod: string;
74
+ };
75
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,26 @@
1
+ export interface DIDDocument {
2
+ '@context': string[];
3
+ id: string;
4
+ verificationMethod?: VerificationMethod[];
5
+ authentication?: (string | VerificationMethod)[];
6
+ assertionMethod?: (string | VerificationMethod)[];
7
+ keyAgreement?: (string | VerificationMethod)[];
8
+ capabilityInvocation?: (string | VerificationMethod)[];
9
+ capabilityDelegation?: (string | VerificationMethod)[];
10
+ service?: ServiceEndpoint[];
11
+ controller?: string[];
12
+ alsoKnownAs?: string[];
13
+ }
14
+ export interface VerificationMethod {
15
+ id: string;
16
+ type: string;
17
+ controller: string;
18
+ publicKeyMultibase: string;
19
+ revoked?: string;
20
+ compromised?: string;
21
+ }
22
+ export interface ServiceEndpoint {
23
+ id: string;
24
+ type: string;
25
+ serviceEndpoint: string | object;
26
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,5 @@
1
+ export * from './common';
2
+ export * from './did';
3
+ export * from './credentials';
4
+ export * from './bitcoin';
5
+ export * from './network';
@@ -0,0 +1,5 @@
1
+ export * from './common';
2
+ export * from './did';
3
+ export * from './credentials';
4
+ export * from './bitcoin';
5
+ export * from './network';
@@ -0,0 +1,78 @@
1
+ /**
2
+ * WebVH Network Configuration
3
+ *
4
+ * Defines the three deployment networks for the Originals Protocol:
5
+ * - magby: Development network (patch versions) → Bitcoin regtest
6
+ * - cleffa: Staging network (minor versions) → Bitcoin signet
7
+ * - pichu: Production network (major versions) → Bitcoin mainnet
8
+ */
9
+ export type WebVHNetworkName = 'magby' | 'cleffa' | 'pichu';
10
+ export type BitcoinNetworkName = 'mainnet' | 'regtest' | 'signet';
11
+ export type VersionStability = 'patch' | 'minor' | 'major';
12
+ export interface WebVHNetworkConfig {
13
+ name: WebVHNetworkName;
14
+ domain: string;
15
+ stability: VersionStability;
16
+ description: string;
17
+ contextUrl: string;
18
+ bitcoinNetwork: BitcoinNetworkName;
19
+ }
20
+ /**
21
+ * Network configurations for the Originals Protocol WebVH deployments
22
+ */
23
+ export declare const WEBVH_NETWORKS: Record<WebVHNetworkName, WebVHNetworkConfig>;
24
+ /**
25
+ * Default network for backward compatibility
26
+ */
27
+ export declare const DEFAULT_WEBVH_NETWORK: WebVHNetworkName;
28
+ /**
29
+ * Get network configuration by name
30
+ * @param network - Network name
31
+ * @returns Network configuration
32
+ */
33
+ export declare function getNetworkConfig(network: WebVHNetworkName): WebVHNetworkConfig;
34
+ /**
35
+ * Get network domain
36
+ * @param network - Network name
37
+ * @returns Network domain
38
+ */
39
+ export declare function getNetworkDomain(network: WebVHNetworkName): string;
40
+ /**
41
+ * Get network context URL
42
+ * @param network - Network name
43
+ * @returns Context URL for the network
44
+ */
45
+ export declare function getNetworkContextUrl(network: WebVHNetworkName): string;
46
+ /**
47
+ * Validate that a version string matches the network's stability requirements
48
+ * @param version - Semver version string (e.g., "1.2.3")
49
+ * @param network - Network name
50
+ * @returns True if the version is allowed on this network
51
+ */
52
+ export declare function validateVersionForNetwork(version: string, network: WebVHNetworkName): boolean;
53
+ /**
54
+ * Get the appropriate network for a given version
55
+ * Returns the most restrictive network that accepts this version
56
+ * @param version - Semver version string
57
+ * @returns Recommended network name
58
+ */
59
+ export declare function getRecommendedNetworkForVersion(version: string): WebVHNetworkName;
60
+ /**
61
+ * Get the corresponding Bitcoin network for a WebVH network
62
+ * This ensures consistent environment mapping across the stack:
63
+ * - magby (dev) → regtest (dev)
64
+ * - cleffa (staging) → signet (staging)
65
+ * - pichu (production) → mainnet (production)
66
+ *
67
+ * @param webvhNetwork - WebVH network name
68
+ * @returns Corresponding Bitcoin network name
69
+ */
70
+ export declare function getBitcoinNetworkForWebVH(webvhNetwork: WebVHNetworkName): BitcoinNetworkName;
71
+ /**
72
+ * Get the WebVH network that corresponds to a Bitcoin network
73
+ * This is the reverse mapping of getBitcoinNetworkForWebVH
74
+ *
75
+ * @param bitcoinNetwork - Bitcoin network name
76
+ * @returns Corresponding WebVH network name, or undefined if no mapping exists
77
+ */
78
+ export declare function getWebVHNetworkForBitcoin(bitcoinNetwork: BitcoinNetworkName): WebVHNetworkName | undefined;