@private.me/xbind 3.0.2 → 3.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (221) hide show
  1. package/README.md +2366 -204
  2. package/README.md.backup +2121 -0
  3. package/dist-standalone/_deps/mldsa-wasm/dist/mldsa.js +1 -1920
  4. package/dist-standalone/_deps/shared/cjs/errors.js +1 -729
  5. package/dist-standalone/_deps/shared/cjs/index.js +1 -463
  6. package/dist-standalone/_deps/shared/cjs/types.js +1 -315
  7. package/dist-standalone/_deps/shared/errors.js +1 -244
  8. package/dist-standalone/_deps/shared/index.js +1 -72
  9. package/dist-standalone/_deps/shared/types.js +1 -86
  10. package/dist-standalone/_deps/ux-helpers/cjs/errors.js +1 -1
  11. package/dist-standalone/_deps/ux-helpers/cjs/index.js +1 -1
  12. package/dist-standalone/_deps/ux-helpers/cjs/pagination.js +1 -1
  13. package/dist-standalone/_deps/ux-helpers/cjs/progress.js +1 -1
  14. package/dist-standalone/_deps/ux-helpers/cjs/search.js +1 -1
  15. package/dist-standalone/_deps/ux-helpers/cjs/types.js +1 -1
  16. package/dist-standalone/_deps/ux-helpers/errors.js +1 -1
  17. package/dist-standalone/_deps/ux-helpers/index.js +1 -1
  18. package/dist-standalone/_deps/ux-helpers/pagination.js +1 -1
  19. package/dist-standalone/_deps/ux-helpers/progress.js +1 -1
  20. package/dist-standalone/_deps/ux-helpers/search.js +1 -1
  21. package/dist-standalone/_deps/xchange/auto-accept.js +1 -1
  22. package/dist-standalone/_deps/xchange/cjs/auto-accept.js +1 -1
  23. package/dist-standalone/_deps/xchange/cjs/errors.js +1 -1
  24. package/dist-standalone/_deps/xchange/cjs/index.js +1 -1
  25. package/dist-standalone/_deps/xchange/cjs/invite-client.js +1 -1
  26. package/dist-standalone/_deps/xchange/cjs/lazy-init.js +1 -1
  27. package/dist-standalone/_deps/xchange/cjs/trust-integration.js +1 -1
  28. package/dist-standalone/_deps/xchange/cjs/xchange.js +1 -1
  29. package/dist-standalone/_deps/xchange/errors.js +1 -1
  30. package/dist-standalone/_deps/xchange/index.js +1 -1
  31. package/dist-standalone/_deps/xchange/invite-client.js +1 -1
  32. package/dist-standalone/_deps/xchange/lazy-init.js +1 -1
  33. package/dist-standalone/_deps/xchange/trust-integration.js +1 -1
  34. package/dist-standalone/_deps/xchange/xchange.js +1 -1
  35. package/dist-standalone/_deps/xregistry/cjs/discovery.js +1 -1
  36. package/dist-standalone/_deps/xregistry/cjs/errors.js +1 -1
  37. package/dist-standalone/_deps/xregistry/cjs/index.js +1 -1
  38. package/dist-standalone/_deps/xregistry/cjs/registry.js +1 -1
  39. package/dist-standalone/_deps/xregistry/cjs/schema.js +1 -1
  40. package/dist-standalone/_deps/xregistry/cjs/types.js +1 -1
  41. package/dist-standalone/_deps/xregistry/discovery.js +1 -1
  42. package/dist-standalone/_deps/xregistry/errors.js +1 -1
  43. package/dist-standalone/_deps/xregistry/index.js +1 -1
  44. package/dist-standalone/_deps/xregistry/registry.js +1 -1
  45. package/dist-standalone/_deps/xregistry/schema.js +1 -1
  46. package/dist-standalone/_deps/xregistry/types.js +1 -1
  47. package/dist-standalone/agent-call.d.ts +2 -2
  48. package/dist-standalone/agent-call.js +1 -659
  49. package/dist-standalone/agent-sdk.js +1 -328
  50. package/dist-standalone/agent.d.ts +2 -0
  51. package/dist-standalone/agent.js +1 -1800
  52. package/dist-standalone/approval.js +1 -193
  53. package/dist-standalone/async-iterators.d.ts +3 -3
  54. package/dist-standalone/async-iterators.js +1 -382
  55. package/dist-standalone/auth.js +1 -219
  56. package/dist-standalone/auto-accept.js +1 -229
  57. package/dist-standalone/backup-config.js +1 -201
  58. package/dist-standalone/backup.js +1 -326
  59. package/dist-standalone/batch-operations.js +1 -388
  60. package/dist-standalone/cancellation.js +1 -477
  61. package/dist-standalone/checkpoint.js +1 -186
  62. package/dist-standalone/circuit-breaker.js +1 -468
  63. package/dist-standalone/cjs/agent-call.js +1 -701
  64. package/dist-standalone/cjs/agent-sdk.js +1 -332
  65. package/dist-standalone/cjs/agent.js +1 -1837
  66. package/dist-standalone/cjs/approval.js +1 -199
  67. package/dist-standalone/cjs/async-iterators.js +1 -392
  68. package/dist-standalone/cjs/auth.js +1 -225
  69. package/dist-standalone/cjs/auto-accept.js +1 -233
  70. package/dist-standalone/cjs/backup-config.js +1 -207
  71. package/dist-standalone/cjs/backup.js +1 -330
  72. package/dist-standalone/cjs/batch-operations.js +1 -397
  73. package/dist-standalone/cjs/cancellation.js +1 -490
  74. package/dist-standalone/cjs/checkpoint.js +1 -193
  75. package/dist-standalone/cjs/circuit-breaker.js +1 -476
  76. package/dist-standalone/cjs/cli/init.js +1 -492
  77. package/dist-standalone/cjs/config-validation.js +1 -522
  78. package/dist-standalone/cjs/connect.js +1 -312
  79. package/dist-standalone/cjs/connection-pool.js +1 -506
  80. package/dist-standalone/cjs/correlation-id.js +1 -339
  81. package/dist-standalone/cjs/crypto-utils.js +1 -176
  82. package/dist-standalone/cjs/debug-mode.js +1 -534
  83. package/dist-standalone/cjs/did-document.js +1 -101
  84. package/dist-standalone/cjs/did-privateme.js +1 -130
  85. package/dist-standalone/cjs/did-web.js +1 -201
  86. package/dist-standalone/cjs/discovery.js +1 -462
  87. package/dist-standalone/cjs/dual-mode.js +1 -251
  88. package/dist-standalone/cjs/email-templates.js +1 -313
  89. package/dist-standalone/cjs/email-transport.js +1 -239
  90. package/dist-standalone/cjs/envelope.js +1 -538
  91. package/dist-standalone/cjs/errors.js +1 -913
  92. package/dist-standalone/cjs/event-emitter.js +1 -461
  93. package/dist-standalone/cjs/gateway-state.js +1 -55
  94. package/dist-standalone/cjs/gateway-transport.js +1 -120
  95. package/dist-standalone/cjs/graceful-degradation.js +1 -403
  96. package/dist-standalone/cjs/guardrails.js +1 -223
  97. package/dist-standalone/cjs/health-check.js +1 -336
  98. package/dist-standalone/cjs/http-compat.js +1 -272
  99. package/dist-standalone/cjs/http-status-map.js +1 -571
  100. package/dist-standalone/cjs/identity.js +1 -645
  101. package/dist-standalone/cjs/index.js +1 -406
  102. package/dist-standalone/cjs/invitation.js +1 -421
  103. package/dist-standalone/cjs/invite.js +1 -328
  104. package/dist-standalone/cjs/key-agreement.js +1 -335
  105. package/dist-standalone/cjs/lazy-init.js +1 -300
  106. package/dist-standalone/cjs/logger.js +1 -291
  107. package/dist-standalone/cjs/loopback-transport.js +1 -0
  108. package/dist-standalone/cjs/mdns-discovery.js +1 -202
  109. package/dist-standalone/cjs/nonce-store.js +1 -80
  110. package/dist-standalone/cjs/pairing-manager.js +1 -223
  111. package/dist-standalone/cjs/plugin-system.js +1 -264
  112. package/dist-standalone/cjs/plugins/logging.js +1 -168
  113. package/dist-standalone/cjs/plugins/metrics.js +1 -181
  114. package/dist-standalone/cjs/plugins/validation.js +1 -302
  115. package/dist-standalone/cjs/policy.js +1 -320
  116. package/dist-standalone/cjs/progress-callbacks.js +1 -583
  117. package/dist-standalone/cjs/redis-nonce-store.js +1 -76
  118. package/dist-standalone/cjs/registry-middleware.js +1 -50
  119. package/dist-standalone/cjs/retry-strategies.js +1 -544
  120. package/dist-standalone/cjs/retry-transport.js +1 -102
  121. package/dist-standalone/cjs/runtime/browser.js +1 -533
  122. package/dist-standalone/cjs/runtime/edge.js +1 -526
  123. package/dist-standalone/cjs/runtime/react-native.js +1 -394
  124. package/dist-standalone/cjs/security-policy.js +1 -245
  125. package/dist-standalone/cjs/serialization.js +1 -1040
  126. package/dist-standalone/cjs/split-channel.js +1 -225
  127. package/dist-standalone/cjs/subscription-proof.js +1 -230
  128. package/dist-standalone/cjs/succession.js +1 -148
  129. package/dist-standalone/cjs/timeouts.js +1 -412
  130. package/dist-standalone/cjs/trace-context.js +1 -424
  131. package/dist-standalone/cjs/trace-spans.js +1 -495
  132. package/dist-standalone/cjs/transport.js +1 -63
  133. package/dist-standalone/cjs/trust-registry.js +1 -991
  134. package/dist-standalone/cjs/types/error-response.js +1 -56
  135. package/dist-standalone/cjs/vault-auth.js +1 -178
  136. package/dist-standalone/cjs/vault-store-loader.js +1 -194
  137. package/dist-standalone/cjs/verify.js +1 -25
  138. package/dist-standalone/cjs/version-info.js +1 -543
  139. package/dist-standalone/cjs/xfetch.js +1 -340
  140. package/dist-standalone/cli/init.js +1 -455
  141. package/dist-standalone/cli/setup.js +1 -514
  142. package/dist-standalone/cli/types.js +1 -27
  143. package/dist-standalone/cli/xbind.js +1 -148
  144. package/dist-standalone/config-validation.js +1 -513
  145. package/dist-standalone/connect.js +1 -274
  146. package/dist-standalone/connection-pool.js +1 -500
  147. package/dist-standalone/correlation-id.js +1 -326
  148. package/dist-standalone/crypto-utils.d.ts +2 -7
  149. package/dist-standalone/crypto-utils.js +1 -157
  150. package/dist-standalone/debug-mode.js +1 -510
  151. package/dist-standalone/did-document.js +1 -96
  152. package/dist-standalone/did-privateme.js +1 -121
  153. package/dist-standalone/did-web.js +1 -196
  154. package/dist-standalone/discovery.js +1 -458
  155. package/dist-standalone/dual-mode.js +1 -247
  156. package/dist-standalone/email-templates.js +1 -309
  157. package/dist-standalone/email-transport.d.ts +2 -2
  158. package/dist-standalone/email-transport.js +1 -232
  159. package/dist-standalone/envelope.js +1 -525
  160. package/dist-standalone/errors.d.ts +13 -3
  161. package/dist-standalone/errors.js +1 -896
  162. package/dist-standalone/event-emitter.js +1 -456
  163. package/dist-standalone/gateway-state.d.ts +1 -1
  164. package/dist-standalone/gateway-state.js +1 -51
  165. package/dist-standalone/gateway-transport.js +1 -116
  166. package/dist-standalone/graceful-degradation.js +1 -396
  167. package/dist-standalone/guardrails.js +1 -216
  168. package/dist-standalone/health-check.d.ts +5 -1
  169. package/dist-standalone/health-check.js +1 -332
  170. package/dist-standalone/http-compat.d.ts +1 -1
  171. package/dist-standalone/http-compat.js +1 -267
  172. package/dist-standalone/http-status-map.js +1 -561
  173. package/dist-standalone/identity.js +1 -619
  174. package/dist-standalone/index.d.ts +15 -4
  175. package/dist-standalone/index.js +1 -78
  176. package/dist-standalone/invitation.js +1 -415
  177. package/dist-standalone/invite.js +1 -324
  178. package/dist-standalone/key-agreement.js +1 -325
  179. package/dist-standalone/lazy-init.d.ts +11 -6
  180. package/dist-standalone/lazy-init.js +1 -295
  181. package/dist-standalone/logger.js +1 -285
  182. package/dist-standalone/loopback-transport.d.ts +87 -0
  183. package/dist-standalone/loopback-transport.js +1 -0
  184. package/dist-standalone/mdns-discovery.js +1 -195
  185. package/dist-standalone/nonce-store.js +1 -76
  186. package/dist-standalone/pairing-manager.js +1 -219
  187. package/dist-standalone/plugin-system.js +1 -257
  188. package/dist-standalone/plugins/logging.js +1 -163
  189. package/dist-standalone/plugins/metrics.d.ts +4 -4
  190. package/dist-standalone/plugins/metrics.js +1 -176
  191. package/dist-standalone/plugins/validation.js +1 -297
  192. package/dist-standalone/policy.js +1 -315
  193. package/dist-standalone/progress-callbacks.js +1 -576
  194. package/dist-standalone/redis-nonce-store.js +1 -72
  195. package/dist-standalone/registry-middleware.js +1 -47
  196. package/dist-standalone/retry-strategies.js +1 -534
  197. package/dist-standalone/retry-transport.js +1 -98
  198. package/dist-standalone/runtime/browser.js +1 -516
  199. package/dist-standalone/runtime/edge.js +1 -511
  200. package/dist-standalone/runtime/react-native.d.ts +1 -1
  201. package/dist-standalone/runtime/react-native.js +1 -383
  202. package/dist-standalone/security-policy.js +1 -239
  203. package/dist-standalone/serialization.js +1 -1031
  204. package/dist-standalone/split-channel.js +1 -219
  205. package/dist-standalone/subscription-proof.js +1 -224
  206. package/dist-standalone/succession.js +1 -142
  207. package/dist-standalone/timeouts.js +1 -398
  208. package/dist-standalone/trace-context.js +1 -414
  209. package/dist-standalone/trace-spans.js +1 -488
  210. package/dist-standalone/transport.js +1 -59
  211. package/dist-standalone/trust-registry.d.ts +3 -3
  212. package/dist-standalone/trust-registry.js +1 -950
  213. package/dist-standalone/types/error-response.js +1 -52
  214. package/dist-standalone/vault-auth.js +1 -174
  215. package/dist-standalone/vault-store-loader.d.ts +9 -0
  216. package/dist-standalone/vault-store-loader.js +1 -187
  217. package/dist-standalone/verify.js +1 -16
  218. package/dist-standalone/version-info.js +1 -530
  219. package/dist-standalone/xfetch.js +1 -335
  220. package/package.json +1 -1
  221. package/share1.dat +0 -0
@@ -1,130 +1 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.publicKeyToPrivateMeDid = publicKeyToPrivateMeDid;
4
- exports.privateMeDidToPublicKeyBytes = privateMeDidToPublicKeyBytes;
5
- exports.isPrivateMeDid = isPrivateMeDid;
6
- exports.isDidKeyFormat = isDidKeyFormat;
7
- exports.convertDidFormat = convertDidFormat;
8
- exports.normalizeDid = normalizeDid;
9
- exports.parseDid = parseDid;
10
- const shared_1 = require("../_deps/shared/index.js");
11
- const identity_js_1 = require("./identity.js");
12
- /**
13
- * Mechanism 4: Convert Ed25519 public key to did:privateme DID.
14
- *
15
- * Format: did:privateme:z + base58btc(0xed01 || publicKey)
16
- *
17
- * This is a new DID method identifier for PRIVATE.ME ACIs.
18
- * It uses the same base58btc encoding as did:key for compatibility,
19
- * but signals that the identity is backed by PRIVATE.ME infrastructure.
20
- *
21
- * Backward compatible: agents accept both did:key and did:privateme formats.
22
- *
23
- * @param rawPublicKey - 32-byte Ed25519 public key
24
- * @returns DID in format did:privateme:z...
25
- */
26
- function publicKeyToPrivateMeDid(rawPublicKey) {
27
- // Use same encoding as did:key, but with privateme method
28
- const didKeyFormat = (0, identity_js_1.publicKeyToDid)(rawPublicKey);
29
- // Replace did:key: with did:privateme:
30
- return didKeyFormat.replace(/^did:key:/, 'did:privateme:');
31
- }
32
- /**
33
- * Extract raw 32-byte public key from a did:privateme DID.
34
- *
35
- * Format: did:privateme:z + base58btc(0xed01 || publicKey)
36
- *
37
- * @param did - DID in format did:privateme:z...
38
- * @returns 32-byte public key or error
39
- */
40
- function privateMeDidToPublicKeyBytes(did) {
41
- if (!did.startsWith('did:privateme:z')) {
42
- return (0, shared_1.err)('INVALID_DID_FORMAT');
43
- }
44
- // Convert to did:key format temporarily for parsing
45
- const didKeyFormat = did.replace(/^did:privateme:/, 'did:key:');
46
- // Use the existing parser
47
- const result = (0, identity_js_1.didToPublicKeyBytes)(didKeyFormat);
48
- if (!result.ok) {
49
- return (0, shared_1.err)(result.error);
50
- }
51
- return (0, shared_1.ok)(result.value);
52
- }
53
- /**
54
- * Determine if a DID is in the new did:privateme format.
55
- *
56
- * @param did - The DID to check
57
- * @returns true if DID is did:privateme format, false otherwise
58
- */
59
- function isPrivateMeDid(did) {
60
- return did.startsWith('did:privateme:');
61
- }
62
- /**
63
- * Determine if a DID is in the did:key format.
64
- *
65
- * @param did - The DID to check
66
- * @returns true if DID is did:key format, false otherwise
67
- */
68
- function isDidKeyFormat(did) {
69
- return did.startsWith('did:key:');
70
- }
71
- /**
72
- * Convert between DID formats (did:key ↔ did:privateme).
73
- *
74
- * Allows backward compatibility between old did:key and new did:privateme formats.
75
- * The public key remains the same; only the method identifier changes.
76
- *
77
- * @param did - Source DID in either format
78
- * @returns Converted DID in the other format, or error
79
- */
80
- function convertDidFormat(did) {
81
- if (isDidKeyFormat(did)) {
82
- // Convert did:key to did:privateme
83
- return (0, shared_1.ok)(did.replace(/^did:key:/, 'did:privateme:'));
84
- }
85
- if (isPrivateMeDid(did)) {
86
- // Convert did:privateme to did:key
87
- return (0, shared_1.ok)(did.replace(/^did:privateme:/, 'did:key:'));
88
- }
89
- return (0, shared_1.err)('UNSUPPORTED_DID_FORMAT');
90
- }
91
- /**
92
- * Normalize a DID to the canonical format (did:privateme).
93
- *
94
- * All DIDs are converted to did:privateme format for consistency.
95
- * Existing did:key DIDs are automatically upgraded.
96
- *
97
- * @param did - Source DID in any supported format
98
- * @returns Normalized DID in did:privateme format
99
- */
100
- function normalizeDid(did) {
101
- if (isPrivateMeDid(did)) {
102
- // Already in target format
103
- return (0, shared_1.ok)(did);
104
- }
105
- if (isDidKeyFormat(did)) {
106
- // Convert to did:privateme
107
- return (0, shared_1.ok)(did.replace(/^did:key:/, 'did:privateme:'));
108
- }
109
- return (0, shared_1.err)('UNSUPPORTED_DID_FORMAT');
110
- }
111
- /**
112
- * Parse a DID into method, identifier, and fragment.
113
- *
114
- * @param did - Full DID string
115
- * @returns Parsed DID components or error
116
- */
117
- function parseDid(did) {
118
- const fragmentMatch = did.indexOf('#');
119
- const base = fragmentMatch >= 0 ? did.substring(0, fragmentMatch) : did;
120
- const fragment = fragmentMatch >= 0 ? did.substring(fragmentMatch + 1) : undefined;
121
- const parts = base.split(':');
122
- if (parts.length < 3 || parts[0] !== 'did') {
123
- return (0, shared_1.err)('INVALID_DID_FORMAT');
124
- }
125
- return (0, shared_1.ok)({
126
- method: parts[1],
127
- identifier: parts.slice(2).join(':'),
128
- fragment,
129
- });
130
- }
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.publicKeyToPrivateMeDid=publicKeyToPrivateMeDid,exports.privateMeDidToPublicKeyBytes=privateMeDidToPublicKeyBytes,exports.isPrivateMeDid=isPrivateMeDid,exports.isDidKeyFormat=isDidKeyFormat,exports.convertDidFormat=convertDidFormat,exports.normalizeDid=normalizeDid,exports.parseDid=parseDid;const shared_1=require("../_deps/shared/index.js"),identity_js_1=require("./identity.js");function publicKeyToPrivateMeDid(e){return(0,identity_js_1.publicKeyToDid)(e).replace(/^did:key:/,"did:privateme:")}function privateMeDidToPublicKeyBytes(e){if(!e.startsWith("did:privateme:z"))return(0,shared_1.err)("INVALID_DID_FORMAT");const i=e.replace(/^did:privateme:/,"did:key:"),r=(0,identity_js_1.didToPublicKeyBytes)(i);return r.ok?(0,shared_1.ok)(r.value):(0,shared_1.err)(r.error)}function isPrivateMeDid(e){return e.startsWith("did:privateme:")}function isDidKeyFormat(e){return e.startsWith("did:key:")}function convertDidFormat(e){return isDidKeyFormat(e)?(0,shared_1.ok)(e.replace(/^did:key:/,"did:privateme:")):isPrivateMeDid(e)?(0,shared_1.ok)(e.replace(/^did:privateme:/,"did:key:")):(0,shared_1.err)("UNSUPPORTED_DID_FORMAT")}function normalizeDid(e){return isPrivateMeDid(e)?(0,shared_1.ok)(e):isDidKeyFormat(e)?(0,shared_1.ok)(e.replace(/^did:key:/,"did:privateme:")):(0,shared_1.err)("UNSUPPORTED_DID_FORMAT")}function parseDid(e){const i=e.indexOf("#"),r=i>=0?e.substring(0,i):e,t=i>=0?e.substring(i+1):void 0,d=r.split(":");return d.length<3||"did"!==d[0]?(0,shared_1.err)("INVALID_DID_FORMAT"):(0,shared_1.ok)({method:d[1],identifier:d.slice(2).join(":"),fragment:t})}
@@ -1,201 +1 @@
1
- "use strict";
2
- /**
3
- * did:web resolver — resolves DIDs hosted on developer domains.
4
- *
5
- * Implements the W3C did:web method:
6
- * did:web:example.com -> https://example.com/.well-known/did.json
7
- * did:web:example.com:path:to -> https://example.com/path/to/did.json
8
- *
9
- * Enables direct agent-to-agent communication without a centralized registry.
10
- * Implements TrustRegistry interface for drop-in use with Agent class.
11
- */
12
- Object.defineProperty(exports, "__esModule", { value: true });
13
- exports.DidWebResolver = void 0;
14
- exports.didWebToUrl = didWebToUrl;
15
- const shared_1 = require("../_deps/shared/index.js");
16
- const crypto_utils_js_1 = require("./crypto-utils.js");
17
- /**
18
- * Resolve did:web DIDs by fetching DID documents from the hosting domain.
19
- *
20
- * Implements TrustRegistry interface so it can be used as a drop-in
21
- * replacement for MemoryTrustRegistry or HttpTrustRegistry.
22
- */
23
- class DidWebResolver {
24
- fetchFn;
25
- cacheTtlMs;
26
- cache = new Map();
27
- constructor(opts) {
28
- this.fetchFn = opts?.fetch ?? globalThis.fetch.bind(globalThis);
29
- this.cacheTtlMs = opts?.cacheTtlMs ?? 300_000;
30
- }
31
- /** Registration not supported for did:web (developers host their own). */
32
- async register(_did, _publicKey, _name, _scopes, _x25519PublicKey) {
33
- return (0, shared_1.err)('ALREADY_REGISTERED');
34
- }
35
- /**
36
- * Resolve a did:web DID to its raw public key bytes.
37
- * @param did - A did:web DID string.
38
- * @returns Public key bytes or error.
39
- */
40
- async resolve(did) {
41
- const entry = await this.fetchEntry(did);
42
- if (!entry.ok)
43
- return entry;
44
- if (entry.value.revoked)
45
- return (0, shared_1.err)('REVOKED');
46
- return (0, shared_1.ok)(entry.value.publicKey);
47
- }
48
- /**
49
- * Check if a did:web DID has a specific scope.
50
- * @param did - The DID to check.
51
- * @param scope - The scope to verify.
52
- * @returns True if scope is granted.
53
- */
54
- async hasScope(did, scope) {
55
- const entry = await this.fetchEntry(did);
56
- if (!entry.ok)
57
- return false;
58
- return entry.value.scopes.has(scope);
59
- }
60
- /**
61
- * Check if a did:web DID has a specific receive scope.
62
- * @param did - The DID to check.
63
- * @param scope - The scope to verify.
64
- * @returns True if receive scope is granted.
65
- */
66
- async hasReceiveScope(did, scope) {
67
- const entry = await this.fetchEntry(did);
68
- if (!entry.ok)
69
- return false;
70
- // Undefined = accept all scopes (backward compatibility)
71
- if (!entry.value.receiveScopes)
72
- return true;
73
- return entry.value.receiveScopes.has(scope);
74
- }
75
- /** Revocation not supported for did:web (developer controls their domain). */
76
- async revoke(_did) {
77
- return (0, shared_1.err)('NOT_FOUND');
78
- }
79
- /**
80
- * Get the full registry entry for a did:web DID.
81
- * @param did - The DID to look up.
82
- * @returns Full entry or error.
83
- */
84
- async getEntry(did) {
85
- return this.fetchEntry(did);
86
- }
87
- /** Number of cached entries (for testing). */
88
- get cacheSize() {
89
- return this.cache.size;
90
- }
91
- /** Fetch and parse a DID document, with caching. */
92
- async fetchEntry(did) {
93
- // Check cache
94
- const cached = this.cache.get(did);
95
- if (cached && Date.now() - cached.fetchedAt < this.cacheTtlMs) {
96
- return (0, shared_1.ok)(cached.entry);
97
- }
98
- const url = didWebToUrl(did);
99
- if (!url)
100
- return (0, shared_1.err)('NOT_FOUND');
101
- try {
102
- const res = await this.fetchFn(url);
103
- if (!res.ok)
104
- return (0, shared_1.err)('NOT_FOUND');
105
- const doc = (await res.json());
106
- const entry = parseDidDocument(did, doc);
107
- if (!entry)
108
- return (0, shared_1.err)('NOT_FOUND');
109
- this.cache.set(did, { entry, fetchedAt: Date.now() });
110
- return (0, shared_1.ok)(entry);
111
- }
112
- catch {
113
- return (0, shared_1.err)('NETWORK_ERROR');
114
- }
115
- }
116
- }
117
- exports.DidWebResolver = DidWebResolver;
118
- /**
119
- * Convert a did:web DID to its HTTPS URL.
120
- * did:web:example.com -> https://example.com/.well-known/did.json
121
- * did:web:example.com:path:to -> https://example.com/path/to/did.json
122
- * @param did - The did:web DID string.
123
- * @returns HTTPS URL or null if invalid.
124
- */
125
- function didWebToUrl(did) {
126
- if (!did.startsWith('did:web:'))
127
- return null;
128
- const parts = did.slice('did:web:'.length).split(':');
129
- if (parts.length === 0 || !parts[0])
130
- return null;
131
- const domain = decodeURIComponent(parts[0]);
132
- if (parts.length === 1) {
133
- return `https://${domain}/.well-known/did.json`;
134
- }
135
- const path = parts.slice(1).map(decodeURIComponent).join('/');
136
- return `https://${domain}/${path}/did.json`;
137
- }
138
- /** Parse a DID document into a RegistryEntry. */
139
- function parseDidDocument(did, doc) {
140
- if (!doc.verificationMethod || doc.verificationMethod.length === 0) {
141
- return null;
142
- }
143
- const vm = doc.verificationMethod[0];
144
- if (!vm)
145
- return null;
146
- let publicKey = null;
147
- if (vm.publicKeyMultibase) {
148
- publicKey = decodeMultibase(vm.publicKeyMultibase);
149
- }
150
- else if (vm.publicKeyBase64) {
151
- publicKey = (0, crypto_utils_js_1.fromBase64)(vm.publicKeyBase64);
152
- }
153
- if (!publicKey)
154
- return null;
155
- return {
156
- did,
157
- publicKey,
158
- name: doc.xailName ?? did,
159
- scopes: new Set(doc.xailScopes ?? []),
160
- revoked: doc.deactivated === true,
161
- rotation_sequence: 1, // DID documents don't track rotation, default to 1
162
- };
163
- }
164
- /** Decode z-prefixed base58btc multibase to bytes. */
165
- function decodeMultibase(mb) {
166
- if (!mb.startsWith('z'))
167
- return null;
168
- return base58Decode(mb.slice(1));
169
- }
170
- /** Base58 decode (Bitcoin alphabet). */
171
- function base58Decode(s) {
172
- const ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';
173
- const BASE = BigInt(58);
174
- let num = BigInt(0);
175
- for (const char of s) {
176
- const idx = ALPHABET.indexOf(char);
177
- if (idx < 0)
178
- return new Uint8Array(0);
179
- num = num * BASE + BigInt(idx);
180
- }
181
- const hex = num.toString(16);
182
- const padded = hex.length % 2 ? '0' + hex : hex;
183
- const bytes = new Uint8Array(padded.length / 2);
184
- for (let i = 0; i < bytes.length; i++) {
185
- bytes[i] = parseInt(padded.slice(i * 2, i * 2 + 2), 16);
186
- }
187
- // Handle leading zeros (base58 "1" = 0x00)
188
- let leadingZeros = 0;
189
- for (const c of s) {
190
- if (c === '1')
191
- leadingZeros++;
192
- else
193
- break;
194
- }
195
- if (leadingZeros > 0) {
196
- const result = new Uint8Array(leadingZeros + bytes.length);
197
- result.set(bytes, leadingZeros);
198
- return result;
199
- }
200
- return bytes;
201
- }
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.DidWebResolver=void 0,exports.didWebToUrl=didWebToUrl;const shared_1=require("../_deps/shared/index.js"),crypto_utils_js_1=require("./crypto-utils.js");class DidWebResolver{fetchFn;cacheTtlMs;cache=new Map;constructor(e){this.fetchFn=e?.fetch??globalThis.fetch.bind(globalThis),this.cacheTtlMs=e?.cacheTtlMs??3e5}async register(e,t,r,n,s){return(0,shared_1.err)("ALREADY_REGISTERED")}async resolve(e){const t=await this.fetchEntry(e);return t.ok?t.value.revoked?(0,shared_1.err)("REVOKED"):(0,shared_1.ok)(t.value.publicKey):t}async hasScope(e,t){const r=await this.fetchEntry(e);return!!r.ok&&r.value.scopes.has(t)}async hasReceiveScope(e,t){const r=await this.fetchEntry(e);return!!r.ok&&(!r.value.receiveScopes||r.value.receiveScopes.has(t))}async revoke(e){return(0,shared_1.err)("NOT_FOUND")}async getEntry(e){return this.fetchEntry(e)}get cacheSize(){return this.cache.size}async fetchEntry(e){const t=this.cache.get(e);if(t&&Date.now()-t.fetchedAt<this.cacheTtlMs)return(0,shared_1.ok)(t.entry);const r=didWebToUrl(e);if(!r)return(0,shared_1.err)("NOT_FOUND");try{const t=await this.fetchFn(r);if(!t.ok)return(0,shared_1.err)("NOT_FOUND");const n=parseDidDocument(e,await t.json());return n?(this.cache.set(e,{entry:n,fetchedAt:Date.now()}),(0,shared_1.ok)(n)):(0,shared_1.err)("NOT_FOUND")}catch{return(0,shared_1.err)("NETWORK_ERROR")}}}function didWebToUrl(e){if(!e.startsWith("did:web:"))return null;const t=e.slice(8).split(":");if(0===t.length||!t[0])return null;const r=decodeURIComponent(t[0]);if(1===t.length)return`https://${r}/.well-known/did.json`;return`https://${r}/${t.slice(1).map(decodeURIComponent).join("/")}/did.json`}function parseDidDocument(e,t){if(!t.verificationMethod||0===t.verificationMethod.length)return null;const r=t.verificationMethod[0];if(!r)return null;let n=null;return r.publicKeyMultibase?n=decodeMultibase(r.publicKeyMultibase):r.publicKeyBase64&&(n=(0,crypto_utils_js_1.fromBase64)(r.publicKeyBase64)),n?{did:e,publicKey:n,name:t.xailName??e,scopes:new Set(t.xailScopes??[]),revoked:!0===t.deactivated,rotation_sequence:1}:null}function decodeMultibase(e){return e.startsWith("z")?base58Decode(e.slice(1)):null}function base58Decode(e){const t=BigInt(58);let r=BigInt(0);for(const n of e){const e="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz".indexOf(n);if(e<0)return new Uint8Array(0);r=r*t+BigInt(e)}const n=r.toString(16),s=n.length%2?"0"+n:n,i=new Uint8Array(s.length/2);for(let e=0;e<i.length;e++)i[e]=parseInt(s.slice(2*e,2*e+2),16);let c=0;for(const t of e){if("1"!==t)break;c++}if(c>0){const e=new Uint8Array(c+i.length);return e.set(i,c),e}return i}exports.DidWebResolver=DidWebResolver;