skybridge 0.0.0-dev.f2c8fae → 0.0.0-dev.f2d6084

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 (322) hide show
  1. package/README.md +123 -124
  2. package/dist/cli/build-helpers.d.ts +7 -0
  3. package/dist/cli/build-helpers.js +82 -0
  4. package/dist/cli/build-helpers.js.map +1 -0
  5. package/dist/cli/build-helpers.test.js +64 -0
  6. package/dist/cli/build-helpers.test.js.map +1 -0
  7. package/dist/cli/detect-port.d.ts +2 -2
  8. package/dist/cli/detect-port.js +9 -20
  9. package/dist/cli/detect-port.js.map +1 -1
  10. package/dist/cli/header.js +1 -1
  11. package/dist/cli/header.js.map +1 -1
  12. package/dist/cli/resolve-views-dir.d.ts +1 -0
  13. package/dist/cli/resolve-views-dir.js +17 -0
  14. package/dist/cli/resolve-views-dir.js.map +1 -0
  15. package/dist/cli/run-command.js.map +1 -1
  16. package/dist/cli/telemetry.js.map +1 -1
  17. package/dist/cli/tunnel-control-server.d.ts +9 -0
  18. package/dist/cli/tunnel-control-server.js +31 -0
  19. package/dist/cli/tunnel-control-server.js.map +1 -0
  20. package/dist/cli/tunnel-control-server.test.js +39 -0
  21. package/dist/cli/tunnel-control-server.test.js.map +1 -0
  22. package/dist/cli/tunnel-handler.d.ts +3 -0
  23. package/dist/cli/tunnel-handler.js +48 -0
  24. package/dist/cli/tunnel-handler.js.map +1 -0
  25. package/dist/cli/tunnel-handler.test.js +105 -0
  26. package/dist/cli/tunnel-handler.test.js.map +1 -0
  27. package/dist/cli/tunnel.d.ts +57 -0
  28. package/dist/cli/tunnel.js +154 -0
  29. package/dist/cli/tunnel.js.map +1 -0
  30. package/dist/cli/tunnel.test.d.ts +1 -0
  31. package/dist/cli/tunnel.test.js +190 -0
  32. package/dist/cli/tunnel.test.js.map +1 -0
  33. package/dist/cli/types.js.map +1 -1
  34. package/dist/cli/use-execute-steps.js.map +1 -1
  35. package/dist/cli/use-messages.d.ts +3 -0
  36. package/dist/cli/use-messages.js +11 -0
  37. package/dist/cli/use-messages.js.map +1 -0
  38. package/dist/cli/use-nodemon.d.ts +2 -2
  39. package/dist/cli/use-nodemon.js +18 -25
  40. package/dist/cli/use-nodemon.js.map +1 -1
  41. package/dist/cli/use-open-browser.d.ts +1 -0
  42. package/dist/cli/use-open-browser.js +44 -0
  43. package/dist/cli/use-open-browser.js.map +1 -0
  44. package/dist/cli/use-open-tunnel-browser.d.ts +6 -0
  45. package/dist/cli/use-open-tunnel-browser.js +19 -0
  46. package/dist/cli/use-open-tunnel-browser.js.map +1 -0
  47. package/dist/cli/use-tunnel.d.ts +13 -7
  48. package/dist/cli/use-tunnel.js +103 -73
  49. package/dist/cli/use-tunnel.js.map +1 -1
  50. package/dist/cli/use-typescript-check.d.ts +1 -0
  51. package/dist/cli/use-typescript-check.js +42 -7
  52. package/dist/cli/use-typescript-check.js.map +1 -1
  53. package/dist/commands/build.d.ts +0 -1
  54. package/dist/commands/build.js +52 -8
  55. package/dist/commands/build.js.map +1 -1
  56. package/dist/commands/create.d.ts +9 -0
  57. package/dist/commands/create.js +30 -0
  58. package/dist/commands/create.js.map +1 -0
  59. package/dist/commands/dev.d.ts +2 -0
  60. package/dist/commands/dev.js +60 -6
  61. package/dist/commands/dev.js.map +1 -1
  62. package/dist/commands/start.js +13 -10
  63. package/dist/commands/start.js.map +1 -1
  64. package/dist/commands/telemetry/disable.js.map +1 -1
  65. package/dist/commands/telemetry/enable.js.map +1 -1
  66. package/dist/commands/telemetry/status.js.map +1 -1
  67. package/dist/server/asset-base-url-transform-plugin.d.ts +1 -0
  68. package/dist/server/asset-base-url-transform-plugin.js +17 -2
  69. package/dist/server/asset-base-url-transform-plugin.js.map +1 -1
  70. package/dist/server/asset-base-url-transform-plugin.test.js +80 -1
  71. package/dist/server/asset-base-url-transform-plugin.test.js.map +1 -1
  72. package/dist/server/auth.d.ts +20 -0
  73. package/dist/server/auth.js +28 -0
  74. package/dist/server/auth.js.map +1 -0
  75. package/dist/server/build-manifest.test.d.ts +1 -0
  76. package/dist/server/build-manifest.test.js +27 -0
  77. package/dist/server/build-manifest.test.js.map +1 -0
  78. package/dist/server/content-helpers.d.ts +67 -0
  79. package/dist/server/content-helpers.js +79 -0
  80. package/dist/server/content-helpers.js.map +1 -0
  81. package/dist/server/content-helpers.test.d.ts +1 -0
  82. package/dist/server/content-helpers.test.js +70 -0
  83. package/dist/server/content-helpers.test.js.map +1 -0
  84. package/dist/server/express.d.ts +2 -6
  85. package/dist/server/express.js +34 -10
  86. package/dist/server/express.js.map +1 -1
  87. package/dist/server/express.test.js +279 -71
  88. package/dist/server/express.test.js.map +1 -1
  89. package/dist/server/file-ref.d.ts +28 -0
  90. package/dist/server/file-ref.js +27 -0
  91. package/dist/server/file-ref.js.map +1 -0
  92. package/dist/server/index.d.ts +6 -3
  93. package/dist/server/index.js +5 -2
  94. package/dist/server/index.js.map +1 -1
  95. package/dist/server/inferUtilityTypes.d.ts +6 -6
  96. package/dist/server/inferUtilityTypes.js.map +1 -1
  97. package/dist/server/metric.d.ts +14 -0
  98. package/dist/server/metric.js +62 -0
  99. package/dist/server/metric.js.map +1 -0
  100. package/dist/server/middleware.d.ts +16 -3
  101. package/dist/server/middleware.js.map +1 -1
  102. package/dist/server/middleware.test-d.js.map +1 -1
  103. package/dist/server/middleware.test.js +12 -9
  104. package/dist/server/middleware.test.js.map +1 -1
  105. package/dist/server/server.d.ts +304 -73
  106. package/dist/server/server.js +438 -130
  107. package/dist/server/server.js.map +1 -1
  108. package/dist/server/templateHelper.d.ts +5 -7
  109. package/dist/server/templateHelper.js +3 -22
  110. package/dist/server/templateHelper.js.map +1 -1
  111. package/dist/server/templates.generated.d.ts +4 -0
  112. package/dist/server/templates.generated.js +47 -0
  113. package/dist/server/templates.generated.js.map +1 -0
  114. package/dist/server/tunnel-proxy-router.d.ts +7 -0
  115. package/dist/server/tunnel-proxy-router.js +110 -0
  116. package/dist/server/tunnel-proxy-router.js.map +1 -0
  117. package/dist/server/tunnel-proxy-router.test.d.ts +1 -0
  118. package/dist/server/tunnel-proxy-router.test.js +229 -0
  119. package/dist/server/tunnel-proxy-router.test.js.map +1 -0
  120. package/dist/server/viewsDevServer.d.ts +14 -0
  121. package/dist/server/viewsDevServer.js +45 -0
  122. package/dist/server/viewsDevServer.js.map +1 -0
  123. package/dist/test/utils.d.ts +13 -21
  124. package/dist/test/utils.js +42 -37
  125. package/dist/test/utils.js.map +1 -1
  126. package/dist/test/view.test.d.ts +1 -0
  127. package/dist/test/view.test.js +568 -0
  128. package/dist/test/view.test.js.map +1 -0
  129. package/dist/version.d.ts +1 -0
  130. package/dist/version.js +3 -0
  131. package/dist/version.js.map +1 -0
  132. package/dist/web/bridges/apps-sdk/adaptor.d.ts +11 -4
  133. package/dist/web/bridges/apps-sdk/adaptor.js +59 -17
  134. package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -1
  135. package/dist/web/bridges/apps-sdk/bridge.d.ts +1 -0
  136. package/dist/web/bridges/apps-sdk/bridge.js +1 -0
  137. package/dist/web/bridges/apps-sdk/bridge.js.map +1 -1
  138. package/dist/web/bridges/apps-sdk/index.js.map +1 -1
  139. package/dist/web/bridges/apps-sdk/types.d.ts +18 -6
  140. package/dist/web/bridges/apps-sdk/types.js.map +1 -1
  141. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.d.ts +11 -0
  142. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js +11 -0
  143. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js.map +1 -1
  144. package/dist/web/bridges/get-adaptor.d.ts +7 -0
  145. package/dist/web/bridges/get-adaptor.js +7 -0
  146. package/dist/web/bridges/get-adaptor.js.map +1 -1
  147. package/dist/web/bridges/index.js.map +1 -1
  148. package/dist/web/bridges/mcp-app/adaptor.d.ts +21 -6
  149. package/dist/web/bridges/mcp-app/adaptor.js +127 -28
  150. package/dist/web/bridges/mcp-app/adaptor.js.map +1 -1
  151. package/dist/web/bridges/mcp-app/bridge.d.ts +4 -2
  152. package/dist/web/bridges/mcp-app/bridge.js +23 -1
  153. package/dist/web/bridges/mcp-app/bridge.js.map +1 -1
  154. package/dist/web/bridges/mcp-app/index.js.map +1 -1
  155. package/dist/web/bridges/mcp-app/types.js.map +1 -1
  156. package/dist/web/bridges/mcp-app/use-mcp-app-context.d.ts +12 -0
  157. package/dist/web/bridges/mcp-app/use-mcp-app-context.js +12 -0
  158. package/dist/web/bridges/mcp-app/use-mcp-app-context.js.map +1 -1
  159. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js.map +1 -1
  160. package/dist/web/bridges/mcp-app/view-tools.test.d.ts +1 -0
  161. package/dist/web/bridges/mcp-app/view-tools.test.js +144 -0
  162. package/dist/web/bridges/mcp-app/view-tools.test.js.map +1 -0
  163. package/dist/web/bridges/types.d.ts +112 -11
  164. package/dist/web/bridges/types.js.map +1 -1
  165. package/dist/web/bridges/use-host-context.d.ts +5 -0
  166. package/dist/web/bridges/use-host-context.js +5 -0
  167. package/dist/web/bridges/use-host-context.js.map +1 -1
  168. package/dist/web/components/modal-provider.js +2 -2
  169. package/dist/web/components/modal-provider.js.map +1 -1
  170. package/dist/web/create-store.d.ts +26 -0
  171. package/dist/web/create-store.js +43 -3
  172. package/dist/web/create-store.js.map +1 -1
  173. package/dist/web/create-store.test.js +14 -16
  174. package/dist/web/create-store.test.js.map +1 -1
  175. package/dist/web/data-llm.d.ts +34 -1
  176. package/dist/web/data-llm.js +31 -3
  177. package/dist/web/data-llm.js.map +1 -1
  178. package/dist/web/data-llm.test.js +22 -22
  179. package/dist/web/data-llm.test.js.map +1 -1
  180. package/dist/web/generate-helpers.d.ts +22 -18
  181. package/dist/web/generate-helpers.js +22 -18
  182. package/dist/web/generate-helpers.js.map +1 -1
  183. package/dist/web/generate-helpers.test-d.js +26 -26
  184. package/dist/web/generate-helpers.test-d.js.map +1 -1
  185. package/dist/web/generate-helpers.test.js.map +1 -1
  186. package/dist/web/helpers/state.d.ts +2 -2
  187. package/dist/web/helpers/state.js +11 -11
  188. package/dist/web/helpers/state.js.map +1 -1
  189. package/dist/web/helpers/state.test.js +9 -9
  190. package/dist/web/helpers/state.test.js.map +1 -1
  191. package/dist/web/hooks/index.d.ts +5 -1
  192. package/dist/web/hooks/index.js +5 -1
  193. package/dist/web/hooks/index.js.map +1 -1
  194. package/dist/web/hooks/test/utils.d.ts +6 -2
  195. package/dist/web/hooks/test/utils.js +13 -2
  196. package/dist/web/hooks/test/utils.js.map +1 -1
  197. package/dist/web/hooks/use-call-tool.d.ts +45 -0
  198. package/dist/web/hooks/use-call-tool.js +28 -0
  199. package/dist/web/hooks/use-call-tool.js.map +1 -1
  200. package/dist/web/hooks/use-call-tool.test-d.js.map +1 -1
  201. package/dist/web/hooks/use-call-tool.test.js +27 -6
  202. package/dist/web/hooks/use-call-tool.test.js.map +1 -1
  203. package/dist/web/hooks/use-display-mode.d.ts +20 -0
  204. package/dist/web/hooks/use-display-mode.js +20 -0
  205. package/dist/web/hooks/use-display-mode.js.map +1 -1
  206. package/dist/web/hooks/use-display-mode.test-d.js.map +1 -1
  207. package/dist/web/hooks/use-display-mode.test.js.map +1 -1
  208. package/dist/web/hooks/use-download.d.ts +5 -0
  209. package/dist/web/hooks/use-download.js +8 -0
  210. package/dist/web/hooks/use-download.js.map +1 -0
  211. package/dist/web/hooks/use-download.test.d.ts +1 -0
  212. package/dist/web/hooks/use-download.test.js +95 -0
  213. package/dist/web/hooks/use-download.test.js.map +1 -0
  214. package/dist/web/hooks/use-files.d.ts +34 -1
  215. package/dist/web/hooks/use-files.js +33 -0
  216. package/dist/web/hooks/use-files.js.map +1 -1
  217. package/dist/web/hooks/use-files.test.js +22 -2
  218. package/dist/web/hooks/use-files.test.js.map +1 -1
  219. package/dist/web/hooks/use-layout.d.ts +2 -0
  220. package/dist/web/hooks/use-layout.js +2 -0
  221. package/dist/web/hooks/use-layout.js.map +1 -1
  222. package/dist/web/hooks/use-layout.test.js.map +1 -1
  223. package/dist/web/hooks/use-open-external.d.ts +17 -0
  224. package/dist/web/hooks/use-open-external.js +16 -0
  225. package/dist/web/hooks/use-open-external.js.map +1 -1
  226. package/dist/web/hooks/use-open-external.test.js.map +1 -1
  227. package/dist/web/hooks/use-register-view-tool.d.ts +38 -0
  228. package/dist/web/hooks/use-register-view-tool.js +50 -0
  229. package/dist/web/hooks/use-register-view-tool.js.map +1 -0
  230. package/dist/web/hooks/use-request-close.d.ts +16 -0
  231. package/dist/web/hooks/use-request-close.js +21 -0
  232. package/dist/web/hooks/use-request-close.js.map +1 -0
  233. package/dist/web/hooks/use-request-close.test.d.ts +1 -0
  234. package/dist/web/hooks/use-request-close.test.js +52 -0
  235. package/dist/web/hooks/use-request-close.test.js.map +1 -0
  236. package/dist/web/hooks/use-request-modal.d.ts +16 -1
  237. package/dist/web/hooks/use-request-modal.js +19 -4
  238. package/dist/web/hooks/use-request-modal.js.map +1 -1
  239. package/dist/web/hooks/use-request-modal.test.js +1 -1
  240. package/dist/web/hooks/use-request-modal.test.js.map +1 -1
  241. package/dist/web/hooks/use-request-size.d.ts +20 -0
  242. package/dist/web/hooks/use-request-size.js +24 -0
  243. package/dist/web/hooks/use-request-size.js.map +1 -0
  244. package/dist/web/hooks/use-request-size.test.d.ts +1 -0
  245. package/dist/web/hooks/use-request-size.test.js +65 -0
  246. package/dist/web/hooks/use-request-size.test.js.map +1 -0
  247. package/dist/web/hooks/use-send-follow-up-message.d.ts +19 -1
  248. package/dist/web/hooks/use-send-follow-up-message.js +19 -2
  249. package/dist/web/hooks/use-send-follow-up-message.js.map +1 -1
  250. package/dist/web/hooks/use-set-open-in-app-url.d.ts +17 -0
  251. package/dist/web/hooks/use-set-open-in-app-url.js +17 -0
  252. package/dist/web/hooks/use-set-open-in-app-url.js.map +1 -1
  253. package/dist/web/hooks/use-set-open-in-app-url.test.js.map +1 -1
  254. package/dist/web/hooks/use-tool-info.d.ts +33 -0
  255. package/dist/web/hooks/use-tool-info.js +26 -0
  256. package/dist/web/hooks/use-tool-info.js.map +1 -1
  257. package/dist/web/hooks/use-tool-info.test-d.js.map +1 -1
  258. package/dist/web/hooks/use-tool-info.test.js.map +1 -1
  259. package/dist/web/hooks/use-user.d.ts +2 -0
  260. package/dist/web/hooks/use-user.js +2 -0
  261. package/dist/web/hooks/use-user.js.map +1 -1
  262. package/dist/web/hooks/use-user.test.js.map +1 -1
  263. package/dist/web/hooks/use-view-state.d.ts +25 -0
  264. package/dist/web/hooks/use-view-state.js +32 -0
  265. package/dist/web/hooks/use-view-state.js.map +1 -0
  266. package/dist/web/hooks/use-view-state.test.d.ts +1 -0
  267. package/dist/web/hooks/use-view-state.test.js +177 -0
  268. package/dist/web/hooks/use-view-state.test.js.map +1 -0
  269. package/dist/web/index.d.ts +1 -2
  270. package/dist/web/index.js +1 -2
  271. package/dist/web/index.js.map +1 -1
  272. package/dist/web/mount-view.d.ts +20 -0
  273. package/dist/web/{mount-widget.js → mount-view.js} +21 -2
  274. package/dist/web/mount-view.js.map +1 -0
  275. package/dist/web/plugin/data-llm.test.js.map +1 -1
  276. package/dist/web/plugin/plugin.d.ts +32 -1
  277. package/dist/web/plugin/plugin.js +160 -25
  278. package/dist/web/plugin/plugin.js.map +1 -1
  279. package/dist/web/plugin/scan-views.d.ts +16 -0
  280. package/dist/web/plugin/scan-views.js +88 -0
  281. package/dist/web/plugin/scan-views.js.map +1 -0
  282. package/dist/web/plugin/scan-views.test.d.ts +1 -0
  283. package/dist/web/plugin/scan-views.test.js +99 -0
  284. package/dist/web/plugin/scan-views.test.js.map +1 -0
  285. package/dist/web/plugin/transform-data-llm.js.map +1 -1
  286. package/dist/web/plugin/transform-data-llm.test.js.map +1 -1
  287. package/dist/web/plugin/validate-view.d.ts +1 -0
  288. package/dist/web/plugin/validate-view.js +9 -0
  289. package/dist/web/plugin/validate-view.js.map +1 -0
  290. package/dist/web/plugin/validate-view.test.d.ts +1 -0
  291. package/dist/web/plugin/validate-view.test.js +24 -0
  292. package/dist/web/plugin/validate-view.test.js.map +1 -0
  293. package/dist/web/proxy.js.map +1 -1
  294. package/dist/web/types.d.ts +4 -0
  295. package/dist/web/types.js.map +1 -1
  296. package/package.json +28 -12
  297. package/tsconfig.base.json +2 -0
  298. package/dist/server/monitoring.d.ts +0 -15
  299. package/dist/server/monitoring.js +0 -66
  300. package/dist/server/monitoring.js.map +0 -1
  301. package/dist/server/templates/development.hbs +0 -12
  302. package/dist/server/templates/production.hbs +0 -6
  303. package/dist/server/widgetsDevServer.d.ts +0 -13
  304. package/dist/server/widgetsDevServer.js +0 -52
  305. package/dist/server/widgetsDevServer.js.map +0 -1
  306. package/dist/test/widget.test.js +0 -263
  307. package/dist/test/widget.test.js.map +0 -1
  308. package/dist/web/hooks/use-widget-state.d.ts +0 -4
  309. package/dist/web/hooks/use-widget-state.js +0 -32
  310. package/dist/web/hooks/use-widget-state.js.map +0 -1
  311. package/dist/web/hooks/use-widget-state.test.js +0 -64
  312. package/dist/web/hooks/use-widget-state.test.js.map +0 -1
  313. package/dist/web/mount-widget.d.ts +0 -1
  314. package/dist/web/mount-widget.js.map +0 -1
  315. package/dist/web/plugin/validate-widget.d.ts +0 -5
  316. package/dist/web/plugin/validate-widget.js +0 -27
  317. package/dist/web/plugin/validate-widget.js.map +0 -1
  318. package/dist/web/plugin/validate-widget.test.js +0 -42
  319. package/dist/web/plugin/validate-widget.test.js.map +0 -1
  320. /package/dist/{test/widget.test.d.ts → cli/build-helpers.test.d.ts} +0 -0
  321. /package/dist/{web/hooks/use-widget-state.test.d.ts → cli/tunnel-control-server.test.d.ts} +0 -0
  322. /package/dist/{web/plugin/validate-widget.test.d.ts → cli/tunnel-handler.test.d.ts} +0 -0
@@ -1,45 +1,125 @@
1
- import type { McpUiResourceMeta } from "@modelcontextprotocol/ext-apps";
2
- import { McpServer as McpServerBase, type RegisteredTool } from "@modelcontextprotocol/sdk/server/mcp.js";
1
+ import type { McpUiToolMeta } from "@modelcontextprotocol/ext-apps";
2
+ import { type ServerOptions } from "@modelcontextprotocol/sdk/server/index.js";
3
+ import { McpServer as McpServerBase } from "@modelcontextprotocol/sdk/server/mcp.js";
3
4
  import type { AnySchema, SchemaOutput, ZodRawShapeCompat } from "@modelcontextprotocol/sdk/server/zod-compat.js";
4
5
  import type { RequestHandlerExtra } from "@modelcontextprotocol/sdk/shared/protocol.js";
5
- import type { CallToolResult, Resource, ServerNotification, ServerRequest, ServerResult, ToolAnnotations } from "@modelcontextprotocol/sdk/types.js";
6
- import type { ErrorRequestHandler, RequestHandler } from "express";
6
+ import type { ContentBlock, Implementation, RequestMeta, ServerNotification, ServerRequest, ServerResult, ToolAnnotations } from "@modelcontextprotocol/sdk/types.js";
7
+ import { type ErrorRequestHandler, type Express, type RequestHandler } from "express";
7
8
  import type { McpExtra, McpExtraFor, McpMethodString, McpMiddlewareFilter, McpMiddlewareFn, McpResultFor, McpTypedMiddlewareFn, McpWildcard } from "./middleware.js";
9
+ /**
10
+ * Type marker for a registered tool — carries its input, output, and response
11
+ * metadata shapes so views can infer types from `typeof server`.
12
+ *
13
+ * You normally never construct this by hand; it is produced by `registerTool`
14
+ * and consumed by helpers like {@link InferTools} and {@link generateHelpers}.
15
+ */
8
16
  export type ToolDef<TInput = unknown, TOutput = unknown, TResponseMetadata = unknown> = {
9
17
  input: TInput;
10
18
  output: TOutput;
11
19
  responseMetadata: TResponseMetadata;
12
20
  };
21
+ /** Which host runtime a view targets — `"apps-sdk"` (ChatGPT) or `"mcp-app"` (MCP Apps spec). */
22
+ export type ViewHostType = "apps-sdk" | "mcp-app";
13
23
  /**
14
- * Extended MCP Apps CSP with upcoming fields from ext-apps PR #158
15
- * and Skybridge-specific fields for OpenAI compatibility
16
- * @see https://github.com/modelcontextprotocol/ext-apps/pull/158
24
+ * Content Security Policy origins attached to a view's resource. Each list is
25
+ * passed through to the host's CSP for the view iframe; omit a field to inherit
26
+ * the host's default for that directive.
17
27
  */
18
- type ExtendedMcpUiResourceCsp = McpUiResourceMeta["csp"] & {
19
- /**
20
- * Origins that can receive openExternal redirects without safe-link modal (OpenAI-specific)
21
- * @see https://developers.openai.com/apps-sdk/reference#component-resource-_meta-fields
22
- */
28
+ export interface ViewCsp {
29
+ /** Origins for static assets (images, fonts, scripts, styles). */
30
+ resourceDomains?: string[];
31
+ /** Origins the view may contact via fetch/XHR. */
32
+ connectDomains?: string[];
33
+ /** Origins allowed for iframe embeds (opts into stricter app review). */
34
+ frameDomains?: string[];
35
+ /** Origins that can receive openExternal redirects without the safe-link modal. */
23
36
  redirectDomains?: string[];
37
+ /** Origins allowed in `<base href>` tags (mcp-apps only). */
38
+ baseUriDomains?: string[];
39
+ }
40
+ /**
41
+ * Registry of view component names. The Skybridge Vite plugin augments this
42
+ * interface in the generated `.skybridge/views.d.ts` with one key per view
43
+ * file, which narrows {@link ViewName} from `string` to the concrete union.
44
+ */
45
+ export interface ViewNameRegistry {
46
+ }
47
+ /** Union of valid view component names. Narrowed by {@link ViewNameRegistry}. */
48
+ export type ViewName = keyof ViewNameRegistry & string;
49
+ /**
50
+ * Pass under `view` in a tool's `registerTool` config to render the tool's
51
+ * result through a Skybridge view instead of a plain text response.
52
+ */
53
+ export interface ViewConfig {
54
+ /** Filename of the view module (without extension) — matches a file in your `viewsDir`. */
55
+ component: ViewName;
56
+ /** Human-readable label the host may show alongside the view. */
57
+ description?: string;
58
+ /** Restrict where the view is rendered. Defaults to all known hosts. */
59
+ hosts?: ViewHostType[];
60
+ /** Apps SDK only: request a visible border around the widget. */
61
+ prefersBorder?: boolean;
62
+ /** Apps SDK only: override the iframe's served domain (advanced). */
63
+ domain?: string;
64
+ /** Per-view CSP overrides — see {@link ViewCsp}. */
65
+ csp?: ViewCsp;
66
+ /** Free-form metadata forwarded on the view resource's `_meta`. */
67
+ _meta?: Record<string, unknown>;
68
+ }
69
+ export type SecurityScheme = {
70
+ type: "noauth";
71
+ } | {
72
+ type: "oauth2";
73
+ scopes?: string[];
24
74
  };
25
- /** Extended MCP Apps resource metadata with upcoming CSP fields */
26
- type ExtendedMcpUiResourceMeta = Omit<McpUiResourceMeta, "csp"> & {
27
- csp?: ExtendedMcpUiResourceCsp;
28
- };
29
- /** User-provided resource configuration with optional CSP override */
30
- export type WidgetResourceMeta = {
31
- ui?: ExtendedMcpUiResourceMeta;
32
- } & Resource["_meta"];
33
- export type WidgetHostType = "apps-sdk" | "mcp-app";
34
- type McpServerOriginalResourceConfig = Omit<Resource, "uri" | "name" | "mimeType" | "_meta"> & {
35
- _meta?: WidgetResourceMeta;
36
- /** Restrict host types to a specific subset */
37
- hosts?: WidgetHostType[];
38
- };
39
- type McpServerOriginalToolConfig = Omit<Parameters<typeof McpServerBase.prototype.registerTool<ZodRawShapeCompat, ZodRawShapeCompat>>[1], "inputSchema" | "outputSchema">;
75
+ /**
76
+ * Well-known keys recognized by host runtimes when set on a tool's `_meta`.
77
+ * Use {@link ToolMeta} to also pass arbitrary custom metadata alongside these.
78
+ *
79
+ * @see https://developers.openai.com/apps-sdk/reference#tool-descriptor-parameters
80
+ */
81
+ export interface KnownToolMeta {
82
+ /** Apps SDK: allow the rendered view to call this tool from inside its iframe. */
83
+ "openai/widgetAccessible"?: boolean;
84
+ /** Apps SDK: status text shown while the tool is running (e.g. `"Searching trips"`). */
85
+ "openai/toolInvocation/invoking"?: string;
86
+ /** Apps SDK: status text shown once the tool returns (e.g. `"Found 3 trips"`). */
87
+ "openai/toolInvocation/invoked"?: string;
88
+ /** Apps SDK: input parameters that hold file references — the host attaches uploaded files to them. */
89
+ "openai/fileParams"?: string[];
90
+ /** MCP Apps: control whether the tool is exposed to the model, the app, or both. */
91
+ ui?: Pick<McpUiToolMeta, "visibility">;
92
+ securitySchemes?: SecurityScheme[];
93
+ }
94
+ /** {@link KnownToolMeta} merged with arbitrary string-keyed metadata for custom flags. */
95
+ export type ToolMeta = KnownToolMeta & Record<string, unknown>;
96
+ /**
97
+ * Convenient return type for tool handlers — a plain string, a single
98
+ * {@link ContentBlock}, or an array. Skybridge normalizes it to the MCP
99
+ * `content: ContentBlock[]` shape before responding.
100
+ */
101
+ export type HandlerContent = string | ContentBlock | ContentBlock[];
102
+ /**
103
+ * Type-level marker interface for cross-package type inference.
104
+ *
105
+ * Consumers infer tool types via the structural `$types` property rather than
106
+ * the `McpServer` class generic, because class-generic inference breaks when
107
+ * `McpServer` comes from different package installations (e.g. a consumer
108
+ * with its own `skybridge` dep vs. the in-tree workspace version).
109
+ *
110
+ * Inspired by tRPC's `_def` pattern and Hono's type markers.
111
+ */
112
+ export interface McpServerTypes<TTools extends Record<string, ToolDef>> {
113
+ readonly tools: TTools;
114
+ }
40
115
  type Simplify<T> = {
41
116
  [K in keyof T]: T[K];
42
117
  };
118
+ type ShapeOutput<Shape extends ZodRawShapeCompat> = Simplify<{
119
+ [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? never : K]: SchemaOutput<Shape[K]>;
120
+ } & {
121
+ [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? K : never]?: SchemaOutput<Shape[K]>;
122
+ }>;
43
123
  type ExtractStructuredContent<T> = T extends {
44
124
  structuredContent: infer SC;
45
125
  } ? Simplify<SC> : never;
@@ -50,62 +130,141 @@ type ExtractMeta<T> = [Extract<T, {
50
130
  }> extends {
51
131
  _meta: infer M;
52
132
  } ? Simplify<M> : unknown;
53
- /**
54
- * Type-level marker interface for cross-package type inference.
55
- * This enables TypeScript to infer tool types across package boundaries
56
- * using structural typing on the $types property, rather than relying on
57
- * class generic inference which fails when McpServer comes from different
58
- * package installations.
59
- *
60
- * Inspired by tRPC's _def pattern and Hono's type markers.
61
- */
62
- export interface McpServerTypes<TTools extends Record<string, ToolDef>> {
63
- readonly tools: TTools;
64
- }
65
- type ShapeOutput<Shape extends ZodRawShapeCompat> = Simplify<{
66
- [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? never : K]: SchemaOutput<Shape[K]>;
67
- } & {
68
- [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? K : never]?: SchemaOutput<Shape[K]>;
69
- }>;
70
133
  type AddTool<TTools, TName extends string, TInput extends ZodRawShapeCompat, TOutput, TResponseMetadata = unknown> = McpServer<TTools & {
71
134
  [K in TName]: ToolDef<ShapeOutput<TInput>, TOutput, TResponseMetadata>;
72
135
  }>;
73
- type ToolConfig<TInput extends ZodRawShapeCompat | AnySchema> = {
136
+ interface ToolConfig<TInput extends ZodRawShapeCompat | AnySchema> {
137
+ name: string;
74
138
  title?: string;
75
139
  description?: string;
76
140
  inputSchema?: TInput;
77
141
  outputSchema?: ZodRawShapeCompat | AnySchema;
78
142
  annotations?: ToolAnnotations;
79
- _meta?: Record<string, unknown>;
143
+ view?: ViewConfig;
144
+ /**
145
+ * Declares which auth schemes this tool supports (e.g. `noauth`, `oauth2`).
146
+ * Lets clients label tools that require sign-in before calling, and pass
147
+ * the right scopes through the OAuth flow. Listing both `noauth` and
148
+ * `oauth2` signals that the tool works for anonymous callers and gives
149
+ * enhanced behavior to authenticated ones.
150
+ */
151
+ securitySchemes?: SecurityScheme[];
152
+ _meta?: ToolMeta;
153
+ }
154
+ /**
155
+ * Optional client-supplied hints attached to `params._meta` on every tool call
156
+ * by the Apps SDK host. Hints only: never use for authorization, and tolerate
157
+ * absence.
158
+ * @see https://developers.openai.com/apps-sdk/reference#_meta-fields-the-client-provides
159
+ */
160
+ export interface ClientHintsMeta {
161
+ /** Requested locale (BCP-47, e.g. `"en-US"`). */
162
+ "openai/locale"?: string;
163
+ /** Browser user-agent */
164
+ "openai/userAgent"?: string;
165
+ /** Coarse user location. May be partially populated. */
166
+ "openai/userLocation"?: {
167
+ city?: string;
168
+ region?: string;
169
+ country?: string;
170
+ timezone?: string;
171
+ longitude?: number;
172
+ latitude?: number;
173
+ };
174
+ /** Anonymized user id. */
175
+ "openai/subject"?: string;
176
+ /** Anonymized conversation id, stable within a ChatGPT session. */
177
+ "openai/session"?: string;
178
+ /** Anonymized organization id, when the user account is part of an organization. */
179
+ "openai/organization"?: string;
180
+ /** Stable id for the currently mounted widget instance. */
181
+ "openai/widgetSessionId"?: string;
182
+ }
183
+ type ToolHandlerExtra = Omit<RequestHandlerExtra<ServerRequest, ServerNotification>, "_meta"> & {
184
+ _meta?: RequestMeta & ClientHintsMeta;
80
185
  };
81
186
  type ToolHandler<TInput extends ZodRawShapeCompat, TReturn extends {
82
- content: CallToolResult["content"];
83
- } = CallToolResult> = (args: ShapeOutput<TInput>, extra: RequestHandlerExtra<ServerRequest, ServerNotification>) => TReturn | Promise<TReturn>;
84
- export declare class McpServer<TTools extends Record<string, ToolDef> = Record<never, ToolDef>> extends McpServerBase {
187
+ content?: HandlerContent;
188
+ } = {
189
+ content?: HandlerContent;
190
+ }> = (args: ShapeOutput<TInput>, extra: ToolHandlerExtra) => TReturn | Promise<TReturn>;
191
+ /**
192
+ * Coerce a tool handler's return value into an MCP `content` array. Strings
193
+ * become a single `TextContent`; a single block is wrapped in an array;
194
+ * `undefined` produces `[]`. Mostly used internally — exported so consumers
195
+ * who build content lazily can apply the same normalization.
196
+ */
197
+ export declare function normalizeContent(content: HandlerContent | undefined): ContentBlock[];
198
+ interface McpServerBaseOmitted extends Omit<McpServerBase, "registerTool" | "connect"> {
199
+ }
200
+ declare const McpServerBaseOmitted: new (...args: ConstructorParameters<typeof McpServerBase>) => McpServerBaseOmitted;
201
+ /**
202
+ * Prime the build-time Vite manifest before user code constructs its
203
+ * `McpServer`. Called from the generated `dist/__entry.js`; not part of the
204
+ * user-facing API.
205
+ *
206
+ * @internal
207
+ */
208
+ export declare function __setBuildManifest(manifest: Record<string, {
209
+ file: string;
210
+ }>): void;
211
+ export declare class McpServer<TTools extends Record<string, ToolDef> = Record<never, ToolDef>> extends McpServerBaseOmitted {
85
212
  readonly $types: McpServerTypes<TTools>;
86
- private express?;
87
- private customMiddleware;
213
+ /**
214
+ * The underlying Express app. Use this to extend the HTTP server with
215
+ * custom routes, middleware, or settings — e.g.
216
+ * `server.express.get("/health", ...)`.
217
+ *
218
+ * `express.json()` is pre-applied. Register your handlers before `run()`;
219
+ * after `run()`, dev-mode middleware, the `/mcp` route, and the default
220
+ * error handler are appended in that order.
221
+ *
222
+ * Note: Alpic Cloud only routes traffic to `/mcp` — custom routes work
223
+ * locally and on self-hosted deployments.
224
+ */
225
+ readonly express: Express;
88
226
  private customErrorMiddleware;
89
227
  private mcpMiddlewareEntries;
90
228
  private mcpMiddlewareApplied;
229
+ private claimedViews;
230
+ private viewMetaBuilders;
231
+ private viteManifest;
232
+ private readonly serverInfo;
233
+ private readonly serverOptions?;
234
+ constructor(serverInfo: Implementation, options?: ServerOptions);
235
+ /**
236
+ * Register Express middleware on the underlying app. Mirrors `app.use` —
237
+ * pass handlers directly or a path-prefixed handler list. Register before
238
+ * {@link McpServer.run}; ordering matches Express.
239
+ *
240
+ * Note: Alpic Cloud only routes traffic to `/mcp`. Custom paths work
241
+ * locally and on self-hosted deployments.
242
+ */
91
243
  use(...handlers: RequestHandler[]): this;
92
244
  use(path: string, ...handlers: RequestHandler[]): this;
93
- useOnError(...handlers: ErrorRequestHandler[]): this;
94
- useOnError(path: string, ...handlers: ErrorRequestHandler[]): this;
95
245
  /**
96
- * Register MCP protocol-level middleware (catch-all).
246
+ * Register Express error-handling middleware to run after the built-in
247
+ * `/mcp` route (or your custom route). Use this to log or transform errors
248
+ * thrown by tool handlers before the default error handler responds.
249
+ *
250
+ * @example
251
+ * ```ts
252
+ * server.useOnError((err, _req, _res, next) => {
253
+ * logger.error(err);
254
+ * next(err);
255
+ * });
256
+ * ```
97
257
  */
258
+ useOnError(...handlers: ErrorRequestHandler[]): this;
259
+ useOnError(path: string, ...handlers: ErrorRequestHandler[]): this;
260
+ /** Register MCP protocol-level middleware (catch-all). */
98
261
  mcpMiddleware(handler: McpMiddlewareFn): this;
99
- /**
100
- * Register MCP protocol-level middleware for all requests (`extra` is `McpExtra`).
101
- */
262
+ /** Register MCP protocol-level middleware for all requests (`extra` is `McpExtra`). */
102
263
  mcpMiddleware(filter: "request", handler: (request: {
103
264
  method: string;
104
265
  params: Record<string, unknown>;
105
266
  }, extra: McpExtra, next: () => Promise<ServerResult>) => Promise<unknown> | unknown): this;
106
- /**
107
- * Register MCP protocol-level middleware for all notifications (`extra` is `undefined`).
108
- */
267
+ /** Register MCP protocol-level middleware for all notifications (`extra` is `undefined`). */
109
268
  mcpMiddleware(filter: "notification", handler: (request: {
110
269
  method: string;
111
270
  params: Record<string, unknown>;
@@ -130,21 +289,93 @@ export declare class McpServer<TTools extends Record<string, ToolDef> = Record<n
130
289
  */
131
290
  mcpMiddleware(filter: McpMiddlewareFilter, handler: McpMiddlewareFn): this;
132
291
  private applyMcpMiddleware;
292
+ /**
293
+ * Connect to an MCP transport (override of the SDK's `connect`). Use this
294
+ * when you're embedding Skybridge in a host that already manages its own
295
+ * transport (e.g. stdio for desktop apps); for HTTP, prefer {@link McpServer.run}
296
+ * which sets the transport up for you. Locks in any middleware registered
297
+ * via {@link McpServer.mcpMiddleware} — further calls to that method will
298
+ * throw afterwards.
299
+ */
133
300
  connect(transport: Parameters<typeof McpServerBase.prototype.connect>[0]): Promise<void>;
134
- run(): Promise<void>;
135
- registerWidget<TName extends string, TInput extends ZodRawShapeCompat, TReturn extends {
136
- content: CallToolResult["content"];
137
- }>(name: TName, resourceConfig: McpServerOriginalResourceConfig, toolConfig: McpServerOriginalToolConfig & {
138
- inputSchema?: TInput;
139
- outputSchema?: ZodRawShapeCompat | AnySchema;
140
- }, toolCallback: ToolHandler<TInput, TReturn>): AddTool<TTools, TName, TInput, ExtractStructuredContent<TReturn>, ExtractMeta<TReturn>>;
141
- registerTool<TName extends string, InputArgs extends ZodRawShapeCompat, TReturn extends {
142
- content: CallToolResult["content"];
143
- }>(name: TName, config: ToolConfig<InputArgs>, cb: ToolHandler<InputArgs, TReturn>): AddTool<TTools, TName, InputArgs, ExtractStructuredContent<TReturn>, ExtractMeta<TReturn>>;
144
- registerTool<InputArgs extends ZodRawShapeCompat>(name: string, config: ToolConfig<InputArgs>, cb: ToolHandler<InputArgs>): RegisteredTool;
145
- private registerWidgetResource;
301
+ /**
302
+ * Per-request stateless connect. The SDK's `Protocol` only allows one
303
+ * transport per instance, so we can't reuse this `McpServer` across
304
+ * concurrent requests. The SDK's idiomatic fix is a `() => McpServer`
305
+ * factory, but that would break Skybridge's singleton API — so instead
306
+ * we build a fresh underlying `Server` per request and share the main
307
+ * server's handler maps by reference. The cast is unavoidable: there's
308
+ * no public API to inject handler maps. `getHandlerMaps` validates the
309
+ * read side and fails fast on SDK field renames.
310
+ */
311
+ connectStatelessTransport(transport: Parameters<typeof McpServerBase.prototype.connect>[0]): Promise<void>;
312
+ /**
313
+ * Start the HTTP server. Listens on `process.env.__PORT` (default `3000`),
314
+ * mounts the `/mcp` route, applies any custom Express middleware registered
315
+ * via {@link McpServer.use} / {@link McpServer.useOnError}, and locks in
316
+ * any MCP middleware registered via {@link McpServer.mcpMiddleware}.
317
+ *
318
+ * On Cloudflare Workers / workerd, returns an object exposing `fetch` so
319
+ * the runtime can bridge incoming requests to the Node HTTP server. On
320
+ * Vercel (`VERCEL === "1"`), returns the Express app directly so the
321
+ * serverless function entry can call it as a `(req, res)` handler. On
322
+ * Node, returns `undefined` once listening.
323
+ */
324
+ run(): Promise<{
325
+ fetch: (...args: unknown[]) => unknown;
326
+ } | Express | undefined>;
327
+ private enforceOneToolPerView;
328
+ private resolveViewRequestContext;
329
+ private registerViewResources;
330
+ private registerViewResource;
331
+ private wrapHandler;
332
+ private computeViewVersionParam;
333
+ private lookupViewFile;
146
334
  private lookupDistFile;
147
- private lookupDistFileWithIndexFallback;
335
+ /**
336
+ * Inject the Vite manifest as a value rather than letting `readManifest()`
337
+ * load it from disk. Required for runtimes without a usable filesystem
338
+ * (Cloudflare Workers, etc.) — the user's `skybridge build` emits the
339
+ * manifest as a JS module which the entry imports and passes here.
340
+ */
341
+ setViteManifest(manifest: Record<string, {
342
+ file: string;
343
+ }>): this;
148
344
  private readManifest;
345
+ /**
346
+ * Register a tool. Pass a `config` describing the tool (name, schemas,
347
+ * optional {@link ViewConfig}, optional {@link ToolMeta}) and a handler that
348
+ * returns the tool's result.
349
+ *
350
+ * Chain calls to build up a server: each call returns a new `McpServer`
351
+ * type that captures the tool's input/output/`_meta` shape so the
352
+ * resulting `typeof server` can drive {@link generateHelpers}.
353
+ *
354
+ * The handler's return shape determines the output types: the
355
+ * `structuredContent` field becomes the tool's typed output, and `_meta`
356
+ * becomes its `responseMetadata`. The `content` field is normalized through
357
+ * {@link normalizeContent}.
358
+ *
359
+ * @example
360
+ * ```ts
361
+ * server.registerTool({
362
+ * name: "search",
363
+ * inputSchema: { query: z.string() },
364
+ * outputSchema: { results: z.array(z.string()) },
365
+ * view: { component: "search" },
366
+ * }, async ({ query }) => ({
367
+ * content: `Found results for ${query}`,
368
+ * structuredContent: { results: [...] },
369
+ * }));
370
+ * ```
371
+ *
372
+ * @see https://docs.skybridge.tech/api-reference/register-tool
373
+ */
374
+ registerTool<TName extends string, InputArgs extends ZodRawShapeCompat, TReturn extends {
375
+ content?: HandlerContent;
376
+ }>(config: ToolConfig<InputArgs> & {
377
+ name: TName;
378
+ }, cb: ToolHandler<InputArgs, TReturn>): AddTool<TTools, TName, InputArgs, ExtractStructuredContent<TReturn>, ExtractMeta<TReturn>>;
379
+ registerTool<InputArgs extends ZodRawShapeCompat>(config: ToolConfig<InputArgs>, cb: ToolHandler<InputArgs>): this;
149
380
  }
150
381
  export {};