@originals/sdk 1.4.3 → 1.5.0

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,24 @@
1
+ export class StructuredError extends Error {
2
+ constructor(code, message, details) {
3
+ super(message);
4
+ this.name = 'StructuredError';
5
+ this.code = code;
6
+ this.details = details;
7
+ }
8
+ }
9
+ export function emitTelemetry(hooks, event) {
10
+ if (hooks && typeof hooks.onEvent === 'function') {
11
+ try {
12
+ hooks.onEvent({ level: 'info', ...event });
13
+ }
14
+ catch (_) { }
15
+ }
16
+ }
17
+ export function emitError(hooks, error) {
18
+ if (hooks && typeof hooks.onError === 'function') {
19
+ try {
20
+ hooks.onError(error);
21
+ }
22
+ catch (_) { }
23
+ }
24
+ }
@@ -0,0 +1,5 @@
1
+ import { DIDDocument, VerifiableCredential } from '../types';
2
+ export declare function validateDID(did: string): boolean;
3
+ export declare function validateCredential(vc: VerifiableCredential): boolean;
4
+ export declare function validateDIDDocument(didDoc: DIDDocument): boolean;
5
+ export declare function hashResource(content: Uint8Array): string;
@@ -0,0 +1,98 @@
1
+ import { sha256 } from '@noble/hashes/sha2.js';
2
+ import { bytesToHex } from '@noble/hashes/utils.js';
3
+ export function validateDID(did) {
4
+ // Validate DID format according to W3C DID spec
5
+ const didRegex = /^did:([a-z0-9]+):(.*)/;
6
+ if (!didRegex.test(did)) {
7
+ return false;
8
+ }
9
+ const match = did.match(didRegex);
10
+ if (!match) {
11
+ return false;
12
+ }
13
+ const method = match[1];
14
+ // Validate supported methods
15
+ const supportedMethods = ['peer', 'webvh', 'btco'];
16
+ if (!supportedMethods.includes(method)) {
17
+ return false;
18
+ }
19
+ return true;
20
+ }
21
+ export function validateCredential(vc) {
22
+ // Validate VC structure according to W3C VC spec
23
+ if (!vc['@context'] || !Array.isArray(vc['@context'])) {
24
+ return false;
25
+ }
26
+ // Require VC v1 context presence
27
+ const contextValues = vc['@context'];
28
+ const hasVcV1 = contextValues.includes('https://www.w3.org/2018/credentials/v1');
29
+ if (!hasVcV1) {
30
+ return false;
31
+ }
32
+ if (!vc.type || !Array.isArray(vc.type)) {
33
+ return false;
34
+ }
35
+ if (!vc.type.includes('VerifiableCredential')) {
36
+ return false;
37
+ }
38
+ if (!vc.issuer || (!vc.issuanceDate)) {
39
+ return false;
40
+ }
41
+ // issuer must be a DID string or an object with DID id
42
+ const issuerIsValidDid = (iss) => {
43
+ if (typeof iss === 'string')
44
+ return validateDID(iss);
45
+ if (iss && typeof iss.id === 'string')
46
+ return validateDID(iss.id);
47
+ return false;
48
+ };
49
+ if (!issuerIsValidDid(vc.issuer)) {
50
+ return false;
51
+ }
52
+ // issuanceDate should be a valid ISO timestamp
53
+ if (typeof vc.issuanceDate !== 'string' || Number.isNaN(Date.parse(vc.issuanceDate))) {
54
+ return false;
55
+ }
56
+ if (!vc.credentialSubject) {
57
+ return false;
58
+ }
59
+ return true;
60
+ }
61
+ export function validateDIDDocument(didDoc) {
62
+ // Validate DID Document structure
63
+ if (!didDoc['@context'] || !Array.isArray(didDoc['@context'])) {
64
+ return false;
65
+ }
66
+ if (!didDoc.id || !validateDID(didDoc.id)) {
67
+ return false;
68
+ }
69
+ // Validate verification methods
70
+ if (didDoc.verificationMethod) {
71
+ for (const vm of didDoc.verificationMethod) {
72
+ if (!vm.id || !vm.type || !vm.controller || !vm.publicKeyMultibase) {
73
+ return false;
74
+ }
75
+ // controller should be a valid DID
76
+ if (typeof vm.controller !== 'string' || !validateDID(vm.controller)) {
77
+ return false;
78
+ }
79
+ // multibase key presence: require base58-btc multibase indicator 'z'
80
+ if (typeof vm.publicKeyMultibase !== 'string' || !vm.publicKeyMultibase.startsWith('z')) {
81
+ return false;
82
+ }
83
+ }
84
+ }
85
+ // If controller array present on the DID Document, validate entries are DIDs
86
+ if (Array.isArray(didDoc.controller)) {
87
+ const ctrls = didDoc.controller;
88
+ if (!ctrls.every((c) => typeof c === 'string' && validateDID(c))) {
89
+ return false;
90
+ }
91
+ }
92
+ return true;
93
+ }
94
+ export function hashResource(content) {
95
+ // Generate SHA-256 hash
96
+ const hash = sha256(content);
97
+ return bytesToHex(hash);
98
+ }
@@ -0,0 +1,329 @@
1
+ import { VerifiableCredential, VerifiablePresentation, CredentialSubject, OriginalsConfig, ExternalSigner, LayerType, AssetResource } from '../types';
2
+ import { DIDManager } from '../did/DIDManager';
3
+ /**
4
+ * Subject data for a ResourceCreated credential
5
+ */
6
+ export interface ResourceCreatedSubject {
7
+ /** ID of the subject (typically the resource DID or asset DID) */
8
+ id: string;
9
+ /** Resource identifier */
10
+ resourceId: string;
11
+ /** Resource type (e.g., 'code', 'text', 'image') */
12
+ resourceType: string;
13
+ /** Content hash of the resource */
14
+ contentHash: string;
15
+ /** MIME content type */
16
+ contentType: string;
17
+ /** Creator DID */
18
+ creator: string;
19
+ /** Creation timestamp */
20
+ createdAt: string;
21
+ }
22
+ /**
23
+ * Subject data for a ResourceUpdated credential
24
+ */
25
+ export interface ResourceUpdatedSubject {
26
+ /** ID of the subject (typically the asset DID) */
27
+ id: string;
28
+ /** Resource identifier */
29
+ resourceId: string;
30
+ /** Previous content hash */
31
+ previousHash: string;
32
+ /** New content hash */
33
+ newHash: string;
34
+ /** Previous version number */
35
+ fromVersion: number;
36
+ /** New version number */
37
+ toVersion: number;
38
+ /** Update timestamp */
39
+ updatedAt: string;
40
+ /** Optional description of changes */
41
+ updateReason?: string;
42
+ }
43
+ /**
44
+ * Subject data for a MigrationCompleted credential
45
+ */
46
+ export interface MigrationSubject {
47
+ /** ID of the subject (typically the asset DID) */
48
+ id: string;
49
+ /** Source DID (before migration) */
50
+ sourceDid: string;
51
+ /** Target DID (after migration) */
52
+ targetDid?: string;
53
+ /** Layer migrated from */
54
+ fromLayer: LayerType;
55
+ /** Layer migrated to */
56
+ toLayer: LayerType;
57
+ /** Migration timestamp */
58
+ migratedAt: string;
59
+ /** Transaction ID (for Bitcoin migrations) */
60
+ transactionId?: string;
61
+ /** Inscription ID (for Bitcoin migrations) */
62
+ inscriptionId?: string;
63
+ /** Satoshi number (for Bitcoin migrations) */
64
+ satoshi?: string;
65
+ /** Optional reason for migration */
66
+ migrationReason?: string;
67
+ }
68
+ /**
69
+ * Subject data for an OwnershipTransferred credential
70
+ */
71
+ export interface OwnershipSubject {
72
+ /** ID of the subject (typically the asset DID) */
73
+ id: string;
74
+ /** Previous owner DID or address */
75
+ previousOwner: string;
76
+ /** New owner DID or address */
77
+ newOwner: string;
78
+ /** Transfer timestamp */
79
+ transferredAt: string;
80
+ /** Transaction ID for the transfer */
81
+ transactionId: string;
82
+ /** Satoshi number of the inscription */
83
+ satoshi?: string;
84
+ /** Optional transfer reason or notes */
85
+ transferReason?: string;
86
+ }
87
+ /**
88
+ * Options for creating credentials with chaining
89
+ */
90
+ export interface CredentialChainOptions {
91
+ /** Previous credential ID to chain from */
92
+ previousCredentialId?: string;
93
+ /** Hash of the previous credential for verification */
94
+ previousCredentialHash?: string;
95
+ /** Optional expiration date */
96
+ expirationDate?: string;
97
+ /** Optional credential status information */
98
+ credentialStatus?: {
99
+ id: string;
100
+ type: string;
101
+ };
102
+ }
103
+ /**
104
+ * Options for BBS+ selective disclosure
105
+ */
106
+ export interface SelectiveDisclosureOptions {
107
+ /** JSON Pointer paths to fields that must always be disclosed */
108
+ mandatoryPointers: string[];
109
+ /** JSON Pointer paths to fields the holder can selectively disclose */
110
+ selectivePointers?: string[];
111
+ }
112
+ /**
113
+ * Result of creating a derived proof with selective disclosure
114
+ */
115
+ export interface DerivedProofResult {
116
+ /** The credential with derived proof */
117
+ credential: VerifiableCredential;
118
+ /** Fields that were disclosed */
119
+ disclosedFields: string[];
120
+ /** Fields that were hidden */
121
+ hiddenFields: string[];
122
+ }
123
+ export declare class CredentialManager {
124
+ private config;
125
+ private didManager?;
126
+ constructor(config: OriginalsConfig, didManager?: DIDManager | undefined);
127
+ createResourceCredential(type: 'ResourceCreated' | 'ResourceUpdated' | 'ResourceMigrated', subject: CredentialSubject, issuer: string): Promise<VerifiableCredential>;
128
+ signCredential(credential: VerifiableCredential, privateKeyMultibase: string, verificationMethod: string): Promise<VerifiableCredential>;
129
+ /**
130
+ * Sign a credential using an external signer (e.g., hardware wallet, Turnkey)
131
+ * @param credential - The unsigned credential
132
+ * @param signer - External signer implementation
133
+ * @returns Signed verifiable credential
134
+ */
135
+ signCredentialWithExternalSigner(credential: VerifiableCredential, signer: ExternalSigner): Promise<VerifiableCredential>;
136
+ verifyCredential(credential: VerifiableCredential): Promise<boolean>;
137
+ createPresentation(credentials: VerifiableCredential[], holder: string): Promise<VerifiablePresentation>;
138
+ private generateProofValue;
139
+ private getSigner;
140
+ private resolveVerificationMethodMultibase;
141
+ private decodeMultibase;
142
+ /**
143
+ * Issue a ResourceCreated credential for a newly created resource
144
+ *
145
+ * @param resource - The created resource
146
+ * @param assetDid - The DID of the asset containing the resource
147
+ * @param creatorDid - The DID of the creator
148
+ * @param chainOptions - Optional chaining options for linking to previous credentials
149
+ * @returns Unsigned verifiable credential
150
+ *
151
+ * @example
152
+ * ```typescript
153
+ * const credential = await credentialManager.issueResourceCredential(
154
+ * resource,
155
+ * 'did:peer:abc...',
156
+ * 'did:peer:creator...'
157
+ * );
158
+ * // Sign the credential with your key
159
+ * const signed = await credentialManager.signCredential(credential, privateKey, vmId);
160
+ * ```
161
+ */
162
+ issueResourceCredential(resource: AssetResource, assetDid: string, creatorDid: string, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
163
+ /**
164
+ * Issue a ResourceUpdated credential for a resource version update
165
+ *
166
+ * @param resourceId - The logical resource ID
167
+ * @param assetDid - The DID of the asset
168
+ * @param previousHash - Hash of the previous version
169
+ * @param newHash - Hash of the new version
170
+ * @param fromVersion - Previous version number
171
+ * @param toVersion - New version number
172
+ * @param updaterDid - DID of the entity performing the update
173
+ * @param updateReason - Optional reason for the update
174
+ * @param chainOptions - Optional chaining options
175
+ * @returns Unsigned verifiable credential
176
+ *
177
+ * @example
178
+ * ```typescript
179
+ * const credential = await credentialManager.issueResourceUpdateCredential(
180
+ * 'main.js',
181
+ * 'did:webvh:example.com:asset',
182
+ * 'abc123...',
183
+ * 'def456...',
184
+ * 1,
185
+ * 2,
186
+ * 'did:webvh:example.com:user',
187
+ * 'Bug fix'
188
+ * );
189
+ * ```
190
+ */
191
+ issueResourceUpdateCredential(resourceId: string, assetDid: string, previousHash: string, newHash: string, fromVersion: number, toVersion: number, updaterDid: string, updateReason?: string, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
192
+ /**
193
+ * Issue a MigrationCompleted credential for layer migrations
194
+ *
195
+ * Records the migration of an asset between Originals layers (peer -> webvh -> btco).
196
+ *
197
+ * @param sourceDid - The source DID (before migration)
198
+ * @param targetDid - The target DID (after migration, if different)
199
+ * @param fromLayer - The source layer
200
+ * @param toLayer - The target layer
201
+ * @param issuerDid - The DID issuing this credential
202
+ * @param details - Optional migration details (transactionId, inscriptionId, satoshi)
203
+ * @param chainOptions - Optional chaining options
204
+ * @returns Unsigned verifiable credential
205
+ *
206
+ * @example
207
+ * ```typescript
208
+ * const credential = await credentialManager.issueMigrationCredential(
209
+ * 'did:peer:abc...',
210
+ * 'did:webvh:example.com:asset',
211
+ * 'did:peer',
212
+ * 'did:webvh',
213
+ * 'did:webvh:example.com:publisher'
214
+ * );
215
+ * ```
216
+ */
217
+ issueMigrationCredential(sourceDid: string, targetDid: string | undefined, fromLayer: LayerType, toLayer: LayerType, issuerDid: string, details?: {
218
+ transactionId?: string;
219
+ inscriptionId?: string;
220
+ satoshi?: string;
221
+ migrationReason?: string;
222
+ }, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
223
+ /**
224
+ * Issue an OwnershipTransferred credential for Bitcoin-anchored asset transfers
225
+ *
226
+ * Records the transfer of ownership of a did:btco asset to a new owner.
227
+ *
228
+ * @param assetDid - The DID of the asset being transferred
229
+ * @param previousOwner - The previous owner (DID or Bitcoin address)
230
+ * @param newOwner - The new owner (Bitcoin address)
231
+ * @param transactionId - The Bitcoin transaction ID
232
+ * @param issuerDid - The DID issuing this credential
233
+ * @param details - Optional additional details
234
+ * @param chainOptions - Optional chaining options
235
+ * @returns Unsigned verifiable credential
236
+ *
237
+ * @example
238
+ * ```typescript
239
+ * const credential = await credentialManager.issueOwnershipCredential(
240
+ * 'did:btco:12345',
241
+ * 'bc1q...oldowner',
242
+ * 'bc1q...newowner',
243
+ * 'abc123...txid',
244
+ * 'did:btco:12345'
245
+ * );
246
+ * ```
247
+ */
248
+ issueOwnershipCredential(assetDid: string, previousOwner: string, newOwner: string, transactionId: string, issuerDid: string, details?: {
249
+ satoshi?: string;
250
+ transferReason?: string;
251
+ }, chainOptions?: CredentialChainOptions): Promise<VerifiableCredential>;
252
+ /**
253
+ * Create a credential with optional chaining to a previous credential
254
+ *
255
+ * Credential chaining creates a verifiable provenance chain by linking
256
+ * credentials together through their IDs and hashes.
257
+ *
258
+ * @param type - The credential type
259
+ * @param subject - The credential subject
260
+ * @param issuer - The issuer DID
261
+ * @param chainOptions - Optional chaining options
262
+ * @returns Unsigned verifiable credential with chain metadata
263
+ */
264
+ private createCredentialWithChain;
265
+ /**
266
+ * Generate a unique credential ID
267
+ */
268
+ private generateCredentialId;
269
+ /**
270
+ * Compute the hash of a credential for chaining purposes
271
+ *
272
+ * @param credential - The credential to hash
273
+ * @returns SHA-256 hash of the canonicalized credential
274
+ */
275
+ computeCredentialHash(credential: VerifiableCredential): Promise<string>;
276
+ /**
277
+ * Verify a credential chain by checking all previous credential links
278
+ *
279
+ * @param credentials - Array of credentials in chain order (oldest first)
280
+ * @returns Verification result with chain integrity status
281
+ */
282
+ verifyCredentialChain(credentials: VerifiableCredential[]): Promise<{
283
+ valid: boolean;
284
+ errors: string[];
285
+ chainLength: number;
286
+ }>;
287
+ /**
288
+ * Prepare a credential for BBS+ selective disclosure
289
+ *
290
+ * This creates a base proof that can later be derived into a proof
291
+ * that selectively discloses only certain fields.
292
+ *
293
+ * Note: This requires BBS+ keys and is primarily used for privacy-preserving
294
+ * credential presentations.
295
+ *
296
+ * @param credential - The credential to prepare
297
+ * @param options - Selective disclosure options
298
+ * @returns The credential with BBS+ base proof metadata
299
+ */
300
+ prepareSelectiveDisclosure(credential: VerifiableCredential, options: SelectiveDisclosureOptions): Promise<{
301
+ credential: VerifiableCredential;
302
+ mandatoryPointers: string[];
303
+ selectivePointers: string[];
304
+ }>;
305
+ /**
306
+ * Create a derived proof with selective disclosure
307
+ *
308
+ * Given a credential with a BBS+ base proof, creates a derived proof
309
+ * that only reveals the specified fields.
310
+ *
311
+ * @param credential - The credential with BBS+ base proof
312
+ * @param fieldsToDisclose - JSON Pointer paths to disclose
313
+ * @param presentationHeader - Optional presentation-specific data
314
+ * @returns The credential with derived proof
315
+ */
316
+ deriveSelectiveProof(credential: VerifiableCredential, fieldsToDisclose: string[], presentationHeader?: Uint8Array): Promise<DerivedProofResult>;
317
+ /**
318
+ * Extract all field paths from a credential as JSON Pointers
319
+ */
320
+ private extractFieldPaths;
321
+ /**
322
+ * Get field value from credential using JSON Pointer
323
+ *
324
+ * @param credential - The credential to read from
325
+ * @param pointer - JSON Pointer path (e.g., /credentialSubject/name)
326
+ * @returns The value at the pointer path, or undefined if not found
327
+ */
328
+ getFieldByPointer(credential: VerifiableCredential, pointer: string): any;
329
+ }