@originals/sdk 1.8.1 → 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.
- package/dist/utils/hash.js +1 -0
- package/package.json +6 -5
- package/src/adapters/FeeOracleMock.ts +9 -0
- package/src/adapters/index.ts +5 -0
- package/src/adapters/providers/OrdHttpProvider.ts +126 -0
- package/src/adapters/providers/OrdMockProvider.ts +101 -0
- package/src/adapters/types.ts +66 -0
- package/src/bitcoin/BitcoinManager.ts +329 -0
- package/src/bitcoin/BroadcastClient.ts +54 -0
- package/src/bitcoin/OrdinalsClient.ts +120 -0
- package/src/bitcoin/PSBTBuilder.ts +106 -0
- package/src/bitcoin/fee-calculation.ts +38 -0
- package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
- package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
- package/src/bitcoin/providers/types.ts +59 -0
- package/src/bitcoin/transactions/commit.ts +465 -0
- package/src/bitcoin/transactions/index.ts +13 -0
- package/src/bitcoin/transfer.ts +43 -0
- package/src/bitcoin/utxo-selection.ts +322 -0
- package/src/bitcoin/utxo.ts +113 -0
- package/src/cel/ExternalReferenceManager.ts +87 -0
- package/src/cel/OriginalsCel.ts +460 -0
- package/src/cel/algorithms/createEventLog.ts +68 -0
- package/src/cel/algorithms/deactivateEventLog.ts +109 -0
- package/src/cel/algorithms/index.ts +11 -0
- package/src/cel/algorithms/updateEventLog.ts +99 -0
- package/src/cel/algorithms/verifyEventLog.ts +306 -0
- package/src/cel/algorithms/witnessEvent.ts +87 -0
- package/src/cel/cli/create.ts +330 -0
- package/src/cel/cli/index.ts +383 -0
- package/src/cel/cli/inspect.ts +549 -0
- package/src/cel/cli/migrate.ts +473 -0
- package/src/cel/cli/verify.ts +249 -0
- package/src/cel/hash.ts +71 -0
- package/src/cel/index.ts +16 -0
- package/src/cel/layers/BtcoCelManager.ts +408 -0
- package/src/cel/layers/PeerCelManager.ts +371 -0
- package/src/cel/layers/WebVHCelManager.ts +361 -0
- package/src/cel/layers/index.ts +27 -0
- package/src/cel/serialization/cbor.ts +189 -0
- package/src/cel/serialization/index.ts +10 -0
- package/src/cel/serialization/json.ts +209 -0
- package/src/cel/types.ts +160 -0
- package/src/cel/witnesses/BitcoinWitness.ts +184 -0
- package/src/cel/witnesses/HttpWitness.ts +241 -0
- package/src/cel/witnesses/WitnessService.ts +51 -0
- package/src/cel/witnesses/index.ts +11 -0
- package/src/contexts/credentials-v1.json +237 -0
- package/src/contexts/credentials-v2-examples.json +5 -0
- package/src/contexts/credentials-v2.json +340 -0
- package/src/contexts/credentials.json +237 -0
- package/src/contexts/data-integrity-v2.json +81 -0
- package/src/contexts/dids.json +58 -0
- package/src/contexts/ed255192020.json +93 -0
- package/src/contexts/ordinals-plus.json +23 -0
- package/src/contexts/originals.json +22 -0
- package/src/core/OriginalsSDK.ts +420 -0
- package/src/crypto/Multikey.ts +194 -0
- package/src/crypto/Signer.ts +262 -0
- package/src/crypto/noble-init.ts +138 -0
- package/src/did/BtcoDidResolver.ts +231 -0
- package/src/did/DIDManager.ts +705 -0
- package/src/did/Ed25519Verifier.ts +68 -0
- package/src/did/KeyManager.ts +239 -0
- package/src/did/WebVHManager.ts +499 -0
- package/src/did/createBtcoDidDocument.ts +60 -0
- package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
- package/src/events/EventEmitter.ts +222 -0
- package/src/events/index.ts +19 -0
- package/src/events/types.ts +331 -0
- package/src/examples/basic-usage.ts +78 -0
- package/src/examples/create-module-original.ts +435 -0
- package/src/examples/full-lifecycle-flow.ts +514 -0
- package/src/examples/run.ts +60 -0
- package/src/index.ts +204 -0
- package/src/kinds/KindRegistry.ts +320 -0
- package/src/kinds/index.ts +74 -0
- package/src/kinds/types.ts +470 -0
- package/src/kinds/validators/AgentValidator.ts +257 -0
- package/src/kinds/validators/AppValidator.ts +211 -0
- package/src/kinds/validators/DatasetValidator.ts +242 -0
- package/src/kinds/validators/DocumentValidator.ts +311 -0
- package/src/kinds/validators/MediaValidator.ts +269 -0
- package/src/kinds/validators/ModuleValidator.ts +225 -0
- package/src/kinds/validators/base.ts +276 -0
- package/src/kinds/validators/index.ts +12 -0
- package/src/lifecycle/BatchOperations.ts +381 -0
- package/src/lifecycle/LifecycleManager.ts +2156 -0
- package/src/lifecycle/OriginalsAsset.ts +524 -0
- package/src/lifecycle/ProvenanceQuery.ts +280 -0
- package/src/lifecycle/ResourceVersioning.ts +163 -0
- package/src/migration/MigrationManager.ts +587 -0
- package/src/migration/audit/AuditLogger.ts +176 -0
- package/src/migration/checkpoint/CheckpointManager.ts +112 -0
- package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
- package/src/migration/index.ts +33 -0
- package/src/migration/operations/BaseMigration.ts +126 -0
- package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
- package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
- package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
- package/src/migration/rollback/RollbackManager.ts +170 -0
- package/src/migration/state/StateMachine.ts +92 -0
- package/src/migration/state/StateTracker.ts +156 -0
- package/src/migration/types.ts +356 -0
- package/src/migration/validation/BitcoinValidator.ts +107 -0
- package/src/migration/validation/CredentialValidator.ts +62 -0
- package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
- package/src/migration/validation/LifecycleValidator.ts +64 -0
- package/src/migration/validation/StorageValidator.ts +79 -0
- package/src/migration/validation/ValidationPipeline.ts +213 -0
- package/src/resources/ResourceManager.ts +655 -0
- package/src/resources/index.ts +21 -0
- package/src/resources/types.ts +202 -0
- package/src/storage/LocalStorageAdapter.ts +64 -0
- package/src/storage/MemoryStorageAdapter.ts +29 -0
- package/src/storage/StorageAdapter.ts +25 -0
- package/src/storage/index.ts +3 -0
- package/src/types/bitcoin.ts +98 -0
- package/src/types/common.ts +92 -0
- package/src/types/credentials.ts +89 -0
- package/src/types/did.ts +31 -0
- package/src/types/external-shims.d.ts +53 -0
- package/src/types/index.ts +7 -0
- package/src/types/network.ts +178 -0
- package/src/utils/EventLogger.ts +298 -0
- package/src/utils/Logger.ts +324 -0
- package/src/utils/MetricsCollector.ts +358 -0
- package/src/utils/bitcoin-address.ts +132 -0
- package/src/utils/cbor.ts +31 -0
- package/src/utils/encoding.ts +135 -0
- package/src/utils/hash.ts +12 -0
- package/src/utils/retry.ts +46 -0
- package/src/utils/satoshi-validation.ts +196 -0
- package/src/utils/serialization.ts +102 -0
- package/src/utils/telemetry.ts +44 -0
- package/src/utils/validation.ts +123 -0
- package/src/vc/CredentialManager.ts +955 -0
- package/src/vc/Issuer.ts +105 -0
- package/src/vc/Verifier.ts +54 -0
- package/src/vc/cryptosuites/bbs.ts +253 -0
- package/src/vc/cryptosuites/bbsSimple.ts +21 -0
- package/src/vc/cryptosuites/eddsa.ts +99 -0
- package/src/vc/documentLoader.ts +81 -0
- package/src/vc/proofs/data-integrity.ts +33 -0
- 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,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
|
+
|
package/src/types/did.ts
ADDED
|
@@ -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
|
+
|