@greensecurity/javascript-sdk 0.19.0 → 0.21.1

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 (338) hide show
  1. package/REACT_QUERY.md +15 -15
  2. package/README.md +93 -9
  3. package/bin/mcp-server.js +1734 -271
  4. package/bin/mcp-server.js.map +50 -26
  5. package/funcs/organizationsListOrSearchFacilities.d.ts +2 -1
  6. package/funcs/organizationsListOrSearchFacilities.d.ts.map +1 -1
  7. package/funcs/organizationsListOrSearchFacilities.js +3 -2
  8. package/funcs/organizationsListOrSearchFacilities.js.map +1 -1
  9. package/funcs/vendorScansVendorScanOut.d.ts +17 -0
  10. package/funcs/vendorScansVendorScanOut.d.ts.map +1 -0
  11. package/funcs/vendorScansVendorScanOut.js +120 -0
  12. package/funcs/vendorScansVendorScanOut.js.map +1 -0
  13. package/funcs/vendorsGetVendorsDetails.d.ts +32 -0
  14. package/funcs/vendorsGetVendorsDetails.d.ts.map +1 -0
  15. package/funcs/vendorsGetVendorsDetails.js +139 -0
  16. package/funcs/vendorsGetVendorsDetails.js.map +1 -0
  17. package/funcs/vendorsListVendorCredentials.d.ts +4 -1
  18. package/funcs/vendorsListVendorCredentials.d.ts.map +1 -1
  19. package/funcs/vendorsListVendorCredentials.js +46 -6
  20. package/funcs/vendorsListVendorCredentials.js.map +1 -1
  21. package/funcs/vendorsListVendorFacilityStatuses.d.ts +1 -1
  22. package/funcs/vendorsListVendorFacilityStatuses.d.ts.map +1 -1
  23. package/funcs/vendorsListVendorFacilityStatuses.js +3 -2
  24. package/funcs/vendorsListVendorFacilityStatuses.js.map +1 -1
  25. package/funcs/vendorsListVendorJobTitles.d.ts +1 -1
  26. package/funcs/vendorsListVendorJobTitles.d.ts.map +1 -1
  27. package/funcs/vendorsListVendorJobTitles.js +21 -6
  28. package/funcs/vendorsListVendorJobTitles.js.map +1 -1
  29. package/funcs/vendorsListVendorScrubDetails.d.ts +18 -0
  30. package/funcs/vendorsListVendorScrubDetails.d.ts.map +1 -0
  31. package/funcs/vendorsListVendorScrubDetails.js +121 -0
  32. package/funcs/vendorsListVendorScrubDetails.js.map +1 -0
  33. package/funcs/vendorsListVendorScrubPurchases.d.ts +20 -0
  34. package/funcs/vendorsListVendorScrubPurchases.d.ts.map +1 -0
  35. package/funcs/vendorsListVendorScrubPurchases.js +160 -0
  36. package/funcs/vendorsListVendorScrubPurchases.js.map +1 -0
  37. package/funcs/webhooksGetWebhookEndpoint.d.ts +18 -0
  38. package/funcs/webhooksGetWebhookEndpoint.d.ts.map +1 -0
  39. package/funcs/webhooksGetWebhookEndpoint.js +121 -0
  40. package/funcs/webhooksGetWebhookEndpoint.js.map +1 -0
  41. package/funcs/webhooksListAllWebhookEndpoints.d.ts +17 -0
  42. package/funcs/webhooksListAllWebhookEndpoints.d.ts.map +1 -0
  43. package/funcs/webhooksListAllWebhookEndpoints.js +121 -0
  44. package/funcs/webhooksListAllWebhookEndpoints.js.map +1 -0
  45. package/jsr.json +1 -1
  46. package/lib/config.d.ts +3 -3
  47. package/lib/config.js +3 -3
  48. package/lib/security.d.ts +4 -3
  49. package/lib/security.d.ts.map +1 -1
  50. package/lib/security.js +6 -1
  51. package/lib/security.js.map +1 -1
  52. package/mcp-server/extensions.d.ts +2 -0
  53. package/mcp-server/extensions.d.ts.map +1 -1
  54. package/mcp-server/mcp-server.js +1 -1
  55. package/mcp-server/prompts.d.ts +26 -0
  56. package/mcp-server/prompts.d.ts.map +1 -0
  57. package/mcp-server/prompts.js +47 -0
  58. package/mcp-server/prompts.js.map +1 -0
  59. package/mcp-server/resources.d.ts.map +1 -1
  60. package/mcp-server/resources.js +1 -0
  61. package/mcp-server/resources.js.map +1 -1
  62. package/mcp-server/server.d.ts.map +1 -1
  63. package/mcp-server/server.js +16 -4
  64. package/mcp-server/server.js.map +1 -1
  65. package/mcp-server/tools/vendorScansVendorScanOut.d.ts +8 -0
  66. package/mcp-server/tools/vendorScansVendorScanOut.d.ts.map +1 -0
  67. package/mcp-server/tools/{userPasswordResetRequest.js → vendorScansVendorScanOut.js} +9 -9
  68. package/mcp-server/tools/{userPasswordResetRequest.js.map → vendorScansVendorScanOut.js.map} +1 -1
  69. package/mcp-server/tools/vendorsGetVendorsDetails.d.ts +8 -0
  70. package/mcp-server/tools/vendorsGetVendorsDetails.d.ts.map +1 -0
  71. package/mcp-server/tools/vendorsGetVendorsDetails.js +78 -0
  72. package/mcp-server/tools/vendorsGetVendorsDetails.js.map +1 -0
  73. package/mcp-server/tools/vendorsListVendorCredentials.js +1 -1
  74. package/mcp-server/tools/vendorsListVendorCredentials.js.map +1 -1
  75. package/mcp-server/tools/vendorsListVendorScrubDetails.d.ts +8 -0
  76. package/mcp-server/tools/vendorsListVendorScrubDetails.d.ts.map +1 -0
  77. package/mcp-server/tools/{userGetUserById.js → vendorsListVendorScrubDetails.js} +9 -9
  78. package/mcp-server/tools/vendorsListVendorScrubDetails.js.map +1 -0
  79. package/mcp-server/tools/vendorsListVendorScrubPurchases.d.ts +8 -0
  80. package/mcp-server/tools/vendorsListVendorScrubPurchases.d.ts.map +1 -0
  81. package/mcp-server/tools/{userPassword.js → vendorsListVendorScrubPurchases.js} +10 -11
  82. package/mcp-server/tools/vendorsListVendorScrubPurchases.js.map +1 -0
  83. package/mcp-server/tools/webhooksGetWebhookEndpoint.d.ts +8 -0
  84. package/mcp-server/tools/webhooksGetWebhookEndpoint.d.ts.map +1 -0
  85. package/mcp-server/tools/{vendorsListVendorJobTitles.js → webhooksGetWebhookEndpoint.js} +10 -10
  86. package/mcp-server/tools/webhooksGetWebhookEndpoint.js.map +1 -0
  87. package/mcp-server/tools/webhooksListAllWebhookEndpoints.d.ts +8 -0
  88. package/mcp-server/tools/webhooksListAllWebhookEndpoints.d.ts.map +1 -0
  89. package/mcp-server/tools/{userMagiclink.js → webhooksListAllWebhookEndpoints.js} +9 -9
  90. package/mcp-server/tools/webhooksListAllWebhookEndpoints.js.map +1 -0
  91. package/mcp-server/tools.d.ts.map +1 -1
  92. package/mcp-server/tools.js +1 -0
  93. package/mcp-server/tools.js.map +1 -1
  94. package/models/components/company.d.ts +15 -15
  95. package/models/components/company.d.ts.map +1 -1
  96. package/models/components/company.js +19 -18
  97. package/models/components/company.js.map +1 -1
  98. package/models/components/contact.d.ts +13 -13
  99. package/models/components/contact.d.ts.map +1 -1
  100. package/models/components/contact.js +16 -16
  101. package/models/components/contact.js.map +1 -1
  102. package/models/components/department.d.ts +34 -0
  103. package/models/components/department.d.ts.map +1 -0
  104. package/models/components/department.js +71 -0
  105. package/models/components/department.js.map +1 -0
  106. package/models/components/expand.d.ts +24 -0
  107. package/models/components/expand.d.ts.map +1 -1
  108. package/models/components/expand.js +8 -0
  109. package/models/components/expand.js.map +1 -1
  110. package/models/components/facility.d.ts +17 -17
  111. package/models/components/facility.d.ts.map +1 -1
  112. package/models/components/facility.js +20 -20
  113. package/models/components/facility.js.map +1 -1
  114. package/models/components/index.d.ts +7 -0
  115. package/models/components/index.d.ts.map +1 -1
  116. package/models/components/index.js +7 -0
  117. package/models/components/index.js.map +1 -1
  118. package/models/components/scantype.d.ts +31 -0
  119. package/models/components/scantype.d.ts.map +1 -0
  120. package/models/components/scantype.js +62 -0
  121. package/models/components/scantype.js.map +1 -0
  122. package/models/components/subscription.d.ts +42 -0
  123. package/models/components/subscription.d.ts.map +1 -0
  124. package/models/components/subscription.js +92 -0
  125. package/models/components/subscription.js.map +1 -0
  126. package/models/components/user.d.ts +8 -25
  127. package/models/components/user.d.ts.map +1 -1
  128. package/models/components/user.js +8 -31
  129. package/models/components/user.js.map +1 -1
  130. package/models/components/vendor.d.ts +374 -0
  131. package/models/components/vendor.d.ts.map +1 -0
  132. package/models/components/vendor.js +523 -0
  133. package/models/components/vendor.js.map +1 -0
  134. package/models/components/vendorscrubdetails.d.ts +42 -0
  135. package/models/components/vendorscrubdetails.d.ts.map +1 -0
  136. package/models/components/vendorscrubdetails.js +98 -0
  137. package/models/components/vendorscrubdetails.js.map +1 -0
  138. package/models/components/vendorscrubpurchase.d.ts +38 -0
  139. package/models/components/vendorscrubpurchase.d.ts.map +1 -0
  140. package/models/components/vendorscrubpurchase.js +84 -0
  141. package/models/components/vendorscrubpurchase.js.map +1 -0
  142. package/models/components/webhookendpoint.d.ts +135 -0
  143. package/models/components/webhookendpoint.d.ts.map +1 -0
  144. package/models/components/webhookendpoint.js +158 -0
  145. package/models/components/webhookendpoint.js.map +1 -0
  146. package/models/operations/getvendorsdetails.d.ts +38 -0
  147. package/models/operations/getvendorsdetails.d.ts.map +1 -0
  148. package/models/operations/getvendorsdetails.js +81 -0
  149. package/models/operations/getvendorsdetails.js.map +1 -0
  150. package/models/operations/getwebhookendpoint.d.ts +32 -0
  151. package/models/operations/getwebhookendpoint.d.ts.map +1 -0
  152. package/models/operations/getwebhookendpoint.js +69 -0
  153. package/models/operations/getwebhookendpoint.js.map +1 -0
  154. package/models/operations/index.d.ts +6 -0
  155. package/models/operations/index.d.ts.map +1 -1
  156. package/models/operations/index.js +6 -0
  157. package/models/operations/index.js.map +1 -1
  158. package/models/operations/listallwebhookendpoints.d.ts +81 -0
  159. package/models/operations/listallwebhookendpoints.d.ts.map +1 -0
  160. package/models/operations/listallwebhookendpoints.js +114 -0
  161. package/models/operations/listallwebhookendpoints.js.map +1 -0
  162. package/models/operations/listorsearchfacilities.d.ts +2 -2
  163. package/models/operations/listorsearchfacilities.d.ts.map +1 -1
  164. package/models/operations/listorsearchfacilities.js +2 -2
  165. package/models/operations/listorsearchfacilities.js.map +1 -1
  166. package/models/operations/listvendorcredentials.d.ts +77 -5
  167. package/models/operations/listvendorcredentials.d.ts.map +1 -1
  168. package/models/operations/listvendorcredentials.js +78 -3
  169. package/models/operations/listvendorcredentials.js.map +1 -1
  170. package/models/operations/listvendorfacilitystatuses.d.ts +5 -0
  171. package/models/operations/listvendorfacilitystatuses.d.ts.map +1 -1
  172. package/models/operations/listvendorfacilitystatuses.js +4 -0
  173. package/models/operations/listvendorfacilitystatuses.js.map +1 -1
  174. package/models/operations/listvendorjobtitles.d.ts +27 -0
  175. package/models/operations/listvendorjobtitles.d.ts.map +1 -1
  176. package/models/operations/listvendorjobtitles.js +38 -1
  177. package/models/operations/listvendorjobtitles.js.map +1 -1
  178. package/models/operations/listvendorscrubdetails.d.ts +32 -0
  179. package/models/operations/listvendorscrubdetails.d.ts.map +1 -0
  180. package/models/operations/listvendorscrubdetails.js +78 -0
  181. package/models/operations/listvendorscrubdetails.js.map +1 -0
  182. package/models/operations/listvendorscrubpurchases.d.ts +111 -0
  183. package/models/operations/listvendorscrubpurchases.d.ts.map +1 -0
  184. package/models/operations/listvendorscrubpurchases.js +153 -0
  185. package/models/operations/listvendorscrubpurchases.js.map +1 -0
  186. package/models/operations/vendorscanout.d.ts +64 -0
  187. package/models/operations/vendorscanout.d.ts.map +1 -0
  188. package/models/operations/vendorscanout.js +100 -0
  189. package/models/operations/vendorscanout.js.map +1 -0
  190. package/package.json +1 -1
  191. package/react-query/index.d.ts +6 -0
  192. package/react-query/index.d.ts.map +1 -1
  193. package/react-query/index.js +6 -0
  194. package/react-query/index.js.map +1 -1
  195. package/react-query/vendorScansVendorScanOut.d.ts +23 -0
  196. package/react-query/vendorScansVendorScanOut.d.ts.map +1 -0
  197. package/react-query/vendorScansVendorScanOut.js +47 -0
  198. package/react-query/vendorScansVendorScanOut.js.map +1 -0
  199. package/react-query/vendorsGetVendorsDetails.d.ts +71 -0
  200. package/react-query/vendorsGetVendorsDetails.d.ts.map +1 -0
  201. package/react-query/vendorsGetVendorsDetails.js +123 -0
  202. package/react-query/vendorsGetVendorsDetails.js.map +1 -0
  203. package/react-query/vendorsListVendorCredentials.d.ts +40 -3
  204. package/react-query/vendorsListVendorCredentials.d.ts.map +1 -1
  205. package/react-query/vendorsListVendorCredentials.js +67 -0
  206. package/react-query/vendorsListVendorCredentials.js.map +1 -1
  207. package/react-query/vendorsListVendorFacilityStatuses.d.ts +3 -0
  208. package/react-query/vendorsListVendorFacilityStatuses.d.ts.map +1 -1
  209. package/react-query/vendorsListVendorFacilityStatuses.js +2 -0
  210. package/react-query/vendorsListVendorFacilityStatuses.js.map +1 -1
  211. package/react-query/vendorsListVendorJobTitles.d.ts +7 -7
  212. package/react-query/vendorsListVendorJobTitles.d.ts.map +1 -1
  213. package/react-query/vendorsListVendorJobTitles.js +15 -15
  214. package/react-query/vendorsListVendorJobTitles.js.map +1 -1
  215. package/react-query/vendorsListVendorScrubDetails.d.ts +31 -0
  216. package/react-query/vendorsListVendorScrubDetails.d.ts.map +1 -0
  217. package/react-query/vendorsListVendorScrubDetails.js +96 -0
  218. package/react-query/vendorsListVendorScrubDetails.js.map +1 -0
  219. package/react-query/vendorsListVendorScrubPurchases.d.ts +77 -0
  220. package/react-query/vendorsListVendorScrubPurchases.d.ts.map +1 -0
  221. package/react-query/vendorsListVendorScrubPurchases.js +160 -0
  222. package/react-query/vendorsListVendorScrubPurchases.js.map +1 -0
  223. package/react-query/webhooksGetWebhookEndpoint.d.ts +31 -0
  224. package/react-query/webhooksGetWebhookEndpoint.d.ts.map +1 -0
  225. package/react-query/webhooksGetWebhookEndpoint.js +96 -0
  226. package/react-query/webhooksGetWebhookEndpoint.js.map +1 -0
  227. package/react-query/webhooksListAllWebhookEndpoints.d.ts +50 -0
  228. package/react-query/webhooksListAllWebhookEndpoints.d.ts.map +1 -0
  229. package/react-query/webhooksListAllWebhookEndpoints.js +101 -0
  230. package/react-query/webhooksListAllWebhookEndpoints.js.map +1 -0
  231. package/sdk/sdk.d.ts +6 -0
  232. package/sdk/sdk.d.ts.map +1 -1
  233. package/sdk/sdk.js +8 -0
  234. package/sdk/sdk.js.map +1 -1
  235. package/sdk/vendors.d.ts +41 -2
  236. package/sdk/vendors.d.ts.map +1 -1
  237. package/sdk/vendors.js +47 -3
  238. package/sdk/vendors.js.map +1 -1
  239. package/sdk/vendorscans.d.ts +12 -0
  240. package/sdk/vendorscans.d.ts.map +1 -0
  241. package/sdk/vendorscans.js +22 -0
  242. package/sdk/vendorscans.js.map +1 -0
  243. package/sdk/webhooks.d.ts +20 -0
  244. package/sdk/webhooks.d.ts.map +1 -0
  245. package/sdk/webhooks.js +32 -0
  246. package/sdk/webhooks.js.map +1 -0
  247. package/src/__tests__/vendors.test.ts +50 -152
  248. package/src/__tests__/vendorscans.test.ts +27 -0
  249. package/src/__tests__/webhooks.test.ts +45 -0
  250. package/src/funcs/organizationsListOrSearchFacilities.ts +12 -1
  251. package/src/funcs/vendorScansVendorScanOut.ts +172 -0
  252. package/src/funcs/vendorsGetVendorsDetails.ts +192 -0
  253. package/src/funcs/vendorsListVendorCredentials.ts +104 -27
  254. package/src/funcs/vendorsListVendorFacilityStatuses.ts +7 -1
  255. package/src/funcs/vendorsListVendorJobTitles.ts +25 -2
  256. package/src/funcs/vendorsListVendorScrubDetails.ts +172 -0
  257. package/src/funcs/vendorsListVendorScrubPurchases.ts +249 -0
  258. package/src/funcs/webhooksGetWebhookEndpoint.ts +173 -0
  259. package/src/funcs/webhooksListAllWebhookEndpoints.ts +174 -0
  260. package/src/lib/config.ts +3 -3
  261. package/src/lib/security.ts +11 -3
  262. package/src/mcp-server/extensions.ts +4 -0
  263. package/src/mcp-server/mcp-server.ts +1 -1
  264. package/src/mcp-server/prompts.ts +110 -0
  265. package/src/mcp-server/resources.ts +1 -0
  266. package/src/mcp-server/server.ts +16 -4
  267. package/src/mcp-server/tools/vendorScansVendorScanOut.ts +37 -0
  268. package/src/mcp-server/tools/vendorsGetVendorsDetails.ts +51 -0
  269. package/src/mcp-server/tools/vendorsListVendorCredentials.ts +1 -1
  270. package/src/mcp-server/tools/vendorsListVendorScrubDetails.ts +37 -0
  271. package/src/mcp-server/tools/vendorsListVendorScrubPurchases.ts +38 -0
  272. package/src/mcp-server/tools/{vendorsListVendorJobTitles.ts → webhooksGetWebhookEndpoint.ts} +8 -8
  273. package/src/mcp-server/tools/webhooksListAllWebhookEndpoints.ts +38 -0
  274. package/src/mcp-server/tools.ts +1 -0
  275. package/src/models/components/company.ts +27 -24
  276. package/src/models/components/contact.ts +24 -20
  277. package/src/models/components/department.ts +69 -0
  278. package/src/models/components/expand.ts +8 -0
  279. package/src/models/components/facility.ts +28 -32
  280. package/src/models/components/index.ts +7 -0
  281. package/src/models/components/scantype.ts +32 -0
  282. package/src/models/components/subscription.ts +98 -0
  283. package/src/models/components/user.ts +19 -53
  284. package/src/models/components/vendor.ts +925 -0
  285. package/src/models/components/vendorscrubdetails.ts +108 -0
  286. package/src/models/components/vendorscrubpurchase.ts +90 -0
  287. package/src/models/components/webhookendpoint.ts +244 -0
  288. package/src/models/operations/getvendorsdetails.ts +86 -0
  289. package/src/models/operations/getwebhookendpoint.ts +69 -0
  290. package/src/models/operations/index.ts +6 -0
  291. package/src/models/operations/listallwebhookendpoints.ts +175 -0
  292. package/src/models/operations/listorsearchfacilities.ts +4 -4
  293. package/src/models/operations/listvendorcredentials.ts +160 -7
  294. package/src/models/operations/listvendorfacilitystatuses.ts +9 -0
  295. package/src/models/operations/listvendorjobtitles.ts +72 -0
  296. package/src/models/operations/listvendorscrubdetails.ts +80 -0
  297. package/src/models/operations/listvendorscrubpurchases.ts +252 -0
  298. package/src/models/operations/vendorscanout.ts +138 -0
  299. package/src/react-query/index.ts +6 -0
  300. package/src/react-query/vendorScansVendorScanOut.ts +89 -0
  301. package/src/react-query/vendorsGetVendorsDetails.ts +201 -0
  302. package/src/react-query/vendorsListVendorCredentials.ts +169 -1
  303. package/src/react-query/vendorsListVendorFacilityStatuses.ts +5 -0
  304. package/src/react-query/vendorsListVendorJobTitles.ts +15 -0
  305. package/src/react-query/vendorsListVendorScrubDetails.ts +166 -0
  306. package/src/react-query/vendorsListVendorScrubPurchases.ts +346 -0
  307. package/src/react-query/webhooksGetWebhookEndpoint.ts +163 -0
  308. package/src/react-query/webhooksListAllWebhookEndpoints.ts +193 -0
  309. package/src/sdk/sdk.ts +12 -0
  310. package/src/sdk/vendors.ts +76 -2
  311. package/src/sdk/vendorscans.ts +27 -0
  312. package/src/sdk/webhooks.ts +46 -0
  313. package/mcp-server/tools/userGetCurrentUser.d.ts +0 -3
  314. package/mcp-server/tools/userGetCurrentUser.d.ts.map +0 -1
  315. package/mcp-server/tools/userGetCurrentUser.js +0 -26
  316. package/mcp-server/tools/userGetCurrentUser.js.map +0 -1
  317. package/mcp-server/tools/userGetUserById.d.ts +0 -8
  318. package/mcp-server/tools/userGetUserById.d.ts.map +0 -1
  319. package/mcp-server/tools/userGetUserById.js.map +0 -1
  320. package/mcp-server/tools/userLogsUserIntoTheSystem.d.ts +0 -8
  321. package/mcp-server/tools/userLogsUserIntoTheSystem.d.ts.map +0 -1
  322. package/mcp-server/tools/userLogsUserIntoTheSystem.js +0 -94
  323. package/mcp-server/tools/userLogsUserIntoTheSystem.js.map +0 -1
  324. package/mcp-server/tools/userMagiclink.d.ts +0 -8
  325. package/mcp-server/tools/userMagiclink.d.ts.map +0 -1
  326. package/mcp-server/tools/userMagiclink.js.map +0 -1
  327. package/mcp-server/tools/userPassword.d.ts +0 -8
  328. package/mcp-server/tools/userPassword.d.ts.map +0 -1
  329. package/mcp-server/tools/userPassword.js.map +0 -1
  330. package/mcp-server/tools/userPasswordResetRequest.d.ts +0 -8
  331. package/mcp-server/tools/userPasswordResetRequest.d.ts.map +0 -1
  332. package/mcp-server/tools/vendorsListVendorJobTitles.d.ts +0 -8
  333. package/mcp-server/tools/vendorsListVendorJobTitles.d.ts.map +0 -1
  334. package/mcp-server/tools/vendorsListVendorJobTitles.js.map +0 -1
  335. package/src/__tests__/organizations.test.ts +0 -78
  336. package/src/__tests__/supportarticles.test.ts +0 -64
  337. package/src/__tests__/user.test.ts +0 -218
  338. package/vitest.config.ts +0 -8
@@ -0,0 +1,249 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { GreenSecurityCore } from "../core.js";
6
+ import { dlv } from "../lib/dlv.js";
7
+ import { encodeFormQuery, encodeSimple } from "../lib/encodings.js";
8
+ import * as M from "../lib/matchers.js";
9
+ import { compactMap } from "../lib/primitives.js";
10
+ import { safeParse } from "../lib/schemas.js";
11
+ import { RequestOptions } from "../lib/sdks.js";
12
+ import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
13
+ import { pathToFunc } from "../lib/url.js";
14
+ import { APIError } from "../models/errors/apierror.js";
15
+ import {
16
+ ConnectionError,
17
+ InvalidRequestError,
18
+ RequestAbortedError,
19
+ RequestTimeoutError,
20
+ UnexpectedClientError,
21
+ } from "../models/errors/httpclienterrors.js";
22
+ import * as errors from "../models/errors/index.js";
23
+ import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
24
+ import * as operations from "../models/operations/index.js";
25
+ import { APICall, APIPromise } from "../types/async.js";
26
+ import { Result } from "../types/fp.js";
27
+ import {
28
+ createPageIterator,
29
+ haltIterator,
30
+ PageIterator,
31
+ Paginator,
32
+ } from "../types/operations.js";
33
+
34
+ /**
35
+ * List vendor scrub purchases
36
+ *
37
+ * @remarks
38
+ * List vendor scrub purchases
39
+ */
40
+ export function vendorsListVendorScrubPurchases(
41
+ client: GreenSecurityCore,
42
+ request: operations.ListVendorScrubPurchasesRequest,
43
+ options?: RequestOptions,
44
+ ): APIPromise<
45
+ PageIterator<
46
+ Result<
47
+ operations.ListVendorScrubPurchasesResponse,
48
+ | errors.ApiErrorResponse
49
+ | APIError
50
+ | SDKValidationError
51
+ | UnexpectedClientError
52
+ | InvalidRequestError
53
+ | RequestAbortedError
54
+ | RequestTimeoutError
55
+ | ConnectionError
56
+ >,
57
+ { page: number }
58
+ >
59
+ > {
60
+ return new APIPromise($do(
61
+ client,
62
+ request,
63
+ options,
64
+ ));
65
+ }
66
+
67
+ async function $do(
68
+ client: GreenSecurityCore,
69
+ request: operations.ListVendorScrubPurchasesRequest,
70
+ options?: RequestOptions,
71
+ ): Promise<
72
+ [
73
+ PageIterator<
74
+ Result<
75
+ operations.ListVendorScrubPurchasesResponse,
76
+ | errors.ApiErrorResponse
77
+ | APIError
78
+ | SDKValidationError
79
+ | UnexpectedClientError
80
+ | InvalidRequestError
81
+ | RequestAbortedError
82
+ | RequestTimeoutError
83
+ | ConnectionError
84
+ >,
85
+ { page: number }
86
+ >,
87
+ APICall,
88
+ ]
89
+ > {
90
+ const parsed = safeParse(
91
+ request,
92
+ (value) =>
93
+ operations.ListVendorScrubPurchasesRequest$outboundSchema.parse(value),
94
+ "Input validation failed",
95
+ );
96
+ if (!parsed.ok) {
97
+ return [haltIterator(parsed), { status: "invalid" }];
98
+ }
99
+ const payload = parsed.value;
100
+ const body = null;
101
+
102
+ const pathParams = {
103
+ vendor_id_or_me: encodeSimple("vendor_id_or_me", payload.vendor_id_or_me, {
104
+ explode: false,
105
+ charEncoding: "percent",
106
+ }),
107
+ };
108
+
109
+ const path = pathToFunc("/vendors/{vendor_id_or_me}/scrub_purchases")(
110
+ pathParams,
111
+ );
112
+
113
+ const query = encodeFormQuery({
114
+ "desc": payload.desc,
115
+ "items_per_page": payload.items_per_page,
116
+ "page": payload.page,
117
+ "sort": payload.sort,
118
+ });
119
+
120
+ const headers = new Headers(compactMap({
121
+ Accept: "application/json",
122
+ }));
123
+
124
+ const securityInput = await extractSecurity(client._options.security);
125
+ const requestSecurity = resolveGlobalSecurity(securityInput);
126
+
127
+ const context = {
128
+ baseURL: options?.serverURL ?? client._baseURL ?? "",
129
+ operationID: "listVendorScrubPurchases",
130
+ oAuth2Scopes: [],
131
+
132
+ resolvedSecurity: requestSecurity,
133
+
134
+ securitySource: client._options.security,
135
+ retryConfig: options?.retries
136
+ || client._options.retryConfig
137
+ || { strategy: "none" },
138
+ retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
139
+ };
140
+
141
+ const requestRes = client._createRequest(context, {
142
+ security: requestSecurity,
143
+ method: "GET",
144
+ baseURL: options?.serverURL,
145
+ path: path,
146
+ headers: headers,
147
+ query: query,
148
+ body: body,
149
+ timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
150
+ }, options);
151
+ if (!requestRes.ok) {
152
+ return [haltIterator(requestRes), { status: "invalid" }];
153
+ }
154
+ const req = requestRes.value;
155
+
156
+ const doResult = await client._do(req, {
157
+ context,
158
+ errorCodes: ["400", "401", "4XX", "5XX"],
159
+ retryConfig: context.retryConfig,
160
+ retryCodes: context.retryCodes,
161
+ });
162
+ if (!doResult.ok) {
163
+ return [haltIterator(doResult), { status: "request-error", request: req }];
164
+ }
165
+ const response = doResult.value;
166
+
167
+ const responseFields = {
168
+ HttpMeta: { Response: response, Request: req },
169
+ };
170
+
171
+ const [result, raw] = await M.match<
172
+ operations.ListVendorScrubPurchasesResponse,
173
+ | errors.ApiErrorResponse
174
+ | APIError
175
+ | SDKValidationError
176
+ | UnexpectedClientError
177
+ | InvalidRequestError
178
+ | RequestAbortedError
179
+ | RequestTimeoutError
180
+ | ConnectionError
181
+ >(
182
+ M.json(200, operations.ListVendorScrubPurchasesResponse$inboundSchema, {
183
+ key: "Result",
184
+ }),
185
+ M.jsonErr([400, 401], errors.ApiErrorResponse$inboundSchema),
186
+ M.fail("4XX"),
187
+ M.fail("5XX"),
188
+ )(response, { extraFields: responseFields });
189
+ if (!result.ok) {
190
+ return [haltIterator(result), {
191
+ status: "complete",
192
+ request: req,
193
+ response,
194
+ }];
195
+ }
196
+
197
+ const nextFunc = (
198
+ responseData: unknown,
199
+ ): {
200
+ next: Paginator<
201
+ Result<
202
+ operations.ListVendorScrubPurchasesResponse,
203
+ | errors.ApiErrorResponse
204
+ | APIError
205
+ | SDKValidationError
206
+ | UnexpectedClientError
207
+ | InvalidRequestError
208
+ | RequestAbortedError
209
+ | RequestTimeoutError
210
+ | ConnectionError
211
+ >
212
+ >;
213
+ "~next"?: { page: number };
214
+ } => {
215
+ const page = request?.page ?? 1;
216
+ const nextPage = page + 1;
217
+
218
+ if (!responseData) {
219
+ return { next: () => null };
220
+ }
221
+ const results = dlv(responseData, "items");
222
+ if (!Array.isArray(results) || !results.length) {
223
+ return { next: () => null };
224
+ }
225
+ const limit = request?.itemsPerPage ?? 0;
226
+ if (results.length < limit) {
227
+ return { next: () => null };
228
+ }
229
+
230
+ const nextVal = () =>
231
+ vendorsListVendorScrubPurchases(
232
+ client,
233
+ {
234
+ ...request,
235
+ page: nextPage,
236
+ },
237
+ options,
238
+ );
239
+
240
+ return { next: nextVal, "~next": { page: nextPage } };
241
+ };
242
+
243
+ const page = { ...result, ...nextFunc(raw) };
244
+ return [{ ...page, ...createPageIterator(page, (v) => !v.ok) }, {
245
+ status: "complete",
246
+ request: req,
247
+ response,
248
+ }];
249
+ }
@@ -0,0 +1,173 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { GreenSecurityCore } from "../core.js";
6
+ import { encodeSimple } from "../lib/encodings.js";
7
+ import * as M from "../lib/matchers.js";
8
+ import { compactMap } from "../lib/primitives.js";
9
+ import { safeParse } from "../lib/schemas.js";
10
+ import { RequestOptions } from "../lib/sdks.js";
11
+ import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
12
+ import { pathToFunc } from "../lib/url.js";
13
+ import * as components from "../models/components/index.js";
14
+ import { APIError } from "../models/errors/apierror.js";
15
+ import {
16
+ ConnectionError,
17
+ InvalidRequestError,
18
+ RequestAbortedError,
19
+ RequestTimeoutError,
20
+ UnexpectedClientError,
21
+ } from "../models/errors/httpclienterrors.js";
22
+ import * as errors from "../models/errors/index.js";
23
+ import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
24
+ import * as operations from "../models/operations/index.js";
25
+ import { APICall, APIPromise } from "../types/async.js";
26
+ import { Result } from "../types/fp.js";
27
+
28
+ /**
29
+ * Retrieves the webhook endpoint with the given ID.
30
+ *
31
+ * @remarks
32
+ * Returns the definition of a webhook endpoint by ID.
33
+ */
34
+ export function webhooksGetWebhookEndpoint(
35
+ client: GreenSecurityCore,
36
+ request: operations.GetWebhookEndpointRequest,
37
+ options?: RequestOptions,
38
+ ): APIPromise<
39
+ Result<
40
+ components.WebhookEndpoint,
41
+ | errors.ApiErrorResponse
42
+ | errors.ApiErrorResponse
43
+ | APIError
44
+ | SDKValidationError
45
+ | UnexpectedClientError
46
+ | InvalidRequestError
47
+ | RequestAbortedError
48
+ | RequestTimeoutError
49
+ | ConnectionError
50
+ >
51
+ > {
52
+ return new APIPromise($do(
53
+ client,
54
+ request,
55
+ options,
56
+ ));
57
+ }
58
+
59
+ async function $do(
60
+ client: GreenSecurityCore,
61
+ request: operations.GetWebhookEndpointRequest,
62
+ options?: RequestOptions,
63
+ ): Promise<
64
+ [
65
+ Result<
66
+ components.WebhookEndpoint,
67
+ | errors.ApiErrorResponse
68
+ | errors.ApiErrorResponse
69
+ | APIError
70
+ | SDKValidationError
71
+ | UnexpectedClientError
72
+ | InvalidRequestError
73
+ | RequestAbortedError
74
+ | RequestTimeoutError
75
+ | ConnectionError
76
+ >,
77
+ APICall,
78
+ ]
79
+ > {
80
+ const parsed = safeParse(
81
+ request,
82
+ (value) => operations.GetWebhookEndpointRequest$outboundSchema.parse(value),
83
+ "Input validation failed",
84
+ );
85
+ if (!parsed.ok) {
86
+ return [parsed, { status: "invalid" }];
87
+ }
88
+ const payload = parsed.value;
89
+ const body = null;
90
+
91
+ const pathParams = {
92
+ id: encodeSimple("id", payload.id, {
93
+ explode: false,
94
+ charEncoding: "percent",
95
+ }),
96
+ };
97
+
98
+ const path = pathToFunc("/webhooks/{id}")(pathParams);
99
+
100
+ const headers = new Headers(compactMap({
101
+ Accept: "application/json",
102
+ }));
103
+
104
+ const securityInput = await extractSecurity(client._options.security);
105
+ const requestSecurity = resolveGlobalSecurity(securityInput);
106
+
107
+ const context = {
108
+ baseURL: options?.serverURL ?? client._baseURL ?? "",
109
+ operationID: "getWebhookEndpoint",
110
+ oAuth2Scopes: [],
111
+
112
+ resolvedSecurity: requestSecurity,
113
+
114
+ securitySource: client._options.security,
115
+ retryConfig: options?.retries
116
+ || client._options.retryConfig
117
+ || { strategy: "none" },
118
+ retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
119
+ };
120
+
121
+ const requestRes = client._createRequest(context, {
122
+ security: requestSecurity,
123
+ method: "GET",
124
+ baseURL: options?.serverURL,
125
+ path: path,
126
+ headers: headers,
127
+ body: body,
128
+ timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
129
+ }, options);
130
+ if (!requestRes.ok) {
131
+ return [requestRes, { status: "invalid" }];
132
+ }
133
+ const req = requestRes.value;
134
+
135
+ const doResult = await client._do(req, {
136
+ context,
137
+ errorCodes: ["400", "401", "403", "4XX", "500", "5XX"],
138
+ retryConfig: context.retryConfig,
139
+ retryCodes: context.retryCodes,
140
+ });
141
+ if (!doResult.ok) {
142
+ return [doResult, { status: "request-error", request: req }];
143
+ }
144
+ const response = doResult.value;
145
+
146
+ const responseFields = {
147
+ HttpMeta: { Response: response, Request: req },
148
+ };
149
+
150
+ const [result] = await M.match<
151
+ components.WebhookEndpoint,
152
+ | errors.ApiErrorResponse
153
+ | errors.ApiErrorResponse
154
+ | APIError
155
+ | SDKValidationError
156
+ | UnexpectedClientError
157
+ | InvalidRequestError
158
+ | RequestAbortedError
159
+ | RequestTimeoutError
160
+ | ConnectionError
161
+ >(
162
+ M.json(200, components.WebhookEndpoint$inboundSchema),
163
+ M.jsonErr([400, 401, 403], errors.ApiErrorResponse$inboundSchema),
164
+ M.jsonErr(500, errors.ApiErrorResponse$inboundSchema),
165
+ M.fail("4XX"),
166
+ M.fail("5XX"),
167
+ )(response, { extraFields: responseFields });
168
+ if (!result.ok) {
169
+ return [result, { status: "complete", request: req, response }];
170
+ }
171
+
172
+ return [result, { status: "complete", request: req, response }];
173
+ }
@@ -0,0 +1,174 @@
1
+ /*
2
+ * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
3
+ */
4
+
5
+ import { GreenSecurityCore } from "../core.js";
6
+ import { encodeFormQuery } from "../lib/encodings.js";
7
+ import * as M from "../lib/matchers.js";
8
+ import { compactMap } from "../lib/primitives.js";
9
+ import { safeParse } from "../lib/schemas.js";
10
+ import { RequestOptions } from "../lib/sdks.js";
11
+ import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
12
+ import { pathToFunc } from "../lib/url.js";
13
+ import { APIError } from "../models/errors/apierror.js";
14
+ import {
15
+ ConnectionError,
16
+ InvalidRequestError,
17
+ RequestAbortedError,
18
+ RequestTimeoutError,
19
+ UnexpectedClientError,
20
+ } from "../models/errors/httpclienterrors.js";
21
+ import * as errors from "../models/errors/index.js";
22
+ import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
23
+ import * as operations from "../models/operations/index.js";
24
+ import { APICall, APIPromise } from "../types/async.js";
25
+ import { Result } from "../types/fp.js";
26
+
27
+ /**
28
+ * List all webhook endpoints
29
+ *
30
+ * @remarks
31
+ * Returns a list of your webhook endpoints.
32
+ */
33
+ export function webhooksListAllWebhookEndpoints(
34
+ client: GreenSecurityCore,
35
+ request: operations.ListAllWebhookEndpointsRequest,
36
+ options?: RequestOptions,
37
+ ): APIPromise<
38
+ Result<
39
+ operations.ListAllWebhookEndpointsResponseBody,
40
+ | errors.ApiErrorResponse
41
+ | errors.ApiErrorResponse
42
+ | APIError
43
+ | SDKValidationError
44
+ | UnexpectedClientError
45
+ | InvalidRequestError
46
+ | RequestAbortedError
47
+ | RequestTimeoutError
48
+ | ConnectionError
49
+ >
50
+ > {
51
+ return new APIPromise($do(
52
+ client,
53
+ request,
54
+ options,
55
+ ));
56
+ }
57
+
58
+ async function $do(
59
+ client: GreenSecurityCore,
60
+ request: operations.ListAllWebhookEndpointsRequest,
61
+ options?: RequestOptions,
62
+ ): Promise<
63
+ [
64
+ Result<
65
+ operations.ListAllWebhookEndpointsResponseBody,
66
+ | errors.ApiErrorResponse
67
+ | errors.ApiErrorResponse
68
+ | APIError
69
+ | SDKValidationError
70
+ | UnexpectedClientError
71
+ | InvalidRequestError
72
+ | RequestAbortedError
73
+ | RequestTimeoutError
74
+ | ConnectionError
75
+ >,
76
+ APICall,
77
+ ]
78
+ > {
79
+ const parsed = safeParse(
80
+ request,
81
+ (value) =>
82
+ operations.ListAllWebhookEndpointsRequest$outboundSchema.parse(value),
83
+ "Input validation failed",
84
+ );
85
+ if (!parsed.ok) {
86
+ return [parsed, { status: "invalid" }];
87
+ }
88
+ const payload = parsed.value;
89
+ const body = null;
90
+
91
+ const path = pathToFunc("/webhooks")();
92
+
93
+ const query = encodeFormQuery({
94
+ "desc": payload.desc,
95
+ "items_per_page": payload.items_per_page,
96
+ "page": payload.page,
97
+ "sort": payload.sort,
98
+ });
99
+
100
+ const headers = new Headers(compactMap({
101
+ Accept: "application/json",
102
+ }));
103
+
104
+ const securityInput = await extractSecurity(client._options.security);
105
+ const requestSecurity = resolveGlobalSecurity(securityInput);
106
+
107
+ const context = {
108
+ baseURL: options?.serverURL ?? client._baseURL ?? "",
109
+ operationID: "listAllWebhookEndpoints",
110
+ oAuth2Scopes: [],
111
+
112
+ resolvedSecurity: requestSecurity,
113
+
114
+ securitySource: client._options.security,
115
+ retryConfig: options?.retries
116
+ || client._options.retryConfig
117
+ || { strategy: "none" },
118
+ retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
119
+ };
120
+
121
+ const requestRes = client._createRequest(context, {
122
+ security: requestSecurity,
123
+ method: "GET",
124
+ baseURL: options?.serverURL,
125
+ path: path,
126
+ headers: headers,
127
+ query: query,
128
+ body: body,
129
+ timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
130
+ }, options);
131
+ if (!requestRes.ok) {
132
+ return [requestRes, { status: "invalid" }];
133
+ }
134
+ const req = requestRes.value;
135
+
136
+ const doResult = await client._do(req, {
137
+ context,
138
+ errorCodes: ["400", "401", "403", "4XX", "500", "5XX"],
139
+ retryConfig: context.retryConfig,
140
+ retryCodes: context.retryCodes,
141
+ });
142
+ if (!doResult.ok) {
143
+ return [doResult, { status: "request-error", request: req }];
144
+ }
145
+ const response = doResult.value;
146
+
147
+ const responseFields = {
148
+ HttpMeta: { Response: response, Request: req },
149
+ };
150
+
151
+ const [result] = await M.match<
152
+ operations.ListAllWebhookEndpointsResponseBody,
153
+ | errors.ApiErrorResponse
154
+ | errors.ApiErrorResponse
155
+ | APIError
156
+ | SDKValidationError
157
+ | UnexpectedClientError
158
+ | InvalidRequestError
159
+ | RequestAbortedError
160
+ | RequestTimeoutError
161
+ | ConnectionError
162
+ >(
163
+ M.json(200, operations.ListAllWebhookEndpointsResponseBody$inboundSchema),
164
+ M.jsonErr([400, 401, 403], errors.ApiErrorResponse$inboundSchema),
165
+ M.jsonErr(500, errors.ApiErrorResponse$inboundSchema),
166
+ M.fail("4XX"),
167
+ M.fail("5XX"),
168
+ )(response, { extraFields: responseFields });
169
+ if (!result.ok) {
170
+ return [result, { status: "complete", request: req, response }];
171
+ }
172
+
173
+ return [result, { status: "complete", request: req, response }];
174
+ }
package/src/lib/config.ts CHANGED
@@ -72,8 +72,8 @@ export function serverURLFromOptions(options: SDKOptions): URL | null {
72
72
  export const SDK_METADATA = {
73
73
  language: "typescript",
74
74
  openapiDocVersion: "0.0.3",
75
- sdkVersion: "0.19.0",
76
- genVersion: "2.548.5",
75
+ sdkVersion: "0.21.1",
76
+ genVersion: "2.558.2",
77
77
  userAgent:
78
- "speakeasy-sdk/typescript 0.19.0 2.548.5 0.0.3 @greensecurity/javascript-sdk",
78
+ "speakeasy-sdk/typescript 0.21.1 2.558.2 0.0.3 @greensecurity/javascript-sdk",
79
79
  } as const;
@@ -4,6 +4,7 @@
4
4
 
5
5
  import * as components from "../models/components/index.js";
6
6
  import { env } from "./env.js";
7
+
7
8
  type OAuth2PasswordFlow = {
8
9
  username: string;
9
10
  password?: string | undefined;
@@ -85,7 +86,9 @@ type SecurityInputOAuth2ClientCredentials = {
85
86
  value:
86
87
  | { clientID?: string | undefined; clientSecret?: string | undefined }
87
88
  | null
89
+ | string
88
90
  | undefined;
91
+ fieldName?: string;
89
92
  };
90
93
 
91
94
  type SecurityInputOAuth2PasswordCredentials = {
@@ -94,13 +97,13 @@ type SecurityInputOAuth2PasswordCredentials = {
94
97
  | string
95
98
  | null
96
99
  | undefined;
97
- fieldName: string;
100
+ fieldName?: string;
98
101
  };
99
102
 
100
103
  type SecurityInputCustom = {
101
104
  type: "http:custom";
102
105
  value: any | null | undefined;
103
- fieldName: string;
106
+ fieldName?: string;
104
107
  };
105
108
 
106
109
  export type SecurityInput =
@@ -137,6 +140,9 @@ export function resolveSecurity(
137
140
  typeof o.value === "string" && !!o.value
138
141
  );
139
142
  } else if (o.type === "oauth2:client_credentials") {
143
+ if (typeof o.value == "string") {
144
+ return !!o.value;
145
+ }
140
146
  return o.value.clientID != null || o.value.clientSecret != null;
141
147
  } else if (typeof o.value === "string") {
142
148
  return !!o.value;
@@ -225,7 +231,9 @@ function applyBearer(
225
231
  value = `Bearer ${value}`;
226
232
  }
227
233
 
228
- state.headers[spec.fieldName] = value;
234
+ if (spec.fieldName !== undefined) {
235
+ state.headers[spec.fieldName] = value;
236
+ }
229
237
  }
230
238
 
231
239
  export function resolveGlobalSecurity(
@@ -3,6 +3,7 @@
3
3
  */
4
4
 
5
5
  import { ZodRawShape } from "zod";
6
+ import { PromptArgsRawShape, PromptDefinition } from "./prompts.js";
6
7
  import { ResourceDefinition, ResourceTemplateDefinition } from "./resources.js";
7
8
  import { ToolDefinition } from "./tools.js";
8
9
 
@@ -10,4 +11,7 @@ export type Register = {
10
11
  tool: <A extends ZodRawShape | undefined>(def: ToolDefinition<A>) => void;
11
12
  resource: (def: ResourceDefinition) => void;
12
13
  resourceTemplate: (def: ResourceTemplateDefinition) => void;
14
+ prompt: <A extends PromptArgsRawShape | undefined>(
15
+ prompt: PromptDefinition<A>,
16
+ ) => void;
13
17
  };
@@ -19,7 +19,7 @@ const routes = buildRouteMap({
19
19
  export const app = buildApplication(routes, {
20
20
  name: "mcp",
21
21
  versionInfo: {
22
- currentVersion: "0.19.0",
22
+ currentVersion: "0.21.1",
23
23
  },
24
24
  });
25
25