skybridge 0.0.0-dev.f762713 → 0.0.0-dev.f784c00

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 (473) hide show
  1. package/README.md +152 -0
  2. package/bin/run.js +5 -0
  3. package/dist/cli/detect-port.d.ts +18 -0
  4. package/dist/cli/detect-port.js +61 -0
  5. package/dist/cli/detect-port.js.map +1 -0
  6. package/dist/cli/header.d.ts +4 -0
  7. package/dist/cli/header.js +6 -0
  8. package/dist/cli/header.js.map +1 -0
  9. package/dist/cli/run-command.d.ts +2 -0
  10. package/dist/cli/run-command.js +43 -0
  11. package/dist/cli/run-command.js.map +1 -0
  12. package/dist/cli/telemetry.d.ts +7 -0
  13. package/dist/cli/telemetry.js +123 -0
  14. package/dist/cli/telemetry.js.map +1 -0
  15. package/dist/cli/tunnel-control-server.d.ts +9 -0
  16. package/dist/cli/tunnel-control-server.js +31 -0
  17. package/dist/cli/tunnel-control-server.js.map +1 -0
  18. package/dist/cli/tunnel-control-server.test.js +39 -0
  19. package/dist/cli/tunnel-control-server.test.js.map +1 -0
  20. package/dist/cli/tunnel-handler.d.ts +3 -0
  21. package/dist/cli/tunnel-handler.js +48 -0
  22. package/dist/cli/tunnel-handler.js.map +1 -0
  23. package/dist/cli/tunnel-handler.test.js +105 -0
  24. package/dist/cli/tunnel-handler.test.js.map +1 -0
  25. package/dist/cli/tunnel.d.ts +57 -0
  26. package/dist/cli/tunnel.js +154 -0
  27. package/dist/cli/tunnel.js.map +1 -0
  28. package/dist/cli/tunnel.test.js +190 -0
  29. package/dist/cli/tunnel.test.js.map +1 -0
  30. package/dist/cli/types.d.ts +5 -0
  31. package/dist/cli/types.js.map +1 -0
  32. package/dist/cli/use-execute-steps.d.ts +11 -0
  33. package/dist/cli/use-execute-steps.js +36 -0
  34. package/dist/cli/use-execute-steps.js.map +1 -0
  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 -0
  39. package/dist/cli/use-nodemon.js +73 -0
  40. package/dist/cli/use-nodemon.js.map +1 -0
  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-tunnel.d.ts +14 -0
  45. package/dist/cli/use-tunnel.js +131 -0
  46. package/dist/cli/use-tunnel.js.map +1 -0
  47. package/dist/cli/use-typescript-check.d.ts +9 -0
  48. package/dist/cli/use-typescript-check.js +94 -0
  49. package/dist/cli/use-typescript-check.js.map +1 -0
  50. package/dist/commands/build.d.ts +9 -0
  51. package/dist/commands/build.js +102 -0
  52. package/dist/commands/build.js.map +1 -0
  53. package/dist/commands/create.d.ts +9 -0
  54. package/dist/commands/create.js +30 -0
  55. package/dist/commands/create.js.map +1 -0
  56. package/dist/commands/dev.d.ts +12 -0
  57. package/dist/commands/dev.js +80 -0
  58. package/dist/commands/dev.js.map +1 -0
  59. package/dist/commands/start.d.ts +9 -0
  60. package/dist/commands/start.js +49 -0
  61. package/dist/commands/start.js.map +1 -0
  62. package/dist/commands/telemetry/disable.d.ts +5 -0
  63. package/dist/commands/telemetry/disable.js +14 -0
  64. package/dist/commands/telemetry/disable.js.map +1 -0
  65. package/dist/commands/telemetry/enable.d.ts +5 -0
  66. package/dist/commands/telemetry/enable.js +14 -0
  67. package/dist/commands/telemetry/enable.js.map +1 -0
  68. package/dist/commands/telemetry/status.d.ts +5 -0
  69. package/dist/commands/telemetry/status.js +14 -0
  70. package/dist/commands/telemetry/status.js.map +1 -0
  71. package/dist/server/asset-base-url-transform-plugin.d.ts +11 -0
  72. package/dist/server/asset-base-url-transform-plugin.js +48 -0
  73. package/dist/server/asset-base-url-transform-plugin.js.map +1 -0
  74. package/dist/server/asset-base-url-transform-plugin.test.js +134 -0
  75. package/dist/server/asset-base-url-transform-plugin.test.js.map +1 -0
  76. package/dist/server/auth.d.ts +20 -0
  77. package/dist/server/auth.js +28 -0
  78. package/dist/server/auth.js.map +1 -0
  79. package/dist/server/content-helpers.d.ts +27 -0
  80. package/dist/server/content-helpers.js +46 -0
  81. package/dist/server/content-helpers.js.map +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 +11 -0
  85. package/dist/server/express.js +101 -0
  86. package/dist/server/express.js.map +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 +8 -0
  93. package/dist/server/index.js +6 -0
  94. package/dist/server/index.js.map +1 -0
  95. package/dist/{src/server → server}/inferUtilityTypes.d.ts +6 -6
  96. package/dist/server/inferUtilityTypes.js.map +1 -0
  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.js +75 -0
  104. package/dist/server/middleware.test-d.js.map +1 -0
  105. package/dist/server/middleware.test.js +493 -0
  106. package/dist/server/middleware.test.js.map +1 -0
  107. package/dist/server/server.d.ts +248 -0
  108. package/dist/server/server.js +508 -0
  109. package/dist/server/server.js.map +1 -0
  110. package/dist/{src/server → server}/templateHelper.d.ts +5 -7
  111. package/dist/server/templateHelper.js +11 -0
  112. package/dist/server/templateHelper.js.map +1 -0
  113. package/dist/server/templates.generated.d.ts +4 -0
  114. package/dist/server/templates.generated.js +47 -0
  115. package/dist/server/templates.generated.js.map +1 -0
  116. package/dist/server/tunnel-proxy-router.d.ts +7 -0
  117. package/dist/server/tunnel-proxy-router.js +110 -0
  118. package/dist/server/tunnel-proxy-router.js.map +1 -0
  119. package/dist/server/tunnel-proxy-router.test.js +229 -0
  120. package/dist/server/tunnel-proxy-router.test.js.map +1 -0
  121. package/dist/server/viewsDevServer.d.ts +14 -0
  122. package/dist/server/viewsDevServer.js +45 -0
  123. package/dist/server/viewsDevServer.js.map +1 -0
  124. package/dist/{src/test → test}/utils.d.ts +13 -21
  125. package/dist/{src/test → test}/utils.js +42 -37
  126. package/dist/test/utils.js.map +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 +27 -0
  133. package/dist/web/bridges/apps-sdk/adaptor.js +112 -0
  134. package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -0
  135. package/dist/web/bridges/apps-sdk/bridge.d.ts +10 -0
  136. package/dist/{src/web/bridges/apps-sdk-bridge.js → web/bridges/apps-sdk/bridge.js} +2 -2
  137. package/dist/web/bridges/apps-sdk/bridge.js.map +1 -0
  138. package/dist/web/bridges/apps-sdk/index.d.ts +5 -0
  139. package/dist/web/bridges/apps-sdk/index.js +5 -0
  140. package/dist/web/bridges/apps-sdk/index.js.map +1 -0
  141. package/dist/web/bridges/apps-sdk/types.d.ts +133 -0
  142. package/dist/{src/web → web/bridges/apps-sdk}/types.js +0 -1
  143. package/dist/web/bridges/apps-sdk/types.js.map +1 -0
  144. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.d.ts +2 -0
  145. package/dist/{src/web/bridges/hooks/use-apps-sdk-bridge.js → web/bridges/apps-sdk/use-apps-sdk-context.js} +3 -3
  146. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js.map +1 -0
  147. package/dist/web/bridges/get-adaptor.d.ts +2 -0
  148. package/dist/web/bridges/get-adaptor.js +8 -0
  149. package/dist/web/bridges/get-adaptor.js.map +1 -0
  150. package/dist/web/bridges/index.d.ts +5 -0
  151. package/dist/web/bridges/index.js +6 -0
  152. package/dist/web/bridges/index.js.map +1 -0
  153. package/dist/web/bridges/mcp-app/adaptor.d.ts +51 -0
  154. package/dist/web/bridges/mcp-app/adaptor.js +279 -0
  155. package/dist/web/bridges/mcp-app/adaptor.js.map +1 -0
  156. package/dist/web/bridges/mcp-app/bridge.d.ts +26 -0
  157. package/dist/web/bridges/mcp-app/bridge.js +102 -0
  158. package/dist/web/bridges/mcp-app/bridge.js.map +1 -0
  159. package/dist/web/bridges/mcp-app/index.d.ts +4 -0
  160. package/dist/web/bridges/mcp-app/index.js +4 -0
  161. package/dist/web/bridges/mcp-app/index.js.map +1 -0
  162. package/dist/web/bridges/mcp-app/types.d.ts +8 -0
  163. package/dist/web/bridges/mcp-app/types.js +2 -0
  164. package/dist/web/bridges/mcp-app/types.js.map +1 -0
  165. package/dist/web/bridges/mcp-app/use-mcp-app-context.d.ts +7 -0
  166. package/dist/web/bridges/mcp-app/use-mcp-app-context.js +7 -0
  167. package/dist/web/bridges/mcp-app/use-mcp-app-context.js.map +1 -0
  168. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js +26 -0
  169. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js.map +1 -0
  170. package/dist/web/bridges/types.d.ts +124 -0
  171. package/dist/web/bridges/types.js +2 -0
  172. package/dist/web/bridges/types.js.map +1 -0
  173. package/dist/web/bridges/use-host-context.d.ts +2 -0
  174. package/dist/web/bridges/use-host-context.js +8 -0
  175. package/dist/web/bridges/use-host-context.js.map +1 -0
  176. package/dist/web/components/modal-provider.d.ts +4 -0
  177. package/dist/web/components/modal-provider.js +45 -0
  178. package/dist/web/components/modal-provider.js.map +1 -0
  179. package/dist/web/create-store.js +38 -0
  180. package/dist/web/create-store.js.map +1 -0
  181. package/dist/web/create-store.test.js +129 -0
  182. package/dist/web/create-store.test.js.map +1 -0
  183. package/dist/{src/web → web}/data-llm.d.ts +1 -1
  184. package/dist/{src/web → web}/data-llm.js +7 -5
  185. package/dist/web/data-llm.js.map +1 -0
  186. package/dist/web/data-llm.test.js +142 -0
  187. package/dist/web/data-llm.test.js.map +1 -0
  188. package/dist/{src/web → web}/generate-helpers.d.ts +22 -19
  189. package/dist/{src/web → web}/generate-helpers.js +20 -18
  190. package/dist/web/generate-helpers.js.map +1 -0
  191. package/dist/{src/web → web}/generate-helpers.test-d.js +26 -26
  192. package/dist/web/generate-helpers.test-d.js.map +1 -0
  193. package/dist/web/generate-helpers.test.js.map +1 -0
  194. package/dist/{src/web → web}/helpers/state.d.ts +2 -2
  195. package/dist/web/helpers/state.js +45 -0
  196. package/dist/web/helpers/state.js.map +1 -0
  197. package/dist/{src/web → web}/helpers/state.test.js +9 -9
  198. package/dist/web/helpers/state.test.js.map +1 -0
  199. package/dist/{src/web → web}/hooks/index.d.ts +6 -3
  200. package/dist/{src/web → web}/hooks/index.js +5 -2
  201. package/dist/web/hooks/index.js.map +1 -0
  202. package/dist/web/hooks/test/utils.d.ts +20 -0
  203. package/dist/web/hooks/test/utils.js +75 -0
  204. package/dist/web/hooks/test/utils.js.map +1 -0
  205. package/dist/{src/web → web}/hooks/use-call-tool.d.ts +2 -1
  206. package/dist/{src/web → web}/hooks/use-call-tool.js +2 -2
  207. package/dist/web/hooks/use-call-tool.js.map +1 -0
  208. package/dist/web/hooks/use-call-tool.test-d.js.map +1 -0
  209. package/dist/{src/web → web}/hooks/use-call-tool.test.js +26 -6
  210. package/dist/web/hooks/use-call-tool.test.js.map +1 -0
  211. package/dist/web/hooks/use-display-mode.d.ts +4 -0
  212. package/dist/web/hooks/use-display-mode.js +9 -0
  213. package/dist/web/hooks/use-display-mode.js.map +1 -0
  214. package/dist/web/hooks/use-display-mode.test-d.js +8 -0
  215. package/dist/web/hooks/use-display-mode.test-d.js.map +1 -0
  216. package/dist/web/hooks/use-display-mode.test.js.map +1 -0
  217. package/dist/web/hooks/use-download.d.ts +5 -0
  218. package/dist/web/hooks/use-download.js +8 -0
  219. package/dist/web/hooks/use-download.js.map +1 -0
  220. package/dist/web/hooks/use-download.test.d.ts +1 -0
  221. package/dist/web/hooks/use-download.test.js +95 -0
  222. package/dist/web/hooks/use-download.test.js.map +1 -0
  223. package/dist/web/hooks/use-files.d.ts +7 -0
  224. package/dist/web/hooks/use-files.js +10 -0
  225. package/dist/web/hooks/use-files.js.map +1 -0
  226. package/dist/web/hooks/use-files.test.d.ts +1 -0
  227. package/dist/web/hooks/use-files.test.js +54 -0
  228. package/dist/web/hooks/use-files.test.js.map +1 -0
  229. package/dist/{src/web → web}/hooks/use-layout.d.ts +2 -2
  230. package/dist/{src/web → web}/hooks/use-layout.js +4 -4
  231. package/dist/web/hooks/use-layout.js.map +1 -0
  232. package/dist/web/hooks/use-layout.test.d.ts +1 -0
  233. package/dist/{src/web → web}/hooks/use-layout.test.js +7 -6
  234. package/dist/web/hooks/use-layout.test.js.map +1 -0
  235. package/dist/web/hooks/use-open-external.d.ts +3 -0
  236. package/dist/web/hooks/use-open-external.js +8 -0
  237. package/dist/web/hooks/use-open-external.js.map +1 -0
  238. package/dist/web/hooks/use-open-external.test.d.ts +1 -0
  239. package/dist/web/hooks/use-open-external.test.js +65 -0
  240. package/dist/web/hooks/use-open-external.test.js.map +1 -0
  241. package/dist/web/hooks/use-request-close.d.ts +2 -0
  242. package/dist/web/hooks/use-request-close.js +8 -0
  243. package/dist/web/hooks/use-request-close.js.map +1 -0
  244. package/dist/web/hooks/use-request-close.test.d.ts +1 -0
  245. package/dist/web/hooks/use-request-close.test.js +52 -0
  246. package/dist/web/hooks/use-request-close.test.js.map +1 -0
  247. package/dist/web/hooks/use-request-modal.d.ts +9 -0
  248. package/dist/web/hooks/use-request-modal.js +16 -0
  249. package/dist/web/hooks/use-request-modal.js.map +1 -0
  250. package/dist/web/hooks/use-request-modal.test.d.ts +1 -0
  251. package/dist/{src/web → web}/hooks/use-request-modal.test.js +5 -1
  252. package/dist/web/hooks/use-request-modal.test.js.map +1 -0
  253. package/dist/web/hooks/use-request-size.d.ts +3 -0
  254. package/dist/web/hooks/use-request-size.js +8 -0
  255. package/dist/web/hooks/use-request-size.js.map +1 -0
  256. package/dist/web/hooks/use-request-size.test.d.ts +1 -0
  257. package/dist/web/hooks/use-request-size.test.js +65 -0
  258. package/dist/web/hooks/use-request-size.test.js.map +1 -0
  259. package/dist/web/hooks/use-send-follow-up-message.d.ts +2 -0
  260. package/dist/web/hooks/use-send-follow-up-message.js +8 -0
  261. package/dist/web/hooks/use-send-follow-up-message.js.map +1 -0
  262. package/dist/web/hooks/use-set-open-in-app-url.d.ts +1 -0
  263. package/dist/web/hooks/use-set-open-in-app-url.js +8 -0
  264. package/dist/web/hooks/use-set-open-in-app-url.js.map +1 -0
  265. package/dist/web/hooks/use-set-open-in-app-url.test.d.ts +1 -0
  266. package/dist/web/hooks/use-set-open-in-app-url.test.js +43 -0
  267. package/dist/web/hooks/use-set-open-in-app-url.test.js.map +1 -0
  268. package/dist/{src/web → web}/hooks/use-tool-info.js +4 -4
  269. package/dist/web/hooks/use-tool-info.js.map +1 -0
  270. package/dist/web/hooks/use-tool-info.test-d.d.ts +1 -0
  271. package/dist/web/hooks/use-tool-info.test-d.js.map +1 -0
  272. package/dist/web/hooks/use-tool-info.test.d.ts +1 -0
  273. package/dist/{src/web → web}/hooks/use-tool-info.test.js +5 -5
  274. package/dist/web/hooks/use-tool-info.test.js.map +1 -0
  275. package/dist/{src/web → web}/hooks/use-user.d.ts +1 -1
  276. package/dist/web/hooks/use-user.js +35 -0
  277. package/dist/web/hooks/use-user.js.map +1 -0
  278. package/dist/web/hooks/use-user.test.d.ts +1 -0
  279. package/dist/{src/web → web}/hooks/use-user.test.js +33 -4
  280. package/dist/web/hooks/use-user.test.js.map +1 -0
  281. package/dist/web/hooks/use-view-state.d.ts +4 -0
  282. package/dist/web/hooks/use-view-state.js +32 -0
  283. package/dist/web/hooks/use-view-state.js.map +1 -0
  284. package/dist/web/hooks/use-view-state.test.d.ts +1 -0
  285. package/dist/web/hooks/use-view-state.test.js +177 -0
  286. package/dist/web/hooks/use-view-state.test.js.map +1 -0
  287. package/dist/{src/web → web}/index.d.ts +1 -2
  288. package/dist/{src/web → web}/index.js +1 -2
  289. package/dist/web/index.js.map +1 -0
  290. package/dist/web/mount-view.d.ts +1 -0
  291. package/dist/{src/web/mount-widget.js → web/mount-view.js} +11 -3
  292. package/dist/web/mount-view.js.map +1 -0
  293. package/dist/web/plugin/data-llm.test.d.ts +1 -0
  294. package/dist/web/plugin/data-llm.test.js.map +1 -0
  295. package/dist/web/plugin/plugin.d.ts +5 -0
  296. package/dist/web/plugin/plugin.js +163 -0
  297. package/dist/web/plugin/plugin.js.map +1 -0
  298. package/dist/web/plugin/scan-views.d.ts +16 -0
  299. package/dist/web/plugin/scan-views.js +88 -0
  300. package/dist/web/plugin/scan-views.js.map +1 -0
  301. package/dist/web/plugin/scan-views.test.d.ts +1 -0
  302. package/dist/web/plugin/scan-views.test.js +99 -0
  303. package/dist/web/plugin/scan-views.test.js.map +1 -0
  304. package/dist/{src/web → web}/plugin/transform-data-llm.js +1 -1
  305. package/dist/web/plugin/transform-data-llm.js.map +1 -0
  306. package/dist/web/plugin/transform-data-llm.test.d.ts +1 -0
  307. package/dist/web/plugin/transform-data-llm.test.js.map +1 -0
  308. package/dist/web/plugin/validate-view.d.ts +1 -0
  309. package/dist/web/plugin/validate-view.js +9 -0
  310. package/dist/web/plugin/validate-view.js.map +1 -0
  311. package/dist/web/plugin/validate-view.test.d.ts +1 -0
  312. package/dist/web/plugin/validate-view.test.js +24 -0
  313. package/dist/web/plugin/validate-view.test.js.map +1 -0
  314. package/dist/{src/web → web}/proxy.js +0 -1
  315. package/dist/web/proxy.js.map +1 -0
  316. package/dist/web/types.d.ts +16 -0
  317. package/dist/web/types.js +2 -0
  318. package/dist/web/types.js.map +1 -0
  319. package/package.json +73 -34
  320. package/tsconfig.base.json +33 -0
  321. package/dist/src/server/devtoolsStaticServer.d.ts +0 -19
  322. package/dist/src/server/devtoolsStaticServer.js +0 -49
  323. package/dist/src/server/devtoolsStaticServer.js.map +0 -1
  324. package/dist/src/server/index.d.ts +0 -5
  325. package/dist/src/server/index.js +0 -4
  326. package/dist/src/server/index.js.map +0 -1
  327. package/dist/src/server/inferUtilityTypes.js.map +0 -1
  328. package/dist/src/server/server.d.ts +0 -74
  329. package/dist/src/server/server.js +0 -82
  330. package/dist/src/server/server.js.map +0 -1
  331. package/dist/src/server/templateHelper.js +0 -30
  332. package/dist/src/server/templateHelper.js.map +0 -1
  333. package/dist/src/server/templates/development.hbs +0 -13
  334. package/dist/src/server/templates/production.hbs +0 -7
  335. package/dist/src/server/widgetsDevServer.d.ts +0 -12
  336. package/dist/src/server/widgetsDevServer.js +0 -39
  337. package/dist/src/server/widgetsDevServer.js.map +0 -1
  338. package/dist/src/test/utils.js.map +0 -1
  339. package/dist/src/test/widget.test.js +0 -146
  340. package/dist/src/test/widget.test.js.map +0 -1
  341. package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.d.ts +0 -12
  342. package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.js +0 -30
  343. package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.js.map +0 -1
  344. package/dist/src/web/bridges/adaptors/mcp-app-adaptor.d.ts +0 -15
  345. package/dist/src/web/bridges/adaptors/mcp-app-adaptor.js +0 -108
  346. package/dist/src/web/bridges/adaptors/mcp-app-adaptor.js.map +0 -1
  347. package/dist/src/web/bridges/apps-sdk-bridge.d.ts +0 -10
  348. package/dist/src/web/bridges/apps-sdk-bridge.js.map +0 -1
  349. package/dist/src/web/bridges/hooks/use-adaptor.d.ts +0 -2
  350. package/dist/src/web/bridges/hooks/use-adaptor.js +0 -8
  351. package/dist/src/web/bridges/hooks/use-adaptor.js.map +0 -1
  352. package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.d.ts +0 -2
  353. package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.js.map +0 -1
  354. package/dist/src/web/bridges/hooks/use-bridge.d.ts +0 -2
  355. package/dist/src/web/bridges/hooks/use-bridge.js +0 -8
  356. package/dist/src/web/bridges/hooks/use-bridge.js.map +0 -1
  357. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.d.ts +0 -5
  358. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.js +0 -7
  359. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.js.map +0 -1
  360. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.test.js +0 -41
  361. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.test.js.map +0 -1
  362. package/dist/src/web/bridges/index.d.ts +0 -4
  363. package/dist/src/web/bridges/index.js +0 -5
  364. package/dist/src/web/bridges/index.js.map +0 -1
  365. package/dist/src/web/bridges/mcp-app-bridge.d.ts +0 -38
  366. package/dist/src/web/bridges/mcp-app-bridge.js +0 -162
  367. package/dist/src/web/bridges/mcp-app-bridge.js.map +0 -1
  368. package/dist/src/web/bridges/types.d.ts +0 -56
  369. package/dist/src/web/bridges/types.js.map +0 -1
  370. package/dist/src/web/create-store.js +0 -25
  371. package/dist/src/web/create-store.js.map +0 -1
  372. package/dist/src/web/create-store.test.js +0 -70
  373. package/dist/src/web/create-store.test.js.map +0 -1
  374. package/dist/src/web/data-llm.js.map +0 -1
  375. package/dist/src/web/data-llm.test.js +0 -76
  376. package/dist/src/web/data-llm.test.js.map +0 -1
  377. package/dist/src/web/generate-helpers.js.map +0 -1
  378. package/dist/src/web/generate-helpers.test-d.js.map +0 -1
  379. package/dist/src/web/generate-helpers.test.js.map +0 -1
  380. package/dist/src/web/helpers/state.js +0 -40
  381. package/dist/src/web/helpers/state.js.map +0 -1
  382. package/dist/src/web/helpers/state.test.js.map +0 -1
  383. package/dist/src/web/hooks/index.js.map +0 -1
  384. package/dist/src/web/hooks/test/utils.d.ts +0 -10
  385. package/dist/src/web/hooks/test/utils.js +0 -40
  386. package/dist/src/web/hooks/test/utils.js.map +0 -1
  387. package/dist/src/web/hooks/use-call-tool.js.map +0 -1
  388. package/dist/src/web/hooks/use-call-tool.test-d.js.map +0 -1
  389. package/dist/src/web/hooks/use-call-tool.test.js.map +0 -1
  390. package/dist/src/web/hooks/use-display-mode.d.ts +0 -4
  391. package/dist/src/web/hooks/use-display-mode.js +0 -10
  392. package/dist/src/web/hooks/use-display-mode.js.map +0 -1
  393. package/dist/src/web/hooks/use-display-mode.test.js.map +0 -1
  394. package/dist/src/web/hooks/use-files.d.ts +0 -10
  395. package/dist/src/web/hooks/use-files.js +0 -7
  396. package/dist/src/web/hooks/use-files.js.map +0 -1
  397. package/dist/src/web/hooks/use-files.test.js +0 -29
  398. package/dist/src/web/hooks/use-files.test.js.map +0 -1
  399. package/dist/src/web/hooks/use-layout.js.map +0 -1
  400. package/dist/src/web/hooks/use-layout.test.js.map +0 -1
  401. package/dist/src/web/hooks/use-open-external.d.ts +0 -1
  402. package/dist/src/web/hooks/use-open-external.js +0 -6
  403. package/dist/src/web/hooks/use-open-external.js.map +0 -1
  404. package/dist/src/web/hooks/use-open-external.test.js +0 -24
  405. package/dist/src/web/hooks/use-open-external.test.js.map +0 -1
  406. package/dist/src/web/hooks/use-openai-global.d.ts +0 -3
  407. package/dist/src/web/hooks/use-openai-global.js +0 -6
  408. package/dist/src/web/hooks/use-openai-global.js.map +0 -1
  409. package/dist/src/web/hooks/use-request-modal.d.ts +0 -9
  410. package/dist/src/web/hooks/use-request-modal.js +0 -14
  411. package/dist/src/web/hooks/use-request-modal.js.map +0 -1
  412. package/dist/src/web/hooks/use-request-modal.test.js.map +0 -1
  413. package/dist/src/web/hooks/use-send-follow-up-message.d.ts +0 -1
  414. package/dist/src/web/hooks/use-send-follow-up-message.js +0 -8
  415. package/dist/src/web/hooks/use-send-follow-up-message.js.map +0 -1
  416. package/dist/src/web/hooks/use-tool-info.js.map +0 -1
  417. package/dist/src/web/hooks/use-tool-info.test-d.js.map +0 -1
  418. package/dist/src/web/hooks/use-tool-info.test.js.map +0 -1
  419. package/dist/src/web/hooks/use-user.js +0 -19
  420. package/dist/src/web/hooks/use-user.js.map +0 -1
  421. package/dist/src/web/hooks/use-user.test.js.map +0 -1
  422. package/dist/src/web/hooks/use-widget-state.d.ts +0 -4
  423. package/dist/src/web/hooks/use-widget-state.js +0 -32
  424. package/dist/src/web/hooks/use-widget-state.js.map +0 -1
  425. package/dist/src/web/hooks/use-widget-state.test.js +0 -61
  426. package/dist/src/web/hooks/use-widget-state.test.js.map +0 -1
  427. package/dist/src/web/index.js.map +0 -1
  428. package/dist/src/web/mount-widget.d.ts +0 -1
  429. package/dist/src/web/mount-widget.js.map +0 -1
  430. package/dist/src/web/plugin/data-llm.test.js.map +0 -1
  431. package/dist/src/web/plugin/plugin.d.ts +0 -2
  432. package/dist/src/web/plugin/plugin.js +0 -39
  433. package/dist/src/web/plugin/plugin.js.map +0 -1
  434. package/dist/src/web/plugin/transform-data-llm.js.map +0 -1
  435. package/dist/src/web/plugin/transform-data-llm.test.js.map +0 -1
  436. package/dist/src/web/proxy.js.map +0 -1
  437. package/dist/src/web/types.d.ts +0 -149
  438. package/dist/src/web/types.js.map +0 -1
  439. package/dist/vitest.config.d.ts +0 -2
  440. package/dist/vitest.config.js +0 -8
  441. package/dist/vitest.config.js.map +0 -1
  442. /package/dist/{src/test/widget.test.d.ts → cli/tunnel-control-server.test.d.ts} +0 -0
  443. /package/dist/{src/web/bridges/hooks/use-mcp-app-bridge.test.d.ts → cli/tunnel-handler.test.d.ts} +0 -0
  444. /package/dist/{src/web/create-store.test.d.ts → cli/tunnel.test.d.ts} +0 -0
  445. /package/dist/{src/web/bridges → cli}/types.js +0 -0
  446. /package/dist/{src/web/data-llm.test.d.ts → server/asset-base-url-transform-plugin.test.d.ts} +0 -0
  447. /package/dist/{src/web/generate-helpers.test-d.d.ts → server/content-helpers.test.d.ts} +0 -0
  448. /package/dist/{src/web/generate-helpers.test.d.ts → server/express.test.d.ts} +0 -0
  449. /package/dist/{src/server → server}/inferUtilityTypes.js +0 -0
  450. /package/dist/{src/web/helpers/state.test.d.ts → server/middleware.test-d.d.ts} +0 -0
  451. /package/dist/{src/web/hooks/use-call-tool.test-d.d.ts → server/middleware.test.d.ts} +0 -0
  452. /package/dist/{src/web/hooks/use-call-tool.test.d.ts → server/tunnel-proxy-router.test.d.ts} +0 -0
  453. /package/dist/{src/web/hooks/use-display-mode.test.d.ts → test/view.test.d.ts} +0 -0
  454. /package/dist/{src/web/hooks/use-files.test.d.ts → web/bridges/mcp-app/use-mcp-app-context.test.d.ts} +0 -0
  455. /package/dist/{src/web → web}/create-store.d.ts +0 -0
  456. /package/dist/{src/web/hooks/use-layout.test.d.ts → web/create-store.test.d.ts} +0 -0
  457. /package/dist/{src/web/plugin → web}/data-llm.test.d.ts +0 -0
  458. /package/dist/{src/web/hooks/use-open-external.test.d.ts → web/generate-helpers.test-d.d.ts} +0 -0
  459. /package/dist/{src/web/hooks/use-request-modal.test.d.ts → web/generate-helpers.test.d.ts} +0 -0
  460. /package/dist/{src/web → web}/generate-helpers.test.js +0 -0
  461. /package/dist/{src/web/hooks/use-tool-info.test-d.d.ts → web/helpers/state.test.d.ts} +0 -0
  462. /package/dist/{src/web/hooks/use-tool-info.test.d.ts → web/hooks/use-call-tool.test-d.d.ts} +0 -0
  463. /package/dist/{src/web → web}/hooks/use-call-tool.test-d.js +0 -0
  464. /package/dist/{src/web/hooks/use-user.test.d.ts → web/hooks/use-call-tool.test.d.ts} +0 -0
  465. /package/dist/{src/web/hooks/use-widget-state.test.d.ts → web/hooks/use-display-mode.test-d.d.ts} +0 -0
  466. /package/dist/{src/web/plugin/transform-data-llm.test.d.ts → web/hooks/use-display-mode.test.d.ts} +0 -0
  467. /package/dist/{src/web → web}/hooks/use-display-mode.test.js +0 -0
  468. /package/dist/{src/web → web}/hooks/use-tool-info.d.ts +0 -0
  469. /package/dist/{src/web → web}/hooks/use-tool-info.test-d.js +0 -0
  470. /package/dist/{src/web → web}/plugin/data-llm.test.js +0 -0
  471. /package/dist/{src/web → web}/plugin/transform-data-llm.d.ts +0 -0
  472. /package/dist/{src/web → web}/plugin/transform-data-llm.test.js +0 -0
  473. /package/dist/{src/web → web}/proxy.d.ts +0 -0
@@ -0,0 +1,20 @@
1
+ import { type BearerAuthMiddlewareOptions } from "@modelcontextprotocol/sdk/server/auth/middleware/bearerAuth.js";
2
+ import type { RequestHandler } from "express";
3
+ export { InvalidTokenError } from "@modelcontextprotocol/sdk/server/auth/errors.js";
4
+ export { type BearerAuthMiddlewareOptions, requireBearerAuth, } from "@modelcontextprotocol/sdk/server/auth/middleware/bearerAuth.js";
5
+ export { type AuthMetadataOptions, mcpAuthMetadataRouter, } from "@modelcontextprotocol/sdk/server/auth/router.js";
6
+ export type { AuthInfo } from "@modelcontextprotocol/sdk/server/auth/types.js";
7
+ /**
8
+ * Like `requireBearerAuth`, but lets requests through when no
9
+ * `Authorization` header is present. Used for mixed-auth servers where some
10
+ * tools are public and others require sign-in: each tool enforces its own
11
+ * `securitySchemes` against `extra.authInfo`.
12
+ *
13
+ * Behavior:
14
+ * - No `Authorization` header → `next()` without `req.auth`.
15
+ * - Valid Bearer token → `req.auth` set, same as `requireBearerAuth`.
16
+ * - Invalid / malformed / expired / insufficient-scope → same error response
17
+ * as `requireBearerAuth` (401/403). Sending a bad token is still a client
18
+ * error.
19
+ */
20
+ export declare function optionalBearerAuth(options: BearerAuthMiddlewareOptions): RequestHandler;
@@ -0,0 +1,28 @@
1
+ import { requireBearerAuth, } from "@modelcontextprotocol/sdk/server/auth/middleware/bearerAuth.js";
2
+ export { InvalidTokenError } from "@modelcontextprotocol/sdk/server/auth/errors.js";
3
+ export { requireBearerAuth, } from "@modelcontextprotocol/sdk/server/auth/middleware/bearerAuth.js";
4
+ export { mcpAuthMetadataRouter, } from "@modelcontextprotocol/sdk/server/auth/router.js";
5
+ /**
6
+ * Like `requireBearerAuth`, but lets requests through when no
7
+ * `Authorization` header is present. Used for mixed-auth servers where some
8
+ * tools are public and others require sign-in: each tool enforces its own
9
+ * `securitySchemes` against `extra.authInfo`.
10
+ *
11
+ * Behavior:
12
+ * - No `Authorization` header → `next()` without `req.auth`.
13
+ * - Valid Bearer token → `req.auth` set, same as `requireBearerAuth`.
14
+ * - Invalid / malformed / expired / insufficient-scope → same error response
15
+ * as `requireBearerAuth` (401/403). Sending a bad token is still a client
16
+ * error.
17
+ */
18
+ export function optionalBearerAuth(options) {
19
+ const required = requireBearerAuth(options);
20
+ return (req, res, next) => {
21
+ if (!req.headers.authorization) {
22
+ next();
23
+ return;
24
+ }
25
+ return required(req, res, next);
26
+ };
27
+ }
28
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/server/auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,GAClB,MAAM,gEAAgE,CAAC;AAIxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iDAAiD,CAAC;AACpF,OAAO,EAEL,iBAAiB,GAClB,MAAM,gEAAgE,CAAC;AACxE,OAAO,EAEL,qBAAqB,GACtB,MAAM,iDAAiD,CAAC;AAGzD;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,kBAAkB,CAChC,OAAoC;IAEpC,MAAM,QAAQ,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAC5C,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QACxB,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;YAC/B,IAAI,EAAE,CAAC;YACP,OAAO;QACT,CAAC;QACD,OAAO,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import {\n type BearerAuthMiddlewareOptions,\n requireBearerAuth,\n} from \"@modelcontextprotocol/sdk/server/auth/middleware/bearerAuth.js\";\n\nimport type { RequestHandler } from \"express\";\n\nexport { InvalidTokenError } from \"@modelcontextprotocol/sdk/server/auth/errors.js\";\nexport {\n type BearerAuthMiddlewareOptions,\n requireBearerAuth,\n} from \"@modelcontextprotocol/sdk/server/auth/middleware/bearerAuth.js\";\nexport {\n type AuthMetadataOptions,\n mcpAuthMetadataRouter,\n} from \"@modelcontextprotocol/sdk/server/auth/router.js\";\nexport type { AuthInfo } from \"@modelcontextprotocol/sdk/server/auth/types.js\";\n\n/**\n * Like `requireBearerAuth`, but lets requests through when no\n * `Authorization` header is present. Used for mixed-auth servers where some\n * tools are public and others require sign-in: each tool enforces its own\n * `securitySchemes` against `extra.authInfo`.\n *\n * Behavior:\n * - No `Authorization` header → `next()` without `req.auth`.\n * - Valid Bearer token → `req.auth` set, same as `requireBearerAuth`.\n * - Invalid / malformed / expired / insufficient-scope → same error response\n * as `requireBearerAuth` (401/403). Sending a bad token is still a client\n * error.\n */\nexport function optionalBearerAuth(\n options: BearerAuthMiddlewareOptions,\n): RequestHandler {\n const required = requireBearerAuth(options);\n return (req, res, next) => {\n if (!req.headers.authorization) {\n next();\n return;\n }\n return required(req, res, next);\n };\n}\n"]}
@@ -0,0 +1,27 @@
1
+ import type { AudioContent, EmbeddedResource, ImageContent, ResourceLink, TextContent } from "@modelcontextprotocol/sdk/types.js";
2
+ type ContentAnnotations = {
3
+ audience?: ("user" | "assistant")[];
4
+ priority?: number;
5
+ lastModified?: string;
6
+ };
7
+ export declare function text(value: string, annotations?: ContentAnnotations): TextContent;
8
+ export declare function image(data: string | Uint8Array, mimeType: string, annotations?: ContentAnnotations): ImageContent;
9
+ export declare function audio(data: string | Uint8Array, mimeType: string, annotations?: ContentAnnotations): AudioContent;
10
+ export declare function embeddedResource(resource: {
11
+ uri: string;
12
+ mimeType?: string;
13
+ text: string;
14
+ } | {
15
+ uri: string;
16
+ mimeType?: string;
17
+ blob: string;
18
+ }, annotations?: ContentAnnotations): EmbeddedResource;
19
+ export declare function resourceLink(link: {
20
+ uri: string;
21
+ name: string;
22
+ title?: string;
23
+ description?: string;
24
+ mimeType?: string;
25
+ size?: number;
26
+ }, annotations?: ContentAnnotations): ResourceLink;
27
+ export {};
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Returns a base64-encoded string.
3
+ * - `Uint8Array` input is encoded via `Buffer.toString("base64")`.
4
+ * - `string` input is assumed to be **already base64-encoded** and is returned
5
+ * as-is. Passing raw/unencoded string bytes will produce invalid MCP content.
6
+ */
7
+ function toBase64(data) {
8
+ if (typeof data === "string") {
9
+ return data;
10
+ }
11
+ return Buffer.from(data).toString("base64");
12
+ }
13
+ export function text(value, annotations) {
14
+ return { type: "text", text: value, ...(annotations && { annotations }) };
15
+ }
16
+ export function image(data, mimeType, annotations) {
17
+ return {
18
+ type: "image",
19
+ data: toBase64(data),
20
+ mimeType,
21
+ ...(annotations && { annotations }),
22
+ };
23
+ }
24
+ export function audio(data, mimeType, annotations) {
25
+ return {
26
+ type: "audio",
27
+ data: toBase64(data),
28
+ mimeType,
29
+ ...(annotations && { annotations }),
30
+ };
31
+ }
32
+ export function embeddedResource(resource, annotations) {
33
+ return {
34
+ type: "resource",
35
+ resource,
36
+ ...(annotations && { annotations }),
37
+ };
38
+ }
39
+ export function resourceLink(link, annotations) {
40
+ return {
41
+ type: "resource_link",
42
+ ...link,
43
+ ...(annotations && { annotations }),
44
+ };
45
+ }
46
+ //# sourceMappingURL=content-helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"content-helpers.js","sourceRoot":"","sources":["../../src/server/content-helpers.ts"],"names":[],"mappings":"AAcA;;;;;GAKG;AACH,SAAS,QAAQ,CAAC,IAAyB;IACzC,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;QAC7B,OAAO,IAAI,CAAC;IACd,CAAC;IACD,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,IAAI,CAClB,KAAa,EACb,WAAgC;IAEhC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,WAAW,IAAI,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC;AAC5E,CAAC;AAED,MAAM,UAAU,KAAK,CACnB,IAAyB,EACzB,QAAgB,EAChB,WAAgC;IAEhC,OAAO;QACL,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC;QACpB,QAAQ;QACR,GAAG,CAAC,WAAW,IAAI,EAAE,WAAW,EAAE,CAAC;KACpC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,KAAK,CACnB,IAAyB,EACzB,QAAgB,EAChB,WAAgC;IAEhC,OAAO;QACL,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC;QACpB,QAAQ;QACR,GAAG,CAAC,WAAW,IAAI,EAAE,WAAW,EAAE,CAAC;KACpC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,QAEoD,EACpD,WAAgC;IAEhC,OAAO;QACL,IAAI,EAAE,UAAU;QAChB,QAAQ;QACR,GAAG,CAAC,WAAW,IAAI,EAAE,WAAW,EAAE,CAAC;KACpC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,YAAY,CAC1B,IAOC,EACD,WAAgC;IAEhC,OAAO;QACL,IAAI,EAAE,eAAe;QACrB,GAAG,IAAI;QACP,GAAG,CAAC,WAAW,IAAI,EAAE,WAAW,EAAE,CAAC;KACpC,CAAC;AACJ,CAAC","sourcesContent":["import type {\n AudioContent,\n EmbeddedResource,\n ImageContent,\n ResourceLink,\n TextContent,\n} from \"@modelcontextprotocol/sdk/types.js\";\n\ntype ContentAnnotations = {\n audience?: (\"user\" | \"assistant\")[];\n priority?: number;\n lastModified?: string;\n};\n\n/**\n * Returns a base64-encoded string.\n * - `Uint8Array` input is encoded via `Buffer.toString(\"base64\")`.\n * - `string` input is assumed to be **already base64-encoded** and is returned\n * as-is. Passing raw/unencoded string bytes will produce invalid MCP content.\n */\nfunction toBase64(data: string | Uint8Array): string {\n if (typeof data === \"string\") {\n return data;\n }\n return Buffer.from(data).toString(\"base64\");\n}\n\nexport function text(\n value: string,\n annotations?: ContentAnnotations,\n): TextContent {\n return { type: \"text\", text: value, ...(annotations && { annotations }) };\n}\n\nexport function image(\n data: string | Uint8Array,\n mimeType: string,\n annotations?: ContentAnnotations,\n): ImageContent {\n return {\n type: \"image\",\n data: toBase64(data),\n mimeType,\n ...(annotations && { annotations }),\n };\n}\n\nexport function audio(\n data: string | Uint8Array,\n mimeType: string,\n annotations?: ContentAnnotations,\n): AudioContent {\n return {\n type: \"audio\",\n data: toBase64(data),\n mimeType,\n ...(annotations && { annotations }),\n };\n}\n\nexport function embeddedResource(\n resource:\n | { uri: string; mimeType?: string; text: string }\n | { uri: string; mimeType?: string; blob: string },\n annotations?: ContentAnnotations,\n): EmbeddedResource {\n return {\n type: \"resource\",\n resource,\n ...(annotations && { annotations }),\n };\n}\n\nexport function resourceLink(\n link: {\n uri: string;\n name: string;\n title?: string;\n description?: string;\n mimeType?: string;\n size?: number;\n },\n annotations?: ContentAnnotations,\n): ResourceLink {\n return {\n type: \"resource_link\",\n ...link,\n ...(annotations && { annotations }),\n };\n}\n"]}
@@ -0,0 +1,70 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { audio, embeddedResource, image, resourceLink, text, } from "./content-helpers.js";
3
+ describe("text", () => {
4
+ it("returns a TextContent without annotations when none given", () => {
5
+ expect(text("hello")).toEqual({ type: "text", text: "hello" });
6
+ });
7
+ it("includes annotations when provided", () => {
8
+ expect(text("hi", { priority: 1 })).toEqual({
9
+ type: "text",
10
+ text: "hi",
11
+ annotations: { priority: 1 },
12
+ });
13
+ });
14
+ });
15
+ describe("image", () => {
16
+ it("base64-encodes Uint8Array data", () => {
17
+ const bytes = new Uint8Array([104, 105]);
18
+ expect(image(bytes, "image/png")).toEqual({
19
+ type: "image",
20
+ data: "aGk=",
21
+ mimeType: "image/png",
22
+ });
23
+ });
24
+ it("passes string data through unchanged (caller is responsible for base64)", () => {
25
+ expect(image("YWxyZWFkeS1iNjQ=", "image/png")).toEqual({
26
+ type: "image",
27
+ data: "YWxyZWFkeS1iNjQ=",
28
+ mimeType: "image/png",
29
+ });
30
+ });
31
+ });
32
+ describe("audio", () => {
33
+ it("base64-encodes Uint8Array data", () => {
34
+ const bytes = new Uint8Array([104, 105]);
35
+ expect(audio(bytes, "audio/mpeg")).toMatchObject({
36
+ type: "audio",
37
+ data: "aGk=",
38
+ mimeType: "audio/mpeg",
39
+ });
40
+ });
41
+ });
42
+ describe("embeddedResource", () => {
43
+ it("wraps a text resource with a type tag", () => {
44
+ expect(embeddedResource({
45
+ uri: "file:///a.txt",
46
+ mimeType: "text/plain",
47
+ text: "x",
48
+ })).toEqual({
49
+ type: "resource",
50
+ resource: { uri: "file:///a.txt", mimeType: "text/plain", text: "x" },
51
+ });
52
+ });
53
+ it("wraps a blob resource with a type tag", () => {
54
+ expect(embeddedResource({ uri: "file:///a.bin", blob: "YmFy" })).toEqual({
55
+ type: "resource",
56
+ resource: { uri: "file:///a.bin", blob: "YmFy" },
57
+ });
58
+ });
59
+ });
60
+ describe("resourceLink", () => {
61
+ it("spreads link fields alongside the type tag", () => {
62
+ expect(resourceLink({ uri: "file:///a", name: "a", title: "A" })).toEqual({
63
+ type: "resource_link",
64
+ uri: "file:///a",
65
+ name: "a",
66
+ title: "A",
67
+ });
68
+ });
69
+ });
70
+ //# sourceMappingURL=content-helpers.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"content-helpers.test.js","sourceRoot":"","sources":["../../src/server/content-helpers.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, expect, it } from \"vitest\";\nimport {\n audio,\n embeddedResource,\n image,\n resourceLink,\n text,\n} from \"./content-helpers.js\";\n\ndescribe(\"text\", () => {\n it(\"returns a TextContent without annotations when none given\", () => {\n expect(text(\"hello\")).toEqual({ type: \"text\", text: \"hello\" });\n });\n\n it(\"includes annotations when provided\", () => {\n expect(text(\"hi\", { priority: 1 })).toEqual({\n type: \"text\",\n text: \"hi\",\n annotations: { priority: 1 },\n });\n });\n});\n\ndescribe(\"image\", () => {\n it(\"base64-encodes Uint8Array data\", () => {\n const bytes = new Uint8Array([104, 105]);\n expect(image(bytes, \"image/png\")).toEqual({\n type: \"image\",\n data: \"aGk=\",\n mimeType: \"image/png\",\n });\n });\n\n it(\"passes string data through unchanged (caller is responsible for base64)\", () => {\n expect(image(\"YWxyZWFkeS1iNjQ=\", \"image/png\")).toEqual({\n type: \"image\",\n data: \"YWxyZWFkeS1iNjQ=\",\n mimeType: \"image/png\",\n });\n });\n});\n\ndescribe(\"audio\", () => {\n it(\"base64-encodes Uint8Array data\", () => {\n const bytes = new Uint8Array([104, 105]);\n expect(audio(bytes, \"audio/mpeg\")).toMatchObject({\n type: \"audio\",\n data: \"aGk=\",\n mimeType: \"audio/mpeg\",\n });\n });\n});\n\ndescribe(\"embeddedResource\", () => {\n it(\"wraps a text resource with a type tag\", () => {\n expect(\n embeddedResource({\n uri: \"file:///a.txt\",\n mimeType: \"text/plain\",\n text: \"x\",\n }),\n ).toEqual({\n type: \"resource\",\n resource: { uri: \"file:///a.txt\", mimeType: \"text/plain\", text: \"x\" },\n });\n });\n\n it(\"wraps a blob resource with a type tag\", () => {\n expect(embeddedResource({ uri: \"file:///a.bin\", blob: \"YmFy\" })).toEqual({\n type: \"resource\",\n resource: { uri: \"file:///a.bin\", blob: \"YmFy\" },\n });\n });\n});\n\ndescribe(\"resourceLink\", () => {\n it(\"spreads link fields alongside the type tag\", () => {\n expect(resourceLink({ uri: \"file:///a\", name: \"a\", title: \"A\" })).toEqual({\n type: \"resource_link\",\n uri: \"file:///a\",\n name: \"a\",\n title: \"A\",\n });\n });\n});\n"]}
@@ -0,0 +1,11 @@
1
+ import type http from "node:http";
2
+ import express from "express";
3
+ import type { McpServer } from "./server.js";
4
+ export declare function createApp({ mcpServer, httpServer, errorMiddleware, }: {
5
+ mcpServer: McpServer;
6
+ httpServer: http.Server;
7
+ errorMiddleware?: {
8
+ path?: string;
9
+ handlers: express.ErrorRequestHandler[];
10
+ }[];
11
+ }): Promise<express.Express>;
@@ -0,0 +1,101 @@
1
+ import path from "node:path";
2
+ import { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
3
+ import cors from "cors";
4
+ import express from "express";
5
+ function parseControlPort(raw) {
6
+ if (raw === undefined) {
7
+ return null;
8
+ }
9
+ const n = Number.parseInt(raw, 10);
10
+ if (!Number.isFinite(n) || n <= 0 || n >= 65536) {
11
+ return null;
12
+ }
13
+ return n;
14
+ }
15
+ function applyMiddlewares(app, middlewares) {
16
+ for (const middleware of middlewares) {
17
+ if (middleware.path) {
18
+ app.use(middleware.path, ...middleware.handlers);
19
+ }
20
+ else {
21
+ app.use(...middleware.handlers);
22
+ }
23
+ }
24
+ }
25
+ function defaultErrorHandler(err, _req, res, _next) {
26
+ console.error("Error handling MCP request:", err);
27
+ if (!res.headersSent) {
28
+ res.status(500).json({
29
+ jsonrpc: "2.0",
30
+ error: { code: -32603, message: "Internal server error" },
31
+ id: null,
32
+ });
33
+ }
34
+ }
35
+ export async function createApp({ mcpServer, httpServer, errorMiddleware = [], }) {
36
+ const app = mcpServer.express;
37
+ // Read `process.env.NODE_ENV` inline: wrangler/esbuild only substitute the literal expression,
38
+ // so a local const would defeat dead-code elimination of the dev-only imports below.
39
+ if (process.env.NODE_ENV !== "production") {
40
+ const { devtoolsStaticServer } = await import("@skybridge/devtools");
41
+ app.use(await devtoolsStaticServer());
42
+ const { viewsDevServer } = await import("./viewsDevServer.js");
43
+ app.use(await viewsDevServer(httpServer));
44
+ const controlPort = parseControlPort(process.env.__TUNNEL_CONTROL_PORT);
45
+ if (controlPort !== null) {
46
+ const { createTunnelProxyRouter } = await import("./tunnel-proxy-router.js");
47
+ app.use(createTunnelProxyRouter(controlPort));
48
+ }
49
+ else if (process.env.__TUNNEL_CONTROL_PORT !== undefined) {
50
+ console.warn(`Ignoring invalid __TUNNEL_CONTROL_PORT=${process.env.__TUNNEL_CONTROL_PORT}`);
51
+ }
52
+ }
53
+ else {
54
+ const assetsPath = path.join(process.cwd(), "dist", "assets");
55
+ app.use("/assets", cors());
56
+ app.use("/assets", express.static(assetsPath));
57
+ }
58
+ app.use("/mcp", mcpMiddleware(mcpServer));
59
+ applyMiddlewares(app, errorMiddleware);
60
+ app.use("/mcp", defaultErrorHandler);
61
+ return app;
62
+ }
63
+ const mcpMiddleware = (server) => {
64
+ return async (req, res, next) => {
65
+ if (req.method !== "POST") {
66
+ res.writeHead(405).end(JSON.stringify({
67
+ jsonrpc: "2.0",
68
+ error: {
69
+ code: -32000,
70
+ message: "Method not allowed.",
71
+ },
72
+ id: null,
73
+ }));
74
+ return;
75
+ }
76
+ try {
77
+ const transport = new StreamableHTTPServerTransport({
78
+ sessionIdGenerator: undefined,
79
+ // Respond with a single JSON body instead of SSE. Skybridge's stateless
80
+ // transport never streams server-initiated messages, so SSE adds no
81
+ // capability — and on workerd specifically, `cloudflare:node`'s http
82
+ // bridge silently drops chunked writes that happen after the request
83
+ // handler awaits, which manifests as a 200 with empty body for any
84
+ // async tools/call.
85
+ enableJsonResponse: true,
86
+ });
87
+ res.on("close", () => {
88
+ transport.close();
89
+ });
90
+ await server.connectStatelessTransport(transport);
91
+ // Express strips the mount path from req.url (e.g. "/mcp" becomes "/").
92
+ // Restore it so the SDK builds the correct requestInfo.url.
93
+ req.url = req.originalUrl;
94
+ await transport.handleRequest(req, res, req.body);
95
+ }
96
+ catch (error) {
97
+ next(error);
98
+ }
99
+ };
100
+ };
101
+ //# sourceMappingURL=express.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"express.js","sourceRoot":"","sources":["../../src/server/express.ts"],"names":[],"mappings":"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","sourcesContent":["import type http from \"node:http\";\nimport path from \"node:path\";\nimport { StreamableHTTPServerTransport } from \"@modelcontextprotocol/sdk/server/streamableHttp.js\";\nimport cors from \"cors\";\nimport express from \"express\";\nimport type { McpServer } from \"./server.js\";\n\nfunction parseControlPort(raw: string | undefined): number | null {\n if (raw === undefined) {\n return null;\n }\n const n = Number.parseInt(raw, 10);\n if (!Number.isFinite(n) || n <= 0 || n >= 65536) {\n return null;\n }\n return n;\n}\n\nfunction applyMiddlewares(\n app: express.Express,\n middlewares: Array<{\n path?: string;\n handlers: express.ErrorRequestHandler[];\n }>,\n): void {\n for (const middleware of middlewares) {\n if (middleware.path) {\n app.use(middleware.path, ...middleware.handlers);\n } else {\n app.use(...middleware.handlers);\n }\n }\n}\n\nfunction defaultErrorHandler(\n err: unknown,\n _req: express.Request,\n res: express.Response,\n _next: express.NextFunction,\n) {\n console.error(\"Error handling MCP request:\", err);\n if (!res.headersSent) {\n res.status(500).json({\n jsonrpc: \"2.0\",\n error: { code: -32603, message: \"Internal server error\" },\n id: null,\n });\n }\n}\n\nexport async function createApp({\n mcpServer,\n httpServer,\n errorMiddleware = [],\n}: {\n mcpServer: McpServer;\n httpServer: http.Server;\n errorMiddleware?: {\n path?: string;\n handlers: express.ErrorRequestHandler[];\n }[];\n}): Promise<express.Express> {\n const app = mcpServer.express;\n\n // Read `process.env.NODE_ENV` inline: wrangler/esbuild only substitute the literal expression,\n // so a local const would defeat dead-code elimination of the dev-only imports below.\n if (process.env.NODE_ENV !== \"production\") {\n const { devtoolsStaticServer } = await import(\"@skybridge/devtools\");\n app.use(await devtoolsStaticServer());\n const { viewsDevServer } = await import(\"./viewsDevServer.js\");\n app.use(await viewsDevServer(httpServer));\n\n const controlPort = parseControlPort(process.env.__TUNNEL_CONTROL_PORT);\n if (controlPort !== null) {\n const { createTunnelProxyRouter } = await import(\n \"./tunnel-proxy-router.js\"\n );\n app.use(createTunnelProxyRouter(controlPort));\n } else if (process.env.__TUNNEL_CONTROL_PORT !== undefined) {\n console.warn(\n `Ignoring invalid __TUNNEL_CONTROL_PORT=${process.env.__TUNNEL_CONTROL_PORT}`,\n );\n }\n } else {\n const assetsPath = path.join(process.cwd(), \"dist\", \"assets\");\n\n app.use(\"/assets\", cors());\n app.use(\"/assets\", express.static(assetsPath));\n }\n\n app.use(\"/mcp\", mcpMiddleware(mcpServer));\n\n applyMiddlewares(app, errorMiddleware);\n\n app.use(\"/mcp\", defaultErrorHandler);\n\n return app;\n}\n\nconst mcpMiddleware = (server: McpServer): express.RequestHandler => {\n return async (\n req: express.Request,\n res: express.Response,\n next: express.NextFunction,\n ) => {\n if (req.method !== \"POST\") {\n res.writeHead(405).end(\n JSON.stringify({\n jsonrpc: \"2.0\",\n error: {\n code: -32000,\n message: \"Method not allowed.\",\n },\n id: null,\n }),\n );\n return;\n }\n\n try {\n const transport = new StreamableHTTPServerTransport({\n sessionIdGenerator: undefined,\n // Respond with a single JSON body instead of SSE. Skybridge's stateless\n // transport never streams server-initiated messages, so SSE adds no\n // capability — and on workerd specifically, `cloudflare:node`'s http\n // bridge silently drops chunked writes that happen after the request\n // handler awaits, which manifests as a 200 with empty body for any\n // async tools/call.\n enableJsonResponse: true,\n });\n\n res.on(\"close\", () => {\n transport.close();\n });\n\n await server.connectStatelessTransport(transport);\n // Express strips the mount path from req.url (e.g. \"/mcp\" becomes \"/\").\n // Restore it so the SDK builds the correct requestInfo.url.\n req.url = req.originalUrl;\n await transport.handleRequest(req, res, req.body);\n } catch (error) {\n next(error);\n }\n };\n};\n"]}