@smithery/api 0.31.0 → 0.33.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (289) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/client.d.mts +5 -5
  3. package/client.d.mts.map +1 -1
  4. package/client.d.ts +5 -5
  5. package/client.d.ts.map +1 -1
  6. package/client.js +3 -3
  7. package/client.js.map +1 -1
  8. package/client.mjs +3 -3
  9. package/client.mjs.map +1 -1
  10. package/core/streaming.d.mts +33 -0
  11. package/core/streaming.d.mts.map +1 -0
  12. package/core/streaming.d.ts +33 -0
  13. package/core/streaming.d.ts.map +1 -0
  14. package/core/streaming.js +263 -0
  15. package/core/streaming.js.map +1 -0
  16. package/core/streaming.mjs +258 -0
  17. package/core/streaming.mjs.map +1 -0
  18. package/internal/decoders/line.d.mts +17 -0
  19. package/internal/decoders/line.d.mts.map +1 -0
  20. package/internal/decoders/line.d.ts +17 -0
  21. package/internal/decoders/line.d.ts.map +1 -0
  22. package/internal/decoders/line.js +113 -0
  23. package/internal/decoders/line.js.map +1 -0
  24. package/internal/decoders/line.mjs +108 -0
  25. package/internal/decoders/line.mjs.map +1 -0
  26. package/internal/parse.d.mts.map +1 -1
  27. package/internal/parse.d.ts.map +1 -1
  28. package/internal/parse.js +10 -0
  29. package/internal/parse.js.map +1 -1
  30. package/internal/parse.mjs +10 -0
  31. package/internal/parse.mjs.map +1 -1
  32. package/internal/request-options.d.mts +2 -0
  33. package/internal/request-options.d.mts.map +1 -1
  34. package/internal/request-options.d.ts +2 -0
  35. package/internal/request-options.d.ts.map +1 -1
  36. package/internal/request-options.js.map +1 -1
  37. package/internal/request-options.mjs.map +1 -1
  38. package/lib/mcp-transport.js +3 -3
  39. package/lib/mcp-transport.js.map +1 -1
  40. package/lib/mcp-transport.mjs +3 -3
  41. package/lib/mcp-transport.mjs.map +1 -1
  42. package/package.json +11 -1
  43. package/resources/{beta → experimental}/agents/agents.d.mts +2 -2
  44. package/resources/experimental/agents/agents.d.mts.map +1 -0
  45. package/resources/{beta → experimental}/agents/agents.d.ts +2 -2
  46. package/resources/experimental/agents/agents.d.ts.map +1 -0
  47. package/resources/experimental/agents/agents.js.map +1 -0
  48. package/resources/experimental/agents/agents.mjs.map +1 -0
  49. package/resources/experimental/agents/index.d.mts +3 -0
  50. package/resources/experimental/agents/index.d.mts.map +1 -0
  51. package/resources/experimental/agents/index.d.ts +3 -0
  52. package/resources/experimental/agents/index.d.ts.map +1 -0
  53. package/resources/experimental/agents/index.js.map +1 -0
  54. package/resources/experimental/agents/index.mjs.map +1 -0
  55. package/resources/experimental/agents/responses.d.mts +116 -0
  56. package/resources/experimental/agents/responses.d.mts.map +1 -0
  57. package/resources/experimental/agents/responses.d.ts +116 -0
  58. package/resources/experimental/agents/responses.d.ts.map +1 -0
  59. package/resources/experimental/agents/responses.js +38 -0
  60. package/resources/experimental/agents/responses.js.map +1 -0
  61. package/resources/experimental/agents/responses.mjs +34 -0
  62. package/resources/experimental/agents/responses.mjs.map +1 -0
  63. package/resources/experimental/agents.d.mts.map +1 -0
  64. package/resources/experimental/agents.d.ts.map +1 -0
  65. package/resources/experimental/agents.js.map +1 -0
  66. package/resources/experimental/agents.mjs.map +1 -0
  67. package/resources/experimental/connect/connect.d.mts.map +1 -0
  68. package/resources/experimental/connect/connect.d.ts.map +1 -0
  69. package/resources/experimental/connect/connect.js.map +1 -0
  70. package/resources/experimental/connect/connect.mjs.map +1 -0
  71. package/resources/{beta → experimental}/connect/connections.d.mts +7 -5
  72. package/resources/experimental/connect/connections.d.mts.map +1 -0
  73. package/resources/{beta → experimental}/connect/connections.d.ts +7 -5
  74. package/resources/experimental/connect/connections.d.ts.map +1 -0
  75. package/resources/{beta → experimental}/connect/connections.js +7 -5
  76. package/resources/experimental/connect/connections.js.map +1 -0
  77. package/resources/{beta → experimental}/connect/connections.mjs +7 -5
  78. package/resources/experimental/connect/connections.mjs.map +1 -0
  79. package/resources/experimental/connect/index.d.mts.map +1 -0
  80. package/resources/experimental/connect/index.d.ts.map +1 -0
  81. package/resources/experimental/connect/index.js.map +1 -0
  82. package/resources/experimental/connect/index.mjs.map +1 -0
  83. package/resources/{beta → experimental}/connect/mcp.d.mts +5 -4
  84. package/resources/experimental/connect/mcp.d.mts.map +1 -0
  85. package/resources/{beta → experimental}/connect/mcp.d.ts +5 -4
  86. package/resources/experimental/connect/mcp.d.ts.map +1 -0
  87. package/resources/{beta → experimental}/connect/mcp.js +5 -4
  88. package/resources/experimental/connect/mcp.js.map +1 -0
  89. package/resources/{beta → experimental}/connect/mcp.mjs +5 -4
  90. package/resources/experimental/connect/mcp.mjs.map +1 -0
  91. package/resources/experimental/connect.d.mts.map +1 -0
  92. package/resources/experimental/connect.d.ts.map +1 -0
  93. package/resources/experimental/connect.js.map +1 -0
  94. package/resources/experimental/connect.mjs.map +1 -0
  95. package/resources/{beta/beta.d.mts → experimental/experimental.d.mts} +3 -3
  96. package/resources/experimental/experimental.d.mts.map +1 -0
  97. package/resources/{beta/beta.d.ts → experimental/experimental.d.ts} +3 -3
  98. package/resources/experimental/experimental.d.ts.map +1 -0
  99. package/resources/{beta/beta.js → experimental/experimental.js} +6 -6
  100. package/resources/experimental/experimental.js.map +1 -0
  101. package/resources/{beta/beta.mjs → experimental/experimental.mjs} +4 -4
  102. package/resources/experimental/experimental.mjs.map +1 -0
  103. package/resources/{beta → experimental}/index.d.mts +1 -1
  104. package/resources/experimental/index.d.mts.map +1 -0
  105. package/resources/{beta → experimental}/index.d.ts +1 -1
  106. package/resources/experimental/index.d.ts.map +1 -0
  107. package/resources/{beta → experimental}/index.js +3 -3
  108. package/resources/experimental/index.js.map +1 -0
  109. package/resources/{beta → experimental}/index.mjs +1 -1
  110. package/resources/experimental/index.mjs.map +1 -0
  111. package/resources/experimental.d.mts +2 -0
  112. package/resources/experimental.d.mts.map +1 -0
  113. package/resources/experimental.d.ts +2 -0
  114. package/resources/experimental.d.ts.map +1 -0
  115. package/resources/{beta.js → experimental.js} +2 -2
  116. package/resources/experimental.js.map +1 -0
  117. package/resources/{beta.mjs → experimental.mjs} +2 -2
  118. package/resources/experimental.mjs.map +1 -0
  119. package/resources/index.d.mts +2 -2
  120. package/resources/index.d.mts.map +1 -1
  121. package/resources/index.d.ts +2 -2
  122. package/resources/index.d.ts.map +1 -1
  123. package/resources/index.js +3 -3
  124. package/resources/index.js.map +1 -1
  125. package/resources/index.mjs +1 -1
  126. package/resources/index.mjs.map +1 -1
  127. package/resources/servers/deployments.d.mts +168 -1
  128. package/resources/servers/deployments.d.mts.map +1 -1
  129. package/resources/servers/deployments.d.ts +168 -1
  130. package/resources/servers/deployments.d.ts.map +1 -1
  131. package/resources/servers/deployments.js +100 -0
  132. package/resources/servers/deployments.js.map +1 -1
  133. package/resources/servers/deployments.mjs +100 -0
  134. package/resources/servers/deployments.mjs.map +1 -1
  135. package/resources/servers/index.d.mts +5 -5
  136. package/resources/servers/index.d.mts.map +1 -1
  137. package/resources/servers/index.d.ts +5 -5
  138. package/resources/servers/index.d.ts.map +1 -1
  139. package/resources/servers/index.js.map +1 -1
  140. package/resources/servers/index.mjs +1 -1
  141. package/resources/servers/index.mjs.map +1 -1
  142. package/resources/servers/logs.d.mts +70 -1
  143. package/resources/servers/logs.d.mts.map +1 -1
  144. package/resources/servers/logs.d.ts +70 -1
  145. package/resources/servers/logs.d.ts.map +1 -1
  146. package/resources/servers/logs.js +14 -0
  147. package/resources/servers/logs.js.map +1 -1
  148. package/resources/servers/logs.mjs +14 -0
  149. package/resources/servers/logs.mjs.map +1 -1
  150. package/resources/servers/repo.d.mts +63 -1
  151. package/resources/servers/repo.d.mts.map +1 -1
  152. package/resources/servers/repo.d.ts +63 -1
  153. package/resources/servers/repo.d.ts.map +1 -1
  154. package/resources/servers/repo.js +40 -0
  155. package/resources/servers/repo.js.map +1 -1
  156. package/resources/servers/repo.mjs +40 -0
  157. package/resources/servers/repo.mjs.map +1 -1
  158. package/resources/servers/secrets.d.mts +57 -1
  159. package/resources/servers/secrets.d.mts.map +1 -1
  160. package/resources/servers/secrets.d.ts +57 -1
  161. package/resources/servers/secrets.d.ts.map +1 -1
  162. package/resources/servers/secrets.js +43 -0
  163. package/resources/servers/secrets.js.map +1 -1
  164. package/resources/servers/secrets.mjs +43 -0
  165. package/resources/servers/secrets.mjs.map +1 -1
  166. package/resources/servers/servers.d.mts +67 -9
  167. package/resources/servers/servers.d.mts.map +1 -1
  168. package/resources/servers/servers.d.ts +67 -9
  169. package/resources/servers/servers.d.ts.map +1 -1
  170. package/resources/servers/servers.js +15 -0
  171. package/resources/servers/servers.js.map +1 -1
  172. package/resources/servers/servers.mjs +16 -1
  173. package/resources/servers/servers.mjs.map +1 -1
  174. package/src/client.ts +6 -4
  175. package/src/core/streaming.ts +315 -0
  176. package/src/internal/decoders/line.ts +135 -0
  177. package/src/internal/parse.ts +14 -0
  178. package/src/internal/request-options.ts +2 -0
  179. package/src/lib/mcp-transport.ts +4 -4
  180. package/src/resources/{beta → experimental}/agents/agents.ts +2 -2
  181. package/src/resources/{beta → experimental}/agents/index.ts +1 -1
  182. package/src/resources/experimental/agents/responses.ts +148 -0
  183. package/src/resources/{beta → experimental}/connect/connections.ts +7 -5
  184. package/src/resources/{beta → experimental}/connect/mcp.ts +5 -4
  185. package/src/resources/{beta/beta.ts → experimental/experimental.ts} +4 -4
  186. package/src/resources/{beta → experimental}/index.ts +1 -1
  187. package/src/resources/{beta.ts → experimental.ts} +1 -1
  188. package/src/resources/index.ts +2 -1
  189. package/src/resources/servers/deployments.ts +281 -0
  190. package/src/resources/servers/index.ts +28 -1
  191. package/src/resources/servers/logs.ts +107 -1
  192. package/src/resources/servers/repo.ts +99 -0
  193. package/src/resources/servers/secrets.ts +88 -0
  194. package/src/resources/servers/servers.ts +135 -2
  195. package/src/streaming.ts +2 -0
  196. package/src/version.ts +1 -1
  197. package/streaming.d.mts +2 -0
  198. package/streaming.d.mts.map +1 -0
  199. package/streaming.d.ts +2 -0
  200. package/streaming.d.ts.map +1 -0
  201. package/streaming.js +6 -0
  202. package/streaming.js.map +1 -0
  203. package/streaming.mjs +2 -0
  204. package/streaming.mjs.map +1 -0
  205. package/version.d.mts +1 -1
  206. package/version.d.ts +1 -1
  207. package/version.js +1 -1
  208. package/version.mjs +1 -1
  209. package/resources/beta/agents/agents.d.mts.map +0 -1
  210. package/resources/beta/agents/agents.d.ts.map +0 -1
  211. package/resources/beta/agents/agents.js.map +0 -1
  212. package/resources/beta/agents/agents.mjs.map +0 -1
  213. package/resources/beta/agents/index.d.mts +0 -3
  214. package/resources/beta/agents/index.d.mts.map +0 -1
  215. package/resources/beta/agents/index.d.ts +0 -3
  216. package/resources/beta/agents/index.d.ts.map +0 -1
  217. package/resources/beta/agents/index.js.map +0 -1
  218. package/resources/beta/agents/index.mjs.map +0 -1
  219. package/resources/beta/agents/responses.d.mts +0 -4
  220. package/resources/beta/agents/responses.d.mts.map +0 -1
  221. package/resources/beta/agents/responses.d.ts +0 -4
  222. package/resources/beta/agents/responses.d.ts.map +0 -1
  223. package/resources/beta/agents/responses.js +0 -9
  224. package/resources/beta/agents/responses.js.map +0 -1
  225. package/resources/beta/agents/responses.mjs +0 -5
  226. package/resources/beta/agents/responses.mjs.map +0 -1
  227. package/resources/beta/agents.d.mts.map +0 -1
  228. package/resources/beta/agents.d.ts.map +0 -1
  229. package/resources/beta/agents.js.map +0 -1
  230. package/resources/beta/agents.mjs.map +0 -1
  231. package/resources/beta/beta.d.mts.map +0 -1
  232. package/resources/beta/beta.d.ts.map +0 -1
  233. package/resources/beta/beta.js.map +0 -1
  234. package/resources/beta/beta.mjs.map +0 -1
  235. package/resources/beta/connect/connect.d.mts.map +0 -1
  236. package/resources/beta/connect/connect.d.ts.map +0 -1
  237. package/resources/beta/connect/connect.js.map +0 -1
  238. package/resources/beta/connect/connect.mjs.map +0 -1
  239. package/resources/beta/connect/connections.d.mts.map +0 -1
  240. package/resources/beta/connect/connections.d.ts.map +0 -1
  241. package/resources/beta/connect/connections.js.map +0 -1
  242. package/resources/beta/connect/connections.mjs.map +0 -1
  243. package/resources/beta/connect/index.d.mts.map +0 -1
  244. package/resources/beta/connect/index.d.ts.map +0 -1
  245. package/resources/beta/connect/index.js.map +0 -1
  246. package/resources/beta/connect/index.mjs.map +0 -1
  247. package/resources/beta/connect/mcp.d.mts.map +0 -1
  248. package/resources/beta/connect/mcp.d.ts.map +0 -1
  249. package/resources/beta/connect/mcp.js.map +0 -1
  250. package/resources/beta/connect/mcp.mjs.map +0 -1
  251. package/resources/beta/connect.d.mts.map +0 -1
  252. package/resources/beta/connect.d.ts.map +0 -1
  253. package/resources/beta/connect.js.map +0 -1
  254. package/resources/beta/connect.mjs.map +0 -1
  255. package/resources/beta/index.d.mts.map +0 -1
  256. package/resources/beta/index.d.ts.map +0 -1
  257. package/resources/beta/index.js.map +0 -1
  258. package/resources/beta/index.mjs.map +0 -1
  259. package/resources/beta.d.mts +0 -2
  260. package/resources/beta.d.mts.map +0 -1
  261. package/resources/beta.d.ts +0 -2
  262. package/resources/beta.d.ts.map +0 -1
  263. package/resources/beta.js.map +0 -1
  264. package/resources/beta.mjs.map +0 -1
  265. package/src/resources/beta/agents/responses.ts +0 -5
  266. /package/resources/{beta → experimental}/agents/agents.js +0 -0
  267. /package/resources/{beta → experimental}/agents/agents.mjs +0 -0
  268. /package/resources/{beta → experimental}/agents/index.js +0 -0
  269. /package/resources/{beta → experimental}/agents/index.mjs +0 -0
  270. /package/resources/{beta → experimental}/agents.d.mts +0 -0
  271. /package/resources/{beta → experimental}/agents.d.ts +0 -0
  272. /package/resources/{beta → experimental}/agents.js +0 -0
  273. /package/resources/{beta → experimental}/agents.mjs +0 -0
  274. /package/resources/{beta → experimental}/connect/connect.d.mts +0 -0
  275. /package/resources/{beta → experimental}/connect/connect.d.ts +0 -0
  276. /package/resources/{beta → experimental}/connect/connect.js +0 -0
  277. /package/resources/{beta → experimental}/connect/connect.mjs +0 -0
  278. /package/resources/{beta → experimental}/connect/index.d.mts +0 -0
  279. /package/resources/{beta → experimental}/connect/index.d.ts +0 -0
  280. /package/resources/{beta → experimental}/connect/index.js +0 -0
  281. /package/resources/{beta → experimental}/connect/index.mjs +0 -0
  282. /package/resources/{beta → experimental}/connect.d.mts +0 -0
  283. /package/resources/{beta → experimental}/connect.d.ts +0 -0
  284. /package/resources/{beta → experimental}/connect.js +0 -0
  285. /package/resources/{beta → experimental}/connect.mjs +0 -0
  286. /package/src/resources/{beta → experimental}/agents.ts +0 -0
  287. /package/src/resources/{beta → experimental}/connect/connect.ts +0 -0
  288. /package/src/resources/{beta → experimental}/connect/index.ts +0 -0
  289. /package/src/resources/{beta → experimental}/connect.ts +0 -0
@@ -86,6 +86,21 @@ class Servers extends resource_1.APIResource {
86
86
  const { namespace } = params;
87
87
  return this._client.get((0, path_1.path) `/servers/${namespace}/${server}`, options);
88
88
  }
89
+ /**
90
+ * Get a server by namespace name. Used for namespace-only servers where the
91
+ * namespace name is also the server name. Also handles deprecated encoded
92
+ * patterns.
93
+ *
94
+ * @example
95
+ * ```ts
96
+ * const response = await client.servers.getByNamespace(
97
+ * 'namespace',
98
+ * );
99
+ * ```
100
+ */
101
+ getByNamespace(namespace, options) {
102
+ return this._client.get((0, path_1.path) `/servers/${namespace}`, options);
103
+ }
89
104
  }
90
105
  exports.Servers = Servers;
91
106
  Servers.Deployments = deployments_1.Deployments;
@@ -1 +1 @@
1
- {"version":3,"file":"servers.js","sourceRoot":"","sources":["../../src/resources/servers/servers.ts"],"names":[],"mappings":";AAAA,sFAAsF;;;;AAEtF,qDAAkD;AAClD,yEAAgD;AAChD,kDAeuB;AACvB,2DAAkC;AAClC,oCAA8D;AAC9D,2DAAkC;AAClC,oCAQgB;AAChB,iEAAwC;AACxC,0CAQmB;AAEnB,yDAA2F;AAC3F,uDAAsD;AAEtD,uDAAiD;AAEjD,MAAa,OAAQ,SAAQ,sBAAW;IAAxC;;QACE,gBAAW,GAA+B,IAAI,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvF,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpD,YAAO,GAAuB,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnE,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IA2EtD,CAAC;IAzEC;;;;;;;;;;OAUG;IACH,IAAI,CACF,QAA6C,EAAE,EAC/C,OAAwB;QAExB,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,EAAE,CAAA,yBAAgC,CAAA,EAAE,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;IACtG,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CACJ,MAAc,EACd,MAA0B,EAC1B,OAAwB;QAExB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,QAAQ,CAAC,MAAc,EAAE,MAA4B,EAAE,OAAwB;QAC7E,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,IAAI,MAAM,WAAW,EAAE;YACtE,GAAG,OAAO;YACV,OAAO,EAAE,IAAA,sBAAY,EAAC,CAAC,EAAE,MAAM,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YACxE,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,GAAG,CAAC,MAAc,EAAE,MAAuB,EAAE,OAAwB;QACnE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC1E,CAAC;CACF;AA/ED,0BA+EC;AAiMD,OAAO,CAAC,WAAW,GAAG,yBAAW,CAAC;AAClC,OAAO,CAAC,IAAI,GAAG,WAAI,CAAC;AACpB,OAAO,CAAC,OAAO,GAAG,iBAAO,CAAC;AAC1B,OAAO,CAAC,IAAI,GAAG,WAAI,CAAC"}
1
+ {"version":3,"file":"servers.js","sourceRoot":"","sources":["../../src/resources/servers/servers.ts"],"names":[],"mappings":";AAAA,sFAAsF;;;;AAEtF,qDAAkD;AAClD,yEAAgD;AAChD,kDA0BuB;AACvB,2DAAkC;AAClC,oCAMgB;AAChB,2DAAkC;AAClC,oCAYgB;AAChB,iEAAwC;AACxC,0CAamB;AAEnB,yDAA2F;AAC3F,uDAAsD;AAEtD,uDAAiD;AAEjD,MAAa,OAAQ,SAAQ,sBAAW;IAAxC;;QACE,gBAAW,GAA+B,IAAI,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvF,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpD,YAAO,GAAuB,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnE,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IA2FtD,CAAC;IAzFC;;;;;;;;;;OAUG;IACH,IAAI,CACF,QAA6C,EAAE,EAC/C,OAAwB;QAExB,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,EAAE,CAAA,yBAAgC,CAAA,EAAE,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;IACtG,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CACJ,MAAc,EACd,MAA0B,EAC1B,OAAwB;QAExB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,QAAQ,CAAC,MAAc,EAAE,MAA4B,EAAE,OAAwB;QAC7E,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,IAAI,MAAM,WAAW,EAAE;YACtE,GAAG,OAAO;YACV,OAAO,EAAE,IAAA,sBAAY,EAAC,CAAC,EAAE,MAAM,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YACxE,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,GAAG,CAAC,MAAc,EAAE,MAAuB,EAAE,OAAwB;QACnE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC1E,CAAC;IAED;;;;;;;;;;;OAWG;IACH,cAAc,CAAC,SAAiB,EAAE,OAAwB;QACxD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAA,WAAI,EAAA,YAAY,SAAS,EAAE,EAAE,OAAO,CAAC,CAAC;IAChE,CAAC;CACF;AA/FD,0BA+FC;AAiQD,OAAO,CAAC,WAAW,GAAG,yBAAW,CAAC;AAClC,OAAO,CAAC,IAAI,GAAG,WAAI,CAAC;AACpB,OAAO,CAAC,OAAO,GAAG,iBAAO,CAAC;AAC1B,OAAO,CAAC,IAAI,GAAG,WAAI,CAAC"}
@@ -3,7 +3,7 @@ import { APIResource } from "../../core/resource.mjs";
3
3
  import * as DeploymentsAPI from "./deployments.mjs";
4
4
  import { Deployments, } from "./deployments.mjs";
5
5
  import * as LogsAPI from "./logs.mjs";
6
- import { Logs } from "./logs.mjs";
6
+ import { Logs, } from "./logs.mjs";
7
7
  import * as RepoAPI from "./repo.mjs";
8
8
  import { Repo, } from "./repo.mjs";
9
9
  import * as SecretsAPI from "./secrets.mjs";
@@ -82,6 +82,21 @@ export class Servers extends APIResource {
82
82
  const { namespace } = params;
83
83
  return this._client.get(path `/servers/${namespace}/${server}`, options);
84
84
  }
85
+ /**
86
+ * Get a server by namespace name. Used for namespace-only servers where the
87
+ * namespace name is also the server name. Also handles deprecated encoded
88
+ * patterns.
89
+ *
90
+ * @example
91
+ * ```ts
92
+ * const response = await client.servers.getByNamespace(
93
+ * 'namespace',
94
+ * );
95
+ * ```
96
+ */
97
+ getByNamespace(namespace, options) {
98
+ return this._client.get(path `/servers/${namespace}`, options);
99
+ }
85
100
  }
86
101
  Servers.Deployments = Deployments;
87
102
  Servers.Logs = Logs;
@@ -1 +1 @@
1
- {"version":3,"file":"servers.mjs","sourceRoot":"","sources":["../../src/resources/servers/servers.ts"],"names":[],"mappings":"AAAA,sFAAsF;OAE/E,EAAE,WAAW,EAAE;OACf,KAAK,cAAc;OACnB,EAUL,WAAW,GAKZ;OACM,KAAK,OAAO;OACZ,EAAkC,IAAI,EAAE;OACxC,KAAK,OAAO;OACZ,EACL,IAAI,GAOL;OACM,KAAK,UAAU;OACf,EAOL,OAAO,GACR;OAEM,EAAe,YAAY,EAA2B;OACtD,EAAE,YAAY,EAAE;OAEhB,EAAE,IAAI,EAAE;AAEf,MAAM,OAAO,OAAQ,SAAQ,WAAW;IAAxC;;QACE,gBAAW,GAA+B,IAAI,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvF,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpD,YAAO,GAAuB,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnE,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IA2EtD,CAAC;IAzEC;;;;;;;;;;OAUG;IACH,IAAI,CACF,QAA6C,EAAE,EAC/C,OAAwB;QAExB,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,EAAE,CAAA,YAAgC,CAAA,EAAE,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;IACtG,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CACJ,MAAc,EACd,MAA0B,EAC1B,OAAwB;QAExB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,QAAQ,CAAC,MAAc,EAAE,MAA4B,EAAE,OAAwB;QAC7E,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAA,YAAY,SAAS,IAAI,MAAM,WAAW,EAAE;YACtE,GAAG,OAAO;YACV,OAAO,EAAE,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YACxE,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,GAAG,CAAC,MAAc,EAAE,MAAuB,EAAE,OAAwB;QACnE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC1E,CAAC;CACF;AAiMD,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC;AAClC,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;AACpB,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC;AAC1B,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC"}
1
+ {"version":3,"file":"servers.mjs","sourceRoot":"","sources":["../../src/resources/servers/servers.ts"],"names":[],"mappings":"AAAA,sFAAsF;OAE/E,EAAE,WAAW,EAAE;OACf,KAAK,cAAc;OACnB,EAqBL,WAAW,GAKZ;OACM,KAAK,OAAO;OACZ,EAKL,IAAI,GACL;OACM,KAAK,OAAO;OACZ,EACL,IAAI,GAWL;OACM,KAAK,UAAU;OACf,EAYL,OAAO,GACR;OAEM,EAAe,YAAY,EAA2B;OACtD,EAAE,YAAY,EAAE;OAEhB,EAAE,IAAI,EAAE;AAEf,MAAM,OAAO,OAAQ,SAAQ,WAAW;IAAxC;;QACE,gBAAW,GAA+B,IAAI,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvF,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpD,YAAO,GAAuB,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnE,SAAI,GAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IA2FtD,CAAC;IAzFC;;;;;;;;;;OAUG;IACH,IAAI,CACF,QAA6C,EAAE,EAC/C,OAAwB;QAExB,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,EAAE,CAAA,YAAgC,CAAA,EAAE,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;IACtG,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CACJ,MAAc,EACd,MAA0B,EAC1B,OAAwB;QAExB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,QAAQ,CAAC,MAAc,EAAE,MAA4B,EAAE,OAAwB;QAC7E,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAA,YAAY,SAAS,IAAI,MAAM,WAAW,EAAE;YACtE,GAAG,OAAO;YACV,OAAO,EAAE,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YACxE,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,GAAG,CAAC,MAAc,EAAE,MAAuB,EAAE,OAAwB;QACnE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAA,YAAY,SAAS,IAAI,MAAM,EAAE,EAAE,OAAO,CAAC,CAAC;IAC1E,CAAC;IAED;;;;;;;;;;;OAWG;IACH,cAAc,CAAC,SAAiB,EAAE,OAAwB;QACxD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAA,YAAY,SAAS,EAAE,EAAE,OAAO,CAAC,CAAC;IAChE,CAAC;CACF;AAiQD,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC;AAClC,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;AACpB,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC;AAC1B,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC"}
package/src/client.ts CHANGED
@@ -39,7 +39,7 @@ import {
39
39
  Tokens,
40
40
  } from './resources/tokens';
41
41
  import { Uplink, UplinkCreateTokenResponse } from './resources/uplink';
42
- import { Beta } from './resources/beta/beta';
42
+ import { Experimental } from './resources/experimental/experimental';
43
43
  import {
44
44
  NamespaceCreateResponse,
45
45
  NamespaceListResponse,
@@ -53,6 +53,7 @@ import {
53
53
  ServerDeleteParams,
54
54
  ServerDeleteResponse,
55
55
  ServerDownloadParams,
56
+ ServerGetByNamespaceResponse,
56
57
  ServerGetParams,
57
58
  ServerGetResponse,
58
59
  ServerListParams,
@@ -766,7 +767,7 @@ export class Smithery {
766
767
  skills: API.Skills = new API.Skills(this);
767
768
  namespaces: API.Namespaces = new API.Namespaces(this);
768
769
  tokens: API.Tokens = new API.Tokens(this);
769
- beta: API.Beta = new API.Beta(this);
770
+ experimental: API.Experimental = new API.Experimental(this);
770
771
  }
771
772
 
772
773
  Smithery.Health = Health;
@@ -775,7 +776,7 @@ Smithery.Uplink = Uplink;
775
776
  Smithery.Skills = Skills;
776
777
  Smithery.Namespaces = Namespaces;
777
778
  Smithery.Tokens = Tokens;
778
- Smithery.Beta = Beta;
779
+ Smithery.Experimental = Experimental;
779
780
 
780
781
  export declare namespace Smithery {
781
782
  export type RequestOptions = Opts.RequestOptions;
@@ -796,6 +797,7 @@ export declare namespace Smithery {
796
797
  type ServerListResponse as ServerListResponse,
797
798
  type ServerDeleteResponse as ServerDeleteResponse,
798
799
  type ServerGetResponse as ServerGetResponse,
800
+ type ServerGetByNamespaceResponse as ServerGetByNamespaceResponse,
799
801
  type ServerListResponsesSmitheryPage as ServerListResponsesSmitheryPage,
800
802
  type ServerListParams as ServerListParams,
801
803
  type ServerDeleteParams as ServerDeleteParams,
@@ -831,5 +833,5 @@ export declare namespace Smithery {
831
833
  type TokenCreateParams as TokenCreateParams,
832
834
  };
833
835
 
834
- export { Beta as Beta };
836
+ export { Experimental as Experimental };
835
837
  }
@@ -0,0 +1,315 @@
1
+ import { SmitheryError } from './error';
2
+ import { type ReadableStream } from '../internal/shim-types';
3
+ import { makeReadableStream } from '../internal/shims';
4
+ import { findDoubleNewlineIndex, LineDecoder } from '../internal/decoders/line';
5
+ import { ReadableStreamToAsyncIterable } from '../internal/shims';
6
+ import { isAbortError } from '../internal/errors';
7
+ import { encodeUTF8 } from '../internal/utils/bytes';
8
+ import { loggerFor } from '../internal/utils/log';
9
+ import type { Smithery } from '../client';
10
+
11
+ type Bytes = string | ArrayBuffer | Uint8Array | null | undefined;
12
+
13
+ export type ServerSentEvent = {
14
+ event: string | null;
15
+ data: string;
16
+ raw: string[];
17
+ };
18
+
19
+ export class Stream<Item> implements AsyncIterable<Item> {
20
+ controller: AbortController;
21
+ #client: Smithery | undefined;
22
+
23
+ constructor(
24
+ private iterator: () => AsyncIterator<Item>,
25
+ controller: AbortController,
26
+ client?: Smithery,
27
+ ) {
28
+ this.controller = controller;
29
+ this.#client = client;
30
+ }
31
+
32
+ static fromSSEResponse<Item>(
33
+ response: Response,
34
+ controller: AbortController,
35
+ client?: Smithery,
36
+ ): Stream<Item> {
37
+ let consumed = false;
38
+ const logger = client ? loggerFor(client) : console;
39
+
40
+ async function* iterator(): AsyncIterator<Item, any, undefined> {
41
+ if (consumed) {
42
+ throw new SmitheryError('Cannot iterate over a consumed stream, use `.tee()` to split the stream.');
43
+ }
44
+ consumed = true;
45
+ let done = false;
46
+ try {
47
+ for await (const sse of _iterSSEMessages(response, controller)) {
48
+ try {
49
+ yield JSON.parse(sse.data);
50
+ } catch (e) {
51
+ logger.error(`Could not parse message into JSON:`, sse.data);
52
+ logger.error(`From chunk:`, sse.raw);
53
+ throw e;
54
+ }
55
+ }
56
+ done = true;
57
+ } catch (e) {
58
+ // If the user calls `stream.controller.abort()`, we should exit without throwing.
59
+ if (isAbortError(e)) return;
60
+ throw e;
61
+ } finally {
62
+ // If the user `break`s, abort the ongoing request.
63
+ if (!done) controller.abort();
64
+ }
65
+ }
66
+
67
+ return new Stream(iterator, controller, client);
68
+ }
69
+
70
+ /**
71
+ * Generates a Stream from a newline-separated ReadableStream
72
+ * where each item is a JSON value.
73
+ */
74
+ static fromReadableStream<Item>(
75
+ readableStream: ReadableStream,
76
+ controller: AbortController,
77
+ client?: Smithery,
78
+ ): Stream<Item> {
79
+ let consumed = false;
80
+
81
+ async function* iterLines(): AsyncGenerator<string, void, unknown> {
82
+ const lineDecoder = new LineDecoder();
83
+
84
+ const iter = ReadableStreamToAsyncIterable<Bytes>(readableStream);
85
+ for await (const chunk of iter) {
86
+ for (const line of lineDecoder.decode(chunk)) {
87
+ yield line;
88
+ }
89
+ }
90
+
91
+ for (const line of lineDecoder.flush()) {
92
+ yield line;
93
+ }
94
+ }
95
+
96
+ async function* iterator(): AsyncIterator<Item, any, undefined> {
97
+ if (consumed) {
98
+ throw new SmitheryError('Cannot iterate over a consumed stream, use `.tee()` to split the stream.');
99
+ }
100
+ consumed = true;
101
+ let done = false;
102
+ try {
103
+ for await (const line of iterLines()) {
104
+ if (done) continue;
105
+ if (line) yield JSON.parse(line);
106
+ }
107
+ done = true;
108
+ } catch (e) {
109
+ // If the user calls `stream.controller.abort()`, we should exit without throwing.
110
+ if (isAbortError(e)) return;
111
+ throw e;
112
+ } finally {
113
+ // If the user `break`s, abort the ongoing request.
114
+ if (!done) controller.abort();
115
+ }
116
+ }
117
+
118
+ return new Stream(iterator, controller, client);
119
+ }
120
+
121
+ [Symbol.asyncIterator](): AsyncIterator<Item> {
122
+ return this.iterator();
123
+ }
124
+
125
+ /**
126
+ * Splits the stream into two streams which can be
127
+ * independently read from at different speeds.
128
+ */
129
+ tee(): [Stream<Item>, Stream<Item>] {
130
+ const left: Array<Promise<IteratorResult<Item>>> = [];
131
+ const right: Array<Promise<IteratorResult<Item>>> = [];
132
+ const iterator = this.iterator();
133
+
134
+ const teeIterator = (queue: Array<Promise<IteratorResult<Item>>>): AsyncIterator<Item> => {
135
+ return {
136
+ next: () => {
137
+ if (queue.length === 0) {
138
+ const result = iterator.next();
139
+ left.push(result);
140
+ right.push(result);
141
+ }
142
+ return queue.shift()!;
143
+ },
144
+ };
145
+ };
146
+
147
+ return [
148
+ new Stream(() => teeIterator(left), this.controller, this.#client),
149
+ new Stream(() => teeIterator(right), this.controller, this.#client),
150
+ ];
151
+ }
152
+
153
+ /**
154
+ * Converts this stream to a newline-separated ReadableStream of
155
+ * JSON stringified values in the stream
156
+ * which can be turned back into a Stream with `Stream.fromReadableStream()`.
157
+ */
158
+ toReadableStream(): ReadableStream {
159
+ const self = this;
160
+ let iter: AsyncIterator<Item>;
161
+
162
+ return makeReadableStream({
163
+ async start() {
164
+ iter = self[Symbol.asyncIterator]();
165
+ },
166
+ async pull(ctrl: any) {
167
+ try {
168
+ const { value, done } = await iter.next();
169
+ if (done) return ctrl.close();
170
+
171
+ const bytes = encodeUTF8(JSON.stringify(value) + '\n');
172
+
173
+ ctrl.enqueue(bytes);
174
+ } catch (err) {
175
+ ctrl.error(err);
176
+ }
177
+ },
178
+ async cancel() {
179
+ await iter.return?.();
180
+ },
181
+ });
182
+ }
183
+ }
184
+
185
+ export async function* _iterSSEMessages(
186
+ response: Response,
187
+ controller: AbortController,
188
+ ): AsyncGenerator<ServerSentEvent, void, unknown> {
189
+ if (!response.body) {
190
+ controller.abort();
191
+ if (
192
+ typeof (globalThis as any).navigator !== 'undefined' &&
193
+ (globalThis as any).navigator.product === 'ReactNative'
194
+ ) {
195
+ throw new SmitheryError(
196
+ `The default react-native fetch implementation does not support streaming. Please use expo/fetch: https://docs.expo.dev/versions/latest/sdk/expo/#expofetch-api`,
197
+ );
198
+ }
199
+ throw new SmitheryError(`Attempted to iterate over a response with no body`);
200
+ }
201
+
202
+ const sseDecoder = new SSEDecoder();
203
+ const lineDecoder = new LineDecoder();
204
+
205
+ const iter = ReadableStreamToAsyncIterable<Bytes>(response.body);
206
+ for await (const sseChunk of iterSSEChunks(iter)) {
207
+ for (const line of lineDecoder.decode(sseChunk)) {
208
+ const sse = sseDecoder.decode(line);
209
+ if (sse) yield sse;
210
+ }
211
+ }
212
+
213
+ for (const line of lineDecoder.flush()) {
214
+ const sse = sseDecoder.decode(line);
215
+ if (sse) yield sse;
216
+ }
217
+ }
218
+
219
+ /**
220
+ * Given an async iterable iterator, iterates over it and yields full
221
+ * SSE chunks, i.e. yields when a double new-line is encountered.
222
+ */
223
+ async function* iterSSEChunks(iterator: AsyncIterableIterator<Bytes>): AsyncGenerator<Uint8Array> {
224
+ let data = new Uint8Array();
225
+
226
+ for await (const chunk of iterator) {
227
+ if (chunk == null) {
228
+ continue;
229
+ }
230
+
231
+ const binaryChunk =
232
+ chunk instanceof ArrayBuffer ? new Uint8Array(chunk)
233
+ : typeof chunk === 'string' ? encodeUTF8(chunk)
234
+ : chunk;
235
+
236
+ let newData = new Uint8Array(data.length + binaryChunk.length);
237
+ newData.set(data);
238
+ newData.set(binaryChunk, data.length);
239
+ data = newData;
240
+
241
+ let patternIndex;
242
+ while ((patternIndex = findDoubleNewlineIndex(data)) !== -1) {
243
+ yield data.slice(0, patternIndex);
244
+ data = data.slice(patternIndex);
245
+ }
246
+ }
247
+
248
+ if (data.length > 0) {
249
+ yield data;
250
+ }
251
+ }
252
+
253
+ class SSEDecoder {
254
+ private data: string[];
255
+ private event: string | null;
256
+ private chunks: string[];
257
+
258
+ constructor() {
259
+ this.event = null;
260
+ this.data = [];
261
+ this.chunks = [];
262
+ }
263
+
264
+ decode(line: string) {
265
+ if (line.endsWith('\r')) {
266
+ line = line.substring(0, line.length - 1);
267
+ }
268
+
269
+ if (!line) {
270
+ // empty line and we didn't previously encounter any messages
271
+ if (!this.event && !this.data.length) return null;
272
+
273
+ const sse: ServerSentEvent = {
274
+ event: this.event,
275
+ data: this.data.join('\n'),
276
+ raw: this.chunks,
277
+ };
278
+
279
+ this.event = null;
280
+ this.data = [];
281
+ this.chunks = [];
282
+
283
+ return sse;
284
+ }
285
+
286
+ this.chunks.push(line);
287
+
288
+ if (line.startsWith(':')) {
289
+ return null;
290
+ }
291
+
292
+ let [fieldname, _, value] = partition(line, ':');
293
+
294
+ if (value.startsWith(' ')) {
295
+ value = value.substring(1);
296
+ }
297
+
298
+ if (fieldname === 'event') {
299
+ this.event = value;
300
+ } else if (fieldname === 'data') {
301
+ this.data.push(value);
302
+ }
303
+
304
+ return null;
305
+ }
306
+ }
307
+
308
+ function partition(str: string, delimiter: string): [string, string, string] {
309
+ const index = str.indexOf(delimiter);
310
+ if (index !== -1) {
311
+ return [str.substring(0, index), delimiter, str.substring(index + delimiter.length)];
312
+ }
313
+
314
+ return [str, '', ''];
315
+ }
@@ -0,0 +1,135 @@
1
+ import { concatBytes, decodeUTF8, encodeUTF8 } from '../utils/bytes';
2
+
3
+ export type Bytes = string | ArrayBuffer | Uint8Array | null | undefined;
4
+
5
+ /**
6
+ * A re-implementation of httpx's `LineDecoder` in Python that handles incrementally
7
+ * reading lines from text.
8
+ *
9
+ * https://github.com/encode/httpx/blob/920333ea98118e9cf617f246905d7b202510941c/httpx/_decoders.py#L258
10
+ */
11
+ export class LineDecoder {
12
+ // prettier-ignore
13
+ static NEWLINE_CHARS = new Set(['\n', '\r']);
14
+ static NEWLINE_REGEXP = /\r\n|[\n\r]/g;
15
+
16
+ #buffer: Uint8Array;
17
+ #carriageReturnIndex: number | null;
18
+
19
+ constructor() {
20
+ this.#buffer = new Uint8Array();
21
+ this.#carriageReturnIndex = null;
22
+ }
23
+
24
+ decode(chunk: Bytes): string[] {
25
+ if (chunk == null) {
26
+ return [];
27
+ }
28
+
29
+ const binaryChunk =
30
+ chunk instanceof ArrayBuffer ? new Uint8Array(chunk)
31
+ : typeof chunk === 'string' ? encodeUTF8(chunk)
32
+ : chunk;
33
+
34
+ this.#buffer = concatBytes([this.#buffer, binaryChunk]);
35
+
36
+ const lines: string[] = [];
37
+ let patternIndex;
38
+ while ((patternIndex = findNewlineIndex(this.#buffer, this.#carriageReturnIndex)) != null) {
39
+ if (patternIndex.carriage && this.#carriageReturnIndex == null) {
40
+ // skip until we either get a corresponding `\n`, a new `\r` or nothing
41
+ this.#carriageReturnIndex = patternIndex.index;
42
+ continue;
43
+ }
44
+
45
+ // we got double \r or \rtext\n
46
+ if (
47
+ this.#carriageReturnIndex != null &&
48
+ (patternIndex.index !== this.#carriageReturnIndex + 1 || patternIndex.carriage)
49
+ ) {
50
+ lines.push(decodeUTF8(this.#buffer.subarray(0, this.#carriageReturnIndex - 1)));
51
+ this.#buffer = this.#buffer.subarray(this.#carriageReturnIndex);
52
+ this.#carriageReturnIndex = null;
53
+ continue;
54
+ }
55
+
56
+ const endIndex =
57
+ this.#carriageReturnIndex !== null ? patternIndex.preceding - 1 : patternIndex.preceding;
58
+
59
+ const line = decodeUTF8(this.#buffer.subarray(0, endIndex));
60
+ lines.push(line);
61
+
62
+ this.#buffer = this.#buffer.subarray(patternIndex.index);
63
+ this.#carriageReturnIndex = null;
64
+ }
65
+
66
+ return lines;
67
+ }
68
+
69
+ flush(): string[] {
70
+ if (!this.#buffer.length) {
71
+ return [];
72
+ }
73
+ return this.decode('\n');
74
+ }
75
+ }
76
+
77
+ /**
78
+ * This function searches the buffer for the end patterns, (\r or \n)
79
+ * and returns an object with the index preceding the matched newline and the
80
+ * index after the newline char. `null` is returned if no new line is found.
81
+ *
82
+ * ```ts
83
+ * findNewLineIndex('abc\ndef') -> { preceding: 2, index: 3 }
84
+ * ```
85
+ */
86
+ function findNewlineIndex(
87
+ buffer: Uint8Array,
88
+ startIndex: number | null,
89
+ ): { preceding: number; index: number; carriage: boolean } | null {
90
+ const newline = 0x0a; // \n
91
+ const carriage = 0x0d; // \r
92
+
93
+ for (let i = startIndex ?? 0; i < buffer.length; i++) {
94
+ if (buffer[i] === newline) {
95
+ return { preceding: i, index: i + 1, carriage: false };
96
+ }
97
+
98
+ if (buffer[i] === carriage) {
99
+ return { preceding: i, index: i + 1, carriage: true };
100
+ }
101
+ }
102
+
103
+ return null;
104
+ }
105
+
106
+ export function findDoubleNewlineIndex(buffer: Uint8Array): number {
107
+ // This function searches the buffer for the end patterns (\r\r, \n\n, \r\n\r\n)
108
+ // and returns the index right after the first occurrence of any pattern,
109
+ // or -1 if none of the patterns are found.
110
+ const newline = 0x0a; // \n
111
+ const carriage = 0x0d; // \r
112
+
113
+ for (let i = 0; i < buffer.length - 1; i++) {
114
+ if (buffer[i] === newline && buffer[i + 1] === newline) {
115
+ // \n\n
116
+ return i + 2;
117
+ }
118
+ if (buffer[i] === carriage && buffer[i + 1] === carriage) {
119
+ // \r\r
120
+ return i + 2;
121
+ }
122
+ if (
123
+ buffer[i] === carriage &&
124
+ buffer[i + 1] === newline &&
125
+ i + 3 < buffer.length &&
126
+ buffer[i + 2] === carriage &&
127
+ buffer[i + 3] === newline
128
+ ) {
129
+ // \r\n\r\n
130
+ return i + 4;
131
+ }
132
+ }
133
+
134
+ return -1;
135
+ }
@@ -1,6 +1,7 @@
1
1
  // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
3
  import type { FinalRequestOptions } from './request-options';
4
+ import { Stream } from '../core/streaming';
4
5
  import { type Smithery } from '../client';
5
6
  import { formatRequestDetails, loggerFor } from './utils/log';
6
7
 
@@ -16,6 +17,19 @@ export type APIResponseProps = {
16
17
  export async function defaultParseResponse<T>(client: Smithery, props: APIResponseProps): Promise<T> {
17
18
  const { response, requestLogID, retryOfRequestLogID, startTime } = props;
18
19
  const body = await (async () => {
20
+ if (props.options.stream) {
21
+ loggerFor(client).debug('response', response.status, response.url, response.headers, response.body);
22
+
23
+ // Note: there is an invariant here that isn't represented in the type system
24
+ // that if you set `stream: true` the response type must also be `Stream<T>`
25
+
26
+ if (props.options.__streamClass) {
27
+ return props.options.__streamClass.fromSSEResponse(response, props.controller, client) as any;
28
+ }
29
+
30
+ return Stream.fromSSEResponse(response, props.controller, client) as any;
31
+ }
32
+
19
33
  // fetch refuses to read the body when the status code is 204.
20
34
  if (response.status === 204) {
21
35
  return null as T;
@@ -3,6 +3,7 @@
3
3
  import { NullableHeaders } from './headers';
4
4
 
5
5
  import type { BodyInit } from './builtin-types';
6
+ import { Stream } from '../core/streaming';
6
7
  import type { HTTPMethod, MergedRequestInit } from './types';
7
8
  import { type HeadersLike } from './headers';
8
9
 
@@ -76,6 +77,7 @@ export type RequestOptions = {
76
77
  defaultBaseURL?: string | undefined;
77
78
 
78
79
  __binaryResponse?: boolean | undefined;
80
+ __streamClass?: typeof Stream;
79
81
  };
80
82
 
81
83
  export type EncodedContent = { bodyHeaders: HeadersLike; body: BodyInit };
@@ -33,7 +33,7 @@
33
33
 
34
34
  import { StreamableHTTPClientTransport } from '@modelcontextprotocol/sdk/client/streamableHttp.js';
35
35
  import { Smithery } from '../client';
36
- import type { Connection } from '../resources/beta/connect/connections';
36
+ import type { Connection } from '../resources/experimental/connect/connections';
37
37
 
38
38
  export interface CreateConnectionOptions {
39
39
  /**
@@ -181,15 +181,15 @@ async function resolveConnection(
181
181
  if (connectionId) {
182
182
  // Connection ID provided: try to get, or create if mcpUrl is provided
183
183
  try {
184
- return await client.beta.connect.connections.get(connectionId, { namespace });
184
+ return await client.experimental.connect.connections.get(connectionId, { namespace });
185
185
  } catch (error) {
186
186
  if (mcpUrl) {
187
- return await client.beta.connect.connections.set(connectionId, { namespace, mcpUrl });
187
+ return await client.experimental.connect.connections.set(connectionId, { namespace, mcpUrl });
188
188
  }
189
189
  throw error;
190
190
  }
191
191
  }
192
192
 
193
193
  // No connection ID: create a new connection with auto-generated ID
194
- return await client.beta.connect.connections.create(namespace, { mcpUrl: mcpUrl! });
194
+ return await client.experimental.connect.connections.create(namespace, { mcpUrl: mcpUrl! });
195
195
  }
@@ -2,7 +2,7 @@
2
2
 
3
3
  import { APIResource } from '../../../core/resource';
4
4
  import * as ResponsesAPI from './responses';
5
- import { Responses } from './responses';
5
+ import { ResponseCreateParams, Responses } from './responses';
6
6
 
7
7
  export class Agents extends APIResource {
8
8
  responses: ResponsesAPI.Responses = new ResponsesAPI.Responses(this._client);
@@ -292,5 +292,5 @@ export declare namespace Agents {
292
292
  type Response as Response,
293
293
  };
294
294
 
295
- export { Responses as Responses };
295
+ export { Responses as Responses, type ResponseCreateParams as ResponseCreateParams };
296
296
  }
@@ -1,4 +1,4 @@
1
1
  // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
3
  export { Agents, type CreateResponseRequest, type ErrorResponse, type Response } from './agents';
4
- export { Responses } from './responses';
4
+ export { Responses, type ResponseCreateParams } from './responses';