skybridge 0.0.0-dev.f091fae → 0.0.0-dev.f0c826f

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/README.md +152 -0
  2. package/dist/cli/detect-port.d.ts +18 -0
  3. package/dist/cli/detect-port.js +61 -0
  4. package/dist/cli/detect-port.js.map +1 -0
  5. package/dist/cli/header.js +1 -1
  6. package/dist/cli/header.js.map +1 -1
  7. package/dist/cli/run-command.js.map +1 -1
  8. package/dist/cli/telemetry.d.ts +7 -0
  9. package/dist/cli/telemetry.js +123 -0
  10. package/dist/cli/telemetry.js.map +1 -0
  11. package/dist/cli/tunnel-control-server.d.ts +9 -0
  12. package/dist/cli/tunnel-control-server.js +31 -0
  13. package/dist/cli/tunnel-control-server.js.map +1 -0
  14. package/dist/cli/tunnel-control-server.test.js +39 -0
  15. package/dist/cli/tunnel-control-server.test.js.map +1 -0
  16. package/dist/cli/tunnel-handler.d.ts +3 -0
  17. package/dist/cli/tunnel-handler.js +48 -0
  18. package/dist/cli/tunnel-handler.js.map +1 -0
  19. package/dist/cli/tunnel-handler.test.js +105 -0
  20. package/dist/cli/tunnel-handler.test.js.map +1 -0
  21. package/dist/cli/tunnel.d.ts +57 -0
  22. package/dist/cli/tunnel.js +154 -0
  23. package/dist/cli/tunnel.js.map +1 -0
  24. package/dist/cli/tunnel.test.d.ts +1 -0
  25. package/dist/cli/tunnel.test.js +190 -0
  26. package/dist/cli/tunnel.test.js.map +1 -0
  27. package/dist/cli/types.d.ts +5 -0
  28. package/dist/cli/types.js +2 -0
  29. package/dist/cli/types.js.map +1 -0
  30. package/dist/cli/use-execute-steps.d.ts +3 -2
  31. package/dist/cli/use-execute-steps.js +6 -1
  32. package/dist/cli/use-execute-steps.js.map +1 -1
  33. package/dist/cli/use-messages.d.ts +3 -0
  34. package/dist/cli/use-messages.js +11 -0
  35. package/dist/cli/use-messages.js.map +1 -0
  36. package/dist/cli/use-nodemon.d.ts +2 -0
  37. package/dist/cli/use-nodemon.js +73 -0
  38. package/dist/cli/use-nodemon.js.map +1 -0
  39. package/dist/cli/use-open-browser.d.ts +1 -0
  40. package/dist/cli/use-open-browser.js +44 -0
  41. package/dist/cli/use-open-browser.js.map +1 -0
  42. package/dist/cli/use-tunnel.d.ts +14 -0
  43. package/dist/cli/use-tunnel.js +131 -0
  44. package/dist/cli/use-tunnel.js.map +1 -0
  45. package/dist/cli/use-typescript-check.d.ts +9 -0
  46. package/dist/cli/use-typescript-check.js +94 -0
  47. package/dist/cli/use-typescript-check.js.map +1 -0
  48. package/dist/commands/build.js +64 -6
  49. package/dist/commands/build.js.map +1 -1
  50. package/dist/commands/create.d.ts +9 -0
  51. package/dist/commands/create.js +30 -0
  52. package/dist/commands/create.js.map +1 -0
  53. package/dist/commands/dev.d.ts +4 -1
  54. package/dist/commands/dev.js +61 -13
  55. package/dist/commands/dev.js.map +1 -1
  56. package/dist/commands/start.d.ts +3 -1
  57. package/dist/commands/start.js +31 -15
  58. package/dist/commands/start.js.map +1 -1
  59. package/dist/commands/telemetry/disable.d.ts +5 -0
  60. package/dist/commands/telemetry/disable.js +14 -0
  61. package/dist/commands/telemetry/disable.js.map +1 -0
  62. package/dist/commands/telemetry/enable.d.ts +5 -0
  63. package/dist/commands/telemetry/enable.js +14 -0
  64. package/dist/commands/telemetry/enable.js.map +1 -0
  65. package/dist/commands/telemetry/status.d.ts +5 -0
  66. package/dist/commands/telemetry/status.js +14 -0
  67. package/dist/commands/telemetry/status.js.map +1 -0
  68. package/dist/server/asset-base-url-transform-plugin.d.ts +11 -0
  69. package/dist/server/asset-base-url-transform-plugin.js +48 -0
  70. package/dist/server/asset-base-url-transform-plugin.js.map +1 -0
  71. package/dist/server/asset-base-url-transform-plugin.test.d.ts +1 -0
  72. package/dist/server/asset-base-url-transform-plugin.test.js +134 -0
  73. package/dist/server/asset-base-url-transform-plugin.test.js.map +1 -0
  74. package/dist/server/auth.d.ts +20 -0
  75. package/dist/server/auth.js +28 -0
  76. package/dist/server/auth.js.map +1 -0
  77. package/dist/server/content-helpers.d.ts +27 -0
  78. package/dist/server/content-helpers.js +46 -0
  79. package/dist/server/content-helpers.js.map +1 -0
  80. package/dist/server/content-helpers.test.d.ts +1 -0
  81. package/dist/server/content-helpers.test.js +70 -0
  82. package/dist/server/content-helpers.test.js.map +1 -0
  83. package/dist/server/express.d.ts +11 -0
  84. package/dist/server/express.js +101 -0
  85. package/dist/server/express.js.map +1 -0
  86. package/dist/server/express.test.d.ts +1 -0
  87. package/dist/server/express.test.js +430 -0
  88. package/dist/server/express.test.js.map +1 -0
  89. package/dist/server/file-ref.d.ts +8 -0
  90. package/dist/server/file-ref.js +8 -0
  91. package/dist/server/file-ref.js.map +1 -0
  92. package/dist/server/index.d.ts +7 -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 +124 -0
  101. package/dist/server/middleware.js +93 -0
  102. package/dist/server/middleware.js.map +1 -0
  103. package/dist/server/middleware.test-d.d.ts +1 -0
  104. package/dist/server/middleware.test-d.js +75 -0
  105. package/dist/server/middleware.test-d.js.map +1 -0
  106. package/dist/server/middleware.test.d.ts +1 -0
  107. package/dist/server/middleware.test.js +493 -0
  108. package/dist/server/middleware.test.js.map +1 -0
  109. package/dist/server/server.d.ts +209 -62
  110. package/dist/server/server.js +401 -64
  111. package/dist/server/server.js.map +1 -1
  112. package/dist/server/templateHelper.d.ts +5 -7
  113. package/dist/server/templateHelper.js +3 -22
  114. package/dist/server/templateHelper.js.map +1 -1
  115. package/dist/server/templates.generated.d.ts +4 -0
  116. package/dist/server/templates.generated.js +47 -0
  117. package/dist/server/templates.generated.js.map +1 -0
  118. package/dist/server/tunnel-proxy-router.d.ts +7 -0
  119. package/dist/server/tunnel-proxy-router.js +110 -0
  120. package/dist/server/tunnel-proxy-router.js.map +1 -0
  121. package/dist/server/tunnel-proxy-router.test.d.ts +1 -0
  122. package/dist/server/tunnel-proxy-router.test.js +229 -0
  123. package/dist/server/tunnel-proxy-router.test.js.map +1 -0
  124. package/dist/server/viewsDevServer.d.ts +14 -0
  125. package/dist/server/viewsDevServer.js +45 -0
  126. package/dist/server/viewsDevServer.js.map +1 -0
  127. package/dist/test/utils.d.ts +13 -21
  128. package/dist/test/utils.js +42 -37
  129. package/dist/test/utils.js.map +1 -1
  130. package/dist/test/view.test.d.ts +1 -0
  131. package/dist/test/view.test.js +523 -0
  132. package/dist/test/view.test.js.map +1 -0
  133. package/dist/version.d.ts +1 -0
  134. package/dist/version.js +3 -0
  135. package/dist/version.js.map +1 -0
  136. package/dist/web/bridges/apps-sdk/adaptor.d.ts +12 -7
  137. package/dist/web/bridges/apps-sdk/adaptor.js +71 -11
  138. package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -1
  139. package/dist/web/bridges/apps-sdk/bridge.d.ts +1 -1
  140. package/dist/web/bridges/apps-sdk/bridge.js.map +1 -1
  141. package/dist/web/bridges/apps-sdk/index.d.ts +1 -1
  142. package/dist/web/bridges/apps-sdk/index.js.map +1 -1
  143. package/dist/web/bridges/apps-sdk/types.d.ts +39 -14
  144. package/dist/web/bridges/apps-sdk/types.js.map +1 -1
  145. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js.map +1 -1
  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 +24 -9
  149. package/dist/web/bridges/mcp-app/adaptor.js +153 -64
  150. package/dist/web/bridges/mcp-app/adaptor.js.map +1 -1
  151. package/dist/web/bridges/mcp-app/bridge.d.ts +13 -30
  152. package/dist/web/bridges/mcp-app/bridge.js +43 -196
  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 +5 -3
  157. package/dist/web/bridges/mcp-app/use-mcp-app-context.js +2 -2
  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 +1 -41
  160. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js.map +1 -1
  161. package/dist/web/bridges/types.d.ts +34 -13
  162. package/dist/web/bridges/types.js.map +1 -1
  163. package/dist/web/bridges/use-host-context.js.map +1 -1
  164. package/dist/web/components/modal-provider.js +3 -5
  165. package/dist/web/components/modal-provider.js.map +1 -1
  166. package/dist/web/create-store.js +17 -3
  167. package/dist/web/create-store.js.map +1 -1
  168. package/dist/web/create-store.test.js +23 -20
  169. package/dist/web/create-store.test.js.map +1 -1
  170. package/dist/web/data-llm.d.ts +1 -1
  171. package/dist/web/data-llm.js +3 -3
  172. package/dist/web/data-llm.js.map +1 -1
  173. package/dist/web/data-llm.test.js +33 -30
  174. package/dist/web/data-llm.test.js.map +1 -1
  175. package/dist/web/generate-helpers.d.ts +20 -18
  176. package/dist/web/generate-helpers.js +20 -18
  177. package/dist/web/generate-helpers.js.map +1 -1
  178. package/dist/web/generate-helpers.test-d.js +26 -26
  179. package/dist/web/generate-helpers.test-d.js.map +1 -1
  180. package/dist/web/generate-helpers.test.js.map +1 -1
  181. package/dist/web/helpers/state.d.ts +2 -2
  182. package/dist/web/helpers/state.js +11 -11
  183. package/dist/web/helpers/state.js.map +1 -1
  184. package/dist/web/helpers/state.test.js +9 -9
  185. package/dist/web/helpers/state.test.js.map +1 -1
  186. package/dist/web/hooks/index.d.ts +5 -2
  187. package/dist/web/hooks/index.js +4 -1
  188. package/dist/web/hooks/index.js.map +1 -1
  189. package/dist/web/hooks/test/utils.js +4 -0
  190. package/dist/web/hooks/test/utils.js.map +1 -1
  191. package/dist/web/hooks/use-call-tool.js.map +1 -1
  192. package/dist/web/hooks/use-call-tool.test-d.js.map +1 -1
  193. package/dist/web/hooks/use-call-tool.test.js +27 -6
  194. package/dist/web/hooks/use-call-tool.test.js.map +1 -1
  195. package/dist/web/hooks/use-display-mode.d.ts +3 -3
  196. package/dist/web/hooks/use-display-mode.js.map +1 -1
  197. package/dist/web/hooks/use-display-mode.test-d.d.ts +1 -0
  198. package/dist/web/hooks/use-display-mode.test-d.js +8 -0
  199. package/dist/web/hooks/use-display-mode.test-d.js.map +1 -0
  200. package/dist/web/hooks/use-display-mode.test.js.map +1 -1
  201. package/dist/web/hooks/use-files.d.ts +2 -1
  202. package/dist/web/hooks/use-files.js +1 -0
  203. package/dist/web/hooks/use-files.js.map +1 -1
  204. package/dist/web/hooks/use-files.test.js +27 -3
  205. package/dist/web/hooks/use-files.test.js.map +1 -1
  206. package/dist/web/hooks/use-layout.js.map +1 -1
  207. package/dist/web/hooks/use-layout.test.js +3 -3
  208. package/dist/web/hooks/use-layout.test.js.map +1 -1
  209. package/dist/web/hooks/use-open-external.d.ts +3 -1
  210. package/dist/web/hooks/use-open-external.js +1 -1
  211. package/dist/web/hooks/use-open-external.js.map +1 -1
  212. package/dist/web/hooks/use-open-external.test.js +26 -11
  213. package/dist/web/hooks/use-open-external.test.js.map +1 -1
  214. package/dist/web/hooks/use-request-close.d.ts +2 -0
  215. package/dist/web/hooks/use-request-close.js +8 -0
  216. package/dist/web/hooks/use-request-close.js.map +1 -0
  217. package/dist/web/hooks/use-request-close.test.d.ts +1 -0
  218. package/dist/web/hooks/use-request-close.test.js +52 -0
  219. package/dist/web/hooks/use-request-close.test.js.map +1 -0
  220. package/dist/web/hooks/use-request-modal.d.ts +1 -1
  221. package/dist/web/hooks/use-request-modal.js +4 -4
  222. package/dist/web/hooks/use-request-modal.js.map +1 -1
  223. package/dist/web/hooks/use-request-modal.test.js +5 -1
  224. package/dist/web/hooks/use-request-modal.test.js.map +1 -1
  225. package/dist/web/hooks/use-request-size.d.ts +3 -0
  226. package/dist/web/hooks/use-request-size.js +8 -0
  227. package/dist/web/hooks/use-request-size.js.map +1 -0
  228. package/dist/web/hooks/use-request-size.test.d.ts +1 -0
  229. package/dist/web/hooks/use-request-size.test.js +65 -0
  230. package/dist/web/hooks/use-request-size.test.js.map +1 -0
  231. package/dist/web/hooks/use-send-follow-up-message.d.ts +2 -1
  232. package/dist/web/hooks/use-send-follow-up-message.js +2 -2
  233. package/dist/web/hooks/use-send-follow-up-message.js.map +1 -1
  234. package/dist/web/hooks/use-set-open-in-app-url.d.ts +1 -0
  235. package/dist/web/hooks/use-set-open-in-app-url.js +8 -0
  236. package/dist/web/hooks/use-set-open-in-app-url.js.map +1 -0
  237. package/dist/web/hooks/use-set-open-in-app-url.test.d.ts +1 -0
  238. package/dist/web/hooks/use-set-open-in-app-url.test.js +43 -0
  239. package/dist/web/hooks/use-set-open-in-app-url.test.js.map +1 -0
  240. package/dist/web/hooks/use-tool-info.js.map +1 -1
  241. package/dist/web/hooks/use-tool-info.test-d.js.map +1 -1
  242. package/dist/web/hooks/use-tool-info.test.js +1 -1
  243. package/dist/web/hooks/use-tool-info.test.js.map +1 -1
  244. package/dist/web/hooks/use-user.js +18 -2
  245. package/dist/web/hooks/use-user.js.map +1 -1
  246. package/dist/web/hooks/use-user.test.js +29 -1
  247. package/dist/web/hooks/use-user.test.js.map +1 -1
  248. package/dist/web/hooks/use-view-state.d.ts +4 -0
  249. package/dist/web/hooks/use-view-state.js +32 -0
  250. package/dist/web/hooks/use-view-state.js.map +1 -0
  251. package/dist/web/hooks/use-view-state.test.d.ts +1 -0
  252. package/dist/web/hooks/use-view-state.test.js +177 -0
  253. package/dist/web/hooks/use-view-state.test.js.map +1 -0
  254. package/dist/web/index.d.ts +1 -2
  255. package/dist/web/index.js +1 -2
  256. package/dist/web/index.js.map +1 -1
  257. package/dist/web/mount-view.d.ts +1 -0
  258. package/dist/web/{mount-widget.js → mount-view.js} +2 -2
  259. package/dist/web/mount-view.js.map +1 -0
  260. package/dist/web/plugin/data-llm.test.js.map +1 -1
  261. package/dist/web/plugin/plugin.d.ts +4 -1
  262. package/dist/web/plugin/plugin.js +142 -18
  263. package/dist/web/plugin/plugin.js.map +1 -1
  264. package/dist/web/plugin/scan-views.d.ts +16 -0
  265. package/dist/web/plugin/scan-views.js +88 -0
  266. package/dist/web/plugin/scan-views.js.map +1 -0
  267. package/dist/web/plugin/scan-views.test.d.ts +1 -0
  268. package/dist/web/plugin/scan-views.test.js +99 -0
  269. package/dist/web/plugin/scan-views.test.js.map +1 -0
  270. package/dist/web/plugin/transform-data-llm.js +1 -1
  271. package/dist/web/plugin/transform-data-llm.js.map +1 -1
  272. package/dist/web/plugin/transform-data-llm.test.js.map +1 -1
  273. package/dist/web/plugin/validate-view.d.ts +1 -0
  274. package/dist/web/plugin/validate-view.js +9 -0
  275. package/dist/web/plugin/validate-view.js.map +1 -0
  276. package/dist/web/plugin/validate-view.test.d.ts +1 -0
  277. package/dist/web/plugin/validate-view.test.js +24 -0
  278. package/dist/web/plugin/validate-view.test.js.map +1 -0
  279. package/dist/web/proxy.js +0 -1
  280. package/dist/web/proxy.js.map +1 -1
  281. package/dist/web/types.js.map +1 -1
  282. package/package.json +53 -29
  283. package/tsconfig.base.json +33 -0
  284. package/dist/server/templates/development.hbs +0 -66
  285. package/dist/server/templates/production.hbs +0 -7
  286. package/dist/server/widgetsDevServer.d.ts +0 -12
  287. package/dist/server/widgetsDevServer.js +0 -47
  288. package/dist/server/widgetsDevServer.js.map +0 -1
  289. package/dist/test/widget.test.js +0 -255
  290. package/dist/test/widget.test.js.map +0 -1
  291. package/dist/web/hooks/use-widget-state.d.ts +0 -4
  292. package/dist/web/hooks/use-widget-state.js +0 -32
  293. package/dist/web/hooks/use-widget-state.js.map +0 -1
  294. package/dist/web/hooks/use-widget-state.test.js +0 -61
  295. package/dist/web/hooks/use-widget-state.test.js.map +0 -1
  296. package/dist/web/mount-widget.d.ts +0 -1
  297. package/dist/web/mount-widget.js.map +0 -1
  298. /package/dist/{test/widget.test.d.ts → cli/tunnel-control-server.test.d.ts} +0 -0
  299. /package/dist/{web/hooks/use-widget-state.test.d.ts → cli/tunnel-handler.test.d.ts} +0 -0
@@ -1,43 +1,78 @@
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, ToolAnnotations } from "@modelcontextprotocol/sdk/types.js";
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";
8
+ import type { McpExtra, McpExtraFor, McpMethodString, McpMiddlewareFilter, McpMiddlewareFn, McpResultFor, McpTypedMiddlewareFn, McpWildcard } from "./middleware.js";
6
9
  export type ToolDef<TInput = unknown, TOutput = unknown, TResponseMetadata = unknown> = {
7
10
  input: TInput;
8
11
  output: TOutput;
9
12
  responseMetadata: TResponseMetadata;
10
13
  };
11
- /**
12
- * Extended MCP Apps CSP with upcoming fields from ext-apps PR #158
13
- * and Skybridge-specific fields for OpenAI compatibility
14
- * @see https://github.com/modelcontextprotocol/ext-apps/pull/158
15
- */
16
- type ExtendedMcpUiResourceCsp = McpUiResourceMeta["csp"] & {
17
- /**
18
- * Origins that can receive openExternal redirects without safe-link modal (OpenAI-specific)
19
- * @see https://developers.openai.com/apps-sdk/reference#component-resource-_meta-fields
20
- */
14
+ export type ViewHostType = "apps-sdk" | "mcp-app";
15
+ export interface ViewCsp {
16
+ /** Origins for static assets (images, fonts, scripts, styles). */
17
+ resourceDomains?: string[];
18
+ /** Origins the view may contact via fetch/XHR. */
19
+ connectDomains?: string[];
20
+ /** Origins allowed for iframe embeds (opts into stricter app review). */
21
+ frameDomains?: string[];
22
+ /** Origins that can receive openExternal redirects without the safe-link modal. */
21
23
  redirectDomains?: string[];
24
+ /** Origins allowed in `<base href>` tags (mcp-apps only). */
25
+ baseUriDomains?: string[];
26
+ }
27
+ export interface ViewNameRegistry {
28
+ }
29
+ export type ViewName = keyof ViewNameRegistry & string;
30
+ export interface ViewConfig {
31
+ component: ViewName;
32
+ description?: string;
33
+ hosts?: ViewHostType[];
34
+ prefersBorder?: boolean;
35
+ domain?: string;
36
+ csp?: ViewCsp;
37
+ _meta?: Record<string, unknown>;
38
+ }
39
+ export type SecurityScheme = {
40
+ type: "noauth";
41
+ } | {
42
+ type: "oauth2";
43
+ scopes?: string[];
22
44
  };
23
- /** Extended MCP Apps resource metadata with upcoming CSP fields */
24
- type ExtendedMcpUiResourceMeta = Omit<McpUiResourceMeta, "csp"> & {
25
- csp?: ExtendedMcpUiResourceCsp;
26
- };
27
- /** User-provided resource configuration with optional CSP override */
28
- export type WidgetResourceMeta = {
29
- ui?: ExtendedMcpUiResourceMeta;
30
- } & Resource["_meta"];
31
- export type WidgetHostType = "apps-sdk" | "mcp-app";
32
- type McpServerOriginalResourceConfig = Omit<Resource, "uri" | "name" | "mimeType" | "_meta"> & {
33
- _meta?: WidgetResourceMeta;
34
- /** Restrict host types to a specific subset */
35
- hosts?: WidgetHostType[];
36
- };
37
- type McpServerOriginalToolConfig = Omit<Parameters<typeof McpServerBase.prototype.registerTool<ZodRawShapeCompat, ZodRawShapeCompat>>[1], "inputSchema" | "outputSchema">;
45
+ export interface KnownToolMeta {
46
+ "openai/widgetAccessible"?: boolean;
47
+ "openai/toolInvocation/invoking"?: string;
48
+ "openai/toolInvocation/invoked"?: string;
49
+ "openai/fileParams"?: string[];
50
+ ui?: Pick<McpUiToolMeta, "visibility">;
51
+ securitySchemes?: SecurityScheme[];
52
+ }
53
+ export type ToolMeta = KnownToolMeta & Record<string, unknown>;
54
+ export type HandlerContent = string | ContentBlock | ContentBlock[];
55
+ /**
56
+ * Type-level marker interface for cross-package type inference.
57
+ *
58
+ * Consumers infer tool types via the structural `$types` property rather than
59
+ * the `McpServer` class generic, because class-generic inference breaks when
60
+ * `McpServer` comes from different package installations (e.g. a consumer
61
+ * with its own `skybridge` dep vs. the in-tree workspace version).
62
+ *
63
+ * Inspired by tRPC's `_def` pattern and Hono's type markers.
64
+ */
65
+ export interface McpServerTypes<TTools extends Record<string, ToolDef>> {
66
+ readonly tools: TTools;
67
+ }
38
68
  type Simplify<T> = {
39
69
  [K in keyof T]: T[K];
40
70
  };
71
+ type ShapeOutput<Shape extends ZodRawShapeCompat> = Simplify<{
72
+ [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? never : K]: SchemaOutput<Shape[K]>;
73
+ } & {
74
+ [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? K : never]?: SchemaOutput<Shape[K]>;
75
+ }>;
41
76
  type ExtractStructuredContent<T> = T extends {
42
77
  structuredContent: infer SC;
43
78
  } ? Simplify<SC> : never;
@@ -48,52 +83,164 @@ type ExtractMeta<T> = [Extract<T, {
48
83
  }> extends {
49
84
  _meta: infer M;
50
85
  } ? Simplify<M> : unknown;
51
- /**
52
- * Type-level marker interface for cross-package type inference.
53
- * This enables TypeScript to infer tool types across package boundaries
54
- * using structural typing on the $types property, rather than relying on
55
- * class generic inference which fails when McpServer comes from different
56
- * package installations.
57
- *
58
- * Inspired by tRPC's _def pattern and Hono's type markers.
59
- */
60
- export interface McpServerTypes<TTools extends Record<string, ToolDef>> {
61
- readonly tools: TTools;
62
- }
63
- type ShapeOutput<Shape extends ZodRawShapeCompat> = Simplify<{
64
- [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? never : K]: SchemaOutput<Shape[K]>;
65
- } & {
66
- [K in keyof Shape as undefined extends SchemaOutput<Shape[K]> ? K : never]?: SchemaOutput<Shape[K]>;
67
- }>;
68
86
  type AddTool<TTools, TName extends string, TInput extends ZodRawShapeCompat, TOutput, TResponseMetadata = unknown> = McpServer<TTools & {
69
87
  [K in TName]: ToolDef<ShapeOutput<TInput>, TOutput, TResponseMetadata>;
70
88
  }>;
71
- type ToolConfig<TInput extends ZodRawShapeCompat | AnySchema> = {
89
+ interface ToolConfig<TInput extends ZodRawShapeCompat | AnySchema> {
90
+ name: string;
72
91
  title?: string;
73
92
  description?: string;
74
93
  inputSchema?: TInput;
75
94
  outputSchema?: ZodRawShapeCompat | AnySchema;
76
95
  annotations?: ToolAnnotations;
77
- _meta?: Record<string, unknown>;
96
+ view?: ViewConfig;
97
+ /**
98
+ * Declares which auth schemes this tool supports (e.g. `noauth`, `oauth2`).
99
+ * Lets clients label tools that require sign-in before calling, and pass
100
+ * the right scopes through the OAuth flow. Listing both `noauth` and
101
+ * `oauth2` signals that the tool works for anonymous callers and gives
102
+ * enhanced behavior to authenticated ones.
103
+ */
104
+ securitySchemes?: SecurityScheme[];
105
+ _meta?: ToolMeta;
106
+ }
107
+ /**
108
+ * Optional client-supplied hints attached to `params._meta` on every tool call
109
+ * by the Apps SDK host. Hints only: never use for authorization, and tolerate
110
+ * absence.
111
+ * @see https://developers.openai.com/apps-sdk/reference#_meta-fields-the-client-provides
112
+ */
113
+ export interface ClientHintsMeta {
114
+ /** Requested locale (BCP-47, e.g. `"en-US"`). */
115
+ "openai/locale"?: string;
116
+ /** Browser user-agent */
117
+ "openai/userAgent"?: string;
118
+ /** Coarse user location. May be partially populated. */
119
+ "openai/userLocation"?: {
120
+ city?: string;
121
+ region?: string;
122
+ country?: string;
123
+ timezone?: string;
124
+ longitude?: number;
125
+ latitude?: number;
126
+ };
127
+ /** Anonymized user id. */
128
+ "openai/subject"?: string;
129
+ /** Anonymized conversation id, stable within a ChatGPT session. */
130
+ "openai/session"?: string;
131
+ /** Anonymized organization id, when the user account is part of an organization. */
132
+ "openai/organization"?: string;
133
+ /** Stable id for the currently mounted widget instance. */
134
+ "openai/widgetSessionId"?: string;
135
+ }
136
+ type ToolHandlerExtra = Omit<RequestHandlerExtra<ServerRequest, ServerNotification>, "_meta"> & {
137
+ _meta?: RequestMeta & ClientHintsMeta;
78
138
  };
79
139
  type ToolHandler<TInput extends ZodRawShapeCompat, TReturn extends {
80
- content: CallToolResult["content"];
81
- } = CallToolResult> = (args: ShapeOutput<TInput>, extra: RequestHandlerExtra<ServerRequest, ServerNotification>) => TReturn | Promise<TReturn>;
82
- export declare class McpServer<TTools extends Record<string, ToolDef> = Record<never, ToolDef>> extends McpServerBase {
140
+ content?: HandlerContent;
141
+ } = {
142
+ content?: HandlerContent;
143
+ }> = (args: ShapeOutput<TInput>, extra: ToolHandlerExtra) => TReturn | Promise<TReturn>;
144
+ export declare function normalizeContent(content: HandlerContent | undefined): ContentBlock[];
145
+ interface McpServerBaseOmitted extends Omit<McpServerBase, "registerTool" | "connect"> {
146
+ }
147
+ declare const McpServerBaseOmitted: new (...args: ConstructorParameters<typeof McpServerBase>) => McpServerBaseOmitted;
148
+ export declare class McpServer<TTools extends Record<string, ToolDef> = Record<never, ToolDef>> extends McpServerBaseOmitted {
83
149
  readonly $types: McpServerTypes<TTools>;
84
- registerWidget<TName extends string, TInput extends ZodRawShapeCompat, TReturn extends {
85
- content: CallToolResult["content"];
86
- }>(name: TName, resourceConfig: McpServerOriginalResourceConfig, toolConfig: McpServerOriginalToolConfig & {
87
- inputSchema?: TInput;
88
- outputSchema?: ZodRawShapeCompat | AnySchema;
89
- }, toolCallback: ToolHandler<TInput, TReturn>): AddTool<TTools, TName, TInput, ExtractStructuredContent<TReturn>, ExtractMeta<TReturn>>;
90
- registerTool<TName extends string, InputArgs extends ZodRawShapeCompat, TReturn extends {
91
- content: CallToolResult["content"];
92
- }>(name: TName, config: ToolConfig<InputArgs>, cb: ToolHandler<InputArgs, TReturn>): AddTool<TTools, TName, InputArgs, ExtractStructuredContent<TReturn>, ExtractMeta<TReturn>>;
93
- registerTool<InputArgs extends ZodRawShapeCompat>(name: string, config: ToolConfig<InputArgs>, cb: ToolHandler<InputArgs>): RegisteredTool;
94
- private registerWidgetResource;
150
+ /**
151
+ * The underlying Express app. Use this to extend the HTTP server with
152
+ * custom routes, middleware, or settings e.g.
153
+ * `server.express.get("/health", ...)`.
154
+ *
155
+ * `express.json()` is pre-applied. Register your handlers before `run()`;
156
+ * after `run()`, dev-mode middleware, the `/mcp` route, and the default
157
+ * error handler are appended in that order.
158
+ *
159
+ * Note: Alpic Cloud only routes traffic to `/mcp` — custom routes work
160
+ * locally and on self-hosted deployments.
161
+ */
162
+ readonly express: Express;
163
+ private customErrorMiddleware;
164
+ private mcpMiddlewareEntries;
165
+ private mcpMiddlewareApplied;
166
+ private claimedViews;
167
+ private viteManifest;
168
+ private readonly serverInfo;
169
+ private readonly serverOptions?;
170
+ constructor(serverInfo: Implementation, options?: ServerOptions);
171
+ use(...handlers: RequestHandler[]): this;
172
+ use(path: string, ...handlers: RequestHandler[]): this;
173
+ useOnError(...handlers: ErrorRequestHandler[]): this;
174
+ useOnError(path: string, ...handlers: ErrorRequestHandler[]): this;
175
+ /** Register MCP protocol-level middleware (catch-all). */
176
+ mcpMiddleware(handler: McpMiddlewareFn): this;
177
+ /** Register MCP protocol-level middleware for all requests (`extra` is `McpExtra`). */
178
+ mcpMiddleware(filter: "request", handler: (request: {
179
+ method: string;
180
+ params: Record<string, unknown>;
181
+ }, extra: McpExtra, next: () => Promise<ServerResult>) => Promise<unknown> | unknown): this;
182
+ /** Register MCP protocol-level middleware for all notifications (`extra` is `undefined`). */
183
+ mcpMiddleware(filter: "notification", handler: (request: {
184
+ method: string;
185
+ params: Record<string, unknown>;
186
+ }, extra: undefined, next: () => Promise<undefined>) => Promise<unknown> | unknown): this;
187
+ /**
188
+ * Register MCP protocol-level middleware for an exact method.
189
+ * Narrows `params`, `extra`, and `next()` result based on the method string.
190
+ */
191
+ mcpMiddleware<M extends McpMethodString>(filter: M, handler: McpTypedMiddlewareFn<M>): this;
192
+ /**
193
+ * Register MCP protocol-level middleware for a wildcard pattern (e.g. `"tools/*"`).
194
+ * `next()` returns the union of result types for matching methods.
195
+ */
196
+ mcpMiddleware<W extends McpWildcard>(filter: W, handler: (request: {
197
+ method: string;
198
+ params: Record<string, unknown>;
199
+ }, extra: McpExtraFor<W>, next: () => Promise<McpResultFor<W>>) => Promise<unknown> | unknown): this;
200
+ /**
201
+ * Register MCP protocol-level middleware with a method filter.
202
+ * Filter can be an exact method (`"tools/call"`), wildcard (`"tools/*"`),
203
+ * category (`"request"` | `"notification"`), or an array of those.
204
+ */
205
+ mcpMiddleware(filter: McpMiddlewareFilter, handler: McpMiddlewareFn): this;
206
+ private applyMcpMiddleware;
207
+ connect(transport: Parameters<typeof McpServerBase.prototype.connect>[0]): Promise<void>;
208
+ /**
209
+ * Per-request stateless connect. The SDK's `Protocol` only allows one
210
+ * transport per instance, so we can't reuse this `McpServer` across
211
+ * concurrent requests. The SDK's idiomatic fix is a `() => McpServer`
212
+ * factory, but that would break Skybridge's singleton API — so instead
213
+ * we build a fresh underlying `Server` per request and share the main
214
+ * server's handler maps by reference. The cast is unavoidable: there's
215
+ * no public API to inject handler maps. `getHandlerMaps` validates the
216
+ * read side and fails fast on SDK field renames.
217
+ */
218
+ connectStatelessTransport(transport: Parameters<typeof McpServerBase.prototype.connect>[0]): Promise<void>;
219
+ run(): Promise<{
220
+ fetch: (...args: unknown[]) => unknown;
221
+ } | undefined>;
222
+ private enforceOneToolPerView;
223
+ private registerViewResources;
224
+ private registerViewResource;
225
+ private wrapHandler;
226
+ private computeViewVersionParam;
227
+ private lookupViewFile;
95
228
  private lookupDistFile;
96
- private lookupDistFileWithIndexFallback;
229
+ /**
230
+ * Inject the Vite manifest as a value rather than letting `readManifest()`
231
+ * load it from disk. Required for runtimes without a usable filesystem
232
+ * (Cloudflare Workers, etc.) — the user's `skybridge build` emits the
233
+ * manifest as a JS module which the entry imports and passes here.
234
+ */
235
+ setViteManifest(manifest: Record<string, {
236
+ file: string;
237
+ }>): this;
97
238
  private readManifest;
239
+ registerTool<TName extends string, InputArgs extends ZodRawShapeCompat, TReturn extends {
240
+ content?: HandlerContent;
241
+ }>(config: ToolConfig<InputArgs> & {
242
+ name: TName;
243
+ }, cb: ToolHandler<InputArgs, TReturn>): AddTool<TTools, TName, InputArgs, ExtractStructuredContent<TReturn>, ExtractMeta<TReturn>>;
244
+ registerTool<InputArgs extends ZodRawShapeCompat>(config: ToolConfig<InputArgs>, cb: ToolHandler<InputArgs>): this;
98
245
  }
99
246
  export {};