@private.me/xbind 1.2.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 (295) hide show
  1. package/AGENTS.md +778 -0
  2. package/LICENSE.md +27 -0
  3. package/README.md +400 -0
  4. package/dist-standalone/_deps/crypto/base64.d.ts +29 -0
  5. package/dist-standalone/_deps/crypto/base64.js +97 -0
  6. package/dist-standalone/_deps/crypto/cjs/base64.js +103 -0
  7. package/dist-standalone/_deps/crypto/cjs/errors.js +119 -0
  8. package/dist-standalone/_deps/crypto/cjs/hmac.js +71 -0
  9. package/dist-standalone/_deps/crypto/cjs/index.js +86 -0
  10. package/dist-standalone/_deps/crypto/cjs/padding.js +57 -0
  11. package/dist-standalone/_deps/crypto/cjs/share-header.js +68 -0
  12. package/dist-standalone/_deps/crypto/cjs/shares.js +152 -0
  13. package/dist-standalone/_deps/crypto/cjs/tlv.js +199 -0
  14. package/dist-standalone/_deps/crypto/cjs/uuid.js +61 -0
  15. package/dist-standalone/_deps/crypto/cjs/verify.js +24 -0
  16. package/dist-standalone/_deps/crypto/cjs/xorida.js +221 -0
  17. package/dist-standalone/_deps/crypto/errors.d.ts +51 -0
  18. package/dist-standalone/_deps/crypto/errors.js +109 -0
  19. package/dist-standalone/_deps/crypto/hmac.d.ts +39 -0
  20. package/dist-standalone/_deps/crypto/hmac.js +66 -0
  21. package/dist-standalone/_deps/crypto/index.d.ts +20 -0
  22. package/dist-standalone/_deps/crypto/index.js +45 -0
  23. package/dist-standalone/_deps/crypto/padding.d.ts +19 -0
  24. package/dist-standalone/_deps/crypto/padding.js +53 -0
  25. package/dist-standalone/_deps/crypto/share-header.d.ts +44 -0
  26. package/dist-standalone/_deps/crypto/share-header.js +63 -0
  27. package/dist-standalone/_deps/crypto/shares.d.ts +27 -0
  28. package/dist-standalone/_deps/crypto/shares.js +148 -0
  29. package/dist-standalone/_deps/crypto/tlv.d.ts +26 -0
  30. package/dist-standalone/_deps/crypto/tlv.js +195 -0
  31. package/dist-standalone/_deps/crypto/uuid.d.ts +22 -0
  32. package/dist-standalone/_deps/crypto/uuid.js +56 -0
  33. package/dist-standalone/_deps/crypto/verify.d.ts +15 -0
  34. package/dist-standalone/_deps/crypto/verify.js +15 -0
  35. package/dist-standalone/_deps/crypto/xorida.d.ts +44 -0
  36. package/dist-standalone/_deps/crypto/xorida.js +215 -0
  37. package/dist-standalone/_deps/mldsa-wasm/LICENSE +24 -0
  38. package/dist-standalone/_deps/mldsa-wasm/dist/mldsa.js +1920 -0
  39. package/dist-standalone/_deps/mldsa-wasm/package.json +46 -0
  40. package/dist-standalone/_deps/mldsa-wasm/types/mldsa.d.ts +30 -0
  41. package/dist-standalone/_deps/shared/cjs/errors.js +582 -0
  42. package/dist-standalone/_deps/shared/cjs/index.js +492 -0
  43. package/dist-standalone/_deps/shared/cjs/package.json +1 -0
  44. package/dist-standalone/_deps/shared/cjs/types.js +403 -0
  45. package/dist-standalone/_deps/shared/errors.d.ts +48 -0
  46. package/dist-standalone/_deps/shared/errors.d.ts.map +1 -0
  47. package/dist-standalone/_deps/shared/errors.js +192 -0
  48. package/dist-standalone/_deps/shared/errors.js.map +1 -0
  49. package/dist-standalone/_deps/shared/index.d.ts +4 -0
  50. package/dist-standalone/_deps/shared/index.d.ts.map +1 -0
  51. package/dist-standalone/_deps/shared/index.js +78 -0
  52. package/dist-standalone/_deps/shared/index.js.map +1 -0
  53. package/dist-standalone/_deps/shared/types.d.ts +1097 -0
  54. package/dist-standalone/_deps/shared/types.d.ts.map +1 -0
  55. package/dist-standalone/_deps/shared/types.js +89 -0
  56. package/dist-standalone/_deps/shared/types.js.map +1 -0
  57. package/dist-standalone/_deps/ux-helpers/cjs/errors.d.ts +115 -0
  58. package/dist-standalone/_deps/ux-helpers/cjs/errors.d.ts.map +1 -0
  59. package/dist-standalone/_deps/ux-helpers/cjs/errors.js +1 -0
  60. package/dist-standalone/_deps/ux-helpers/cjs/errors.js.map +1 -0
  61. package/dist-standalone/_deps/ux-helpers/cjs/index.d.ts +13 -0
  62. package/dist-standalone/_deps/ux-helpers/cjs/index.d.ts.map +1 -0
  63. package/dist-standalone/_deps/ux-helpers/cjs/index.js +1 -0
  64. package/dist-standalone/_deps/ux-helpers/cjs/index.js.map +1 -0
  65. package/dist-standalone/_deps/ux-helpers/cjs/package.json +1 -0
  66. package/dist-standalone/_deps/ux-helpers/cjs/pagination.d.ts +39 -0
  67. package/dist-standalone/_deps/ux-helpers/cjs/pagination.d.ts.map +1 -0
  68. package/dist-standalone/_deps/ux-helpers/cjs/pagination.js +83 -0
  69. package/dist-standalone/_deps/ux-helpers/cjs/pagination.js.map +1 -0
  70. package/dist-standalone/_deps/ux-helpers/cjs/progress.d.ts +99 -0
  71. package/dist-standalone/_deps/ux-helpers/cjs/progress.d.ts.map +1 -0
  72. package/dist-standalone/_deps/ux-helpers/cjs/progress.js +143 -0
  73. package/dist-standalone/_deps/ux-helpers/cjs/progress.js.map +1 -0
  74. package/dist-standalone/_deps/ux-helpers/cjs/search.d.ts +32 -0
  75. package/dist-standalone/_deps/ux-helpers/cjs/search.d.ts.map +1 -0
  76. package/dist-standalone/_deps/ux-helpers/cjs/search.js +119 -0
  77. package/dist-standalone/_deps/ux-helpers/cjs/search.js.map +1 -0
  78. package/dist-standalone/_deps/ux-helpers/cjs/types.d.ts +109 -0
  79. package/dist-standalone/_deps/ux-helpers/cjs/types.d.ts.map +1 -0
  80. package/dist-standalone/_deps/ux-helpers/cjs/types.js +8 -0
  81. package/dist-standalone/_deps/ux-helpers/cjs/types.js.map +1 -0
  82. package/dist-standalone/_deps/ux-helpers/errors.d.ts +115 -0
  83. package/dist-standalone/_deps/ux-helpers/errors.d.ts.map +1 -0
  84. package/dist-standalone/_deps/ux-helpers/errors.js +253 -0
  85. package/dist-standalone/_deps/ux-helpers/errors.js.map +1 -0
  86. package/dist-standalone/_deps/ux-helpers/index.d.ts +13 -0
  87. package/dist-standalone/_deps/ux-helpers/index.d.ts.map +1 -0
  88. package/dist-standalone/_deps/ux-helpers/index.js +16 -0
  89. package/dist-standalone/_deps/ux-helpers/index.js.map +1 -0
  90. package/dist-standalone/_deps/ux-helpers/pagination.d.ts +39 -0
  91. package/dist-standalone/_deps/ux-helpers/pagination.d.ts.map +1 -0
  92. package/dist-standalone/_deps/ux-helpers/pagination.js +79 -0
  93. package/dist-standalone/_deps/ux-helpers/pagination.js.map +1 -0
  94. package/dist-standalone/_deps/ux-helpers/progress.d.ts +99 -0
  95. package/dist-standalone/_deps/ux-helpers/progress.d.ts.map +1 -0
  96. package/dist-standalone/_deps/ux-helpers/progress.js +138 -0
  97. package/dist-standalone/_deps/ux-helpers/progress.js.map +1 -0
  98. package/dist-standalone/_deps/ux-helpers/search.d.ts +32 -0
  99. package/dist-standalone/_deps/ux-helpers/search.d.ts.map +1 -0
  100. package/dist-standalone/_deps/ux-helpers/search.js +116 -0
  101. package/dist-standalone/_deps/ux-helpers/search.js.map +1 -0
  102. package/dist-standalone/_deps/ux-helpers/types.d.ts +109 -0
  103. package/dist-standalone/_deps/ux-helpers/types.d.ts.map +1 -0
  104. package/dist-standalone/_deps/ux-helpers/types.js +7 -0
  105. package/dist-standalone/_deps/ux-helpers/types.js.map +1 -0
  106. package/dist-standalone/_deps/xchange/auto-accept.d.ts +127 -0
  107. package/dist-standalone/_deps/xchange/auto-accept.js +1 -0
  108. package/dist-standalone/_deps/xchange/cjs/auto-accept.js +1 -0
  109. package/dist-standalone/_deps/xchange/cjs/errors.js +1 -0
  110. package/dist-standalone/_deps/xchange/cjs/index.js +1 -0
  111. package/dist-standalone/_deps/xchange/cjs/invite-client.js +1 -0
  112. package/dist-standalone/_deps/xchange/cjs/lazy-init.js +1 -0
  113. package/dist-standalone/_deps/xchange/cjs/package.json +1 -0
  114. package/dist-standalone/_deps/xchange/cjs/trust-integration.js +1 -0
  115. package/dist-standalone/_deps/xchange/cjs/xchange.js +1 -0
  116. package/dist-standalone/_deps/xchange/errors.d.ts +69 -0
  117. package/dist-standalone/_deps/xchange/errors.js +1 -0
  118. package/dist-standalone/_deps/xchange/index.d.ts +15 -0
  119. package/dist-standalone/_deps/xchange/index.js +1 -0
  120. package/dist-standalone/_deps/xchange/invite-client.d.ts +178 -0
  121. package/dist-standalone/_deps/xchange/invite-client.js +1 -0
  122. package/dist-standalone/_deps/xchange/lazy-init.d.ts +176 -0
  123. package/dist-standalone/_deps/xchange/lazy-init.js +1 -0
  124. package/dist-standalone/_deps/xchange/trust-integration.d.ts +102 -0
  125. package/dist-standalone/_deps/xchange/trust-integration.js +1 -0
  126. package/dist-standalone/_deps/xchange/xchange.d.ts +60 -0
  127. package/dist-standalone/_deps/xchange/xchange.js +1 -0
  128. package/dist-standalone/_deps/xregistry/cjs/discovery.js +1 -0
  129. package/dist-standalone/_deps/xregistry/cjs/errors.js +1 -0
  130. package/dist-standalone/_deps/xregistry/cjs/index.js +1 -0
  131. package/dist-standalone/_deps/xregistry/cjs/package.json +1 -0
  132. package/dist-standalone/_deps/xregistry/cjs/registry.js +1 -0
  133. package/dist-standalone/_deps/xregistry/cjs/schema.js +1 -0
  134. package/dist-standalone/_deps/xregistry/cjs/types.js +1 -0
  135. package/dist-standalone/_deps/xregistry/discovery.d.ts +126 -0
  136. package/dist-standalone/_deps/xregistry/discovery.d.ts.map +1 -0
  137. package/dist-standalone/_deps/xregistry/discovery.js +1 -0
  138. package/dist-standalone/_deps/xregistry/discovery.js.map +1 -0
  139. package/dist-standalone/_deps/xregistry/errors.d.ts +41 -0
  140. package/dist-standalone/_deps/xregistry/errors.d.ts.map +1 -0
  141. package/dist-standalone/_deps/xregistry/errors.js +1 -0
  142. package/dist-standalone/_deps/xregistry/errors.js.map +1 -0
  143. package/dist-standalone/_deps/xregistry/index.d.ts +8 -0
  144. package/dist-standalone/_deps/xregistry/index.d.ts.map +1 -0
  145. package/dist-standalone/_deps/xregistry/index.js +1 -0
  146. package/dist-standalone/_deps/xregistry/index.js.map +1 -0
  147. package/dist-standalone/_deps/xregistry/registry.d.ts +85 -0
  148. package/dist-standalone/_deps/xregistry/registry.d.ts.map +1 -0
  149. package/dist-standalone/_deps/xregistry/registry.js +1 -0
  150. package/dist-standalone/_deps/xregistry/registry.js.map +1 -0
  151. package/dist-standalone/_deps/xregistry/schema.d.ts +81 -0
  152. package/dist-standalone/_deps/xregistry/schema.d.ts.map +1 -0
  153. package/dist-standalone/_deps/xregistry/schema.js +1 -0
  154. package/dist-standalone/_deps/xregistry/schema.js.map +1 -0
  155. package/dist-standalone/_deps/xregistry/types.d.ts +95 -0
  156. package/dist-standalone/_deps/xregistry/types.d.ts.map +1 -0
  157. package/dist-standalone/_deps/xregistry/types.js +1 -0
  158. package/dist-standalone/_deps/xregistry/types.js.map +1 -0
  159. package/dist-standalone/agent-call.d.ts +286 -0
  160. package/dist-standalone/agent-call.js +642 -0
  161. package/dist-standalone/agent-sdk.d.ts +207 -0
  162. package/dist-standalone/agent-sdk.js +328 -0
  163. package/dist-standalone/agent.d.ts +670 -0
  164. package/dist-standalone/agent.js +1529 -0
  165. package/dist-standalone/approval.d.ts +145 -0
  166. package/dist-standalone/approval.js +193 -0
  167. package/dist-standalone/auth.d.ts +75 -0
  168. package/dist-standalone/auth.js +219 -0
  169. package/dist-standalone/auto-accept.d.ts +102 -0
  170. package/dist-standalone/auto-accept.js +229 -0
  171. package/dist-standalone/backup-config.d.ts +150 -0
  172. package/dist-standalone/backup-config.js +201 -0
  173. package/dist-standalone/checkpoint.d.ts +125 -0
  174. package/dist-standalone/checkpoint.js +186 -0
  175. package/dist-standalone/cjs/agent-call.js +651 -0
  176. package/dist-standalone/cjs/agent-sdk.js +332 -0
  177. package/dist-standalone/cjs/agent.js +1566 -0
  178. package/dist-standalone/cjs/approval.js +199 -0
  179. package/dist-standalone/cjs/auth.js +225 -0
  180. package/dist-standalone/cjs/auto-accept.js +233 -0
  181. package/dist-standalone/cjs/backup-config.js +207 -0
  182. package/dist-standalone/cjs/checkpoint.js +193 -0
  183. package/dist-standalone/cjs/cli/init.js +487 -0
  184. package/dist-standalone/cjs/connect.js +312 -0
  185. package/dist-standalone/cjs/did-document.js +101 -0
  186. package/dist-standalone/cjs/did-privateme.js +130 -0
  187. package/dist-standalone/cjs/did-web.js +201 -0
  188. package/dist-standalone/cjs/discovery.js +462 -0
  189. package/dist-standalone/cjs/dual-mode.js +251 -0
  190. package/dist-standalone/cjs/email-templates.js +313 -0
  191. package/dist-standalone/cjs/email-transport.js +239 -0
  192. package/dist-standalone/cjs/envelope.js +510 -0
  193. package/dist-standalone/cjs/errors.js +562 -0
  194. package/dist-standalone/cjs/gateway-state.js +55 -0
  195. package/dist-standalone/cjs/gateway-transport.js +120 -0
  196. package/dist-standalone/cjs/guardrails.js +223 -0
  197. package/dist-standalone/cjs/http-compat.js +272 -0
  198. package/dist-standalone/cjs/identity.js +541 -0
  199. package/dist-standalone/cjs/index.js +224 -0
  200. package/dist-standalone/cjs/invitation.js +421 -0
  201. package/dist-standalone/cjs/invite.js +328 -0
  202. package/dist-standalone/cjs/key-agreement.js +246 -0
  203. package/dist-standalone/cjs/lazy-init.js +300 -0
  204. package/dist-standalone/cjs/mdns-discovery.js +202 -0
  205. package/dist-standalone/cjs/nonce-store.js +66 -0
  206. package/dist-standalone/cjs/package.json +3 -0
  207. package/dist-standalone/cjs/pairing-manager.js +223 -0
  208. package/dist-standalone/cjs/policy.js +320 -0
  209. package/dist-standalone/cjs/redis-nonce-store.js +76 -0
  210. package/dist-standalone/cjs/registry-middleware.js +50 -0
  211. package/dist-standalone/cjs/retry-transport.js +102 -0
  212. package/dist-standalone/cjs/security-policy.js +204 -0
  213. package/dist-standalone/cjs/split-channel.js +177 -0
  214. package/dist-standalone/cjs/subscription-proof.js +230 -0
  215. package/dist-standalone/cjs/succession.js +148 -0
  216. package/dist-standalone/cjs/transport.js +63 -0
  217. package/dist-standalone/cjs/trust-registry.js +742 -0
  218. package/dist-standalone/cjs/verify.js +25 -0
  219. package/dist-standalone/cjs/xfetch.js +252 -0
  220. package/dist-standalone/cli/init.d.ts +63 -0
  221. package/dist-standalone/cli/init.js +450 -0
  222. package/dist-standalone/connect.d.ts +143 -0
  223. package/dist-standalone/connect.js +274 -0
  224. package/dist-standalone/did-document.d.ts +65 -0
  225. package/dist-standalone/did-document.js +96 -0
  226. package/dist-standalone/did-privateme.d.ts +70 -0
  227. package/dist-standalone/did-privateme.js +121 -0
  228. package/dist-standalone/did-web.d.ts +73 -0
  229. package/dist-standalone/did-web.js +196 -0
  230. package/dist-standalone/discovery.d.ts +176 -0
  231. package/dist-standalone/discovery.js +458 -0
  232. package/dist-standalone/dual-mode.d.ts +145 -0
  233. package/dist-standalone/dual-mode.js +247 -0
  234. package/dist-standalone/email-templates.d.ts +41 -0
  235. package/dist-standalone/email-templates.js +309 -0
  236. package/dist-standalone/email-transport.d.ts +139 -0
  237. package/dist-standalone/email-transport.js +232 -0
  238. package/dist-standalone/envelope.d.ts +288 -0
  239. package/dist-standalone/envelope.js +497 -0
  240. package/dist-standalone/errors.d.ts +74 -0
  241. package/dist-standalone/errors.js +548 -0
  242. package/dist-standalone/gateway-state.d.ts +32 -0
  243. package/dist-standalone/gateway-state.js +51 -0
  244. package/dist-standalone/gateway-transport.d.ts +59 -0
  245. package/dist-standalone/gateway-transport.js +116 -0
  246. package/dist-standalone/guardrails.d.ts +136 -0
  247. package/dist-standalone/guardrails.js +216 -0
  248. package/dist-standalone/http-compat.d.ts +150 -0
  249. package/dist-standalone/http-compat.js +267 -0
  250. package/dist-standalone/identity.d.ts +176 -0
  251. package/dist-standalone/identity.js +516 -0
  252. package/dist-standalone/index.d.ts +83 -0
  253. package/dist-standalone/index.js +51 -0
  254. package/dist-standalone/invitation.d.ts +211 -0
  255. package/dist-standalone/invitation.js +415 -0
  256. package/dist-standalone/invite.d.ts +192 -0
  257. package/dist-standalone/invite.js +324 -0
  258. package/dist-standalone/key-agreement.d.ts +122 -0
  259. package/dist-standalone/key-agreement.js +236 -0
  260. package/dist-standalone/lazy-init.d.ts +167 -0
  261. package/dist-standalone/lazy-init.js +295 -0
  262. package/dist-standalone/mdns-discovery.d.ts +117 -0
  263. package/dist-standalone/mdns-discovery.js +195 -0
  264. package/dist-standalone/nonce-store.d.ts +39 -0
  265. package/dist-standalone/nonce-store.js +62 -0
  266. package/dist-standalone/package.json +11 -0
  267. package/dist-standalone/pairing-manager.d.ts +147 -0
  268. package/dist-standalone/pairing-manager.js +219 -0
  269. package/dist-standalone/policy.d.ts +150 -0
  270. package/dist-standalone/policy.js +315 -0
  271. package/dist-standalone/redis-nonce-store.d.ts +93 -0
  272. package/dist-standalone/redis-nonce-store.js +72 -0
  273. package/dist-standalone/registry-middleware.d.ts +38 -0
  274. package/dist-standalone/registry-middleware.js +47 -0
  275. package/dist-standalone/retry-transport.d.ts +76 -0
  276. package/dist-standalone/retry-transport.js +98 -0
  277. package/dist-standalone/security-policy.d.ts +146 -0
  278. package/dist-standalone/security-policy.js +198 -0
  279. package/dist-standalone/split-channel.d.ts +69 -0
  280. package/dist-standalone/split-channel.js +171 -0
  281. package/dist-standalone/subscription-proof.d.ts +103 -0
  282. package/dist-standalone/subscription-proof.js +224 -0
  283. package/dist-standalone/succession.d.ts +57 -0
  284. package/dist-standalone/succession.js +142 -0
  285. package/dist-standalone/transport.d.ts +50 -0
  286. package/dist-standalone/transport.js +59 -0
  287. package/dist-standalone/trust-registry.d.ts +286 -0
  288. package/dist-standalone/trust-registry.js +702 -0
  289. package/dist-standalone/verify.d.ts +16 -0
  290. package/dist-standalone/verify.js +16 -0
  291. package/dist-standalone/xfetch.d.ts +129 -0
  292. package/dist-standalone/xfetch.js +247 -0
  293. package/llms.txt +800 -0
  294. package/package.json +79 -0
  295. package/share1.dat +0 -0
@@ -0,0 +1,196 @@
1
+ /**
2
+ * did:web resolver — resolves DIDs hosted on developer domains.
3
+ *
4
+ * Implements the W3C did:web method:
5
+ * did:web:example.com -> https://example.com/.well-known/did.json
6
+ * did:web:example.com:path:to -> https://example.com/path/to/did.json
7
+ *
8
+ * Enables direct agent-to-agent communication without a centralized registry.
9
+ * Implements TrustRegistry interface for drop-in use with Agent class.
10
+ */
11
+ import { ok, err } from"./_deps/shared/index.js";
12
+ import { fromBase64 } from"./_deps/crypto/index.js";
13
+ /**
14
+ * Resolve did:web DIDs by fetching DID documents from the hosting domain.
15
+ *
16
+ * Implements TrustRegistry interface so it can be used as a drop-in
17
+ * replacement for MemoryTrustRegistry or HttpTrustRegistry.
18
+ */
19
+ export class DidWebResolver {
20
+ fetchFn;
21
+ cacheTtlMs;
22
+ cache = new Map();
23
+ constructor(opts) {
24
+ this.fetchFn = opts?.fetch ?? globalThis.fetch.bind(globalThis);
25
+ this.cacheTtlMs = opts?.cacheTtlMs ?? 300_000;
26
+ }
27
+ /** Registration not supported for did:web (developers host their own). */
28
+ async register(_did, _publicKey, _name, _scopes, _x25519PublicKey) {
29
+ return err('ALREADY_REGISTERED');
30
+ }
31
+ /**
32
+ * Resolve a did:web DID to its raw public key bytes.
33
+ * @param did - A did:web DID string.
34
+ * @returns Public key bytes or error.
35
+ */
36
+ async resolve(did) {
37
+ const entry = await this.fetchEntry(did);
38
+ if (!entry.ok)
39
+ return entry;
40
+ if (entry.value.revoked)
41
+ return err('REVOKED');
42
+ return ok(entry.value.publicKey);
43
+ }
44
+ /**
45
+ * Check if a did:web DID has a specific scope.
46
+ * @param did - The DID to check.
47
+ * @param scope - The scope to verify.
48
+ * @returns True if scope is granted.
49
+ */
50
+ async hasScope(did, scope) {
51
+ const entry = await this.fetchEntry(did);
52
+ if (!entry.ok)
53
+ return false;
54
+ return entry.value.scopes.has(scope);
55
+ }
56
+ /**
57
+ * Check if a did:web DID has a specific receive scope.
58
+ * @param did - The DID to check.
59
+ * @param scope - The scope to verify.
60
+ * @returns True if receive scope is granted.
61
+ */
62
+ async hasReceiveScope(did, scope) {
63
+ const entry = await this.fetchEntry(did);
64
+ if (!entry.ok)
65
+ return false;
66
+ // Undefined = accept all scopes (backward compatibility)
67
+ if (!entry.value.receiveScopes)
68
+ return true;
69
+ return entry.value.receiveScopes.has(scope);
70
+ }
71
+ /** Revocation not supported for did:web (developer controls their domain). */
72
+ async revoke(_did) {
73
+ return err('NOT_FOUND');
74
+ }
75
+ /**
76
+ * Get the full registry entry for a did:web DID.
77
+ * @param did - The DID to look up.
78
+ * @returns Full entry or error.
79
+ */
80
+ async getEntry(did) {
81
+ return this.fetchEntry(did);
82
+ }
83
+ /** Number of cached entries (for testing). */
84
+ get cacheSize() {
85
+ return this.cache.size;
86
+ }
87
+ /** Fetch and parse a DID document, with caching. */
88
+ async fetchEntry(did) {
89
+ // Check cache
90
+ const cached = this.cache.get(did);
91
+ if (cached && Date.now() - cached.fetchedAt < this.cacheTtlMs) {
92
+ return ok(cached.entry);
93
+ }
94
+ const url = didWebToUrl(did);
95
+ if (!url)
96
+ return err('NOT_FOUND');
97
+ try {
98
+ const res = await this.fetchFn(url);
99
+ if (!res.ok)
100
+ return err('NOT_FOUND');
101
+ const doc = (await res.json());
102
+ const entry = parseDidDocument(did, doc);
103
+ if (!entry)
104
+ return err('NOT_FOUND');
105
+ this.cache.set(did, { entry, fetchedAt: Date.now() });
106
+ return ok(entry);
107
+ }
108
+ catch {
109
+ return err('NETWORK_ERROR');
110
+ }
111
+ }
112
+ }
113
+ /**
114
+ * Convert a did:web DID to its HTTPS URL.
115
+ * did:web:example.com -> https://example.com/.well-known/did.json
116
+ * did:web:example.com:path:to -> https://example.com/path/to/did.json
117
+ * @param did - The did:web DID string.
118
+ * @returns HTTPS URL or null if invalid.
119
+ */
120
+ export function didWebToUrl(did) {
121
+ if (!did.startsWith('did:web:'))
122
+ return null;
123
+ const parts = did.slice('did:web:'.length).split(':');
124
+ if (parts.length === 0 || !parts[0])
125
+ return null;
126
+ const domain = decodeURIComponent(parts[0]);
127
+ if (parts.length === 1) {
128
+ return `https://${domain}/.well-known/did.json`;
129
+ }
130
+ const path = parts.slice(1).map(decodeURIComponent).join('/');
131
+ return `https://${domain}/${path}/did.json`;
132
+ }
133
+ /** Parse a DID document into a RegistryEntry. */
134
+ function parseDidDocument(did, doc) {
135
+ if (!doc.verificationMethod || doc.verificationMethod.length === 0) {
136
+ return null;
137
+ }
138
+ const vm = doc.verificationMethod[0];
139
+ if (!vm)
140
+ return null;
141
+ let publicKey = null;
142
+ if (vm.publicKeyMultibase) {
143
+ publicKey = decodeMultibase(vm.publicKeyMultibase);
144
+ }
145
+ else if (vm.publicKeyBase64) {
146
+ publicKey = fromBase64(vm.publicKeyBase64);
147
+ }
148
+ if (!publicKey)
149
+ return null;
150
+ return {
151
+ did,
152
+ publicKey,
153
+ name: doc.xailName ?? did,
154
+ scopes: new Set(doc.xailScopes ?? []),
155
+ revoked: doc.deactivated === true,
156
+ rotation_sequence: 1, // DID documents don't track rotation, default to 1
157
+ };
158
+ }
159
+ /** Decode z-prefixed base58btc multibase to bytes. */
160
+ function decodeMultibase(mb) {
161
+ if (!mb.startsWith('z'))
162
+ return null;
163
+ return base58Decode(mb.slice(1));
164
+ }
165
+ /** Base58 decode (Bitcoin alphabet). */
166
+ function base58Decode(s) {
167
+ const ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';
168
+ const BASE = BigInt(58);
169
+ let num = BigInt(0);
170
+ for (const char of s) {
171
+ const idx = ALPHABET.indexOf(char);
172
+ if (idx < 0)
173
+ return new Uint8Array(0);
174
+ num = num * BASE + BigInt(idx);
175
+ }
176
+ const hex = num.toString(16);
177
+ const padded = hex.length % 2 ? '0' + hex : hex;
178
+ const bytes = new Uint8Array(padded.length / 2);
179
+ for (let i = 0; i < bytes.length; i++) {
180
+ bytes[i] = parseInt(padded.slice(i * 2, i * 2 + 2), 16);
181
+ }
182
+ // Handle leading zeros (base58 "1" = 0x00)
183
+ let leadingZeros = 0;
184
+ for (const c of s) {
185
+ if (c === '1')
186
+ leadingZeros++;
187
+ else
188
+ break;
189
+ }
190
+ if (leadingZeros > 0) {
191
+ const result = new Uint8Array(leadingZeros + bytes.length);
192
+ result.set(bytes, leadingZeros);
193
+ return result;
194
+ }
195
+ return bytes;
196
+ }
@@ -0,0 +1,176 @@
1
+ /**
2
+ * @module discovery
3
+ * Service discovery for zero-config XBind connections.
4
+ *
5
+ * Enables: `xbind connect payments-service`
6
+ *
7
+ * Four-tier discovery:
8
+ * 1. Public registry (xbind.registry.io)
9
+ * 2. Well-known URL (https://service.com/.well-known/xbind)
10
+ * 3. DNS TXT record (_xbind.service.com)
11
+ * 4. Direct URL/QR code
12
+ */
13
+ import { Result } from '@private.me/shared';
14
+ /**
15
+ * Service metadata returned from discovery.
16
+ */
17
+ export interface ServiceInfo {
18
+ /** Service identifier (e.g., "payments-service") */
19
+ name: string;
20
+ /** XBind endpoint URL */
21
+ endpoint: string;
22
+ /** DID of the service */
23
+ did: string;
24
+ /** Public key (Ed25519, base64) */
25
+ publicKey: string;
26
+ /** X25519 public key for ECDH (optional, base64) */
27
+ x25519PublicKey?: string;
28
+ /** ML-KEM-768 public key for PQ KEM (optional, base64) */
29
+ mlKemPublicKey?: string;
30
+ /** Service description */
31
+ description?: string;
32
+ /** Logo URL */
33
+ logo?: string;
34
+ /** Documentation URL */
35
+ docs?: string;
36
+ /** Whether this service is verified */
37
+ verified?: boolean;
38
+ }
39
+ /**
40
+ * Discovery error codes.
41
+ */
42
+ export declare enum DiscoveryErrorCode {
43
+ SERVICE_NOT_FOUND = "DISCOVERY_SERVICE_NOT_FOUND",
44
+ REGISTRY_UNREACHABLE = "DISCOVERY_REGISTRY_UNREACHABLE",
45
+ INVALID_RESPONSE = "DISCOVERY_INVALID_RESPONSE",
46
+ NETWORK_ERROR = "DISCOVERY_NETWORK_ERROR",
47
+ INVALID_SERVICE_NAME = "DISCOVERY_INVALID_SERVICE_NAME",
48
+ DNS_ERROR = "DISCOVERY_DNS_ERROR",
49
+ INVALID_EMAIL = "DISCOVERY_INVALID_EMAIL",
50
+ PERSONAL_EMAIL_DOMAIN = "DISCOVERY_PERSONAL_EMAIL_DOMAIN"
51
+ }
52
+ /**
53
+ * Discovery error.
54
+ */
55
+ export interface DiscoveryError {
56
+ code: DiscoveryErrorCode;
57
+ message: string;
58
+ hint?: string;
59
+ }
60
+ /**
61
+ * Discovery client for finding services.
62
+ */
63
+ export declare class ServiceDiscovery {
64
+ private registryUrl;
65
+ private dnsCache;
66
+ /**
67
+ * Create a discovery client.
68
+ *
69
+ * @param options - Configuration options
70
+ * @param options.registryUrl - Registry URL (default: https://xbind.registry.io)
71
+ */
72
+ constructor(options?: {
73
+ registryUrl?: string;
74
+ });
75
+ /**
76
+ * Discover a service by name.
77
+ *
78
+ * Tries:
79
+ * 1. Email-based discovery (extracts domain from email)
80
+ * 2. Public registry lookup
81
+ * 3. Well-known URL if name is a domain
82
+ * 4. DNS TXT record (_xbind.domain)
83
+ * 5. Direct URL if name is a full URL
84
+ *
85
+ * @param nameOrUrl - Service name, email, domain, or URL
86
+ * @returns Service info or error
87
+ *
88
+ * @example
89
+ * ```ts
90
+ * const discovery = new ServiceDiscovery();
91
+ *
92
+ * // By name (registry lookup):
93
+ * const result = await discovery.discover('payments-service');
94
+ *
95
+ * // By email (domain extraction):
96
+ * const result = await discovery.discover('alice@company.com');
97
+ *
98
+ * // By domain (well-known):
99
+ * const result = await discovery.discover('payments.example.com');
100
+ *
101
+ * // By URL (direct):
102
+ * const result = await discovery.discover('https://api.payments.com/xbind');
103
+ * ```
104
+ */
105
+ discover(nameOrUrl: string): Promise<Result<ServiceInfo, DiscoveryError>>;
106
+ /**
107
+ * Look up service in public registry.
108
+ *
109
+ * GET https://xbind.registry.io/lookup/:name
110
+ */
111
+ private discoverRegistry;
112
+ /**
113
+ * Discover via .well-known/xbind.
114
+ *
115
+ * GET https://domain/.well-known/xbind
116
+ */
117
+ private discoverWellKnown;
118
+ /**
119
+ * Discover via direct URL.
120
+ */
121
+ private discoverDirect;
122
+ /**
123
+ * Discover via DNS TXT record.
124
+ *
125
+ * Looks up TXT record at _xbind.domain
126
+ *
127
+ * Supports two formats:
128
+ * 1. Full record: "xbind-endpoint=https://...;did=did:web:...;publicKey=..." (all fields in DNS)
129
+ * 2. Simple redirect: "xbind=https://api.example.com/xbind" (fetch from endpoint)
130
+ *
131
+ * Includes 5-minute caching to reduce DNS queries.
132
+ */
133
+ private discoverDnsTxt;
134
+ /**
135
+ * Parse DNS TXT record into ServiceInfo.
136
+ *
137
+ * Expected format:
138
+ * xbind-endpoint=https://...;did=did:web:...;publicKey=...;version=1.0
139
+ *
140
+ * Optional fields:
141
+ * x25519PublicKey=...;mlKemPublicKey=...;description=...;logo=...;docs=...
142
+ */
143
+ private parseDnsTxtRecord;
144
+ /**
145
+ * Discover service via email address.
146
+ *
147
+ * Extracts domain from email and performs discovery.
148
+ * Personal email domains (gmail.com, outlook.com, etc.) are rejected.
149
+ *
150
+ * @param email - Email address (e.g., "alice@company.com")
151
+ * @returns Service info or error
152
+ *
153
+ * @example
154
+ * ```ts
155
+ * const discovery = new ServiceDiscovery();
156
+ * const result = await discovery.discoverEmail('alice@company.com');
157
+ * // Discovers service at company.com
158
+ * ```
159
+ */
160
+ private discoverEmail;
161
+ /**
162
+ * Extract domain from email address.
163
+ * Handles edge cases: subdomains, plus addressing, etc.
164
+ *
165
+ * @param email - Email address
166
+ * @returns Domain or null if extraction fails
167
+ *
168
+ * @example
169
+ * ```ts
170
+ * extractDomain('alice@company.com') // 'company.com'
171
+ * extractDomain('alice+label@company.com') // 'company.com'
172
+ * extractDomain('alice@mail.company.com') // 'mail.company.com'
173
+ * ```
174
+ */
175
+ private extractDomain;
176
+ }