@wootsup/yt-builder-mcp 0.2.0-alpha.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.
Files changed (299) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +221 -0
  3. package/bin/yt-builder-mcp.js +59 -0
  4. package/dist/auth.d.ts +39 -0
  5. package/dist/auth.d.ts.map +1 -0
  6. package/dist/auth.js +93 -0
  7. package/dist/auth.js.map +1 -0
  8. package/dist/client.d.ts +84 -0
  9. package/dist/client.d.ts.map +1 -0
  10. package/dist/client.js +151 -0
  11. package/dist/client.js.map +1 -0
  12. package/dist/clients/claude-code.d.ts +18 -0
  13. package/dist/clients/claude-code.d.ts.map +1 -0
  14. package/dist/clients/claude-code.js +53 -0
  15. package/dist/clients/claude-code.js.map +1 -0
  16. package/dist/clients/claude-desktop.d.ts +19 -0
  17. package/dist/clients/claude-desktop.d.ts.map +1 -0
  18. package/dist/clients/claude-desktop.js +56 -0
  19. package/dist/clients/claude-desktop.js.map +1 -0
  20. package/dist/clients/cline.d.ts +26 -0
  21. package/dist/clients/cline.d.ts.map +1 -0
  22. package/dist/clients/cline.js +80 -0
  23. package/dist/clients/cline.js.map +1 -0
  24. package/dist/clients/codex-cli.d.ts +42 -0
  25. package/dist/clients/codex-cli.d.ts.map +1 -0
  26. package/dist/clients/codex-cli.js +194 -0
  27. package/dist/clients/codex-cli.js.map +1 -0
  28. package/dist/clients/continue.d.ts +13 -0
  29. package/dist/clients/continue.d.ts.map +1 -0
  30. package/dist/clients/continue.js +52 -0
  31. package/dist/clients/continue.js.map +1 -0
  32. package/dist/clients/cursor.d.ts +12 -0
  33. package/dist/clients/cursor.d.ts.map +1 -0
  34. package/dist/clients/cursor.js +38 -0
  35. package/dist/clients/cursor.js.map +1 -0
  36. package/dist/clients/gemini-cli.d.ts +18 -0
  37. package/dist/clients/gemini-cli.d.ts.map +1 -0
  38. package/dist/clients/gemini-cli.js +44 -0
  39. package/dist/clients/gemini-cli.js.map +1 -0
  40. package/dist/clients/home.d.ts +14 -0
  41. package/dist/clients/home.d.ts.map +1 -0
  42. package/dist/clients/home.js +20 -0
  43. package/dist/clients/home.js.map +1 -0
  44. package/dist/clients/index.d.ts +52 -0
  45. package/dist/clients/index.d.ts.map +1 -0
  46. package/dist/clients/index.js +72 -0
  47. package/dist/clients/index.js.map +1 -0
  48. package/dist/clients/roo-code.d.ts +23 -0
  49. package/dist/clients/roo-code.d.ts.map +1 -0
  50. package/dist/clients/roo-code.js +69 -0
  51. package/dist/clients/roo-code.js.map +1 -0
  52. package/dist/clients/zed.d.ts +12 -0
  53. package/dist/clients/zed.d.ts.map +1 -0
  54. package/dist/clients/zed.js +41 -0
  55. package/dist/clients/zed.js.map +1 -0
  56. package/dist/errors/hints.d.ts +51 -0
  57. package/dist/errors/hints.d.ts.map +1 -0
  58. package/dist/errors/hints.js +95 -0
  59. package/dist/errors/hints.js.map +1 -0
  60. package/dist/errors/mask.d.ts +35 -0
  61. package/dist/errors/mask.d.ts.map +1 -0
  62. package/dist/errors/mask.js +49 -0
  63. package/dist/errors/mask.js.map +1 -0
  64. package/dist/errors/sanitize.d.ts +31 -0
  65. package/dist/errors/sanitize.d.ts.map +1 -0
  66. package/dist/errors/sanitize.js +90 -0
  67. package/dist/errors/sanitize.js.map +1 -0
  68. package/dist/errors.d.ts +42 -0
  69. package/dist/errors.d.ts.map +1 -0
  70. package/dist/errors.js +61 -0
  71. package/dist/errors.js.map +1 -0
  72. package/dist/gateway/advanced-tool/discovery.d.ts +19 -0
  73. package/dist/gateway/advanced-tool/discovery.d.ts.map +1 -0
  74. package/dist/gateway/advanced-tool/discovery.js +53 -0
  75. package/dist/gateway/advanced-tool/discovery.js.map +1 -0
  76. package/dist/gateway/advanced-tool/domains.d.ts +42 -0
  77. package/dist/gateway/advanced-tool/domains.d.ts.map +1 -0
  78. package/dist/gateway/advanced-tool/domains.js +88 -0
  79. package/dist/gateway/advanced-tool/domains.js.map +1 -0
  80. package/dist/gateway/advanced-tool/execute.d.ts +29 -0
  81. package/dist/gateway/advanced-tool/execute.d.ts.map +1 -0
  82. package/dist/gateway/advanced-tool/execute.js +54 -0
  83. package/dist/gateway/advanced-tool/execute.js.map +1 -0
  84. package/dist/gateway/advanced-tool/index.d.ts +36 -0
  85. package/dist/gateway/advanced-tool/index.d.ts.map +1 -0
  86. package/dist/gateway/advanced-tool/index.js +39 -0
  87. package/dist/gateway/advanced-tool/index.js.map +1 -0
  88. package/dist/gateway/advanced-tool/register.d.ts +18 -0
  89. package/dist/gateway/advanced-tool/register.d.ts.map +1 -0
  90. package/dist/gateway/advanced-tool/register.js +62 -0
  91. package/dist/gateway/advanced-tool/register.js.map +1 -0
  92. package/dist/gateway/advanced-tool.d.ts +13 -0
  93. package/dist/gateway/advanced-tool.d.ts.map +1 -0
  94. package/dist/gateway/advanced-tool.js +13 -0
  95. package/dist/gateway/advanced-tool.js.map +1 -0
  96. package/dist/gateway/capturing-server.d.ts +117 -0
  97. package/dist/gateway/capturing-server.d.ts.map +1 -0
  98. package/dist/gateway/capturing-server.js +103 -0
  99. package/dist/gateway/capturing-server.js.map +1 -0
  100. package/dist/gateway/essentials.d.ts +49 -0
  101. package/dist/gateway/essentials.d.ts.map +1 -0
  102. package/dist/gateway/essentials.js +62 -0
  103. package/dist/gateway/essentials.js.map +1 -0
  104. package/dist/gateway/test-support.d.ts +41 -0
  105. package/dist/gateway/test-support.d.ts.map +1 -0
  106. package/dist/gateway/test-support.js +60 -0
  107. package/dist/gateway/test-support.js.map +1 -0
  108. package/dist/index.d.ts +25 -0
  109. package/dist/index.d.ts.map +1 -0
  110. package/dist/index.js +77 -0
  111. package/dist/index.js.map +1 -0
  112. package/dist/install-skill.d.ts +35 -0
  113. package/dist/install-skill.d.ts.map +1 -0
  114. package/dist/install-skill.js +107 -0
  115. package/dist/install-skill.js.map +1 -0
  116. package/dist/platform/index.d.ts +49 -0
  117. package/dist/platform/index.d.ts.map +1 -0
  118. package/dist/platform/index.js +38 -0
  119. package/dist/platform/index.js.map +1 -0
  120. package/dist/server.d.ts +50 -0
  121. package/dist/server.d.ts.map +1 -0
  122. package/dist/server.js +117 -0
  123. package/dist/server.js.map +1 -0
  124. package/dist/setup-cli.d.ts +100 -0
  125. package/dist/setup-cli.d.ts.map +1 -0
  126. package/dist/setup-cli.js +355 -0
  127. package/dist/setup-cli.js.map +1 -0
  128. package/dist/setup-prompts.d.ts +41 -0
  129. package/dist/setup-prompts.d.ts.map +1 -0
  130. package/dist/setup-prompts.js +142 -0
  131. package/dist/setup-prompts.js.map +1 -0
  132. package/dist/setup-token.d.ts +38 -0
  133. package/dist/setup-token.d.ts.map +1 -0
  134. package/dist/setup-token.js +106 -0
  135. package/dist/setup-token.js.map +1 -0
  136. package/dist/setup-wizard-defaults.d.ts +43 -0
  137. package/dist/setup-wizard-defaults.d.ts.map +1 -0
  138. package/dist/setup-wizard-defaults.js +160 -0
  139. package/dist/setup-wizard-defaults.js.map +1 -0
  140. package/dist/setup-wizard-handshake.d.ts +25 -0
  141. package/dist/setup-wizard-handshake.d.ts.map +1 -0
  142. package/dist/setup-wizard-handshake.js +103 -0
  143. package/dist/setup-wizard-handshake.js.map +1 -0
  144. package/dist/setup-wizard-types.d.ts +148 -0
  145. package/dist/setup-wizard-types.d.ts.map +1 -0
  146. package/dist/setup-wizard-types.js +11 -0
  147. package/dist/setup-wizard-types.js.map +1 -0
  148. package/dist/setup-wizard.d.ts +33 -0
  149. package/dist/setup-wizard.d.ts.map +1 -0
  150. package/dist/setup-wizard.js +166 -0
  151. package/dist/setup-wizard.js.map +1 -0
  152. package/dist/setup.d.ts +17 -0
  153. package/dist/setup.d.ts.map +1 -0
  154. package/dist/setup.js +33 -0
  155. package/dist/setup.js.map +1 -0
  156. package/dist/tools/elements/builders.d.ts +24 -0
  157. package/dist/tools/elements/builders.d.ts.map +1 -0
  158. package/dist/tools/elements/builders.js +150 -0
  159. package/dist/tools/elements/builders.js.map +1 -0
  160. package/dist/tools/elements/handlers-write.d.ts +48 -0
  161. package/dist/tools/elements/handlers-write.d.ts.map +1 -0
  162. package/dist/tools/elements/handlers-write.js +141 -0
  163. package/dist/tools/elements/handlers-write.js.map +1 -0
  164. package/dist/tools/elements/handlers.d.ts +56 -0
  165. package/dist/tools/elements/handlers.d.ts.map +1 -0
  166. package/dist/tools/elements/handlers.js +113 -0
  167. package/dist/tools/elements/handlers.js.map +1 -0
  168. package/dist/tools/elements/index.d.ts +28 -0
  169. package/dist/tools/elements/index.d.ts.map +1 -0
  170. package/dist/tools/elements/index.js +27 -0
  171. package/dist/tools/elements/index.js.map +1 -0
  172. package/dist/tools/elements.d.ts +13 -0
  173. package/dist/tools/elements.d.ts.map +1 -0
  174. package/dist/tools/elements.js +13 -0
  175. package/dist/tools/elements.js.map +1 -0
  176. package/dist/tools/elicitation.d.ts +87 -0
  177. package/dist/tools/elicitation.d.ts.map +1 -0
  178. package/dist/tools/elicitation.js +100 -0
  179. package/dist/tools/elicitation.js.map +1 -0
  180. package/dist/tools/format/elements-format.d.ts +34 -0
  181. package/dist/tools/format/elements-format.d.ts.map +1 -0
  182. package/dist/tools/format/elements-format.js +112 -0
  183. package/dist/tools/format/elements-format.js.map +1 -0
  184. package/dist/tools/format/health-format.d.ts +73 -0
  185. package/dist/tools/format/health-format.d.ts.map +1 -0
  186. package/dist/tools/format/health-format.js +178 -0
  187. package/dist/tools/format/health-format.js.map +1 -0
  188. package/dist/tools/format/inspection-format.d.ts +45 -0
  189. package/dist/tools/format/inspection-format.d.ts.map +1 -0
  190. package/dist/tools/format/inspection-format.js +125 -0
  191. package/dist/tools/format/inspection-format.js.map +1 -0
  192. package/dist/tools/format/pages-format.d.ts +39 -0
  193. package/dist/tools/format/pages-format.d.ts.map +1 -0
  194. package/dist/tools/format/pages-format.js +110 -0
  195. package/dist/tools/format/pages-format.js.map +1 -0
  196. package/dist/tools/format/sources-format.d.ts +25 -0
  197. package/dist/tools/format/sources-format.d.ts.map +1 -0
  198. package/dist/tools/format/sources-format.js +113 -0
  199. package/dist/tools/format/sources-format.js.map +1 -0
  200. package/dist/tools/health.d.ts +22 -0
  201. package/dist/tools/health.d.ts.map +1 -0
  202. package/dist/tools/health.js +147 -0
  203. package/dist/tools/health.js.map +1 -0
  204. package/dist/tools/index.d.ts +23 -0
  205. package/dist/tools/index.d.ts.map +1 -0
  206. package/dist/tools/index.js +23 -0
  207. package/dist/tools/index.js.map +1 -0
  208. package/dist/tools/inspection.d.ts +14 -0
  209. package/dist/tools/inspection.d.ts.map +1 -0
  210. package/dist/tools/inspection.js +115 -0
  211. package/dist/tools/inspection.js.map +1 -0
  212. package/dist/tools/layout-flatten.d.ts +63 -0
  213. package/dist/tools/layout-flatten.d.ts.map +1 -0
  214. package/dist/tools/layout-flatten.js +95 -0
  215. package/dist/tools/layout-flatten.js.map +1 -0
  216. package/dist/tools/pages/builders.d.ts +14 -0
  217. package/dist/tools/pages/builders.d.ts.map +1 -0
  218. package/dist/tools/pages/builders.js +97 -0
  219. package/dist/tools/pages/builders.js.map +1 -0
  220. package/dist/tools/pages/handlers-read.d.ts +24 -0
  221. package/dist/tools/pages/handlers-read.d.ts.map +1 -0
  222. package/dist/tools/pages/handlers-read.js +141 -0
  223. package/dist/tools/pages/handlers-read.js.map +1 -0
  224. package/dist/tools/pages/handlers-write.d.ts +21 -0
  225. package/dist/tools/pages/handlers-write.d.ts.map +1 -0
  226. package/dist/tools/pages/handlers-write.js +52 -0
  227. package/dist/tools/pages/handlers-write.js.map +1 -0
  228. package/dist/tools/pages/index.d.ts +17 -0
  229. package/dist/tools/pages/index.d.ts.map +1 -0
  230. package/dist/tools/pages/index.js +17 -0
  231. package/dist/tools/pages/index.js.map +1 -0
  232. package/dist/tools/pages/schemas.d.ts +30 -0
  233. package/dist/tools/pages/schemas.d.ts.map +1 -0
  234. package/dist/tools/pages/schemas.js +30 -0
  235. package/dist/tools/pages/schemas.js.map +1 -0
  236. package/dist/tools/pages.d.ts +13 -0
  237. package/dist/tools/pages.d.ts.map +1 -0
  238. package/dist/tools/pages.js +13 -0
  239. package/dist/tools/pages.js.map +1 -0
  240. package/dist/tools/progress-phases.d.ts +46 -0
  241. package/dist/tools/progress-phases.d.ts.map +1 -0
  242. package/dist/tools/progress-phases.js +48 -0
  243. package/dist/tools/progress-phases.js.map +1 -0
  244. package/dist/tools/shared-schemas.d.ts +15 -0
  245. package/dist/tools/shared-schemas.d.ts.map +1 -0
  246. package/dist/tools/shared-schemas.js +30 -0
  247. package/dist/tools/shared-schemas.js.map +1 -0
  248. package/dist/tools/sources/builders.d.ts +13 -0
  249. package/dist/tools/sources/builders.d.ts.map +1 -0
  250. package/dist/tools/sources/builders.js +88 -0
  251. package/dist/tools/sources/builders.js.map +1 -0
  252. package/dist/tools/sources/handlers-bind.d.ts +26 -0
  253. package/dist/tools/sources/handlers-bind.d.ts.map +1 -0
  254. package/dist/tools/sources/handlers-bind.js +123 -0
  255. package/dist/tools/sources/handlers-bind.js.map +1 -0
  256. package/dist/tools/sources/handlers.d.ts +45 -0
  257. package/dist/tools/sources/handlers.d.ts.map +1 -0
  258. package/dist/tools/sources/handlers.js +84 -0
  259. package/dist/tools/sources/handlers.js.map +1 -0
  260. package/dist/tools/sources/index.d.ts +19 -0
  261. package/dist/tools/sources/index.d.ts.map +1 -0
  262. package/dist/tools/sources/index.js +18 -0
  263. package/dist/tools/sources/index.js.map +1 -0
  264. package/dist/tools/sources.d.ts +14 -0
  265. package/dist/tools/sources.d.ts.map +1 -0
  266. package/dist/tools/sources.js +14 -0
  267. package/dist/tools/sources.js.map +1 -0
  268. package/dist/tools/sparse-fields.d.ts +80 -0
  269. package/dist/tools/sparse-fields.d.ts.map +1 -0
  270. package/dist/tools/sparse-fields.js +144 -0
  271. package/dist/tools/sparse-fields.js.map +1 -0
  272. package/dist/tools/tool-builder/annotations.d.ts +22 -0
  273. package/dist/tools/tool-builder/annotations.d.ts.map +1 -0
  274. package/dist/tools/tool-builder/annotations.js +35 -0
  275. package/dist/tools/tool-builder/annotations.js.map +1 -0
  276. package/dist/tools/tool-builder/define.d.ts +31 -0
  277. package/dist/tools/tool-builder/define.d.ts.map +1 -0
  278. package/dist/tools/tool-builder/define.js +31 -0
  279. package/dist/tools/tool-builder/define.js.map +1 -0
  280. package/dist/tools/tool-builder/index.d.ts +28 -0
  281. package/dist/tools/tool-builder/index.d.ts.map +1 -0
  282. package/dist/tools/tool-builder/index.js +27 -0
  283. package/dist/tools/tool-builder/index.js.map +1 -0
  284. package/dist/tools/tool-builder/results.d.ts +59 -0
  285. package/dist/tools/tool-builder/results.d.ts.map +1 -0
  286. package/dist/tools/tool-builder/results.js +125 -0
  287. package/dist/tools/tool-builder/results.js.map +1 -0
  288. package/dist/tools/tool-builder/types.d.ts +82 -0
  289. package/dist/tools/tool-builder/types.d.ts.map +1 -0
  290. package/dist/tools/tool-builder/types.js +9 -0
  291. package/dist/tools/tool-builder/types.js.map +1 -0
  292. package/dist/tools/tool-builder.d.ts +16 -0
  293. package/dist/tools/tool-builder.d.ts.map +1 -0
  294. package/dist/tools/tool-builder.js +16 -0
  295. package/dist/tools/tool-builder.js.map +1 -0
  296. package/icon.png +0 -0
  297. package/manifest.json +63 -0
  298. package/package.json +81 -0
  299. package/skills/yootheme-builder/SKILL.md +582 -0
@@ -0,0 +1,106 @@
1
+ /**
2
+ * Pure helpers for the setup wizard — token decode + URL extraction.
3
+ *
4
+ * Split out of `setup-prompts.ts` so it can be unit-tested without a TTY
5
+ * and so the `runWizard` body can decode a token without dragging in the
6
+ * @clack/prompts UI surface.
7
+ *
8
+ * The decode is intentionally signature-UNVERIFIED. The wizard cannot
9
+ * verify the HMAC signature (that requires the plugin's signing-secret
10
+ * which only the server holds). We use the decoded payload purely to
11
+ * pre-fill the URL prompt as a convenience — the canonical auth check
12
+ * happens later when `runWizard` hits `/v1/health` with the token; if
13
+ * the payload has been tampered with, that probe rejects it.
14
+ *
15
+ * @license MIT
16
+ */
17
+ /** Plugin token format: ytb_(live|test)_<base64url-payload>.<base64url-sig> */
18
+ const TOKEN_FORMAT = /^ytb_(?:live|test)_([A-Za-z0-9_-]+)\.([A-Za-z0-9_-]+)$/;
19
+ /**
20
+ * Decode the base64url payload of a Bearer key.
21
+ *
22
+ * Returns `null` when the token shape is invalid OR the payload JSON is
23
+ * malformed OR the required fields (kid + scope + iss) are missing or
24
+ * the wrong type. Callers should treat `null` as "this token is unusable
25
+ * for URL pre-fill; ask the user to type the URL by hand."
26
+ */
27
+ export function decodeToken(token) {
28
+ const trimmed = token.trim();
29
+ const match = TOKEN_FORMAT.exec(trimmed);
30
+ if (match === null)
31
+ return null;
32
+ const payloadB64 = match[1];
33
+ if (typeof payloadB64 !== 'string' || payloadB64.length === 0)
34
+ return null;
35
+ let json;
36
+ try {
37
+ json = base64UrlDecode(payloadB64);
38
+ }
39
+ catch {
40
+ return null;
41
+ }
42
+ let parsed;
43
+ try {
44
+ parsed = JSON.parse(json);
45
+ }
46
+ catch {
47
+ return null;
48
+ }
49
+ if (parsed === null || typeof parsed !== 'object' || Array.isArray(parsed)) {
50
+ return null;
51
+ }
52
+ const obj = parsed;
53
+ const kid = obj['kid'];
54
+ const scope = obj['scope'];
55
+ const iss = obj['iss'];
56
+ if (typeof kid !== 'string' || kid === '')
57
+ return null;
58
+ if (typeof iss !== 'string' || iss === '')
59
+ return null;
60
+ let scopeList;
61
+ if (Array.isArray(scope)) {
62
+ scopeList = scope.filter((s) => typeof s === 'string');
63
+ }
64
+ else if (typeof scope === 'string') {
65
+ scopeList = [scope];
66
+ }
67
+ else {
68
+ return null;
69
+ }
70
+ const exp = obj['exp'];
71
+ const payload = {
72
+ kid,
73
+ scope: scopeList,
74
+ iss: iss.replace(/\/+$/, ''),
75
+ ...(typeof exp === 'number' && Number.isFinite(exp) ? { exp } : {}),
76
+ };
77
+ return payload;
78
+ }
79
+ /**
80
+ * Normalise a URL string the way the wizard wants it:
81
+ * - trim whitespace
82
+ * - strip trailing slashes
83
+ * - return empty string on null/undefined input
84
+ *
85
+ * Exposed so the prompt validator and the identity probe share one
86
+ * canonicalisation rule (otherwise drift causes "looks the same to the
87
+ * human, mismatches in code" bugs).
88
+ */
89
+ export function normaliseUrl(input) {
90
+ if (typeof input !== 'string')
91
+ return '';
92
+ return input.trim().replace(/\/+$/, '');
93
+ }
94
+ /**
95
+ * Standard base64url → utf-8 decoder. Pads + decodes via Buffer; throws
96
+ * a generic Error when the input isn't valid base64url so callers can
97
+ * `try/catch` and return null.
98
+ */
99
+ function base64UrlDecode(input) {
100
+ const padded = input.replace(/-/g, '+').replace(/_/g, '/');
101
+ const padding = padded.length % 4;
102
+ const fullPadded = padding === 0 ? padded : padded + '='.repeat(4 - padding);
103
+ const buf = Buffer.from(fullPadded, 'base64');
104
+ return buf.toString('utf8');
105
+ }
106
+ //# sourceMappingURL=setup-token.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-token.js","sourceRoot":"","sources":["../src/setup-token.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * Default `WizardDeps` implementations — real-I/O side of the wizard
3
+ * (FS writes, rollback, client-config dispatch).
4
+ *
5
+ * REST probes + handshake/version-check live in
6
+ * `./setup-wizard-handshake.ts` (Round-2 R2-A2-IMP1 split for headroom).
7
+ * Clack prompts live in `./setup-prompts.ts` (Round-1.5 split). The
8
+ * wizard algorithm lives in `./setup-wizard.ts`.
9
+ *
10
+ * Re-exports `majorMinor` from the handshake module so existing
11
+ * consumers (`tests/setup/wizard-defaults.test.ts`, `setup-wizard.ts`)
12
+ * keep working through this barrel.
13
+ *
14
+ * @license MIT
15
+ */
16
+ import { majorMinor } from './setup-wizard-handshake.js';
17
+ import type { PickupResult, WizardDeps, WriteResult } from './setup-wizard-types.js';
18
+ export { majorMinor };
19
+ /**
20
+ * Roll back a list of write-results: restore previous content (or
21
+ * remove freshly written files). Best-effort — errors surface via
22
+ * `logFn` so partial rollback doesn't mask the original failure.
23
+ */
24
+ export declare function rollbackWrites(writes: readonly WriteResult[], logFn: (line: string) => void): Promise<void>;
25
+ /**
26
+ * Default implementation of `WizardDeps.fetchPickup` — POSTs the nonce
27
+ * to the pickup URL revealed in wp-admin and maps the snake_case payload
28
+ * (`site_url`, `plugin_version`) to camelCase (`siteurl`, `pluginVersion`).
29
+ *
30
+ * Failure modes throw with explicit, user-actionable messages:
31
+ * - 404 → "pickup expired or already claimed (5-minute TTL)"
32
+ * - 403 → "pickup bound to a different IP — regenerate from wp-admin"
33
+ * - 429 → "rate limit — wait ~60s and try again"
34
+ * - 400 → "invalid request" (echoes server's message when parseable)
35
+ * - network → "check URL is reachable + plugin is active"
36
+ *
37
+ * The function intentionally has no retry loop — a one-shot nonce that
38
+ * fails has either been consumed or expired; the only sensible recovery
39
+ * is for the operator to regenerate from wp-admin.
40
+ */
41
+ export declare function defaultFetchPickup(pickupUrl: string, nonce: string): Promise<PickupResult>;
42
+ export declare const DEFAULT_WIZARD_DEPS: WizardDeps;
43
+ //# sourceMappingURL=setup-wizard-defaults.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-wizard-defaults.d.ts","sourceRoot":"","sources":["../src/setup-wizard-defaults.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAQH,OAAO,EAKH,UAAU,EACb,MAAM,6BAA6B,CAAC;AACrC,OAAO,KAAK,EACR,YAAY,EACZ,UAAU,EACV,WAAW,EACd,MAAM,yBAAyB,CAAC;AAIjC,OAAO,EAAE,UAAU,EAAE,CAAC;AAEtB;;;;GAIG;AACH,wBAAsB,cAAc,CAChC,MAAM,EAAE,SAAS,WAAW,EAAE,EAC9B,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,GAC9B,OAAO,CAAC,IAAI,CAAC,CAgBf;AAgCD;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,kBAAkB,CACpC,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,MAAM,GACd,OAAO,CAAC,YAAY,CAAC,CAsEvB;AAED,eAAO,MAAM,mBAAmB,EAAE,UAUjC,CAAC"}
@@ -0,0 +1,160 @@
1
+ /**
2
+ * Default `WizardDeps` implementations — real-I/O side of the wizard
3
+ * (FS writes, rollback, client-config dispatch).
4
+ *
5
+ * REST probes + handshake/version-check live in
6
+ * `./setup-wizard-handshake.ts` (Round-2 R2-A2-IMP1 split for headroom).
7
+ * Clack prompts live in `./setup-prompts.ts` (Round-1.5 split). The
8
+ * wizard algorithm lives in `./setup-wizard.ts`.
9
+ *
10
+ * Re-exports `majorMinor` from the handshake module so existing
11
+ * consumers (`tests/setup/wizard-defaults.test.ts`, `setup-wizard.ts`)
12
+ * keep working through this barrel.
13
+ *
14
+ * @license MIT
15
+ */
16
+ import { detectAvailableClients, findClient, } from './clients/index.js';
17
+ import { defaultConfirmContinue, defaultPrompt } from './setup-prompts.js';
18
+ import { defaultHandshake, defaultProbeAuth, defaultProbeHealth, defaultProbeIdentity, majorMinor, } from './setup-wizard-handshake.js';
19
+ // Re-export for backward-compat with existing call-sites
20
+ // (`setup-wizard.ts`, `tests/setup/wizard-defaults.test.ts`).
21
+ export { majorMinor };
22
+ /**
23
+ * Roll back a list of write-results: restore previous content (or
24
+ * remove freshly written files). Best-effort — errors surface via
25
+ * `logFn` so partial rollback doesn't mask the original failure.
26
+ */
27
+ export async function rollbackWrites(writes, logFn) {
28
+ const { unlink, writeFile } = await import('node:fs/promises');
29
+ for (const w of writes) {
30
+ if (!w.ok || w.path === '')
31
+ continue;
32
+ try {
33
+ if (w.previousContent === null) {
34
+ await unlink(w.path);
35
+ logFn(` ↩ removed ${w.path}`);
36
+ }
37
+ else {
38
+ await writeFile(w.path, w.previousContent, 'utf-8');
39
+ logFn(` ↩ restored ${w.path}`);
40
+ }
41
+ }
42
+ catch (e) {
43
+ logFn(` ↩ rollback FAILED for ${w.path}: ${e instanceof Error ? e.message : String(e)}`);
44
+ }
45
+ }
46
+ }
47
+ async function readIfExists(path) {
48
+ try {
49
+ const { readFile } = await import('node:fs/promises');
50
+ const { existsSync } = await import('node:fs');
51
+ return existsSync(path) ? await readFile(path, 'utf-8') : null;
52
+ }
53
+ catch {
54
+ return null;
55
+ }
56
+ }
57
+ async function defaultWriteClient(id, serverName, config) {
58
+ const writer = findClient(id);
59
+ if (writer === undefined) {
60
+ return { id, label: id, ok: false, error: 'Unknown client.', path: '', previousContent: null };
61
+ }
62
+ const path = writer.configPath();
63
+ const previousContent = await readIfExists(path);
64
+ try {
65
+ await writer.apply(serverName, config);
66
+ return { id, label: writer.label, ok: true, path, previousContent };
67
+ }
68
+ catch (e) {
69
+ const error = e instanceof Error ? e.message : String(e);
70
+ return { id, label: writer.label, ok: false, error, path, previousContent };
71
+ }
72
+ }
73
+ /**
74
+ * Default implementation of `WizardDeps.fetchPickup` — POSTs the nonce
75
+ * to the pickup URL revealed in wp-admin and maps the snake_case payload
76
+ * (`site_url`, `plugin_version`) to camelCase (`siteurl`, `pluginVersion`).
77
+ *
78
+ * Failure modes throw with explicit, user-actionable messages:
79
+ * - 404 → "pickup expired or already claimed (5-minute TTL)"
80
+ * - 403 → "pickup bound to a different IP — regenerate from wp-admin"
81
+ * - 429 → "rate limit — wait ~60s and try again"
82
+ * - 400 → "invalid request" (echoes server's message when parseable)
83
+ * - network → "check URL is reachable + plugin is active"
84
+ *
85
+ * The function intentionally has no retry loop — a one-shot nonce that
86
+ * fails has either been consumed or expired; the only sensible recovery
87
+ * is for the operator to regenerate from wp-admin.
88
+ */
89
+ export async function defaultFetchPickup(pickupUrl, nonce) {
90
+ let response;
91
+ try {
92
+ response = await fetch(pickupUrl, {
93
+ method: 'POST',
94
+ headers: { 'Content-Type': 'application/json' },
95
+ body: JSON.stringify({ nonce }),
96
+ });
97
+ }
98
+ catch (e) {
99
+ const msg = e instanceof Error ? e.message : String(e);
100
+ throw new Error(`Could not reach the pickup URL (${msg}). Check the URL is reachable and the plugin is active.`);
101
+ }
102
+ if (response.status === 200) {
103
+ let raw;
104
+ try {
105
+ raw = await response.json();
106
+ }
107
+ catch {
108
+ throw new Error('Pickup response was not valid JSON. Re-generate the pickup URL from wp-admin.');
109
+ }
110
+ if (raw === null || typeof raw !== 'object') {
111
+ throw new Error('Pickup response had an unexpected shape (not an object).');
112
+ }
113
+ const obj = raw;
114
+ const token = typeof obj.token === 'string' ? obj.token : undefined;
115
+ const siteurl = typeof obj.site_url === 'string' ? obj.site_url : undefined;
116
+ const pluginVersion = typeof obj.plugin_version === 'string' ? obj.plugin_version : undefined;
117
+ if (token === undefined || siteurl === undefined || pluginVersion === undefined) {
118
+ throw new Error('Pickup response missing required fields (token, site_url, plugin_version). Update the plugin.');
119
+ }
120
+ return { token, siteurl, pluginVersion };
121
+ }
122
+ // Try to surface the server's structured message when it's there.
123
+ let serverMessage;
124
+ try {
125
+ const body = await response.json();
126
+ if (body !== null && typeof body === 'object') {
127
+ const m = body.message;
128
+ if (typeof m === 'string' && m !== '')
129
+ serverMessage = m;
130
+ }
131
+ }
132
+ catch {
133
+ // body not JSON — ignore.
134
+ }
135
+ if (response.status === 404) {
136
+ throw new Error('Pickup not available. The URL may have expired (5-minute TTL) or already been claimed. Generate a fresh pickup from wp-admin.');
137
+ }
138
+ if (response.status === 403) {
139
+ throw new Error('Pickup is bound to a different IP. Regenerate from wp-admin with the "different machine" option, or run this CLI from the same network as the browser session.');
140
+ }
141
+ if (response.status === 429) {
142
+ throw new Error('Rate limit hit on pickup endpoint. Wait ~60s and try again.');
143
+ }
144
+ if (response.status === 400) {
145
+ throw new Error(`Pickup rejected the request as malformed${serverMessage ? `: ${serverMessage}` : ''}. Re-generate the pickup URL from wp-admin.`);
146
+ }
147
+ throw new Error(`Pickup failed with HTTP ${response.status}${serverMessage ? `: ${serverMessage}` : ''}.`);
148
+ }
149
+ export const DEFAULT_WIZARD_DEPS = {
150
+ prompt: defaultPrompt,
151
+ detectClients: () => detectAvailableClients(),
152
+ probeHealth: defaultProbeHealth,
153
+ probeIdentity: defaultProbeIdentity,
154
+ probeAuth: defaultProbeAuth,
155
+ confirmContinue: defaultConfirmContinue,
156
+ writeClient: defaultWriteClient,
157
+ handshake: defaultHandshake,
158
+ fetchPickup: defaultFetchPickup,
159
+ };
160
+ //# sourceMappingURL=setup-wizard-defaults.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-wizard-defaults.js","sourceRoot":"","sources":["../src/setup-wizard-defaults.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Setup-wizard REST-probe + handshake helpers.
3
+ *
4
+ * Split out of `setup-wizard-defaults.ts` (Round-2 R2-A2-IMP1) to
5
+ * give the defaults file headroom under the §11 150-LoC cap.
6
+ *
7
+ * @license MIT
8
+ */
9
+ import type { AuthProbeResult, HandshakeResult, HealthProbeResult, IdentityProbeResult } from './setup-wizard-types.js';
10
+ export declare function defaultProbeHealth(wpUrl: string): Promise<HealthProbeResult>;
11
+ /**
12
+ * Probe `/v1/identity` — public endpoint introduced in plugin Wave 6.5.
13
+ * Returns ok=true ONLY when the response shape matches our plugin
14
+ * (product field === 'yt-builder-mcp'); a 200 OK from a different
15
+ * plugin at the same URL is treated as not-installed.
16
+ *
17
+ * Soft-failure on 404 keeps back-compat with pre-6.5 plugins — the
18
+ * wizard falls through to the existing /health-only probe path.
19
+ */
20
+ export declare function defaultProbeIdentity(wpUrl: string): Promise<IdentityProbeResult>;
21
+ export declare function defaultProbeAuth(wpUrl: string, bearer: string): Promise<AuthProbeResult>;
22
+ /** Extract `major.minor` from a semver-like string (`0.1.0-alpha.1` → `0.1`); `''` on malformed input. */
23
+ export declare function majorMinor(version: string): string;
24
+ export declare function defaultHandshake(wpUrl: string, bearer: string, packageVersion: string): Promise<HandshakeResult>;
25
+ //# sourceMappingURL=setup-wizard-handshake.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-wizard-handshake.d.ts","sourceRoot":"","sources":["../src/setup-wizard-handshake.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,KAAK,EACR,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,mBAAmB,EACtB,MAAM,yBAAyB,CAAC;AAejC,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAQlF;AAED;;;;;;;;GAQG;AACH,wBAAsB,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAuBtF;AAED,wBAAsB,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAQ9F;AAED,0GAA0G;AAC1G,wBAAgB,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAGlD;AAED,wBAAsB,gBAAgB,CAClC,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,GACvB,OAAO,CAAC,eAAe,CAAC,CAgB1B"}
@@ -0,0 +1,103 @@
1
+ /**
2
+ * Setup-wizard REST-probe + handshake helpers.
3
+ *
4
+ * Split out of `setup-wizard-defaults.ts` (Round-2 R2-A2-IMP1) to
5
+ * give the defaults file headroom under the §11 150-LoC cap.
6
+ *
7
+ * @license MIT
8
+ */
9
+ import { RestClient } from './client.js';
10
+ // Placeholder Bearer used only for the unauthenticated /health probe;
11
+ // constructed dynamically so the secret-grep-gate doesn't flag the
12
+ // call-site as a hardcoded credential.
13
+ const HEALTH_PROBE_PLACEHOLDER_TOKEN = ['health', 'probe', 'no-auth'].join('-');
14
+ function extractPluginVersion(raw) {
15
+ if (raw === null || typeof raw !== 'object')
16
+ return undefined;
17
+ const obj = raw;
18
+ if (typeof obj.plugin_version === 'string')
19
+ return obj.plugin_version;
20
+ if (typeof obj.version === 'string')
21
+ return obj.version;
22
+ return undefined;
23
+ }
24
+ export async function defaultProbeHealth(wpUrl) {
25
+ try {
26
+ const client = new RestClient({ baseUrl: wpUrl, bearerToken: HEALTH_PROBE_PLACEHOLDER_TOKEN });
27
+ const pluginVersion = extractPluginVersion(await client.get('/health'));
28
+ return pluginVersion !== undefined ? { ok: true, pluginVersion } : { ok: true };
29
+ }
30
+ catch (e) {
31
+ return { ok: false, error: e instanceof Error ? e.message : String(e) };
32
+ }
33
+ }
34
+ /**
35
+ * Probe `/v1/identity` — public endpoint introduced in plugin Wave 6.5.
36
+ * Returns ok=true ONLY when the response shape matches our plugin
37
+ * (product field === 'yt-builder-mcp'); a 200 OK from a different
38
+ * plugin at the same URL is treated as not-installed.
39
+ *
40
+ * Soft-failure on 404 keeps back-compat with pre-6.5 plugins — the
41
+ * wizard falls through to the existing /health-only probe path.
42
+ */
43
+ export async function defaultProbeIdentity(wpUrl) {
44
+ try {
45
+ const client = new RestClient({ baseUrl: wpUrl, bearerToken: HEALTH_PROBE_PLACEHOLDER_TOKEN });
46
+ const raw = await client.get('/identity');
47
+ if (raw === null || typeof raw !== 'object') {
48
+ return { ok: false, error: 'unexpected response shape (not an object)' };
49
+ }
50
+ const obj = raw;
51
+ const product = typeof obj.product === 'string' ? obj.product : undefined;
52
+ if (product !== 'yt-builder-mcp') {
53
+ return { ok: false, error: `URL responds but is not a yt-builder-mcp install (product=${product ?? 'missing'})` };
54
+ }
55
+ const result = {
56
+ ok: true,
57
+ product,
58
+ ...(typeof obj.siteurl === 'string' ? { siteurl: obj.siteurl.replace(/\/+$/, '') } : {}),
59
+ ...(obj.platform === 'wordpress' || obj.platform === 'joomla' ? { platform: obj.platform } : {}),
60
+ ...(typeof obj.plugin_version === 'string' ? { pluginVersion: obj.plugin_version } : {}),
61
+ };
62
+ return result;
63
+ }
64
+ catch (e) {
65
+ return { ok: false, error: e instanceof Error ? e.message : String(e) };
66
+ }
67
+ }
68
+ export async function defaultProbeAuth(wpUrl, bearer) {
69
+ try {
70
+ const client = new RestClient({ baseUrl: wpUrl, bearerToken: bearer });
71
+ await client.get('/etag');
72
+ return { ok: true };
73
+ }
74
+ catch (e) {
75
+ return { ok: false, error: e instanceof Error ? e.message : String(e) };
76
+ }
77
+ }
78
+ /** Extract `major.minor` from a semver-like string (`0.1.0-alpha.1` → `0.1`); `''` on malformed input. */
79
+ export function majorMinor(version) {
80
+ const m = version.match(/^(\d+)\.(\d+)/);
81
+ return m ? `${m[1]}.${m[2]}` : '';
82
+ }
83
+ export async function defaultHandshake(wpUrl, bearer, packageVersion) {
84
+ const health = await defaultProbeHealth(wpUrl);
85
+ if (!health.ok)
86
+ return { ok: false, error: health.error ?? 'health probe failed' };
87
+ const auth = await defaultProbeAuth(wpUrl, bearer);
88
+ if (!auth.ok)
89
+ return { ok: false, error: auth.error ?? 'auth probe failed' };
90
+ if (health.pluginVersion === undefined)
91
+ return { ok: true };
92
+ const enriched = { ok: true, pluginVersion: health.pluginVersion };
93
+ const pkgMm = majorMinor(packageVersion);
94
+ const plgMm = majorMinor(health.pluginVersion);
95
+ if (pkgMm !== '' && plgMm !== '' && pkgMm !== plgMm) {
96
+ return {
97
+ ...enriched,
98
+ warning: `MCP package v${packageVersion} (${pkgMm}.x) ↔ plugin v${health.pluginVersion} (${plgMm}.x) — major/minor mismatch. Upgrade the plugin or pin the MCP package to match.`,
99
+ };
100
+ }
101
+ return enriched;
102
+ }
103
+ //# sourceMappingURL=setup-wizard-handshake.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-wizard-handshake.js","sourceRoot":"","sources":["../src/setup-wizard-handshake.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,148 @@
1
+ /**
2
+ * Public types for the interactive setup wizard.
3
+ *
4
+ * Split out of `setup-wizard.ts` in the Round-1 audit I5 fix so the
5
+ * type surface is consumable without dragging in @clack/prompts or the
6
+ * RestClient. Tests and other modules import these types alone.
7
+ *
8
+ * @license MIT
9
+ */
10
+ import type { DetectedClient, McpServerConfig } from './clients/index.js';
11
+ export interface WizardAnswers {
12
+ /** Trimmed, trailing-slash-stripped WordPress base URL. */
13
+ readonly wpUrl: string;
14
+ /** Trimmed Bearer key. */
15
+ readonly bearer: string;
16
+ /** IDs of clients the user wants wired up. */
17
+ readonly selectedClients: readonly string[];
18
+ /**
19
+ * Profile name (multi-site switching). Optional for back-compat with
20
+ * non-interactive flag paths that don't ask for it; the wizard
21
+ * defaults missing/empty values to `'default'`.
22
+ */
23
+ readonly profileName?: string;
24
+ }
25
+ /**
26
+ * Decoded payload of a Bearer key. The plugin signs `kid`, `scope`, `iss`
27
+ * (issuer = WordPress `site_url`), and optionally `exp` into the token's
28
+ * base64url payload section. The wizard decodes this WITHOUT verifying the
29
+ * signature (verification requires the plugin's secret) — `iss` is used
30
+ * purely to pre-fill the URL prompt; the canonical auth check happens
31
+ * later when the wizard hits `/v1/health` with the token.
32
+ */
33
+ export interface DecodedTokenPayload {
34
+ readonly kid: string;
35
+ readonly scope: readonly string[];
36
+ /** Issuer — canonical WordPress site URL the key was generated on. */
37
+ readonly iss: string;
38
+ /** Unix expiry timestamp, if the operator opted-in to expiry. */
39
+ readonly exp?: number;
40
+ }
41
+ /**
42
+ * Result of the public `/v1/identity` probe — the wizard uses this to
43
+ * (a) confirm the plugin is installed at the URL the user typed and
44
+ * (b) cross-check the URL against the token's `iss` claim before writing
45
+ * any AI-client config.
46
+ */
47
+ export interface IdentityProbeResult {
48
+ readonly ok: boolean;
49
+ /** Canonical site URL reported by the plugin. */
50
+ readonly siteurl?: string;
51
+ /** Platform discriminator: 'wordpress' today, 'joomla' later. */
52
+ readonly platform?: 'wordpress' | 'joomla';
53
+ /** Product discriminator (defends against another MCP at the same URL). */
54
+ readonly product?: string;
55
+ /** Plugin version (for diagnostic display). */
56
+ readonly pluginVersion?: string;
57
+ /** Failure message when ok=false. */
58
+ readonly error?: string;
59
+ }
60
+ /**
61
+ * Result of a successful `/setup/pickup` POST — a one-shot, IP-bound,
62
+ * 5-minute-TTL retrieval of a freshly-minted Bearer token + the
63
+ * canonical site URL the plugin reports. The wizard treats this as
64
+ * "answers obtained" and skips the URL/token prompts.
65
+ *
66
+ * Failure modes (404 expired/consumed, 403 IP-mismatch, 429 rate-limit,
67
+ * 400 invalid) are signalled by `fetchPickup` rejecting with a thrown
68
+ * Error — there is no partial success shape.
69
+ */
70
+ export interface PickupResult {
71
+ /** Bearer token in plugin format `ytb_(live|test)_<payload>.<sig>`. */
72
+ readonly token: string;
73
+ /** Canonical WordPress site URL reported by the plugin. */
74
+ readonly siteurl: string;
75
+ /** Plugin version string for diagnostic display. */
76
+ readonly pluginVersion: string;
77
+ }
78
+ export interface HealthProbeResult {
79
+ readonly ok: boolean;
80
+ /** Plugin version reported by the server (if any). */
81
+ readonly pluginVersion?: string;
82
+ /** Error message if `ok=false`. */
83
+ readonly error?: string;
84
+ }
85
+ export interface AuthProbeResult {
86
+ readonly ok: boolean;
87
+ readonly error?: string;
88
+ }
89
+ export interface HandshakeResult {
90
+ readonly ok: boolean;
91
+ readonly pluginVersion?: string;
92
+ /** Mismatch warning string when plugin version != NPM package version. */
93
+ readonly warning?: string;
94
+ readonly error?: string;
95
+ }
96
+ export interface WriteResult {
97
+ readonly id: string;
98
+ readonly label: string;
99
+ readonly ok: boolean;
100
+ readonly error?: string;
101
+ /** Path that was written. Empty string on failure. */
102
+ readonly path: string;
103
+ /** Snapshot of the file content BEFORE the write (for rollback). */
104
+ readonly previousContent: string | null;
105
+ }
106
+ export interface WizardDeps {
107
+ /** Collect answers from the user. Return `null` on cancel. */
108
+ prompt: (input: {
109
+ detected: readonly DetectedClient[];
110
+ }) => Promise<WizardAnswers | null>;
111
+ /** Detect installed AI clients. */
112
+ detectClients: () => readonly DetectedClient[];
113
+ /** Probe the plugin /health endpoint (no auth). */
114
+ probeHealth: (wpUrl: string) => Promise<HealthProbeResult>;
115
+ /**
116
+ * Probe the plugin /identity endpoint (no auth) — used to verify the
117
+ * URL belongs to a yt-builder-mcp install and cross-check it
118
+ * against the token's `iss` claim. Optional for back-compat: when the
119
+ * field is missing the wizard skips the identity check.
120
+ */
121
+ probeIdentity?: (wpUrl: string) => Promise<IdentityProbeResult>;
122
+ /** Probe the plugin /etag endpoint (Bearer auth). */
123
+ probeAuth: (wpUrl: string, bearer: string) => Promise<AuthProbeResult>;
124
+ /** Confirm whether to continue when a probe fails. */
125
+ confirmContinue: (message: string) => Promise<boolean>;
126
+ /** Write the MCP server config for a single client. */
127
+ writeClient: (id: string, serverName: string, config: McpServerConfig) => Promise<WriteResult>;
128
+ /** Re-run the auth probe AFTER the configs were written and parse
129
+ * the plugin version. Used as the dist-tag handshake. */
130
+ handshake: (wpUrl: string, bearer: string, packageVersion: string) => Promise<HandshakeResult>;
131
+ /**
132
+ * POST `{ nonce }` to the pickup URL revealed by wp-admin and resolve
133
+ * to a `PickupResult` (token + canonical site URL + plugin version).
134
+ *
135
+ * Implementations MUST throw on any non-200 response (404 expired /
136
+ * consumed, 403 IP-mismatch, 429 rate-limited, 400 malformed) so the
137
+ * wizard's pickup branch can abort with a single error path. The
138
+ * thrown Error's `.message` is what gets shown to the user.
139
+ *
140
+ * Optional for back-compat with older WizardDeps bags constructed
141
+ * before Wave-C — when missing, callers that pass `--pickup` get a
142
+ * clear "pickup not supported by this WizardDeps" error.
143
+ */
144
+ fetchPickup?: (pickupUrl: string, nonce: string) => Promise<PickupResult>;
145
+ /** Optional sink for human-facing status lines. */
146
+ log?: (line: string) => void;
147
+ }
148
+ //# sourceMappingURL=setup-wizard-types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-wizard-types.d.ts","sourceRoot":"","sources":["../src/setup-wizard-types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Public types for the interactive setup wizard.
3
+ *
4
+ * Split out of `setup-wizard.ts` in the Round-1 audit I5 fix so the
5
+ * type surface is consumable without dragging in @clack/prompts or the
6
+ * RestClient. Tests and other modules import these types alone.
7
+ *
8
+ * @license MIT
9
+ */
10
+ export {};
11
+ //# sourceMappingURL=setup-wizard-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup-wizard-types.js","sourceRoot":"","sources":["../src/setup-wizard-types.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG"}