@unkey/api 2.0.0-alpha.1 → 2.0.0-alpha.5

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 (344) hide show
  1. package/README.md +99 -34
  2. package/bin/mcp-server.js +37676 -0
  3. package/bin/mcp-server.js.map +275 -0
  4. package/dist/commonjs/funcs/livenessCheck.d.ts +2 -2
  5. package/dist/commonjs/funcs/livenessCheck.d.ts.map +1 -1
  6. package/dist/commonjs/funcs/livenessCheck.js +5 -11
  7. package/dist/commonjs/funcs/livenessCheck.js.map +1 -1
  8. package/dist/commonjs/funcs/ratelimitDeleteOverride.d.ts +1 -2
  9. package/dist/commonjs/funcs/ratelimitDeleteOverride.d.ts.map +1 -1
  10. package/dist/commonjs/funcs/ratelimitDeleteOverride.js +5 -16
  11. package/dist/commonjs/funcs/ratelimitDeleteOverride.js.map +1 -1
  12. package/dist/commonjs/funcs/ratelimitGetOverride.d.ts +1 -2
  13. package/dist/commonjs/funcs/ratelimitGetOverride.d.ts.map +1 -1
  14. package/dist/commonjs/funcs/ratelimitGetOverride.js +5 -16
  15. package/dist/commonjs/funcs/ratelimitGetOverride.js.map +1 -1
  16. package/dist/commonjs/funcs/ratelimitLimit.d.ts +1 -2
  17. package/dist/commonjs/funcs/ratelimitLimit.d.ts.map +1 -1
  18. package/dist/commonjs/funcs/ratelimitLimit.js +5 -16
  19. package/dist/commonjs/funcs/ratelimitLimit.js.map +1 -1
  20. package/dist/commonjs/funcs/ratelimitSetOverride.d.ts +1 -2
  21. package/dist/commonjs/funcs/ratelimitSetOverride.d.ts.map +1 -1
  22. package/dist/commonjs/funcs/ratelimitSetOverride.js +5 -16
  23. package/dist/commonjs/funcs/ratelimitSetOverride.js.map +1 -1
  24. package/dist/commonjs/lib/config.d.ts +3 -3
  25. package/dist/commonjs/lib/config.js +3 -3
  26. package/dist/commonjs/lib/matchers.d.ts.map +1 -1
  27. package/dist/commonjs/lib/matchers.js +5 -1
  28. package/dist/commonjs/lib/matchers.js.map +1 -1
  29. package/dist/commonjs/mcp-server/cli/start/command.d.ts +2 -0
  30. package/dist/commonjs/mcp-server/cli/start/command.d.ts.map +1 -0
  31. package/dist/commonjs/mcp-server/cli/start/command.js +138 -0
  32. package/dist/commonjs/mcp-server/cli/start/command.js.map +1 -0
  33. package/dist/commonjs/mcp-server/cli/start/impl.d.ts +18 -0
  34. package/dist/commonjs/mcp-server/cli/start/impl.d.ts.map +1 -0
  35. package/dist/commonjs/mcp-server/cli/start/impl.js +104 -0
  36. package/dist/commonjs/mcp-server/cli/start/impl.js.map +1 -0
  37. package/dist/commonjs/mcp-server/cli.d.ts +6 -0
  38. package/dist/commonjs/mcp-server/cli.d.ts.map +1 -0
  39. package/dist/commonjs/mcp-server/cli.js +10 -0
  40. package/dist/commonjs/mcp-server/cli.js.map +1 -0
  41. package/dist/commonjs/mcp-server/console-logger.d.ts +7 -0
  42. package/dist/commonjs/mcp-server/console-logger.d.ts.map +1 -0
  43. package/dist/commonjs/mcp-server/console-logger.js +59 -0
  44. package/dist/commonjs/mcp-server/console-logger.js.map +1 -0
  45. package/dist/commonjs/mcp-server/extensions.d.ts +11 -0
  46. package/dist/commonjs/mcp-server/extensions.d.ts.map +1 -0
  47. package/dist/commonjs/mcp-server/extensions.js +6 -0
  48. package/dist/commonjs/mcp-server/extensions.js.map +1 -0
  49. package/dist/commonjs/mcp-server/mcp-server.d.ts +2 -0
  50. package/dist/commonjs/mcp-server/mcp-server.d.ts.map +1 -0
  51. package/dist/commonjs/mcp-server/mcp-server.js +29 -0
  52. package/dist/commonjs/mcp-server/mcp-server.js.map +1 -0
  53. package/dist/commonjs/mcp-server/prompts.d.ts +26 -0
  54. package/dist/commonjs/mcp-server/prompts.d.ts.map +1 -0
  55. package/dist/commonjs/mcp-server/prompts.js +47 -0
  56. package/dist/commonjs/mcp-server/prompts.js.map +1 -0
  57. package/dist/commonjs/mcp-server/resources.d.ts +32 -0
  58. package/dist/commonjs/mcp-server/resources.d.ts.map +1 -0
  59. package/dist/commonjs/mcp-server/resources.js +79 -0
  60. package/dist/commonjs/mcp-server/resources.js.map +1 -0
  61. package/dist/commonjs/mcp-server/scopes.d.ts +3 -0
  62. package/dist/commonjs/mcp-server/scopes.d.ts.map +1 -0
  63. package/dist/commonjs/mcp-server/scopes.js +8 -0
  64. package/dist/commonjs/mcp-server/scopes.js.map +1 -0
  65. package/dist/commonjs/mcp-server/server.d.ts +13 -0
  66. package/dist/commonjs/mcp-server/server.d.ts.map +1 -0
  67. package/dist/commonjs/mcp-server/server.js +43 -0
  68. package/dist/commonjs/mcp-server/server.js.map +1 -0
  69. package/dist/commonjs/mcp-server/shared.d.ts +7 -0
  70. package/dist/commonjs/mcp-server/shared.d.ts.map +1 -0
  71. package/dist/commonjs/mcp-server/shared.js +98 -0
  72. package/dist/commonjs/mcp-server/shared.js.map +1 -0
  73. package/dist/commonjs/mcp-server/tools/livenessCheck.d.ts +3 -0
  74. package/dist/commonjs/mcp-server/tools/livenessCheck.d.ts.map +1 -0
  75. package/dist/commonjs/mcp-server/tools/livenessCheck.js +26 -0
  76. package/dist/commonjs/mcp-server/tools/livenessCheck.js.map +1 -0
  77. package/dist/commonjs/mcp-server/tools/ratelimitDeleteOverride.d.ts +8 -0
  78. package/dist/commonjs/mcp-server/tools/ratelimitDeleteOverride.d.ts.map +1 -0
  79. package/dist/commonjs/mcp-server/tools/ratelimitDeleteOverride.js +62 -0
  80. package/dist/commonjs/mcp-server/tools/ratelimitDeleteOverride.js.map +1 -0
  81. package/dist/commonjs/mcp-server/tools/ratelimitGetOverride.d.ts +8 -0
  82. package/dist/commonjs/mcp-server/tools/ratelimitGetOverride.d.ts.map +1 -0
  83. package/dist/commonjs/mcp-server/tools/ratelimitGetOverride.js +62 -0
  84. package/dist/commonjs/mcp-server/tools/ratelimitGetOverride.js.map +1 -0
  85. package/dist/commonjs/mcp-server/tools/ratelimitLimit.d.ts +8 -0
  86. package/dist/commonjs/mcp-server/tools/ratelimitLimit.d.ts.map +1 -0
  87. package/dist/commonjs/mcp-server/tools/ratelimitLimit.js +62 -0
  88. package/dist/commonjs/mcp-server/tools/ratelimitLimit.js.map +1 -0
  89. package/dist/commonjs/mcp-server/tools/ratelimitSetOverride.d.ts +8 -0
  90. package/dist/commonjs/mcp-server/tools/ratelimitSetOverride.d.ts.map +1 -0
  91. package/dist/commonjs/mcp-server/tools/ratelimitSetOverride.js +62 -0
  92. package/dist/commonjs/mcp-server/tools/ratelimitSetOverride.js.map +1 -0
  93. package/dist/commonjs/mcp-server/tools.d.ts +25 -0
  94. package/dist/commonjs/mcp-server/tools.d.ts.map +1 -0
  95. package/dist/commonjs/mcp-server/tools.js +81 -0
  96. package/dist/commonjs/mcp-server/tools.js.map +1 -0
  97. package/dist/{esm/models/errors/notfounderror.d.ts → commonjs/models/errors/baseerror.d.ts} +15 -15
  98. package/dist/commonjs/models/errors/baseerror.d.ts.map +1 -0
  99. package/dist/commonjs/models/errors/{notfounderror.js → baseerror.js} +15 -15
  100. package/dist/commonjs/models/errors/baseerror.js.map +1 -0
  101. package/dist/commonjs/models/errors/index.d.ts +1 -5
  102. package/dist/commonjs/models/errors/index.d.ts.map +1 -1
  103. package/dist/commonjs/models/errors/index.js +1 -5
  104. package/dist/commonjs/models/errors/index.js.map +1 -1
  105. package/dist/commonjs/sdk/liveness.d.ts +2 -2
  106. package/dist/commonjs/sdk/liveness.d.ts.map +1 -1
  107. package/dist/commonjs/sdk/ratelimit.d.ts +4 -5
  108. package/dist/commonjs/sdk/ratelimit.d.ts.map +1 -1
  109. package/dist/commonjs/sdk/ratelimit.js.map +1 -1
  110. package/dist/esm/funcs/livenessCheck.d.ts +2 -2
  111. package/dist/esm/funcs/livenessCheck.d.ts.map +1 -1
  112. package/dist/esm/funcs/livenessCheck.js +5 -11
  113. package/dist/esm/funcs/livenessCheck.js.map +1 -1
  114. package/dist/esm/funcs/ratelimitDeleteOverride.d.ts +1 -2
  115. package/dist/esm/funcs/ratelimitDeleteOverride.d.ts.map +1 -1
  116. package/dist/esm/funcs/ratelimitDeleteOverride.js +5 -16
  117. package/dist/esm/funcs/ratelimitDeleteOverride.js.map +1 -1
  118. package/dist/esm/funcs/ratelimitGetOverride.d.ts +1 -2
  119. package/dist/esm/funcs/ratelimitGetOverride.d.ts.map +1 -1
  120. package/dist/esm/funcs/ratelimitGetOverride.js +5 -16
  121. package/dist/esm/funcs/ratelimitGetOverride.js.map +1 -1
  122. package/dist/esm/funcs/ratelimitLimit.d.ts +1 -2
  123. package/dist/esm/funcs/ratelimitLimit.d.ts.map +1 -1
  124. package/dist/esm/funcs/ratelimitLimit.js +5 -16
  125. package/dist/esm/funcs/ratelimitLimit.js.map +1 -1
  126. package/dist/esm/funcs/ratelimitSetOverride.d.ts +1 -2
  127. package/dist/esm/funcs/ratelimitSetOverride.d.ts.map +1 -1
  128. package/dist/esm/funcs/ratelimitSetOverride.js +5 -16
  129. package/dist/esm/funcs/ratelimitSetOverride.js.map +1 -1
  130. package/dist/esm/lib/config.d.ts +3 -3
  131. package/dist/esm/lib/config.js +3 -3
  132. package/dist/esm/lib/matchers.d.ts.map +1 -1
  133. package/dist/esm/lib/matchers.js +5 -1
  134. package/dist/esm/lib/matchers.js.map +1 -1
  135. package/dist/esm/mcp-server/build.d.mts.map +1 -0
  136. package/dist/esm/mcp-server/build.mjs +14 -0
  137. package/dist/esm/mcp-server/build.mjs.map +1 -0
  138. package/dist/esm/mcp-server/cli/start/command.d.ts +2 -0
  139. package/dist/esm/mcp-server/cli/start/command.d.ts.map +1 -0
  140. package/dist/esm/mcp-server/cli/start/command.js +102 -0
  141. package/dist/esm/mcp-server/cli/start/command.js.map +1 -0
  142. package/dist/esm/mcp-server/cli/start/impl.d.ts +18 -0
  143. package/dist/esm/mcp-server/cli/start/impl.d.ts.map +1 -0
  144. package/dist/esm/mcp-server/cli/start/impl.js +98 -0
  145. package/dist/esm/mcp-server/cli/start/impl.js.map +1 -0
  146. package/dist/esm/mcp-server/cli.d.ts +6 -0
  147. package/dist/esm/mcp-server/cli.d.ts.map +1 -0
  148. package/dist/esm/mcp-server/cli.js +7 -0
  149. package/dist/esm/mcp-server/cli.js.map +1 -0
  150. package/dist/esm/mcp-server/console-logger.d.ts +7 -0
  151. package/dist/esm/mcp-server/console-logger.d.ts.map +1 -0
  152. package/dist/esm/mcp-server/console-logger.js +55 -0
  153. package/dist/esm/mcp-server/console-logger.js.map +1 -0
  154. package/dist/esm/mcp-server/extensions.d.ts +11 -0
  155. package/dist/esm/mcp-server/extensions.d.ts.map +1 -0
  156. package/dist/esm/mcp-server/extensions.js +5 -0
  157. package/dist/esm/mcp-server/extensions.js.map +1 -0
  158. package/dist/esm/mcp-server/mcp-server.d.ts +2 -0
  159. package/dist/esm/mcp-server/mcp-server.d.ts.map +1 -0
  160. package/dist/esm/mcp-server/mcp-server.js +23 -0
  161. package/dist/esm/mcp-server/mcp-server.js.map +1 -0
  162. package/dist/esm/mcp-server/prompts.d.ts +26 -0
  163. package/dist/esm/mcp-server/prompts.d.ts.map +1 -0
  164. package/dist/esm/mcp-server/prompts.js +43 -0
  165. package/dist/esm/mcp-server/prompts.js.map +1 -0
  166. package/dist/esm/mcp-server/resources.d.ts +32 -0
  167. package/dist/esm/mcp-server/resources.d.ts.map +1 -0
  168. package/dist/esm/mcp-server/resources.js +74 -0
  169. package/dist/esm/mcp-server/resources.js.map +1 -0
  170. package/dist/esm/mcp-server/scopes.d.ts +3 -0
  171. package/dist/esm/mcp-server/scopes.d.ts.map +1 -0
  172. package/dist/esm/mcp-server/scopes.js +5 -0
  173. package/dist/esm/mcp-server/scopes.js.map +1 -0
  174. package/dist/esm/mcp-server/server.d.ts +13 -0
  175. package/dist/esm/mcp-server/server.d.ts.map +1 -0
  176. package/dist/esm/mcp-server/server.js +40 -0
  177. package/dist/esm/mcp-server/server.js.map +1 -0
  178. package/dist/esm/mcp-server/shared.d.ts +7 -0
  179. package/dist/esm/mcp-server/shared.d.ts.map +1 -0
  180. package/dist/esm/mcp-server/shared.js +59 -0
  181. package/dist/esm/mcp-server/shared.js.map +1 -0
  182. package/dist/esm/mcp-server/tools/livenessCheck.d.ts +3 -0
  183. package/dist/esm/mcp-server/tools/livenessCheck.d.ts.map +1 -0
  184. package/dist/esm/mcp-server/tools/livenessCheck.js +23 -0
  185. package/dist/esm/mcp-server/tools/livenessCheck.js.map +1 -0
  186. package/dist/esm/mcp-server/tools/ratelimitDeleteOverride.d.ts +8 -0
  187. package/dist/esm/mcp-server/tools/ratelimitDeleteOverride.d.ts.map +1 -0
  188. package/dist/esm/mcp-server/tools/ratelimitDeleteOverride.js +26 -0
  189. package/dist/esm/mcp-server/tools/ratelimitDeleteOverride.js.map +1 -0
  190. package/dist/esm/mcp-server/tools/ratelimitGetOverride.d.ts +8 -0
  191. package/dist/esm/mcp-server/tools/ratelimitGetOverride.d.ts.map +1 -0
  192. package/dist/esm/mcp-server/tools/ratelimitGetOverride.js +26 -0
  193. package/dist/esm/mcp-server/tools/ratelimitGetOverride.js.map +1 -0
  194. package/dist/esm/mcp-server/tools/ratelimitLimit.d.ts +8 -0
  195. package/dist/esm/mcp-server/tools/ratelimitLimit.d.ts.map +1 -0
  196. package/dist/esm/mcp-server/tools/ratelimitLimit.js +26 -0
  197. package/dist/esm/mcp-server/tools/ratelimitLimit.js.map +1 -0
  198. package/dist/esm/mcp-server/tools/ratelimitSetOverride.d.ts +8 -0
  199. package/dist/esm/mcp-server/tools/ratelimitSetOverride.d.ts.map +1 -0
  200. package/dist/esm/mcp-server/tools/ratelimitSetOverride.js +26 -0
  201. package/dist/esm/mcp-server/tools/ratelimitSetOverride.js.map +1 -0
  202. package/dist/esm/mcp-server/tools.d.ts +25 -0
  203. package/dist/esm/mcp-server/tools.d.ts.map +1 -0
  204. package/dist/esm/mcp-server/tools.js +77 -0
  205. package/dist/esm/mcp-server/tools.js.map +1 -0
  206. package/dist/{commonjs/models/errors/notfounderror.d.ts → esm/models/errors/baseerror.d.ts} +15 -15
  207. package/dist/esm/models/errors/baseerror.d.ts.map +1 -0
  208. package/dist/esm/models/errors/{notfounderror.js → baseerror.js} +13 -13
  209. package/dist/esm/models/errors/baseerror.js.map +1 -0
  210. package/dist/esm/models/errors/index.d.ts +1 -5
  211. package/dist/esm/models/errors/index.d.ts.map +1 -1
  212. package/dist/esm/models/errors/index.js +1 -5
  213. package/dist/esm/models/errors/index.js.map +1 -1
  214. package/dist/esm/sdk/liveness.d.ts +2 -2
  215. package/dist/esm/sdk/liveness.d.ts.map +1 -1
  216. package/dist/esm/sdk/ratelimit.d.ts +4 -5
  217. package/dist/esm/sdk/ratelimit.d.ts.map +1 -1
  218. package/dist/esm/sdk/ratelimit.js.map +1 -1
  219. package/docs/sdks/liveness/README.md +6 -6
  220. package/docs/sdks/ratelimit/README.md +28 -36
  221. package/jsr.json +1 -1
  222. package/package.json +18 -14
  223. package/src/funcs/livenessCheck.ts +15 -21
  224. package/src/funcs/ratelimitDeleteOverride.ts +14 -33
  225. package/src/funcs/ratelimitGetOverride.ts +14 -33
  226. package/src/funcs/ratelimitLimit.ts +14 -33
  227. package/src/funcs/ratelimitSetOverride.ts +14 -33
  228. package/src/lib/config.ts +3 -3
  229. package/src/lib/matchers.ts +4 -1
  230. package/src/mcp-server/cli/start/command.ts +107 -0
  231. package/src/mcp-server/cli/start/impl.ts +134 -0
  232. package/src/mcp-server/cli.ts +13 -0
  233. package/src/mcp-server/console-logger.ts +71 -0
  234. package/src/mcp-server/extensions.ts +17 -0
  235. package/src/mcp-server/mcp-server.ts +26 -0
  236. package/src/mcp-server/prompts.ts +110 -0
  237. package/src/mcp-server/resources.ts +158 -0
  238. package/src/mcp-server/scopes.ts +7 -0
  239. package/src/mcp-server/server.ts +69 -0
  240. package/src/mcp-server/shared.ts +75 -0
  241. package/src/mcp-server/tools/livenessCheck.ts +30 -0
  242. package/src/mcp-server/tools/ratelimitDeleteOverride.ts +35 -0
  243. package/src/mcp-server/tools/ratelimitGetOverride.ts +35 -0
  244. package/src/mcp-server/tools/ratelimitLimit.ts +35 -0
  245. package/src/mcp-server/tools/ratelimitSetOverride.ts +35 -0
  246. package/src/mcp-server/tools.ts +126 -0
  247. package/src/models/errors/{notfounderror.ts → baseerror.ts} +20 -20
  248. package/src/models/errors/index.ts +1 -5
  249. package/src/sdk/liveness.ts +2 -2
  250. package/src/sdk/ratelimit.ts +4 -5
  251. package/dist/commonjs/models/errors/forbiddenerror.d.ts +0 -82
  252. package/dist/commonjs/models/errors/forbiddenerror.d.ts.map +0 -1
  253. package/dist/commonjs/models/errors/forbiddenerror.js +0 -93
  254. package/dist/commonjs/models/errors/forbiddenerror.js.map +0 -1
  255. package/dist/commonjs/models/errors/internalservererror.d.ts +0 -82
  256. package/dist/commonjs/models/errors/internalservererror.d.ts.map +0 -1
  257. package/dist/commonjs/models/errors/internalservererror.js +0 -93
  258. package/dist/commonjs/models/errors/internalservererror.js.map +0 -1
  259. package/dist/commonjs/models/errors/notfounderror.d.ts.map +0 -1
  260. package/dist/commonjs/models/errors/notfounderror.js.map +0 -1
  261. package/dist/commonjs/models/errors/preconditionfailederror.d.ts +0 -82
  262. package/dist/commonjs/models/errors/preconditionfailederror.d.ts.map +0 -1
  263. package/dist/commonjs/models/errors/preconditionfailederror.js +0 -93
  264. package/dist/commonjs/models/errors/preconditionfailederror.js.map +0 -1
  265. package/dist/commonjs/models/errors/unauthorizederror.d.ts +0 -82
  266. package/dist/commonjs/models/errors/unauthorizederror.d.ts.map +0 -1
  267. package/dist/commonjs/models/errors/unauthorizederror.js +0 -93
  268. package/dist/commonjs/models/errors/unauthorizederror.js.map +0 -1
  269. package/dist/commonjs/models/operations/index.d.ts +0 -6
  270. package/dist/commonjs/models/operations/index.d.ts.map +0 -1
  271. package/dist/commonjs/models/operations/index.js +0 -25
  272. package/dist/commonjs/models/operations/index.js.map +0 -1
  273. package/dist/commonjs/models/operations/liveness.d.ts +0 -48
  274. package/dist/commonjs/models/operations/liveness.d.ts.map +0 -1
  275. package/dist/commonjs/models/operations/liveness.js +0 -95
  276. package/dist/commonjs/models/operations/liveness.js.map +0 -1
  277. package/dist/commonjs/models/operations/ratelimitdeleteoverride.d.ts +0 -48
  278. package/dist/commonjs/models/operations/ratelimitdeleteoverride.d.ts.map +0 -1
  279. package/dist/commonjs/models/operations/ratelimitdeleteoverride.js +0 -95
  280. package/dist/commonjs/models/operations/ratelimitdeleteoverride.js.map +0 -1
  281. package/dist/commonjs/models/operations/ratelimitgetoverride.d.ts +0 -48
  282. package/dist/commonjs/models/operations/ratelimitgetoverride.d.ts.map +0 -1
  283. package/dist/commonjs/models/operations/ratelimitgetoverride.js +0 -95
  284. package/dist/commonjs/models/operations/ratelimitgetoverride.js.map +0 -1
  285. package/dist/commonjs/models/operations/ratelimitsetoverride.d.ts +0 -48
  286. package/dist/commonjs/models/operations/ratelimitsetoverride.d.ts.map +0 -1
  287. package/dist/commonjs/models/operations/ratelimitsetoverride.js +0 -95
  288. package/dist/commonjs/models/operations/ratelimitsetoverride.js.map +0 -1
  289. package/dist/commonjs/models/operations/v1ratelimitlimit.d.ts +0 -48
  290. package/dist/commonjs/models/operations/v1ratelimitlimit.d.ts.map +0 -1
  291. package/dist/commonjs/models/operations/v1ratelimitlimit.js +0 -95
  292. package/dist/commonjs/models/operations/v1ratelimitlimit.js.map +0 -1
  293. package/dist/esm/models/errors/forbiddenerror.d.ts +0 -82
  294. package/dist/esm/models/errors/forbiddenerror.d.ts.map +0 -1
  295. package/dist/esm/models/errors/forbiddenerror.js +0 -56
  296. package/dist/esm/models/errors/forbiddenerror.js.map +0 -1
  297. package/dist/esm/models/errors/internalservererror.d.ts +0 -82
  298. package/dist/esm/models/errors/internalservererror.d.ts.map +0 -1
  299. package/dist/esm/models/errors/internalservererror.js +0 -56
  300. package/dist/esm/models/errors/internalservererror.js.map +0 -1
  301. package/dist/esm/models/errors/notfounderror.d.ts.map +0 -1
  302. package/dist/esm/models/errors/notfounderror.js.map +0 -1
  303. package/dist/esm/models/errors/preconditionfailederror.d.ts +0 -82
  304. package/dist/esm/models/errors/preconditionfailederror.d.ts.map +0 -1
  305. package/dist/esm/models/errors/preconditionfailederror.js +0 -56
  306. package/dist/esm/models/errors/preconditionfailederror.js.map +0 -1
  307. package/dist/esm/models/errors/unauthorizederror.d.ts +0 -82
  308. package/dist/esm/models/errors/unauthorizederror.d.ts.map +0 -1
  309. package/dist/esm/models/errors/unauthorizederror.js +0 -56
  310. package/dist/esm/models/errors/unauthorizederror.js.map +0 -1
  311. package/dist/esm/models/operations/index.d.ts +0 -6
  312. package/dist/esm/models/operations/index.d.ts.map +0 -1
  313. package/dist/esm/models/operations/index.js +0 -9
  314. package/dist/esm/models/operations/index.js.map +0 -1
  315. package/dist/esm/models/operations/liveness.d.ts +0 -48
  316. package/dist/esm/models/operations/liveness.d.ts.map +0 -1
  317. package/dist/esm/models/operations/liveness.js +0 -57
  318. package/dist/esm/models/operations/liveness.js.map +0 -1
  319. package/dist/esm/models/operations/ratelimitdeleteoverride.d.ts +0 -48
  320. package/dist/esm/models/operations/ratelimitdeleteoverride.d.ts.map +0 -1
  321. package/dist/esm/models/operations/ratelimitdeleteoverride.js +0 -57
  322. package/dist/esm/models/operations/ratelimitdeleteoverride.js.map +0 -1
  323. package/dist/esm/models/operations/ratelimitgetoverride.d.ts +0 -48
  324. package/dist/esm/models/operations/ratelimitgetoverride.d.ts.map +0 -1
  325. package/dist/esm/models/operations/ratelimitgetoverride.js +0 -57
  326. package/dist/esm/models/operations/ratelimitgetoverride.js.map +0 -1
  327. package/dist/esm/models/operations/ratelimitsetoverride.d.ts +0 -48
  328. package/dist/esm/models/operations/ratelimitsetoverride.d.ts.map +0 -1
  329. package/dist/esm/models/operations/ratelimitsetoverride.js +0 -57
  330. package/dist/esm/models/operations/ratelimitsetoverride.js.map +0 -1
  331. package/dist/esm/models/operations/v1ratelimitlimit.d.ts +0 -48
  332. package/dist/esm/models/operations/v1ratelimitlimit.d.ts.map +0 -1
  333. package/dist/esm/models/operations/v1ratelimitlimit.js +0 -57
  334. package/dist/esm/models/operations/v1ratelimitlimit.js.map +0 -1
  335. package/src/models/errors/forbiddenerror.ts +0 -135
  336. package/src/models/errors/internalservererror.ts +0 -135
  337. package/src/models/errors/preconditionfailederror.ts +0 -135
  338. package/src/models/errors/unauthorizederror.ts +0 -135
  339. package/src/models/operations/index.ts +0 -9
  340. package/src/models/operations/liveness.ts +0 -112
  341. package/src/models/operations/ratelimitdeleteoverride.ts +0 -118
  342. package/src/models/operations/ratelimitgetoverride.ts +0 -116
  343. package/src/models/operations/ratelimitsetoverride.ts +0 -116
  344. package/src/models/operations/v1ratelimitlimit.ts +0 -114
@@ -0,0 +1,107 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { buildCommand } from "@stricli/core";
6
+ import { numberParser } from "@stricli/core";
7
+ import * as z from "zod";
8
+ import { consoleLoggerLevels } from "../../console-logger.js";
9
+ import { mcpScopes } from "../../scopes.js";
10
+
11
+ export const startCommand = buildCommand({
12
+ loader: async () => {
13
+ const { main } = await import("./impl.js");
14
+ return main;
15
+ },
16
+ parameters: {
17
+ flags: {
18
+ transport: {
19
+ kind: "enum",
20
+ brief: "The transport to use for communicating with the server",
21
+ default: "stdio",
22
+ values: ["stdio", "sse"],
23
+ },
24
+ port: {
25
+ kind: "parsed",
26
+ brief: "The port to use when the SSE transport is enabled",
27
+ default: "2718",
28
+ parse: (val: string) =>
29
+ z.coerce.number().int().gte(0).lt(65536).parse(val),
30
+ },
31
+ tool: {
32
+ kind: "parsed",
33
+ brief: "Specify tools to mount on the server",
34
+ optional: true,
35
+ variadic: true,
36
+ parse: (value) => {
37
+ return z.string().parse(value);
38
+ },
39
+ },
40
+ ...(mcpScopes.length
41
+ ? {
42
+ scope: {
43
+ kind: "enum",
44
+ brief:
45
+ "Mount tools/resources that match given scope (repeatable flag)",
46
+ values: mcpScopes,
47
+ variadic: true,
48
+ optional: true,
49
+ },
50
+ }
51
+ : {}),
52
+ "root-key": {
53
+ kind: "parsed",
54
+ brief: "Sets the rootKey auth field for the API",
55
+ optional: true,
56
+ parse: (value) => {
57
+ return z.string().parse(value);
58
+ },
59
+ },
60
+ "server-url": {
61
+ kind: "parsed",
62
+ brief: "Overrides the default server URL used by the SDK",
63
+ optional: true,
64
+ parse: (value) => new URL(value).toString(),
65
+ },
66
+ "server-index": {
67
+ kind: "parsed",
68
+ brief: "Selects a predefined server used by the SDK",
69
+ optional: true,
70
+ parse: numberParser,
71
+ },
72
+ "log-level": {
73
+ kind: "enum",
74
+ brief: "The log level to use for the server",
75
+ default: "info",
76
+ values: consoleLoggerLevels,
77
+ },
78
+ env: {
79
+ kind: "parsed",
80
+ brief: "Environment variables made available to the server",
81
+ optional: true,
82
+ variadic: true,
83
+ parse: (val: string) => {
84
+ const sepIdx = val.indexOf("=");
85
+ if (sepIdx === -1) {
86
+ throw new Error("Invalid environment variable format");
87
+ }
88
+
89
+ const key = val.slice(0, sepIdx);
90
+ const value = val.slice(sepIdx + 1);
91
+
92
+ return [
93
+ z.string().nonempty({
94
+ message: "Environment variable key must be a non-empty string",
95
+ }).parse(key),
96
+ z.string().nonempty({
97
+ message: "Environment variable value must be a non-empty string",
98
+ }).parse(value),
99
+ ] satisfies [string, string];
100
+ },
101
+ },
102
+ },
103
+ },
104
+ docs: {
105
+ brief: "Run the Model Context Protocol server",
106
+ },
107
+ });
@@ -0,0 +1,134 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { SSEServerTransport } from "@modelcontextprotocol/sdk/server/sse.js";
6
+ import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
7
+ import express from "express";
8
+ import { SDKOptions } from "../../../lib/config.js";
9
+ import { LocalContext } from "../../cli.js";
10
+ import {
11
+ ConsoleLoggerLevel,
12
+ createConsoleLogger,
13
+ } from "../../console-logger.js";
14
+ import { MCPScope } from "../../scopes.js";
15
+ import { createMCPServer } from "../../server.js";
16
+
17
+ interface StartCommandFlags {
18
+ readonly transport: "stdio" | "sse";
19
+ readonly port: number;
20
+ readonly tool?: string[];
21
+ readonly scope?: MCPScope[];
22
+ readonly "root-key"?: string | undefined;
23
+ readonly "server-url"?: string;
24
+ readonly "server-index"?: SDKOptions["serverIdx"];
25
+ readonly "log-level": ConsoleLoggerLevel;
26
+ readonly env?: [string, string][];
27
+ }
28
+
29
+ export async function main(this: LocalContext, flags: StartCommandFlags) {
30
+ flags.env?.forEach(([key, value]) => {
31
+ process.env[key] = value;
32
+ });
33
+
34
+ switch (flags.transport) {
35
+ case "stdio":
36
+ await startStdio(flags);
37
+ break;
38
+ case "sse":
39
+ await startSSE(flags);
40
+ break;
41
+ default:
42
+ throw new Error(`Invalid transport: ${flags.transport}`);
43
+ }
44
+ }
45
+
46
+ async function startStdio(flags: StartCommandFlags) {
47
+ const logger = createConsoleLogger(flags["log-level"]);
48
+ const transport = new StdioServerTransport();
49
+ const server = createMCPServer({
50
+ logger,
51
+ allowedTools: flags.tool,
52
+ scopes: flags.scope,
53
+ ...{ rootKey: flags["root-key"] },
54
+ serverURL: flags["server-url"],
55
+ serverIdx: flags["server-index"],
56
+ });
57
+ await server.connect(transport);
58
+
59
+ const abort = async () => {
60
+ await server.close();
61
+ process.exit(0);
62
+ };
63
+ process.on("SIGTERM", abort);
64
+ process.on("SIGINT", abort);
65
+ }
66
+
67
+ async function startSSE(flags: StartCommandFlags) {
68
+ const logger = createConsoleLogger(flags["log-level"]);
69
+ const app = express();
70
+ const mcpServer = createMCPServer({
71
+ logger,
72
+ allowedTools: flags.tool,
73
+ scopes: flags.scope,
74
+ ...{ rootKey: flags["root-key"] },
75
+ serverURL: flags["server-url"],
76
+ serverIdx: flags["server-index"],
77
+ });
78
+ let transport: SSEServerTransport | undefined;
79
+ const controller = new AbortController();
80
+
81
+ app.get("/sse", async (_req, res) => {
82
+ transport = new SSEServerTransport("/message", res);
83
+
84
+ await mcpServer.connect(transport);
85
+
86
+ mcpServer.server.onclose = async () => {
87
+ res.end();
88
+ };
89
+ });
90
+
91
+ app.post("/message", async (req, res) => {
92
+ if (!transport) {
93
+ throw new Error("Server transport not initialized");
94
+ }
95
+
96
+ await transport.handlePostMessage(req, res);
97
+ });
98
+
99
+ const httpServer = app.listen(flags.port, "0.0.0.0", () => {
100
+ const ha = httpServer.address();
101
+ const host = typeof ha === "string" ? ha : `${ha?.address}:${ha?.port}`;
102
+ logger.info("MCP HTTP server started", { host });
103
+ });
104
+
105
+ let closing = false;
106
+ controller.signal.addEventListener("abort", async () => {
107
+ if (closing) {
108
+ logger.info("Received second signal. Forcing shutdown.");
109
+ process.exit(1);
110
+ }
111
+ closing = true;
112
+
113
+ logger.info("Shutting down MCP server");
114
+
115
+ await mcpServer.close();
116
+
117
+ logger.info("Shutting down HTTP server");
118
+
119
+ const timer = setTimeout(() => {
120
+ logger.info("Forcing shutdown");
121
+ process.exit(1);
122
+ }, 5000);
123
+
124
+ httpServer.close(() => {
125
+ clearTimeout(timer);
126
+ logger.info("Graceful shutdown complete");
127
+ process.exit(0);
128
+ });
129
+ });
130
+
131
+ const abort = () => controller.abort();
132
+ process.on("SIGTERM", abort);
133
+ process.on("SIGINT", abort);
134
+ }
@@ -0,0 +1,13 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { CommandContext, StricliProcess } from "@stricli/core";
6
+
7
+ export interface LocalContext extends CommandContext {
8
+ readonly process: StricliProcess;
9
+ }
10
+
11
+ export function buildContext(process: NodeJS.Process): LocalContext {
12
+ return { process: process as StricliProcess };
13
+ }
@@ -0,0 +1,71 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ export const consoleLoggerLevels = [
6
+ "debug",
7
+ "warning",
8
+ "info",
9
+ "error",
10
+ ] as const;
11
+
12
+ export type ConsoleLoggerLevel = (typeof consoleLoggerLevels)[number];
13
+
14
+ export type ConsoleLogger = {
15
+ [key in ConsoleLoggerLevel]: (
16
+ message: string,
17
+ data?: Record<string, unknown>,
18
+ ) => void;
19
+ };
20
+
21
+ export function createConsoleLogger(level: ConsoleLoggerLevel): ConsoleLogger {
22
+ const min = consoleLoggerLevels.indexOf(level);
23
+ const noop = () => {};
24
+
25
+ const logger: ConsoleLogger = {
26
+ debug: noop,
27
+ warning: noop,
28
+ info: noop,
29
+ error: noop,
30
+ };
31
+
32
+ return consoleLoggerLevels.reduce((logger, level, i) => {
33
+ if (i < min) {
34
+ return logger;
35
+ }
36
+
37
+ logger[level] = log.bind(null, level);
38
+
39
+ return logger;
40
+ }, logger);
41
+ }
42
+
43
+ function log(
44
+ level: ConsoleLoggerLevel,
45
+ message: string,
46
+ data?: Record<string, unknown>,
47
+ ) {
48
+ let line = "";
49
+ const allData = [{ msg: message, l: level }, data];
50
+
51
+ for (const ctx of allData) {
52
+ for (const [key, value] of Object.entries(ctx || {})) {
53
+ if (value == null) {
54
+ line += ` ${key}=<${value}>`;
55
+ } else if (typeof value === "function") {
56
+ line += ` ${key}=<function>`;
57
+ } else if (typeof value === "symbol") {
58
+ line += ` ${key}=${value.toString()}`;
59
+ } else if (typeof value === "string") {
60
+ const v = value.search(/\s/g) >= 0 ? JSON.stringify(value) : value;
61
+ line += ` ${key}=${v}`;
62
+ } else if (typeof value !== "object") {
63
+ line += ` ${key}=${value}`;
64
+ } else {
65
+ line += ` ${key}="${JSON.stringify(value)}"`;
66
+ }
67
+ }
68
+ }
69
+
70
+ console.error(line);
71
+ }
@@ -0,0 +1,17 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { ZodRawShape } from "zod";
6
+ import { PromptArgsRawShape, PromptDefinition } from "./prompts.js";
7
+ import { ResourceDefinition, ResourceTemplateDefinition } from "./resources.js";
8
+ import { ToolDefinition } from "./tools.js";
9
+
10
+ export type Register = {
11
+ tool: <A extends ZodRawShape | undefined>(def: ToolDefinition<A>) => void;
12
+ resource: (def: ResourceDefinition) => void;
13
+ resourceTemplate: (def: ResourceTemplateDefinition) => void;
14
+ prompt: <A extends PromptArgsRawShape | undefined>(
15
+ prompt: PromptDefinition<A>,
16
+ ) => void;
17
+ };
@@ -0,0 +1,26 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { buildApplication, buildRouteMap, run } from "@stricli/core";
6
+ import process from "node:process";
7
+ import { buildContext } from "./cli.js";
8
+ import { startCommand } from "./cli/start/command.js";
9
+
10
+ const routes = buildRouteMap({
11
+ routes: {
12
+ start: startCommand,
13
+ },
14
+ docs: {
15
+ brief: "MCP server CLI",
16
+ },
17
+ });
18
+
19
+ export const app = buildApplication(routes, {
20
+ name: "mcp",
21
+ versionInfo: {
22
+ currentVersion: "2.0.0-alpha.5",
23
+ },
24
+ });
25
+
26
+ run(app, process.argv.slice(2), buildContext(process));
@@ -0,0 +1,110 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
6
+ import { RequestHandlerExtra } from "@modelcontextprotocol/sdk/shared/protocol.js";
7
+ import { GetPromptResult } from "@modelcontextprotocol/sdk/types.js";
8
+ import {
9
+ objectOutputType,
10
+ ZodOptional,
11
+ ZodType,
12
+ ZodTypeAny,
13
+ ZodTypeDef,
14
+ } from "zod";
15
+ import { UnkeyCore } from "../core.js";
16
+ import { ConsoleLogger } from "./console-logger.js";
17
+ import { MCPScope } from "./scopes.js";
18
+
19
+ // '@modelcontextprotocol/sdk' currently does not export this type
20
+ export type PromptArgsRawShape = {
21
+ [k: string]:
22
+ | ZodType<string, ZodTypeDef, string>
23
+ | ZodOptional<ZodType<string, ZodTypeDef, string>>;
24
+ };
25
+
26
+ export type PromptDefinition<
27
+ Args extends undefined | PromptArgsRawShape = undefined,
28
+ > = Args extends PromptArgsRawShape ? {
29
+ name: string;
30
+ description?: string;
31
+ scopes?: MCPScope[];
32
+ args: Args;
33
+ prompt: (
34
+ client: UnkeyCore,
35
+ args: objectOutputType<Args, ZodTypeAny>,
36
+ extra: RequestHandlerExtra,
37
+ ) => GetPromptResult | Promise<GetPromptResult>;
38
+ }
39
+ : {
40
+ name: string;
41
+ description?: string;
42
+ scopes?: MCPScope[];
43
+ args?: undefined;
44
+ prompt: (
45
+ client: UnkeyCore,
46
+ extra: RequestHandlerExtra,
47
+ ) => GetPromptResult | Promise<GetPromptResult>;
48
+ };
49
+
50
+ // Optional function to assist with formatting prompt results
51
+ export async function formatResult(value: string): Promise<GetPromptResult> {
52
+ return {
53
+ messages: [
54
+ {
55
+ role: "user",
56
+ content: {
57
+ type: "text",
58
+ text: value,
59
+ },
60
+ },
61
+ ],
62
+ };
63
+ }
64
+
65
+ export function createRegisterPrompt(
66
+ logger: ConsoleLogger,
67
+ server: McpServer,
68
+ sdk: UnkeyCore,
69
+ allowedScopes: Set<MCPScope>,
70
+ ): <A extends PromptArgsRawShape | undefined>(
71
+ prompt: PromptDefinition<A>,
72
+ ) => void {
73
+ return <A extends PromptArgsRawShape | undefined>(
74
+ prompt: PromptDefinition<A>,
75
+ ): void => {
76
+ const scopes = prompt.scopes ?? [];
77
+ if (!scopes.every((s: MCPScope) => allowedScopes.has(s))) {
78
+ return;
79
+ }
80
+
81
+ if (prompt.args) {
82
+ if (prompt.description) {
83
+ server.prompt(
84
+ prompt.name,
85
+ prompt.description,
86
+ prompt.args,
87
+ async (args, ctx) => prompt.prompt(sdk, args, ctx),
88
+ );
89
+ } else {
90
+ server.prompt(
91
+ prompt.name,
92
+ prompt.args,
93
+ async (args, ctx) => prompt.prompt(sdk, args, ctx),
94
+ );
95
+ }
96
+ } else {
97
+ if (prompt.description) {
98
+ server.prompt(
99
+ prompt.name,
100
+ prompt.description,
101
+ async (ctx) => prompt.prompt(sdk, ctx),
102
+ );
103
+ } else {
104
+ server.prompt(prompt.name, async (ctx) => prompt.prompt(sdk, ctx));
105
+ }
106
+ }
107
+
108
+ logger.debug("Registered prompt", { name: prompt.name });
109
+ };
110
+ }
@@ -0,0 +1,158 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import {
6
+ McpServer,
7
+ ResourceMetadata,
8
+ ResourceTemplate,
9
+ } from "@modelcontextprotocol/sdk/server/mcp.js";
10
+ import { RequestHandlerExtra } from "@modelcontextprotocol/sdk/shared/protocol.js";
11
+ import { Variables } from "@modelcontextprotocol/sdk/shared/uriTemplate.js";
12
+ import { ReadResourceResult } from "@modelcontextprotocol/sdk/types.js";
13
+ import { UnkeyCore } from "../core.js";
14
+ import { ConsoleLogger } from "./console-logger.js";
15
+ import { MCPScope } from "./scopes.js";
16
+ import { isAsyncIterable, isBinaryData, valueToBase64 } from "./shared.js";
17
+
18
+ export type ReadResourceCallback = (
19
+ client: UnkeyCore,
20
+ uri: URL,
21
+ extra: RequestHandlerExtra,
22
+ ) => ReadResourceResult | Promise<ReadResourceResult>;
23
+
24
+ export type ResourceDefinition = {
25
+ name: string;
26
+ description?: string;
27
+ metadata?: ResourceMetadata;
28
+ scopes?: MCPScope[];
29
+ resource: string;
30
+ read: ReadResourceCallback;
31
+ };
32
+
33
+ export type ReadResourceTemplateCallback = (
34
+ client: UnkeyCore,
35
+ uri: URL,
36
+ vars: Variables,
37
+ extra: RequestHandlerExtra,
38
+ ) => ReadResourceResult | Promise<ReadResourceResult>;
39
+
40
+ export type ResourceTemplateDefinition = {
41
+ name: string;
42
+ description: string;
43
+ metadata?: ResourceMetadata;
44
+ scopes?: MCPScope[];
45
+ resource: ResourceTemplate;
46
+ read: ReadResourceTemplateCallback;
47
+ };
48
+
49
+ // Optional function to assist with formatting resource results
50
+ export async function formatResult(
51
+ value: unknown,
52
+ uri: URL,
53
+ init: { mimeType?: string | undefined; response?: Response | undefined },
54
+ ): Promise<ReadResourceResult> {
55
+ if (typeof value === "undefined") {
56
+ return { contents: [] };
57
+ }
58
+
59
+ let contents: ReadResourceResult["contents"] = [];
60
+
61
+ const mimeType = init.mimeType ?? init.response?.headers.get("content-type")
62
+ ?? "";
63
+
64
+ if (mimeType.search(/\bjson\b/g) !== -1) {
65
+ contents = [{ uri: uri.toString(), mimeType, text: JSON.stringify(value) }];
66
+ } else if (
67
+ mimeType.startsWith("text/event-stream")
68
+ && isAsyncIterable(value)
69
+ ) {
70
+ contents = [
71
+ {
72
+ uri: uri.toString(),
73
+ mimeType: "application/json",
74
+ text: await stringifySSEToJSON(value),
75
+ },
76
+ ];
77
+ } else if (
78
+ (mimeType.startsWith("text/") || mimeType.startsWith("application/"))
79
+ && typeof value === "string"
80
+ ) {
81
+ contents = [{ uri: uri.toString(), mimeType, text: value }];
82
+ } else if (isBinaryData(value)) {
83
+ const blob = await valueToBase64(value);
84
+ contents = blob == null ? [] : [{ uri: uri.toString(), blob, mimeType }];
85
+ } else {
86
+ throw new Error(`Unsupported content type: "${mimeType}"`);
87
+ }
88
+
89
+ return { contents };
90
+ }
91
+
92
+ async function stringifySSEToJSON(
93
+ value: AsyncIterable<unknown>,
94
+ ): Promise<string> {
95
+ const payloads = [];
96
+
97
+ for await (const chunk of value) {
98
+ payloads.push(chunk);
99
+ }
100
+
101
+ return JSON.stringify(payloads);
102
+ }
103
+
104
+ export function createRegisterResource(
105
+ logger: ConsoleLogger,
106
+ server: McpServer,
107
+ sdk: UnkeyCore,
108
+ allowedScopes: Set<MCPScope>,
109
+ ): (resource: ResourceDefinition) => void {
110
+ return (resource: ResourceDefinition): void => {
111
+ const scopes = resource.scopes ?? [];
112
+ if (!scopes.every((s: MCPScope) => allowedScopes.has(s))) {
113
+ return;
114
+ }
115
+
116
+ const metadata: ResourceMetadata = {
117
+ ...resource.metadata,
118
+ description: resource.description,
119
+ };
120
+
121
+ server.resource(
122
+ resource.name,
123
+ resource.resource,
124
+ metadata,
125
+ async (uri, ctx) => resource.read(sdk, uri, ctx),
126
+ );
127
+
128
+ logger.debug("Registered resource", { name: resource.name });
129
+ };
130
+ }
131
+
132
+ export function createRegisterResourceTemplate(
133
+ logger: ConsoleLogger,
134
+ server: McpServer,
135
+ sdk: UnkeyCore,
136
+ allowedScopes: Set<MCPScope>,
137
+ ): (resource: ResourceTemplateDefinition) => void {
138
+ return (resource: ResourceTemplateDefinition): void => {
139
+ const scopes = resource.scopes ?? [];
140
+ if (!scopes.every((s: MCPScope) => allowedScopes.has(s))) {
141
+ return;
142
+ }
143
+
144
+ const metadata: ResourceMetadata = {
145
+ ...resource.metadata,
146
+ description: resource.description,
147
+ };
148
+
149
+ server.resource(
150
+ resource.name,
151
+ resource.resource,
152
+ metadata,
153
+ async (uri, vars, ctx) => resource.read(sdk, uri, vars, ctx),
154
+ );
155
+
156
+ logger.debug("Registered resource template", { name: resource.name });
157
+ };
158
+ }
@@ -0,0 +1,7 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ export const mcpScopes = [] as const;
6
+
7
+ export type MCPScope = (typeof mcpScopes)[number];