@metronome/mcp 0.3.0 → 2.0.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 (709) hide show
  1. package/README.md +1062 -76
  2. package/code-tool-paths.cjs +6 -0
  3. package/code-tool-paths.cjs.map +1 -0
  4. package/code-tool-paths.d.cts +2 -0
  5. package/code-tool-paths.d.cts.map +1 -0
  6. package/code-tool-types.d.mts +14 -0
  7. package/code-tool-types.d.mts.map +1 -0
  8. package/code-tool-types.d.ts +14 -0
  9. package/code-tool-types.d.ts.map +1 -0
  10. package/code-tool-types.js +4 -0
  11. package/code-tool-types.js.map +1 -0
  12. package/code-tool-types.mjs +3 -0
  13. package/code-tool-types.mjs.map +1 -0
  14. package/code-tool-worker.d.mts +5 -0
  15. package/code-tool-worker.d.mts.map +1 -0
  16. package/code-tool-worker.d.ts +5 -0
  17. package/code-tool-worker.d.ts.map +1 -0
  18. package/code-tool-worker.js +45 -0
  19. package/code-tool-worker.js.map +1 -0
  20. package/code-tool-worker.mjs +40 -0
  21. package/code-tool-worker.mjs.map +1 -0
  22. package/code-tool.d.mts +12 -0
  23. package/code-tool.d.mts.map +1 -0
  24. package/code-tool.d.ts +12 -0
  25. package/code-tool.d.ts.map +1 -0
  26. package/code-tool.js +158 -0
  27. package/code-tool.js.map +1 -0
  28. package/code-tool.mjs +122 -0
  29. package/code-tool.mjs.map +1 -0
  30. package/compat.d.mts +4 -2
  31. package/compat.d.mts.map +1 -1
  32. package/compat.d.ts +4 -2
  33. package/compat.d.ts.map +1 -1
  34. package/compat.js +3 -1
  35. package/compat.js.map +1 -1
  36. package/compat.mjs +2 -0
  37. package/compat.mjs.map +1 -1
  38. package/docs-search-tool.d.mts +44 -0
  39. package/docs-search-tool.d.mts.map +1 -0
  40. package/docs-search-tool.d.ts +44 -0
  41. package/docs-search-tool.d.ts.map +1 -0
  42. package/docs-search-tool.js +43 -0
  43. package/docs-search-tool.js.map +1 -0
  44. package/docs-search-tool.mjs +39 -0
  45. package/docs-search-tool.mjs.map +1 -0
  46. package/dynamic-tools.js +3 -3
  47. package/dynamic-tools.js.map +1 -1
  48. package/dynamic-tools.mjs +3 -3
  49. package/dynamic-tools.mjs.map +1 -1
  50. package/headers.d.mts +1 -1
  51. package/headers.d.mts.map +1 -1
  52. package/headers.d.ts +1 -1
  53. package/headers.d.ts.map +1 -1
  54. package/headers.js +1 -1
  55. package/headers.js.map +1 -1
  56. package/headers.mjs +1 -1
  57. package/headers.mjs.map +1 -1
  58. package/http.d.mts +6 -3
  59. package/http.d.mts.map +1 -1
  60. package/http.d.ts +6 -3
  61. package/http.d.ts.map +1 -1
  62. package/http.js +25 -10
  63. package/http.js.map +1 -1
  64. package/http.mjs +25 -10
  65. package/http.mjs.map +1 -1
  66. package/index.js +6 -6
  67. package/index.js.map +1 -1
  68. package/index.mjs +7 -7
  69. package/index.mjs.map +1 -1
  70. package/options.d.mts +9 -6
  71. package/options.d.mts.map +1 -1
  72. package/options.d.ts +9 -6
  73. package/options.d.ts.map +1 -1
  74. package/options.js +126 -16
  75. package/options.js.map +1 -1
  76. package/options.mjs +125 -16
  77. package/options.mjs.map +1 -1
  78. package/package.json +171 -10
  79. package/server.d.mts +3 -16
  80. package/server.d.mts.map +1 -1
  81. package/server.d.ts +3 -16
  82. package/server.d.ts.map +1 -1
  83. package/server.js +87 -25
  84. package/server.js.map +1 -1
  85. package/server.mjs +86 -24
  86. package/server.mjs.map +1 -1
  87. package/src/code-tool-paths.cts +3 -0
  88. package/src/code-tool-types.ts +14 -0
  89. package/src/code-tool-worker.ts +46 -0
  90. package/src/code-tool.ts +147 -0
  91. package/src/compat.ts +4 -2
  92. package/src/docs-search-tool.ts +48 -0
  93. package/src/dynamic-tools.ts +3 -3
  94. package/src/headers.ts +2 -3
  95. package/src/http.ts +54 -26
  96. package/src/index.ts +7 -7
  97. package/src/options.ts +147 -22
  98. package/src/server.ts +99 -36
  99. package/src/stdio.ts +3 -4
  100. package/src/tools/index.ts +12 -0
  101. package/src/tools/v1/alerts/archive-v1-alerts.ts +3 -3
  102. package/src/tools/v1/alerts/create-v1-alerts.ts +15 -14
  103. package/src/tools/v1/audit-logs/list-v1-audit-logs.ts +1 -1
  104. package/src/tools/v1/billable-metrics/archive-v1-billable-metrics.ts +1 -1
  105. package/src/tools/v1/billable-metrics/create-v1-billable-metrics.ts +1 -1
  106. package/src/tools/v1/billable-metrics/list-v1-billable-metrics.ts +1 -1
  107. package/src/tools/v1/billable-metrics/retrieve-v1-billable-metrics.ts +1 -1
  108. package/src/tools/v1/contracts/add-manual-balance-entry-v1-contracts.ts +2 -1
  109. package/src/tools/v1/contracts/amend-v1-contracts.ts +86 -143
  110. package/src/tools/v1/contracts/archive-v1-contracts.ts +1 -1
  111. package/src/tools/v1/contracts/create-historical-invoices-v1-contracts.ts +3 -1
  112. package/src/tools/v1/contracts/create-v1-contracts.ts +258 -517
  113. package/src/tools/v1/contracts/list-balances-v1-contracts.ts +4 -2
  114. package/src/tools/v1/contracts/list-v1-contracts.ts +1 -1
  115. package/src/tools/v1/contracts/named-schedules/retrieve-contracts-v1-named-schedules.ts +1 -1
  116. package/src/tools/v1/contracts/products/archive-contracts-v1-products.ts +1 -1
  117. package/src/tools/v1/contracts/products/create-contracts-v1-products.ts +2 -1
  118. package/src/tools/v1/contracts/products/list-contracts-v1-products.ts +1 -1
  119. package/src/tools/v1/contracts/products/retrieve-contracts-v1-products.ts +1 -1
  120. package/src/tools/v1/contracts/products/update-contracts-v1-products.ts +1 -1
  121. package/src/tools/v1/contracts/rate-cards/archive-contracts-v1-rate-cards.ts +1 -1
  122. package/src/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.ts +2 -1
  123. package/src/tools/v1/contracts/rate-cards/list-contracts-v1-rate-cards.ts +1 -1
  124. package/src/tools/v1/contracts/rate-cards/named-schedules/retrieve-rate-cards-contracts-v1-named-schedules.ts +1 -1
  125. package/src/tools/v1/contracts/rate-cards/product-orders/set-rate-cards-contracts-v1-product-orders.ts +1 -1
  126. package/src/tools/v1/contracts/rate-cards/product-orders/update-rate-cards-contracts-v1-product-orders.ts +1 -1
  127. package/src/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.ts +25 -22
  128. package/src/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.ts +25 -22
  129. package/src/tools/v1/contracts/rate-cards/rates/list-rate-cards-contracts-v1-rates.ts +1 -1
  130. package/src/tools/v1/contracts/rate-cards/retrieve-contracts-v1-rate-cards.ts +1 -1
  131. package/src/tools/v1/contracts/rate-cards/retrieve-rate-schedule-contracts-v1-rate-cards.ts +1 -1
  132. package/src/tools/v1/contracts/rate-cards/update-contracts-v1-rate-cards.ts +1 -1
  133. package/src/tools/v1/contracts/retrieve-rate-schedule-v1-contracts.ts +1 -1
  134. package/src/tools/v1/contracts/retrieve-subscription-quantity-history-v1-contracts.ts +1 -1
  135. package/src/tools/v1/contracts/set-usage-filter-v1-contracts.ts +2 -1
  136. package/src/tools/v1/contracts/update-end-date-v1-contracts.ts +1 -1
  137. package/src/tools/v1/credit-grants/create-v1-credit-grants.ts +1 -1
  138. package/src/tools/v1/credit-grants/edit-v1-credit-grants.ts +1 -1
  139. package/src/tools/v1/credit-grants/list-entries-v1-credit-grants.ts +3 -2
  140. package/src/tools/v1/credit-grants/list-v1-credit-grants.ts +1 -1
  141. package/src/tools/v1/credit-grants/void-v1-credit-grants.ts +1 -1
  142. package/src/tools/v1/custom-fields/add-key-v1-custom-fields.ts +1 -1
  143. package/src/tools/v1/custom-fields/delete-values-v1-custom-fields.ts +2 -1
  144. package/src/tools/v1/custom-fields/list-keys-v1-custom-fields.ts +3 -2
  145. package/src/tools/v1/custom-fields/remove-key-v1-custom-fields.ts +2 -1
  146. package/src/tools/v1/custom-fields/set-values-v1-custom-fields.ts +2 -1
  147. package/src/tools/v1/customers/alerts/list-customers-v1-alerts.ts +5 -3
  148. package/src/tools/v1/customers/alerts/reset-customers-v1-alerts.ts +3 -2
  149. package/src/tools/v1/customers/alerts/retrieve-customers-v1-alerts.ts +24 -12
  150. package/src/tools/v1/customers/archive-v1-customers.ts +1 -1
  151. package/src/tools/v1/customers/billing-config/create-customers-v1-billing-config.ts +6 -1
  152. package/src/tools/v1/customers/billing-config/retrieve-customers-v1-billing-config.ts +1 -1
  153. package/src/tools/v1/customers/commits/create-customers-v1-commits.ts +32 -33
  154. package/src/tools/v1/customers/commits/list-customers-v1-commits.ts +4 -2
  155. package/src/tools/v1/customers/commits/update-end-date-customers-v1-commits.ts +1 -1
  156. package/src/tools/v1/customers/create-v1-customers.ts +14 -2
  157. package/src/tools/v1/customers/credits/create-customers-v1-credits.ts +30 -24
  158. package/src/tools/v1/customers/credits/list-customers-v1-credits.ts +4 -2
  159. package/src/tools/v1/customers/credits/update-end-date-customers-v1-credits.ts +1 -1
  160. package/src/tools/v1/customers/invoices/add-charge-customers-v1-invoices.ts +1 -1
  161. package/src/tools/v1/customers/invoices/list-breakdowns-customers-v1-invoices.ts +1 -1
  162. package/src/tools/v1/customers/invoices/list-customers-v1-invoices.ts +1 -1
  163. package/src/tools/v1/customers/invoices/retrieve-customers-v1-invoices.ts +2 -1
  164. package/src/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.ts +43 -0
  165. package/src/tools/v1/customers/list-billable-metrics-v1-customers.ts +1 -1
  166. package/src/tools/v1/customers/list-costs-v1-customers.ts +1 -1
  167. package/src/tools/v1/customers/list-v1-customers.ts +1 -1
  168. package/src/tools/v1/customers/named-schedules/retrieve-customers-v1-named-schedules.ts +1 -1
  169. package/src/tools/v1/customers/plans/add-customers-v1-plans.ts +1 -1
  170. package/src/tools/v1/customers/plans/end-customers-v1-plans.ts +1 -1
  171. package/src/tools/v1/customers/plans/list-customers-v1-plans.ts +1 -1
  172. package/src/tools/v1/customers/plans/list-price-adjustments-customers-v1-plans.ts +1 -1
  173. package/src/tools/v1/customers/preview-events-v1-customers.ts +2 -7
  174. package/src/tools/v1/customers/retrieve-billing-configurations-v1-customers.ts +50 -0
  175. package/src/tools/v1/customers/retrieve-v1-customers.ts +1 -1
  176. package/src/tools/v1/customers/set-billing-configurations-v1-customers.ts +85 -0
  177. package/src/tools/v1/customers/set-ingest-aliases-v1-customers.ts +1 -1
  178. package/src/tools/v1/customers/set-name-v1-customers.ts +1 -1
  179. package/src/tools/v1/customers/update-config-v1-customers.ts +2 -1
  180. package/src/tools/v1/dashboards/get-embeddable-url-v1-dashboards.ts +1 -1
  181. package/src/tools/v1/invoices/regenerate-v1-invoices.ts +1 -1
  182. package/src/tools/v1/invoices/void-v1-invoices.ts +1 -1
  183. package/src/tools/v1/payments/attempt-v1-payments.ts +48 -0
  184. package/src/tools/v1/payments/cancel-v1-payments.ts +48 -0
  185. package/src/tools/v1/payments/list-v1-payments.ts +69 -0
  186. package/src/tools/v1/plans/get-details-v1-plans.ts +1 -1
  187. package/src/tools/v1/plans/list-charges-v1-plans.ts +1 -1
  188. package/src/tools/v1/plans/list-customers-v1-plans.ts +1 -1
  189. package/src/tools/v1/plans/list-v1-plans.ts +1 -1
  190. package/src/tools/v1/pricing-units/list-v1-pricing-units.ts +1 -1
  191. package/src/tools/v1/services/list-v1-services.ts +1 -1
  192. package/src/tools/v1/usage/ingest-v1-usage.ts +2 -2
  193. package/src/tools/v1/usage/list-v1-usage.ts +3 -2
  194. package/src/tools/v1/usage/list-with-groups-v1-usage.ts +1 -1
  195. package/src/tools/v1/usage/search-v1-usage.ts +1 -1
  196. package/src/tools/v2/contracts/edit-commit-v2-contracts.ts +84 -24
  197. package/src/tools/v2/contracts/edit-credit-v2-contracts.ts +84 -24
  198. package/src/tools/v2/contracts/edit-v2-contracts.ts +314 -782
  199. package/src/tools/v2/contracts/get-edit-history-v2-contracts.ts +1 -1
  200. package/src/tools/v2/contracts/list-v2-contracts.ts +1 -1
  201. package/src/tools/v2/contracts/retrieve-v2-contracts.ts +2 -1
  202. package/stdio.d.mts +1 -2
  203. package/stdio.d.mts.map +1 -1
  204. package/stdio.d.ts +1 -2
  205. package/stdio.d.ts.map +1 -1
  206. package/stdio.js +2 -2
  207. package/stdio.js.map +1 -1
  208. package/stdio.mjs +3 -3
  209. package/stdio.mjs.map +1 -1
  210. package/tools/index.d.mts.map +1 -1
  211. package/tools/index.d.ts.map +1 -1
  212. package/tools/index.js +12 -0
  213. package/tools/index.js.map +1 -1
  214. package/tools/index.mjs +12 -0
  215. package/tools/index.mjs.map +1 -1
  216. package/tools/v1/alerts/archive-v1-alerts.js +3 -3
  217. package/tools/v1/alerts/archive-v1-alerts.js.map +1 -1
  218. package/tools/v1/alerts/archive-v1-alerts.mjs +3 -3
  219. package/tools/v1/alerts/archive-v1-alerts.mjs.map +1 -1
  220. package/tools/v1/alerts/create-v1-alerts.d.mts.map +1 -1
  221. package/tools/v1/alerts/create-v1-alerts.d.ts.map +1 -1
  222. package/tools/v1/alerts/create-v1-alerts.js +14 -14
  223. package/tools/v1/alerts/create-v1-alerts.js.map +1 -1
  224. package/tools/v1/alerts/create-v1-alerts.mjs +14 -14
  225. package/tools/v1/alerts/create-v1-alerts.mjs.map +1 -1
  226. package/tools/v1/audit-logs/list-v1-audit-logs.js +1 -1
  227. package/tools/v1/audit-logs/list-v1-audit-logs.js.map +1 -1
  228. package/tools/v1/audit-logs/list-v1-audit-logs.mjs +1 -1
  229. package/tools/v1/audit-logs/list-v1-audit-logs.mjs.map +1 -1
  230. package/tools/v1/billable-metrics/archive-v1-billable-metrics.js +1 -1
  231. package/tools/v1/billable-metrics/archive-v1-billable-metrics.js.map +1 -1
  232. package/tools/v1/billable-metrics/archive-v1-billable-metrics.mjs +1 -1
  233. package/tools/v1/billable-metrics/archive-v1-billable-metrics.mjs.map +1 -1
  234. package/tools/v1/billable-metrics/create-v1-billable-metrics.js +1 -1
  235. package/tools/v1/billable-metrics/create-v1-billable-metrics.js.map +1 -1
  236. package/tools/v1/billable-metrics/create-v1-billable-metrics.mjs +1 -1
  237. package/tools/v1/billable-metrics/create-v1-billable-metrics.mjs.map +1 -1
  238. package/tools/v1/billable-metrics/list-v1-billable-metrics.js +1 -1
  239. package/tools/v1/billable-metrics/list-v1-billable-metrics.js.map +1 -1
  240. package/tools/v1/billable-metrics/list-v1-billable-metrics.mjs +1 -1
  241. package/tools/v1/billable-metrics/list-v1-billable-metrics.mjs.map +1 -1
  242. package/tools/v1/billable-metrics/retrieve-v1-billable-metrics.js +1 -1
  243. package/tools/v1/billable-metrics/retrieve-v1-billable-metrics.js.map +1 -1
  244. package/tools/v1/billable-metrics/retrieve-v1-billable-metrics.mjs +1 -1
  245. package/tools/v1/billable-metrics/retrieve-v1-billable-metrics.mjs.map +1 -1
  246. package/tools/v1/contracts/add-manual-balance-entry-v1-contracts.d.mts.map +1 -1
  247. package/tools/v1/contracts/add-manual-balance-entry-v1-contracts.d.ts.map +1 -1
  248. package/tools/v1/contracts/add-manual-balance-entry-v1-contracts.js +1 -1
  249. package/tools/v1/contracts/add-manual-balance-entry-v1-contracts.js.map +1 -1
  250. package/tools/v1/contracts/add-manual-balance-entry-v1-contracts.mjs +1 -1
  251. package/tools/v1/contracts/add-manual-balance-entry-v1-contracts.mjs.map +1 -1
  252. package/tools/v1/contracts/amend-v1-contracts.d.mts.map +1 -1
  253. package/tools/v1/contracts/amend-v1-contracts.d.ts.map +1 -1
  254. package/tools/v1/contracts/amend-v1-contracts.js +85 -139
  255. package/tools/v1/contracts/amend-v1-contracts.js.map +1 -1
  256. package/tools/v1/contracts/amend-v1-contracts.mjs +85 -139
  257. package/tools/v1/contracts/amend-v1-contracts.mjs.map +1 -1
  258. package/tools/v1/contracts/archive-v1-contracts.js +1 -1
  259. package/tools/v1/contracts/archive-v1-contracts.js.map +1 -1
  260. package/tools/v1/contracts/archive-v1-contracts.mjs +1 -1
  261. package/tools/v1/contracts/archive-v1-contracts.mjs.map +1 -1
  262. package/tools/v1/contracts/create-historical-invoices-v1-contracts.d.mts.map +1 -1
  263. package/tools/v1/contracts/create-historical-invoices-v1-contracts.d.ts.map +1 -1
  264. package/tools/v1/contracts/create-historical-invoices-v1-contracts.js +2 -1
  265. package/tools/v1/contracts/create-historical-invoices-v1-contracts.js.map +1 -1
  266. package/tools/v1/contracts/create-historical-invoices-v1-contracts.mjs +2 -1
  267. package/tools/v1/contracts/create-historical-invoices-v1-contracts.mjs.map +1 -1
  268. package/tools/v1/contracts/create-v1-contracts.d.mts.map +1 -1
  269. package/tools/v1/contracts/create-v1-contracts.d.ts.map +1 -1
  270. package/tools/v1/contracts/create-v1-contracts.js +241 -485
  271. package/tools/v1/contracts/create-v1-contracts.js.map +1 -1
  272. package/tools/v1/contracts/create-v1-contracts.mjs +241 -485
  273. package/tools/v1/contracts/create-v1-contracts.mjs.map +1 -1
  274. package/tools/v1/contracts/list-balances-v1-contracts.d.mts.map +1 -1
  275. package/tools/v1/contracts/list-balances-v1-contracts.d.ts.map +1 -1
  276. package/tools/v1/contracts/list-balances-v1-contracts.js +3 -2
  277. package/tools/v1/contracts/list-balances-v1-contracts.js.map +1 -1
  278. package/tools/v1/contracts/list-balances-v1-contracts.mjs +3 -2
  279. package/tools/v1/contracts/list-balances-v1-contracts.mjs.map +1 -1
  280. package/tools/v1/contracts/list-v1-contracts.js +1 -1
  281. package/tools/v1/contracts/list-v1-contracts.js.map +1 -1
  282. package/tools/v1/contracts/list-v1-contracts.mjs +1 -1
  283. package/tools/v1/contracts/list-v1-contracts.mjs.map +1 -1
  284. package/tools/v1/contracts/named-schedules/retrieve-contracts-v1-named-schedules.js +1 -1
  285. package/tools/v1/contracts/named-schedules/retrieve-contracts-v1-named-schedules.js.map +1 -1
  286. package/tools/v1/contracts/named-schedules/retrieve-contracts-v1-named-schedules.mjs +1 -1
  287. package/tools/v1/contracts/named-schedules/retrieve-contracts-v1-named-schedules.mjs.map +1 -1
  288. package/tools/v1/contracts/products/archive-contracts-v1-products.js +1 -1
  289. package/tools/v1/contracts/products/archive-contracts-v1-products.js.map +1 -1
  290. package/tools/v1/contracts/products/archive-contracts-v1-products.mjs +1 -1
  291. package/tools/v1/contracts/products/archive-contracts-v1-products.mjs.map +1 -1
  292. package/tools/v1/contracts/products/create-contracts-v1-products.d.mts.map +1 -1
  293. package/tools/v1/contracts/products/create-contracts-v1-products.d.ts.map +1 -1
  294. package/tools/v1/contracts/products/create-contracts-v1-products.js +2 -1
  295. package/tools/v1/contracts/products/create-contracts-v1-products.js.map +1 -1
  296. package/tools/v1/contracts/products/create-contracts-v1-products.mjs +2 -1
  297. package/tools/v1/contracts/products/create-contracts-v1-products.mjs.map +1 -1
  298. package/tools/v1/contracts/products/list-contracts-v1-products.js +1 -1
  299. package/tools/v1/contracts/products/list-contracts-v1-products.js.map +1 -1
  300. package/tools/v1/contracts/products/list-contracts-v1-products.mjs +1 -1
  301. package/tools/v1/contracts/products/list-contracts-v1-products.mjs.map +1 -1
  302. package/tools/v1/contracts/products/retrieve-contracts-v1-products.js +1 -1
  303. package/tools/v1/contracts/products/retrieve-contracts-v1-products.js.map +1 -1
  304. package/tools/v1/contracts/products/retrieve-contracts-v1-products.mjs +1 -1
  305. package/tools/v1/contracts/products/retrieve-contracts-v1-products.mjs.map +1 -1
  306. package/tools/v1/contracts/products/update-contracts-v1-products.js +1 -1
  307. package/tools/v1/contracts/products/update-contracts-v1-products.js.map +1 -1
  308. package/tools/v1/contracts/products/update-contracts-v1-products.mjs +1 -1
  309. package/tools/v1/contracts/products/update-contracts-v1-products.mjs.map +1 -1
  310. package/tools/v1/contracts/rate-cards/archive-contracts-v1-rate-cards.js +1 -1
  311. package/tools/v1/contracts/rate-cards/archive-contracts-v1-rate-cards.js.map +1 -1
  312. package/tools/v1/contracts/rate-cards/archive-contracts-v1-rate-cards.mjs +1 -1
  313. package/tools/v1/contracts/rate-cards/archive-contracts-v1-rate-cards.mjs.map +1 -1
  314. package/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.d.mts.map +1 -1
  315. package/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.d.ts.map +1 -1
  316. package/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.js +2 -1
  317. package/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.js.map +1 -1
  318. package/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.mjs +2 -1
  319. package/tools/v1/contracts/rate-cards/create-contracts-v1-rate-cards.mjs.map +1 -1
  320. package/tools/v1/contracts/rate-cards/list-contracts-v1-rate-cards.js +1 -1
  321. package/tools/v1/contracts/rate-cards/list-contracts-v1-rate-cards.js.map +1 -1
  322. package/tools/v1/contracts/rate-cards/list-contracts-v1-rate-cards.mjs +1 -1
  323. package/tools/v1/contracts/rate-cards/list-contracts-v1-rate-cards.mjs.map +1 -1
  324. package/tools/v1/contracts/rate-cards/named-schedules/retrieve-rate-cards-contracts-v1-named-schedules.js +1 -1
  325. package/tools/v1/contracts/rate-cards/named-schedules/retrieve-rate-cards-contracts-v1-named-schedules.js.map +1 -1
  326. package/tools/v1/contracts/rate-cards/named-schedules/retrieve-rate-cards-contracts-v1-named-schedules.mjs +1 -1
  327. package/tools/v1/contracts/rate-cards/named-schedules/retrieve-rate-cards-contracts-v1-named-schedules.mjs.map +1 -1
  328. package/tools/v1/contracts/rate-cards/product-orders/set-rate-cards-contracts-v1-product-orders.js +1 -1
  329. package/tools/v1/contracts/rate-cards/product-orders/set-rate-cards-contracts-v1-product-orders.js.map +1 -1
  330. package/tools/v1/contracts/rate-cards/product-orders/set-rate-cards-contracts-v1-product-orders.mjs +1 -1
  331. package/tools/v1/contracts/rate-cards/product-orders/set-rate-cards-contracts-v1-product-orders.mjs.map +1 -1
  332. package/tools/v1/contracts/rate-cards/product-orders/update-rate-cards-contracts-v1-product-orders.js +1 -1
  333. package/tools/v1/contracts/rate-cards/product-orders/update-rate-cards-contracts-v1-product-orders.js.map +1 -1
  334. package/tools/v1/contracts/rate-cards/product-orders/update-rate-cards-contracts-v1-product-orders.mjs +1 -1
  335. package/tools/v1/contracts/rate-cards/product-orders/update-rate-cards-contracts-v1-product-orders.mjs.map +1 -1
  336. package/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.d.mts.map +1 -1
  337. package/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.d.ts.map +1 -1
  338. package/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.js +24 -21
  339. package/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.js.map +1 -1
  340. package/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.mjs +24 -21
  341. package/tools/v1/contracts/rate-cards/rates/add-many-rate-cards-contracts-v1-rates.mjs.map +1 -1
  342. package/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.d.mts.map +1 -1
  343. package/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.d.ts.map +1 -1
  344. package/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.js +24 -21
  345. package/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.js.map +1 -1
  346. package/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.mjs +24 -21
  347. package/tools/v1/contracts/rate-cards/rates/add-rate-cards-contracts-v1-rates.mjs.map +1 -1
  348. package/tools/v1/contracts/rate-cards/rates/list-rate-cards-contracts-v1-rates.js +1 -1
  349. package/tools/v1/contracts/rate-cards/rates/list-rate-cards-contracts-v1-rates.js.map +1 -1
  350. package/tools/v1/contracts/rate-cards/rates/list-rate-cards-contracts-v1-rates.mjs +1 -1
  351. package/tools/v1/contracts/rate-cards/rates/list-rate-cards-contracts-v1-rates.mjs.map +1 -1
  352. package/tools/v1/contracts/rate-cards/retrieve-contracts-v1-rate-cards.js +1 -1
  353. package/tools/v1/contracts/rate-cards/retrieve-contracts-v1-rate-cards.js.map +1 -1
  354. package/tools/v1/contracts/rate-cards/retrieve-contracts-v1-rate-cards.mjs +1 -1
  355. package/tools/v1/contracts/rate-cards/retrieve-contracts-v1-rate-cards.mjs.map +1 -1
  356. package/tools/v1/contracts/rate-cards/retrieve-rate-schedule-contracts-v1-rate-cards.js +1 -1
  357. package/tools/v1/contracts/rate-cards/retrieve-rate-schedule-contracts-v1-rate-cards.js.map +1 -1
  358. package/tools/v1/contracts/rate-cards/retrieve-rate-schedule-contracts-v1-rate-cards.mjs +1 -1
  359. package/tools/v1/contracts/rate-cards/retrieve-rate-schedule-contracts-v1-rate-cards.mjs.map +1 -1
  360. package/tools/v1/contracts/rate-cards/update-contracts-v1-rate-cards.js +1 -1
  361. package/tools/v1/contracts/rate-cards/update-contracts-v1-rate-cards.js.map +1 -1
  362. package/tools/v1/contracts/rate-cards/update-contracts-v1-rate-cards.mjs +1 -1
  363. package/tools/v1/contracts/rate-cards/update-contracts-v1-rate-cards.mjs.map +1 -1
  364. package/tools/v1/contracts/retrieve-rate-schedule-v1-contracts.js +1 -1
  365. package/tools/v1/contracts/retrieve-rate-schedule-v1-contracts.js.map +1 -1
  366. package/tools/v1/contracts/retrieve-rate-schedule-v1-contracts.mjs +1 -1
  367. package/tools/v1/contracts/retrieve-rate-schedule-v1-contracts.mjs.map +1 -1
  368. package/tools/v1/contracts/retrieve-subscription-quantity-history-v1-contracts.js +1 -1
  369. package/tools/v1/contracts/retrieve-subscription-quantity-history-v1-contracts.js.map +1 -1
  370. package/tools/v1/contracts/retrieve-subscription-quantity-history-v1-contracts.mjs +1 -1
  371. package/tools/v1/contracts/retrieve-subscription-quantity-history-v1-contracts.mjs.map +1 -1
  372. package/tools/v1/contracts/set-usage-filter-v1-contracts.d.mts.map +1 -1
  373. package/tools/v1/contracts/set-usage-filter-v1-contracts.d.ts.map +1 -1
  374. package/tools/v1/contracts/set-usage-filter-v1-contracts.js +1 -1
  375. package/tools/v1/contracts/set-usage-filter-v1-contracts.js.map +1 -1
  376. package/tools/v1/contracts/set-usage-filter-v1-contracts.mjs +1 -1
  377. package/tools/v1/contracts/set-usage-filter-v1-contracts.mjs.map +1 -1
  378. package/tools/v1/contracts/update-end-date-v1-contracts.js +1 -1
  379. package/tools/v1/contracts/update-end-date-v1-contracts.js.map +1 -1
  380. package/tools/v1/contracts/update-end-date-v1-contracts.mjs +1 -1
  381. package/tools/v1/contracts/update-end-date-v1-contracts.mjs.map +1 -1
  382. package/tools/v1/credit-grants/create-v1-credit-grants.js +1 -1
  383. package/tools/v1/credit-grants/create-v1-credit-grants.js.map +1 -1
  384. package/tools/v1/credit-grants/create-v1-credit-grants.mjs +1 -1
  385. package/tools/v1/credit-grants/create-v1-credit-grants.mjs.map +1 -1
  386. package/tools/v1/credit-grants/edit-v1-credit-grants.js +1 -1
  387. package/tools/v1/credit-grants/edit-v1-credit-grants.js.map +1 -1
  388. package/tools/v1/credit-grants/edit-v1-credit-grants.mjs +1 -1
  389. package/tools/v1/credit-grants/edit-v1-credit-grants.mjs.map +1 -1
  390. package/tools/v1/credit-grants/list-entries-v1-credit-grants.d.mts.map +1 -1
  391. package/tools/v1/credit-grants/list-entries-v1-credit-grants.d.ts.map +1 -1
  392. package/tools/v1/credit-grants/list-entries-v1-credit-grants.js +3 -2
  393. package/tools/v1/credit-grants/list-entries-v1-credit-grants.js.map +1 -1
  394. package/tools/v1/credit-grants/list-entries-v1-credit-grants.mjs +3 -2
  395. package/tools/v1/credit-grants/list-entries-v1-credit-grants.mjs.map +1 -1
  396. package/tools/v1/credit-grants/list-v1-credit-grants.js +1 -1
  397. package/tools/v1/credit-grants/list-v1-credit-grants.js.map +1 -1
  398. package/tools/v1/credit-grants/list-v1-credit-grants.mjs +1 -1
  399. package/tools/v1/credit-grants/list-v1-credit-grants.mjs.map +1 -1
  400. package/tools/v1/credit-grants/void-v1-credit-grants.js +1 -1
  401. package/tools/v1/credit-grants/void-v1-credit-grants.js.map +1 -1
  402. package/tools/v1/credit-grants/void-v1-credit-grants.mjs +1 -1
  403. package/tools/v1/credit-grants/void-v1-credit-grants.mjs.map +1 -1
  404. package/tools/v1/custom-fields/add-key-v1-custom-fields.js +1 -1
  405. package/tools/v1/custom-fields/add-key-v1-custom-fields.js.map +1 -1
  406. package/tools/v1/custom-fields/add-key-v1-custom-fields.mjs +1 -1
  407. package/tools/v1/custom-fields/add-key-v1-custom-fields.mjs.map +1 -1
  408. package/tools/v1/custom-fields/delete-values-v1-custom-fields.d.mts.map +1 -1
  409. package/tools/v1/custom-fields/delete-values-v1-custom-fields.d.ts.map +1 -1
  410. package/tools/v1/custom-fields/delete-values-v1-custom-fields.js +1 -1
  411. package/tools/v1/custom-fields/delete-values-v1-custom-fields.js.map +1 -1
  412. package/tools/v1/custom-fields/delete-values-v1-custom-fields.mjs +1 -1
  413. package/tools/v1/custom-fields/delete-values-v1-custom-fields.mjs.map +1 -1
  414. package/tools/v1/custom-fields/list-keys-v1-custom-fields.d.mts.map +1 -1
  415. package/tools/v1/custom-fields/list-keys-v1-custom-fields.d.ts.map +1 -1
  416. package/tools/v1/custom-fields/list-keys-v1-custom-fields.js +3 -2
  417. package/tools/v1/custom-fields/list-keys-v1-custom-fields.js.map +1 -1
  418. package/tools/v1/custom-fields/list-keys-v1-custom-fields.mjs +3 -2
  419. package/tools/v1/custom-fields/list-keys-v1-custom-fields.mjs.map +1 -1
  420. package/tools/v1/custom-fields/remove-key-v1-custom-fields.d.mts.map +1 -1
  421. package/tools/v1/custom-fields/remove-key-v1-custom-fields.d.ts.map +1 -1
  422. package/tools/v1/custom-fields/remove-key-v1-custom-fields.js +1 -1
  423. package/tools/v1/custom-fields/remove-key-v1-custom-fields.js.map +1 -1
  424. package/tools/v1/custom-fields/remove-key-v1-custom-fields.mjs +1 -1
  425. package/tools/v1/custom-fields/remove-key-v1-custom-fields.mjs.map +1 -1
  426. package/tools/v1/custom-fields/set-values-v1-custom-fields.d.mts.map +1 -1
  427. package/tools/v1/custom-fields/set-values-v1-custom-fields.d.ts.map +1 -1
  428. package/tools/v1/custom-fields/set-values-v1-custom-fields.js +2 -1
  429. package/tools/v1/custom-fields/set-values-v1-custom-fields.js.map +1 -1
  430. package/tools/v1/custom-fields/set-values-v1-custom-fields.mjs +2 -1
  431. package/tools/v1/custom-fields/set-values-v1-custom-fields.mjs.map +1 -1
  432. package/tools/v1/customers/alerts/list-customers-v1-alerts.d.mts.map +1 -1
  433. package/tools/v1/customers/alerts/list-customers-v1-alerts.d.ts.map +1 -1
  434. package/tools/v1/customers/alerts/list-customers-v1-alerts.js +4 -3
  435. package/tools/v1/customers/alerts/list-customers-v1-alerts.js.map +1 -1
  436. package/tools/v1/customers/alerts/list-customers-v1-alerts.mjs +4 -3
  437. package/tools/v1/customers/alerts/list-customers-v1-alerts.mjs.map +1 -1
  438. package/tools/v1/customers/alerts/reset-customers-v1-alerts.d.mts.map +1 -1
  439. package/tools/v1/customers/alerts/reset-customers-v1-alerts.d.ts.map +1 -1
  440. package/tools/v1/customers/alerts/reset-customers-v1-alerts.js +2 -2
  441. package/tools/v1/customers/alerts/reset-customers-v1-alerts.js.map +1 -1
  442. package/tools/v1/customers/alerts/reset-customers-v1-alerts.mjs +2 -2
  443. package/tools/v1/customers/alerts/reset-customers-v1-alerts.mjs.map +1 -1
  444. package/tools/v1/customers/alerts/retrieve-customers-v1-alerts.d.mts.map +1 -1
  445. package/tools/v1/customers/alerts/retrieve-customers-v1-alerts.d.ts.map +1 -1
  446. package/tools/v1/customers/alerts/retrieve-customers-v1-alerts.js +22 -11
  447. package/tools/v1/customers/alerts/retrieve-customers-v1-alerts.js.map +1 -1
  448. package/tools/v1/customers/alerts/retrieve-customers-v1-alerts.mjs +22 -11
  449. package/tools/v1/customers/alerts/retrieve-customers-v1-alerts.mjs.map +1 -1
  450. package/tools/v1/customers/archive-v1-customers.js +1 -1
  451. package/tools/v1/customers/archive-v1-customers.js.map +1 -1
  452. package/tools/v1/customers/archive-v1-customers.mjs +1 -1
  453. package/tools/v1/customers/archive-v1-customers.mjs.map +1 -1
  454. package/tools/v1/customers/billing-config/create-customers-v1-billing-config.d.mts.map +1 -1
  455. package/tools/v1/customers/billing-config/create-customers-v1-billing-config.d.ts.map +1 -1
  456. package/tools/v1/customers/billing-config/create-customers-v1-billing-config.js +6 -1
  457. package/tools/v1/customers/billing-config/create-customers-v1-billing-config.js.map +1 -1
  458. package/tools/v1/customers/billing-config/create-customers-v1-billing-config.mjs +6 -1
  459. package/tools/v1/customers/billing-config/create-customers-v1-billing-config.mjs.map +1 -1
  460. package/tools/v1/customers/billing-config/retrieve-customers-v1-billing-config.js +1 -1
  461. package/tools/v1/customers/billing-config/retrieve-customers-v1-billing-config.js.map +1 -1
  462. package/tools/v1/customers/billing-config/retrieve-customers-v1-billing-config.mjs +1 -1
  463. package/tools/v1/customers/billing-config/retrieve-customers-v1-billing-config.mjs.map +1 -1
  464. package/tools/v1/customers/commits/create-customers-v1-commits.d.mts.map +1 -1
  465. package/tools/v1/customers/commits/create-customers-v1-commits.d.ts.map +1 -1
  466. package/tools/v1/customers/commits/create-customers-v1-commits.js +31 -31
  467. package/tools/v1/customers/commits/create-customers-v1-commits.js.map +1 -1
  468. package/tools/v1/customers/commits/create-customers-v1-commits.mjs +31 -31
  469. package/tools/v1/customers/commits/create-customers-v1-commits.mjs.map +1 -1
  470. package/tools/v1/customers/commits/list-customers-v1-commits.d.mts.map +1 -1
  471. package/tools/v1/customers/commits/list-customers-v1-commits.d.ts.map +1 -1
  472. package/tools/v1/customers/commits/list-customers-v1-commits.js +3 -2
  473. package/tools/v1/customers/commits/list-customers-v1-commits.js.map +1 -1
  474. package/tools/v1/customers/commits/list-customers-v1-commits.mjs +3 -2
  475. package/tools/v1/customers/commits/list-customers-v1-commits.mjs.map +1 -1
  476. package/tools/v1/customers/commits/update-end-date-customers-v1-commits.js +1 -1
  477. package/tools/v1/customers/commits/update-end-date-customers-v1-commits.js.map +1 -1
  478. package/tools/v1/customers/commits/update-end-date-customers-v1-commits.mjs +1 -1
  479. package/tools/v1/customers/commits/update-end-date-customers-v1-commits.mjs.map +1 -1
  480. package/tools/v1/customers/create-v1-customers.d.mts.map +1 -1
  481. package/tools/v1/customers/create-v1-customers.d.ts.map +1 -1
  482. package/tools/v1/customers/create-v1-customers.js +13 -2
  483. package/tools/v1/customers/create-v1-customers.js.map +1 -1
  484. package/tools/v1/customers/create-v1-customers.mjs +13 -2
  485. package/tools/v1/customers/create-v1-customers.mjs.map +1 -1
  486. package/tools/v1/customers/credits/create-customers-v1-credits.d.mts.map +1 -1
  487. package/tools/v1/customers/credits/create-customers-v1-credits.d.ts.map +1 -1
  488. package/tools/v1/customers/credits/create-customers-v1-credits.js +29 -23
  489. package/tools/v1/customers/credits/create-customers-v1-credits.js.map +1 -1
  490. package/tools/v1/customers/credits/create-customers-v1-credits.mjs +29 -23
  491. package/tools/v1/customers/credits/create-customers-v1-credits.mjs.map +1 -1
  492. package/tools/v1/customers/credits/list-customers-v1-credits.d.mts.map +1 -1
  493. package/tools/v1/customers/credits/list-customers-v1-credits.d.ts.map +1 -1
  494. package/tools/v1/customers/credits/list-customers-v1-credits.js +3 -2
  495. package/tools/v1/customers/credits/list-customers-v1-credits.js.map +1 -1
  496. package/tools/v1/customers/credits/list-customers-v1-credits.mjs +3 -2
  497. package/tools/v1/customers/credits/list-customers-v1-credits.mjs.map +1 -1
  498. package/tools/v1/customers/credits/update-end-date-customers-v1-credits.js +1 -1
  499. package/tools/v1/customers/credits/update-end-date-customers-v1-credits.js.map +1 -1
  500. package/tools/v1/customers/credits/update-end-date-customers-v1-credits.mjs +1 -1
  501. package/tools/v1/customers/credits/update-end-date-customers-v1-credits.mjs.map +1 -1
  502. package/tools/v1/customers/invoices/add-charge-customers-v1-invoices.js +1 -1
  503. package/tools/v1/customers/invoices/add-charge-customers-v1-invoices.js.map +1 -1
  504. package/tools/v1/customers/invoices/add-charge-customers-v1-invoices.mjs +1 -1
  505. package/tools/v1/customers/invoices/add-charge-customers-v1-invoices.mjs.map +1 -1
  506. package/tools/v1/customers/invoices/list-breakdowns-customers-v1-invoices.js +1 -1
  507. package/tools/v1/customers/invoices/list-breakdowns-customers-v1-invoices.js.map +1 -1
  508. package/tools/v1/customers/invoices/list-breakdowns-customers-v1-invoices.mjs +1 -1
  509. package/tools/v1/customers/invoices/list-breakdowns-customers-v1-invoices.mjs.map +1 -1
  510. package/tools/v1/customers/invoices/list-customers-v1-invoices.js +1 -1
  511. package/tools/v1/customers/invoices/list-customers-v1-invoices.js.map +1 -1
  512. package/tools/v1/customers/invoices/list-customers-v1-invoices.mjs +1 -1
  513. package/tools/v1/customers/invoices/list-customers-v1-invoices.mjs.map +1 -1
  514. package/tools/v1/customers/invoices/retrieve-customers-v1-invoices.d.mts.map +1 -1
  515. package/tools/v1/customers/invoices/retrieve-customers-v1-invoices.d.ts.map +1 -1
  516. package/tools/v1/customers/invoices/retrieve-customers-v1-invoices.js +1 -1
  517. package/tools/v1/customers/invoices/retrieve-customers-v1-invoices.js.map +1 -1
  518. package/tools/v1/customers/invoices/retrieve-customers-v1-invoices.mjs +1 -1
  519. package/tools/v1/customers/invoices/retrieve-customers-v1-invoices.mjs.map +1 -1
  520. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.d.mts +45 -0
  521. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.d.mts.map +1 -0
  522. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.d.ts +45 -0
  523. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.d.ts.map +1 -0
  524. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.js +39 -0
  525. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.js.map +1 -0
  526. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.mjs +35 -0
  527. package/tools/v1/customers/invoices/retrieve-pdf-customers-v1-invoices.mjs.map +1 -0
  528. package/tools/v1/customers/list-billable-metrics-v1-customers.js +1 -1
  529. package/tools/v1/customers/list-billable-metrics-v1-customers.js.map +1 -1
  530. package/tools/v1/customers/list-billable-metrics-v1-customers.mjs +1 -1
  531. package/tools/v1/customers/list-billable-metrics-v1-customers.mjs.map +1 -1
  532. package/tools/v1/customers/list-costs-v1-customers.js +1 -1
  533. package/tools/v1/customers/list-costs-v1-customers.js.map +1 -1
  534. package/tools/v1/customers/list-costs-v1-customers.mjs +1 -1
  535. package/tools/v1/customers/list-costs-v1-customers.mjs.map +1 -1
  536. package/tools/v1/customers/list-v1-customers.js +1 -1
  537. package/tools/v1/customers/list-v1-customers.js.map +1 -1
  538. package/tools/v1/customers/list-v1-customers.mjs +1 -1
  539. package/tools/v1/customers/list-v1-customers.mjs.map +1 -1
  540. package/tools/v1/customers/named-schedules/retrieve-customers-v1-named-schedules.js +1 -1
  541. package/tools/v1/customers/named-schedules/retrieve-customers-v1-named-schedules.js.map +1 -1
  542. package/tools/v1/customers/named-schedules/retrieve-customers-v1-named-schedules.mjs +1 -1
  543. package/tools/v1/customers/named-schedules/retrieve-customers-v1-named-schedules.mjs.map +1 -1
  544. package/tools/v1/customers/plans/add-customers-v1-plans.js +1 -1
  545. package/tools/v1/customers/plans/add-customers-v1-plans.js.map +1 -1
  546. package/tools/v1/customers/plans/add-customers-v1-plans.mjs +1 -1
  547. package/tools/v1/customers/plans/add-customers-v1-plans.mjs.map +1 -1
  548. package/tools/v1/customers/plans/end-customers-v1-plans.js +1 -1
  549. package/tools/v1/customers/plans/end-customers-v1-plans.js.map +1 -1
  550. package/tools/v1/customers/plans/end-customers-v1-plans.mjs +1 -1
  551. package/tools/v1/customers/plans/end-customers-v1-plans.mjs.map +1 -1
  552. package/tools/v1/customers/plans/list-customers-v1-plans.js +1 -1
  553. package/tools/v1/customers/plans/list-customers-v1-plans.js.map +1 -1
  554. package/tools/v1/customers/plans/list-customers-v1-plans.mjs +1 -1
  555. package/tools/v1/customers/plans/list-customers-v1-plans.mjs.map +1 -1
  556. package/tools/v1/customers/plans/list-price-adjustments-customers-v1-plans.js +1 -1
  557. package/tools/v1/customers/plans/list-price-adjustments-customers-v1-plans.js.map +1 -1
  558. package/tools/v1/customers/plans/list-price-adjustments-customers-v1-plans.mjs +1 -1
  559. package/tools/v1/customers/plans/list-price-adjustments-customers-v1-plans.mjs.map +1 -1
  560. package/tools/v1/customers/preview-events-v1-customers.d.mts.map +1 -1
  561. package/tools/v1/customers/preview-events-v1-customers.d.ts.map +1 -1
  562. package/tools/v1/customers/preview-events-v1-customers.js +2 -6
  563. package/tools/v1/customers/preview-events-v1-customers.js.map +1 -1
  564. package/tools/v1/customers/preview-events-v1-customers.mjs +2 -6
  565. package/tools/v1/customers/preview-events-v1-customers.mjs.map +1 -1
  566. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.d.mts +45 -0
  567. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.d.mts.map +1 -0
  568. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.d.ts +45 -0
  569. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.d.ts.map +1 -0
  570. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.js +43 -0
  571. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.js.map +1 -0
  572. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.mjs +39 -0
  573. package/tools/v1/customers/retrieve-billing-configurations-v1-customers.mjs.map +1 -0
  574. package/tools/v1/customers/retrieve-v1-customers.js +1 -1
  575. package/tools/v1/customers/retrieve-v1-customers.js.map +1 -1
  576. package/tools/v1/customers/retrieve-v1-customers.mjs +1 -1
  577. package/tools/v1/customers/retrieve-v1-customers.mjs.map +1 -1
  578. package/tools/v1/customers/set-billing-configurations-v1-customers.d.mts +45 -0
  579. package/tools/v1/customers/set-billing-configurations-v1-customers.d.mts.map +1 -0
  580. package/tools/v1/customers/set-billing-configurations-v1-customers.d.ts +45 -0
  581. package/tools/v1/customers/set-billing-configurations-v1-customers.d.ts.map +1 -0
  582. package/tools/v1/customers/set-billing-configurations-v1-customers.js +77 -0
  583. package/tools/v1/customers/set-billing-configurations-v1-customers.js.map +1 -0
  584. package/tools/v1/customers/set-billing-configurations-v1-customers.mjs +73 -0
  585. package/tools/v1/customers/set-billing-configurations-v1-customers.mjs.map +1 -0
  586. package/tools/v1/customers/set-ingest-aliases-v1-customers.js +1 -1
  587. package/tools/v1/customers/set-ingest-aliases-v1-customers.js.map +1 -1
  588. package/tools/v1/customers/set-ingest-aliases-v1-customers.mjs +1 -1
  589. package/tools/v1/customers/set-ingest-aliases-v1-customers.mjs.map +1 -1
  590. package/tools/v1/customers/set-name-v1-customers.js +1 -1
  591. package/tools/v1/customers/set-name-v1-customers.js.map +1 -1
  592. package/tools/v1/customers/set-name-v1-customers.mjs +1 -1
  593. package/tools/v1/customers/set-name-v1-customers.mjs.map +1 -1
  594. package/tools/v1/customers/update-config-v1-customers.d.mts.map +1 -1
  595. package/tools/v1/customers/update-config-v1-customers.d.ts.map +1 -1
  596. package/tools/v1/customers/update-config-v1-customers.js +1 -1
  597. package/tools/v1/customers/update-config-v1-customers.js.map +1 -1
  598. package/tools/v1/customers/update-config-v1-customers.mjs +1 -1
  599. package/tools/v1/customers/update-config-v1-customers.mjs.map +1 -1
  600. package/tools/v1/dashboards/get-embeddable-url-v1-dashboards.js +1 -1
  601. package/tools/v1/dashboards/get-embeddable-url-v1-dashboards.js.map +1 -1
  602. package/tools/v1/dashboards/get-embeddable-url-v1-dashboards.mjs +1 -1
  603. package/tools/v1/dashboards/get-embeddable-url-v1-dashboards.mjs.map +1 -1
  604. package/tools/v1/invoices/regenerate-v1-invoices.js +1 -1
  605. package/tools/v1/invoices/regenerate-v1-invoices.js.map +1 -1
  606. package/tools/v1/invoices/regenerate-v1-invoices.mjs +1 -1
  607. package/tools/v1/invoices/regenerate-v1-invoices.mjs.map +1 -1
  608. package/tools/v1/invoices/void-v1-invoices.js +1 -1
  609. package/tools/v1/invoices/void-v1-invoices.js.map +1 -1
  610. package/tools/v1/invoices/void-v1-invoices.mjs +1 -1
  611. package/tools/v1/invoices/void-v1-invoices.mjs.map +1 -1
  612. package/tools/v1/payments/attempt-v1-payments.d.mts +45 -0
  613. package/tools/v1/payments/attempt-v1-payments.d.mts.map +1 -0
  614. package/tools/v1/payments/attempt-v1-payments.d.ts +45 -0
  615. package/tools/v1/payments/attempt-v1-payments.d.ts.map +1 -0
  616. package/tools/v1/payments/attempt-v1-payments.js +43 -0
  617. package/tools/v1/payments/attempt-v1-payments.js.map +1 -0
  618. package/tools/v1/payments/attempt-v1-payments.mjs +39 -0
  619. package/tools/v1/payments/attempt-v1-payments.mjs.map +1 -0
  620. package/tools/v1/payments/cancel-v1-payments.d.mts +45 -0
  621. package/tools/v1/payments/cancel-v1-payments.d.mts.map +1 -0
  622. package/tools/v1/payments/cancel-v1-payments.d.ts +45 -0
  623. package/tools/v1/payments/cancel-v1-payments.d.ts.map +1 -0
  624. package/tools/v1/payments/cancel-v1-payments.js +43 -0
  625. package/tools/v1/payments/cancel-v1-payments.js.map +1 -0
  626. package/tools/v1/payments/cancel-v1-payments.mjs +39 -0
  627. package/tools/v1/payments/cancel-v1-payments.mjs.map +1 -0
  628. package/tools/v1/payments/list-v1-payments.d.mts +45 -0
  629. package/tools/v1/payments/list-v1-payments.d.mts.map +1 -0
  630. package/tools/v1/payments/list-v1-payments.d.ts +45 -0
  631. package/tools/v1/payments/list-v1-payments.d.ts.map +1 -0
  632. package/tools/v1/payments/list-v1-payments.js +64 -0
  633. package/tools/v1/payments/list-v1-payments.js.map +1 -0
  634. package/tools/v1/payments/list-v1-payments.mjs +60 -0
  635. package/tools/v1/payments/list-v1-payments.mjs.map +1 -0
  636. package/tools/v1/plans/get-details-v1-plans.js +1 -1
  637. package/tools/v1/plans/get-details-v1-plans.js.map +1 -1
  638. package/tools/v1/plans/get-details-v1-plans.mjs +1 -1
  639. package/tools/v1/plans/get-details-v1-plans.mjs.map +1 -1
  640. package/tools/v1/plans/list-charges-v1-plans.js +1 -1
  641. package/tools/v1/plans/list-charges-v1-plans.js.map +1 -1
  642. package/tools/v1/plans/list-charges-v1-plans.mjs +1 -1
  643. package/tools/v1/plans/list-charges-v1-plans.mjs.map +1 -1
  644. package/tools/v1/plans/list-customers-v1-plans.js +1 -1
  645. package/tools/v1/plans/list-customers-v1-plans.js.map +1 -1
  646. package/tools/v1/plans/list-customers-v1-plans.mjs +1 -1
  647. package/tools/v1/plans/list-customers-v1-plans.mjs.map +1 -1
  648. package/tools/v1/plans/list-v1-plans.js +1 -1
  649. package/tools/v1/plans/list-v1-plans.js.map +1 -1
  650. package/tools/v1/plans/list-v1-plans.mjs +1 -1
  651. package/tools/v1/plans/list-v1-plans.mjs.map +1 -1
  652. package/tools/v1/pricing-units/list-v1-pricing-units.js +1 -1
  653. package/tools/v1/pricing-units/list-v1-pricing-units.js.map +1 -1
  654. package/tools/v1/pricing-units/list-v1-pricing-units.mjs +1 -1
  655. package/tools/v1/pricing-units/list-v1-pricing-units.mjs.map +1 -1
  656. package/tools/v1/services/list-v1-services.js +1 -1
  657. package/tools/v1/services/list-v1-services.js.map +1 -1
  658. package/tools/v1/services/list-v1-services.mjs +1 -1
  659. package/tools/v1/services/list-v1-services.mjs.map +1 -1
  660. package/tools/v1/usage/ingest-v1-usage.js +2 -2
  661. package/tools/v1/usage/ingest-v1-usage.js.map +1 -1
  662. package/tools/v1/usage/ingest-v1-usage.mjs +2 -2
  663. package/tools/v1/usage/ingest-v1-usage.mjs.map +1 -1
  664. package/tools/v1/usage/list-v1-usage.d.mts.map +1 -1
  665. package/tools/v1/usage/list-v1-usage.d.ts.map +1 -1
  666. package/tools/v1/usage/list-v1-usage.js +3 -2
  667. package/tools/v1/usage/list-v1-usage.js.map +1 -1
  668. package/tools/v1/usage/list-v1-usage.mjs +3 -2
  669. package/tools/v1/usage/list-v1-usage.mjs.map +1 -1
  670. package/tools/v1/usage/list-with-groups-v1-usage.js +1 -1
  671. package/tools/v1/usage/list-with-groups-v1-usage.js.map +1 -1
  672. package/tools/v1/usage/list-with-groups-v1-usage.mjs +1 -1
  673. package/tools/v1/usage/list-with-groups-v1-usage.mjs.map +1 -1
  674. package/tools/v1/usage/search-v1-usage.js +1 -1
  675. package/tools/v1/usage/search-v1-usage.js.map +1 -1
  676. package/tools/v1/usage/search-v1-usage.mjs +1 -1
  677. package/tools/v1/usage/search-v1-usage.mjs.map +1 -1
  678. package/tools/v2/contracts/edit-commit-v2-contracts.d.mts.map +1 -1
  679. package/tools/v2/contracts/edit-commit-v2-contracts.d.ts.map +1 -1
  680. package/tools/v2/contracts/edit-commit-v2-contracts.js +82 -23
  681. package/tools/v2/contracts/edit-commit-v2-contracts.js.map +1 -1
  682. package/tools/v2/contracts/edit-commit-v2-contracts.mjs +82 -23
  683. package/tools/v2/contracts/edit-commit-v2-contracts.mjs.map +1 -1
  684. package/tools/v2/contracts/edit-credit-v2-contracts.d.mts.map +1 -1
  685. package/tools/v2/contracts/edit-credit-v2-contracts.d.ts.map +1 -1
  686. package/tools/v2/contracts/edit-credit-v2-contracts.js +82 -23
  687. package/tools/v2/contracts/edit-credit-v2-contracts.js.map +1 -1
  688. package/tools/v2/contracts/edit-credit-v2-contracts.mjs +82 -23
  689. package/tools/v2/contracts/edit-credit-v2-contracts.mjs.map +1 -1
  690. package/tools/v2/contracts/edit-v2-contracts.d.mts.map +1 -1
  691. package/tools/v2/contracts/edit-v2-contracts.d.ts.map +1 -1
  692. package/tools/v2/contracts/edit-v2-contracts.js +303 -741
  693. package/tools/v2/contracts/edit-v2-contracts.js.map +1 -1
  694. package/tools/v2/contracts/edit-v2-contracts.mjs +303 -741
  695. package/tools/v2/contracts/edit-v2-contracts.mjs.map +1 -1
  696. package/tools/v2/contracts/get-edit-history-v2-contracts.js +1 -1
  697. package/tools/v2/contracts/get-edit-history-v2-contracts.js.map +1 -1
  698. package/tools/v2/contracts/get-edit-history-v2-contracts.mjs +1 -1
  699. package/tools/v2/contracts/get-edit-history-v2-contracts.mjs.map +1 -1
  700. package/tools/v2/contracts/list-v2-contracts.js +1 -1
  701. package/tools/v2/contracts/list-v2-contracts.js.map +1 -1
  702. package/tools/v2/contracts/list-v2-contracts.mjs +1 -1
  703. package/tools/v2/contracts/list-v2-contracts.mjs.map +1 -1
  704. package/tools/v2/contracts/retrieve-v2-contracts.d.mts.map +1 -1
  705. package/tools/v2/contracts/retrieve-v2-contracts.d.ts.map +1 -1
  706. package/tools/v2/contracts/retrieve-v2-contracts.js +1 -1
  707. package/tools/v2/contracts/retrieve-v2-contracts.js.map +1 -1
  708. package/tools/v2/contracts/retrieve-v2-contracts.mjs +1 -1
  709. package/tools/v2/contracts/retrieve-v2-contracts.mjs.map +1 -1
@@ -1,6 +1,5 @@
1
1
  // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
- import { maybeFilter } from '@metronome/mcp/filtering';
4
3
  import { Metadata, asTextContentResult } from '@metronome/mcp/tools/types';
5
4
 
6
5
  import { Tool } from '@modelcontextprotocol/sdk/types.js';
@@ -18,7 +17,7 @@ export const metadata: Metadata = {
18
17
  export const tool: Tool = {
19
18
  name: 'create_customers_v1_commits',
20
19
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nCreate a new commit at the customer level.\n\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ],\n $defs: {\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
20
+ 'Creates customer-level commits that establish spending commitments for customers across their Metronome usage. Commits represent contracted spending obligations that can be either prepaid (paid upfront) or postpaid (billed later). \n\nNote: In most cases, you should add commitments directly to customer contracts using the contract/create or contract/edit APIs.\n\n### Use this endpoint to:\nUse this endpoint when you need to establish customer-level spending commitments that can be applied across multiple contracts or scoped to specific contracts. Customer-level commits are ideal for:\n- Enterprise-wide minimum spending agreements that span multiple contracts\n- Multi-contract volume commitments with shared spending pools\n- Cross-contract discount tiers based on aggregate usage\n\n#### Commit type Requirements: \n- You must specify either "prepaid" or "postpaid" as the commit type:\n- Prepaid commits: Customer pays upfront; invoice_schedule is optional (if omitted, creates a commit without an invoice)\n- Postpaid commits: Customer pays when the commitment expires (the end of the access_schedule); invoice_schedule is required and must match access_schedule totals. \n\n#### Billing configuration:\n- invoice_contract_id is required for postpaid commits and for prepaid commits with billing (only optional for free prepaid commits)\n- For postpaid commits: access_schedule and invoice_schedule must have matching amounts\n- For postpaid commits: only one schedule item is allowed in both schedules.\n\n#### Scoping flexibility:\nCustomer-level commits can be configured in a few ways:\n- Contract-specific: Use the `applicable_contract_ids` field to limit the commit to specific contracts\n- Cross-contract: Leave `applicable_contract_ids` empty to allow the commit to be used across all of the customer\'s contracts\n\n#### Product targeting:\nCommits can be scoped to specific products using applicable_product_ids, applicable_product_tags, or specifiers, or left unrestricted to apply to all products.\n\n#### Priority considerations:\nWhen multiple commits are applicable, the one with the lower priority value will be consumed first. If there is a tie, contract level commits and credits will be applied before customer level commits and credits. Plan your priority scheme carefully to ensure commits are applied in the desired order.\n\n### Usage guidelines:\n⚠️ Preferred Alternative: In most cases, you should add commits directly to contracts using the create contract or edit contract APIs instead of creating customer-level commits. Contract-level commits provide better organization and are the recommended approach for standard use cases.\n',
22
21
  inputSchema: {
23
22
  type: 'object',
24
23
  properties: {
@@ -99,6 +98,7 @@ export const tool: Tool = {
99
98
  },
100
99
  custom_fields: {
101
100
  type: 'object',
101
+ description: 'Custom fields to be added eg. { "key1": "value1", "key2": "value2" }',
102
102
  additionalProperties: true,
103
103
  },
104
104
  description: {
@@ -218,29 +218,7 @@ export const tool: Tool = {
218
218
  description:
219
219
  "List of filters that determine what kind of customer usage draws down a commit or credit. A customer's usage needs to meet the condition of at least one of the specifiers to contribute to a commit's or credit's drawdown. This field cannot be used together with `applicable_product_ids` or `applicable_product_tags`.",
220
220
  items: {
221
- type: 'object',
222
- properties: {
223
- presentation_group_values: {
224
- type: 'object',
225
- additionalProperties: true,
226
- },
227
- pricing_group_values: {
228
- type: 'object',
229
- additionalProperties: true,
230
- },
231
- product_id: {
232
- type: 'string',
233
- description: 'If provided, the specifier will only apply to the product with the specified ID.',
234
- },
235
- product_tags: {
236
- type: 'array',
237
- description:
238
- 'If provided, the specifier will only apply to products with all the specified tags.',
239
- items: {
240
- type: 'string',
241
- },
242
- },
243
- },
221
+ $ref: '#/$defs/commit_specifier_input',
244
222
  },
245
223
  },
246
224
  uniqueness_key: {
@@ -248,21 +226,42 @@ export const tool: Tool = {
248
226
  description:
249
227
  'Prevents the creation of duplicates. If a request to create a commit or credit is made with a uniqueness key that was previously used to create a commit or credit, a new record will not be created and the request will fail with a 409 error.',
250
228
  },
251
- jq_filter: {
252
- type: 'string',
253
- title: 'jq Filter',
254
- description:
255
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
256
- },
257
229
  },
258
230
  required: ['access_schedule', 'customer_id', 'priority', 'product_id', 'type'],
231
+ $defs: {
232
+ commit_specifier_input: {
233
+ type: 'object',
234
+ properties: {
235
+ presentation_group_values: {
236
+ type: 'object',
237
+ additionalProperties: true,
238
+ },
239
+ pricing_group_values: {
240
+ type: 'object',
241
+ additionalProperties: true,
242
+ },
243
+ product_id: {
244
+ type: 'string',
245
+ description: 'If provided, the specifier will only apply to the product with the specified ID.',
246
+ },
247
+ product_tags: {
248
+ type: 'array',
249
+ description:
250
+ 'If provided, the specifier will only apply to products with all the specified tags.',
251
+ items: {
252
+ type: 'string',
253
+ },
254
+ },
255
+ },
256
+ },
257
+ },
259
258
  },
260
259
  annotations: {},
261
260
  };
262
261
 
263
262
  export const handler = async (client: Metronome, args: Record<string, unknown> | undefined) => {
264
- const { jq_filter, ...body } = args as any;
265
- return asTextContentResult(await maybeFilter(jq_filter, await client.v1.customers.commits.create(body)));
263
+ const body = args as any;
264
+ return asTextContentResult(await client.v1.customers.commits.create(body));
266
265
  };
267
266
 
268
267
  export default { metadata, tool, handler };
@@ -16,7 +16,8 @@ export const metadata: Metadata = {
16
16
 
17
17
  export const tool: Tool = {
18
18
  name: 'list_customers_v1_commits',
19
- description: 'List commits.\n',
19
+ description:
20
+ "Retrieve all commit agreements for a customer, including both prepaid and postpaid commitments. This endpoint provides comprehensive visibility into contractual spending obligations, enabling you to track commitment utilization and manage customer contracts effectively.\n\n### Use this endpoint to:\n- Display commitment balances and utilization in customer dashboards\n- Track prepaid commitment drawdown and remaining balances\n- Monitor postpaid commitment progress toward minimum thresholds\n- Build commitment tracking and forecasting tools\n- Show commitment history with optional ledger details\n- Manage rollover balances between contract periods\n\n### Key response fields:\nAn array of Commit objects containing:\n- Commit type: PREPAID (pay upfront) or POSTPAID (pay at true-up)\n- Rate type: COMMIT_RATE (discounted) or LIST_RATE (standard pricing)\n- Access schedule: When commitment funds become available\n- Invoice schedule: When the customer is billed\n- Product targeting: Which product(s) usage is eligible to draw from this commit\n- Optional ledger entries: Transaction history (if `include_ledgers=true`)\n- Balance information: Current available amount (if `include_balance=true`)\n- Rollover settings: Fraction of unused amount that carries forward\n\n### Usage guidelines:\n- Pagination: Results limited to 25 commits per page; use 'next_page' for more\n- Date filtering options:\n - `covering_date`: Commits active on a specific date\n - `starting_at`: Commits with access on/after a date\n - `effective_before`: Commits with access before a date (exclusive)\n- Scope options:\n - `include_contract_commits`: Include contract-level commits (not just customer-level)\n - `include_archived`: Include archived commits and commits from archived contracts\n- Performance considerations:\n - include_ledgers: Adds detailed transaction history (slower)\n - include_balance: Adds current balance calculation (slower)\n- Optional filtering: Use commit_id to retrieve a specific commit\n",
20
21
  inputSchema: {
21
22
  type: 'object',
22
23
  properties: {
@@ -75,7 +76,8 @@ export const tool: Tool = {
75
76
 
76
77
  export const handler = async (client: Metronome, args: Record<string, unknown> | undefined) => {
77
78
  const body = args as any;
78
- return asTextContentResult(await client.v1.customers.commits.list(body));
79
+ const response = await client.v1.customers.commits.list(body).asResponse();
80
+ return asTextContentResult(await response.json());
79
81
  };
80
82
 
81
83
  export default { metadata, tool, handler };
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'update_end_date_customers_v1_commits',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nPull forward the end date of a prepaid commit. Use the \"edit a commit\" endpoint to extend the end date of a prepaid commit, or to make other edits to the commit.\n\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ],\n $defs: {\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nShortens the end date of a prepaid commit to terminate it earlier than originally scheduled. Use this endpoint when you need to cancel or reduce the duration of an existing prepaid commit. Only works with prepaid commit types and can only move the end date forward (earlier), not extend it. \n\n### Usage guidelines:\nTo extend commit end dates or make other comprehensive edits, use the 'edit commit' endpoint instead.\n\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/commit_update_end_date_response',\n $defs: {\n commit_update_end_date_response: {\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ]\n },\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'create_v1_customers',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nCreate a new customer\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/customer'\n }\n },\n required: [ 'data'\n ],\n $defs: {\n customer: {\n type: 'object',\n properties: {\n id: {\n type: 'string',\n description: 'the Metronome ID of the customer'\n },\n external_id: {\n type: 'string',\n description: '(deprecated, use ingest_aliases instead) the first ID (Metronome or ingest alias) that can be used in usage events'\n },\n ingest_aliases: {\n type: 'array',\n description: 'aliases for this customer that can be used instead of the Metronome customer ID in usage events',\n items: {\n type: 'string'\n }\n },\n name: {\n type: 'string'\n },\n custom_fields: {\n type: 'object',\n additionalProperties: true\n }\n },\n required: [ 'id',\n 'external_id',\n 'ingest_aliases',\n 'name'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nCreate a new customer in Metronome and optionally the billing configuration (recommended) which dictates where invoices for the customer will be sent or where payment will be collected. \n\n### Use this endpoint to:\nExecute your customer provisioning workflows for either PLG motions, where customers originate in your platform, or SLG motions, where customers originate in your sales system.\n\n### Key response fields: \nThis end-point returns the `customer_id` created by the request. This id can be used to fetch relevant billing configurations and create contracts.\n\n### Example workflow:\n- Generally, Metronome recommends first creating the customer in the downstream payment / ERP system when payment method is collected and then creating the customer in Metronome using the response (i.e. `customer_id`) from the downstream system. If you do not create a billing configuration on customer creation, you can add it later. \n- Once a customer is created, you can then create a contract for the customer. In the contract creation process, you will need to add the customer billing configuration to the contract to ensure Metronome invoices the customer correctly. This is because a customer can have multiple configurations.\n- As part of the customer creation process, set the ingest alias for the customer which will ensure usage is accurately mapped to the customer. Ingest aliases can be added or changed after the creation process as well.\n\n### Usage guidelines:\nFor details on different billing configurations for different systems, review the `/setCustomerBillingConfiguration` end-point.\n\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/customer_create_response',\n $defs: {\n customer_create_response: {\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/customer'\n }\n },\n required: [ 'data'\n ]\n },\n customer: {\n type: 'object',\n properties: {\n id: {\n type: 'string',\n description: 'the Metronome ID of the customer'\n },\n external_id: {\n type: 'string',\n description: '(deprecated, use ingest_aliases instead) the first ID (Metronome or ingest alias) that can be used in usage events'\n },\n ingest_aliases: {\n type: 'array',\n description: 'aliases for this customer that can be used instead of the Metronome customer ID in usage events',\n items: {\n type: 'string'\n }\n },\n name: {\n type: 'string'\n },\n custom_fields: {\n type: 'object',\n description: 'Custom fields to be added eg. { \"key1\": \"value1\", \"key2\": \"value2\" }',\n additionalProperties: true\n }\n },\n required: [ 'id',\n 'external_id',\n 'ingest_aliases',\n 'name'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -84,13 +84,19 @@ export const tool: Tool = {
84
84
  },
85
85
  stripe_collection_method: {
86
86
  type: 'string',
87
- enum: ['charge_automatically', 'send_invoice'],
87
+ enum: [
88
+ 'charge_automatically',
89
+ 'send_invoice',
90
+ 'auto_charge_payment_intent',
91
+ 'manually_charge_payment_intent',
92
+ ],
88
93
  },
89
94
  },
90
95
  required: ['billing_provider_customer_id', 'billing_provider_type'],
91
96
  },
92
97
  custom_fields: {
93
98
  type: 'object',
99
+ description: 'Custom fields to be added eg. { "key1": "value1", "key2": "value2" }',
94
100
  additionalProperties: true,
95
101
  },
96
102
  customer_billing_provider_configurations: {
@@ -120,6 +126,12 @@ export const tool: Tool = {
120
126
  description:
121
127
  'ID of the delivery method to use for this customer. If not provided, the `delivery_method` must be provided.',
122
128
  },
129
+ tax_provider: {
130
+ type: 'string',
131
+ description:
132
+ 'Specifies which tax provider Metronome should use for tax calculation when billing through Stripe. This is only supported for Stripe billing provider configurations with auto_charge_payment_intent or manual_charge_payment_intent collection methods.',
133
+ enum: ['anrok', 'avalara', 'stripe'],
134
+ },
123
135
  },
124
136
  required: ['billing_provider'],
125
137
  },
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'create_customers_v1_credits',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nCreate a new credit at the customer level.\n\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ],\n $defs: {\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nCreates customer-level credits that provide spending allowances or free credit balances for customers across their Metronome usage. Note: In most cases, you should add credits directly to customer contracts using the contract/create or contract/edit APIs.\n\n### Use this endpoint to:\nUse this endpoint when you need to provision credits directly at the customer level that can be applied across multiple contracts or scoped to specific contracts. Customer-level credits are ideal for:\n- Customer onboarding incentives that apply globally\n- Flexible spending allowances that aren't tied to a single contract\n- Migration scenarios where you need to preserve existing customer balances\n\n#### Scoping flexibility: \nCustomer-level credits can be configured in two ways:\n- Contract-specific: Use the applicable_contract_ids field to limit the credit to specific contracts\n- Cross-contract: Leave applicable_contract_ids empty to allow the credit to be used across all of the customer's contracts\n\n#### Product Targeting: \nCredits can be scoped to specific products using `applicable_product_ids` or `applicable_product_tags`, or left unrestricted to apply to all products.\n\n#### Priority considerations: \nWhen multiple credits are applicable, the one with the lower priority value will be consumed first. If there is a tie, contract level commits and credits will be applied before customer level commits and credits. Plan your priority scheme carefully to ensure credits are applied in the desired order.\n\n#### Access Schedule Required: \nYou must provide an `access_schedule` that defines when and how much credit becomes available to the customer over time. This usually is aligned to the contract schedule or starts immediately and is set to expire in the future.\n\n### Usage Guidelines:\n⚠️ Preferred Alternative: In most cases, you should add credits directly to contracts using the contract/create or contract/edit APIs instead of creating customer-level credits. Contract-level credits provide better organization, and are easier for finance teams to recognize revenue, and are the recommended approach for most use cases.\n\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/credit_create_response',\n $defs: {\n credit_create_response: {\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ]\n },\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -92,6 +92,7 @@ export const tool: Tool = {
92
92
  },
93
93
  custom_fields: {
94
94
  type: 'object',
95
+ description: 'Custom fields to be added eg. { "key1": "value1", "key2": "value2" }',
95
96
  additionalProperties: true,
96
97
  },
97
98
  description: {
@@ -119,29 +120,7 @@ export const tool: Tool = {
119
120
  description:
120
121
  "List of filters that determine what kind of customer usage draws down a commit or credit. A customer's usage needs to meet the condition of at least one of the specifiers to contribute to a commit's or credit's drawdown. This field cannot be used together with `applicable_product_ids` or `applicable_product_tags`.",
121
122
  items: {
122
- type: 'object',
123
- properties: {
124
- presentation_group_values: {
125
- type: 'object',
126
- additionalProperties: true,
127
- },
128
- pricing_group_values: {
129
- type: 'object',
130
- additionalProperties: true,
131
- },
132
- product_id: {
133
- type: 'string',
134
- description: 'If provided, the specifier will only apply to the product with the specified ID.',
135
- },
136
- product_tags: {
137
- type: 'array',
138
- description:
139
- 'If provided, the specifier will only apply to products with all the specified tags.',
140
- items: {
141
- type: 'string',
142
- },
143
- },
144
- },
123
+ $ref: '#/$defs/commit_specifier_input',
145
124
  },
146
125
  },
147
126
  uniqueness_key: {
@@ -157,6 +136,33 @@ export const tool: Tool = {
157
136
  },
158
137
  },
159
138
  required: ['access_schedule', 'customer_id', 'priority', 'product_id'],
139
+ $defs: {
140
+ commit_specifier_input: {
141
+ type: 'object',
142
+ properties: {
143
+ presentation_group_values: {
144
+ type: 'object',
145
+ additionalProperties: true,
146
+ },
147
+ pricing_group_values: {
148
+ type: 'object',
149
+ additionalProperties: true,
150
+ },
151
+ product_id: {
152
+ type: 'string',
153
+ description: 'If provided, the specifier will only apply to the product with the specified ID.',
154
+ },
155
+ product_tags: {
156
+ type: 'array',
157
+ description:
158
+ 'If provided, the specifier will only apply to products with all the specified tags.',
159
+ items: {
160
+ type: 'string',
161
+ },
162
+ },
163
+ },
164
+ },
165
+ },
160
166
  },
161
167
  annotations: {},
162
168
  };
@@ -16,7 +16,8 @@ export const metadata: Metadata = {
16
16
 
17
17
  export const tool: Tool = {
18
18
  name: 'list_customers_v1_credits',
19
- description: 'List credits.\n',
19
+ description:
20
+ 'Retrieve a detailed list of all credits available to a customer, including promotional credits and contract-specific credits. This endpoint provides comprehensive visibility into credit balances, access schedules, and usage rules, enabling you to build credit management interfaces and track available funding.\n\n### Use this endpoint to:\n- Display all available credits in customer billing dashboards\n- Show credit balances and expiration dates\n- Track credit usage history with optional ledger details\n- Build credit management and reporting tools\n- Monitor promotional credit utilization\n• Support customer inquiries about available credits\n\n### Key response fields:\nAn array of Credit objects containing:\n- Credit details: Name, priority, and which applicable products/tags it applies to\n- Product ID: The `product_id` of the credit. This is for external mapping into your quote-to-cash stack, not the product it applies to. \n- Access schedule: When credits become available and expire\n- Optional ledger entries: Transaction history (if `include_ledgers=true`)\n- Balance information: Current available amount (if `include_balance=true`)\n- Metadata: Custom fields and usage specifiers\n\n### Usage guidelines:\n- Pagination: Results limited to 25 commits per page; use next_page for more\n- Date filtering options:\n - `covering_date`: Credits active on a specific date\n - `starting_at`: Credits with access on/after a date\n - `effective_before`: Credits with access before a date (exclusive)\n- Scope options:\n - `include_contract_credits`: Include contract-level credits (not just customer-level)\n - `include_archived`: Include archived credits and credits from archived contracts\n- Performance considerations:\n - `include_ledgers`: Adds detailed transaction history (slower)\n - `include_balance`: Adds current balance calculation (slower)\n- Optional filtering: Use credit_id to retrieve a specific commit\n',
20
21
  inputSchema: {
21
22
  type: 'object',
22
23
  properties: {
@@ -75,7 +76,8 @@ export const tool: Tool = {
75
76
 
76
77
  export const handler = async (client: Metronome, args: Record<string, unknown> | undefined) => {
77
78
  const body = args as any;
78
- return asTextContentResult(await client.v1.customers.credits.list(body));
79
+ const response = await client.v1.customers.credits.list(body).asResponse();
80
+ return asTextContentResult(await response.json());
79
81
  };
80
82
 
81
83
  export default { metadata, tool, handler };
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'update_end_date_customers_v1_credits',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nPull forward the end date of a credit. Use the \"edit a credit\" endpoint to extend the end date of a credit, or to make other edits to the credit.\n\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ],\n $defs: {\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nShortens the end date of an existing customer credit to terminate it earlier than originally scheduled. Only allows moving end dates forward (earlier), not extending them. \n\nNote: To extend credit end dates or make comprehensive edits, use the 'edit credit' endpoint instead.\n\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/credit_update_end_date_response',\n $defs: {\n credit_update_end_date_response: {\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ]\n },\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'add_charge_customers_v1_invoices',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nAdd a one time charge to the specified invoice\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {}\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nAdd a one time charge to the specified invoice\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/invoice_add_charge_response',\n $defs: {\n invoice_add_charge_response: {\n type: 'object',\n properties: {}\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -17,7 +17,7 @@ export const metadata: Metadata = {
17
17
  export const tool: Tool = {
18
18
  name: 'list_breakdowns_customers_v1_invoices',
19
19
  description:
20
- 'List daily or hourly invoice breakdowns for a given customer, optionally filtered by status, date range, and/or credit type.\nImportant considerations:\n- If we receive backdated usage after an invoice has been finalized, the backdated usage will be included in the response and usage numbers may differ.',
20
+ 'Retrieve granular time-series breakdowns of invoice data at hourly or daily intervals. This endpoint transforms standard invoices into detailed timelines, enabling you to track usage patterns, identify consumption spikes, and provide customers with transparency into their billing details throughout the billing period.\n\n### Use this endpoint to:\n- Build usage analytics dashboards showing daily or hourly consumption trends\n- Identify peak usage periods for capacity planning and cost optimization\n- Generate detailed billing reports for finance teams and customer success\n- Troubleshoot billing disputes by examining usage patterns at specific times\n- Power real-time cost monitoring and alerting systems\n\n### Key response fields:\nAn array of BreakdownInvoice objects, each containing:\n- All standard invoice fields (ID, customer, commit, line items, totals, status)\n- Line items with quantities and costs for that specific period\n- `breakdown_start_timestamp`: Start of the specific time window\n- `breakdown_end_timestamp`: End of the specific time window\n- `next_page`: Pagination cursor for large result sets\n\n### Usage guidelines:\n- Time granularity: Set `window_size` to hour or day based on your analysis needs\n- Response limits: Daily breakdowns return up to 35 days; hourly breakdowns return up to 24 hours per request\n- Date filtering: Use `starting_on` and `ending_before` to focus on specific periods\n- Performance: For large date ranges, use pagination to retrieve all data efficiently\n- Backdated usage: If usage events arrive after invoice finalization, breakdowns will reflect the updated usage\n- Zero quantity filtering: Use `skip_zero_qty_line_items=true` to exclude periods with no usage',
21
21
  inputSchema: {
22
22
  type: 'object',
23
23
  properties: {
@@ -17,7 +17,7 @@ export const metadata: Metadata = {
17
17
  export const tool: Tool = {
18
18
  name: 'list_customers_v1_invoices',
19
19
  description:
20
- 'List all invoices for a given customer, optionally filtered by status, date range, and/or credit type.',
20
+ "Retrieves a paginated list of invoices for a specific customer, with flexible filtering options to narrow results by status, date range, credit type, and more. This endpoint provides a comprehensive view of a customer's billing history and current charges, supporting both real-time billing dashboards and historical reporting needs.\n\n### Use this endpoint to:\n- Display historical invoice details in customer-facing dashboards or billing portals.\n- Retrieve current month draft invoices to show customers their month-to-date spend.\n- Access finalized invoices for historical billing records and payment reconciliation.\n- Validate customer pricing and credit applications for customer support queries. \n- Generate financial reports by filtering invoices within specific date ranges\n\n### Key response fields:\nArray of invoice objects containing:\n- Invoice ID and status (DRAFT, FINALIZED, VOID)\n- Invoice type (USAGE, SCHEDULED)\n- Billing period start and end dates\n- Issue date and due date\n- Total amount, subtotal, and amount due\n- Applied credits summary\n- Contract ID reference\n- External billing provider status (if integrated with Stripe, etc.)\n- Pagination metadata `next_page` cursor\n\n### Usage guidelines:\n- The endpoint returns invoice summaries; use the Get Invoice endpoint for detailed line items\n- Draft invoices are continuously updated as new usage is reported and will show real-time spend\n- Results are ordered by creation date descending by default (newest first)\n- When filtering by date range, the filter applies to the billing period, not the issue date\n- For customers with many invoices, implement pagination to ensure all results are retrieved\nExternal billing provider statuses (like Stripe payment status) are included when applicable\n- Voided invoices are included in results by default unless filtered out by status\n",
21
21
  inputSchema: {
22
22
  type: 'object',
23
23
  properties: {
@@ -16,7 +16,8 @@ export const metadata: Metadata = {
16
16
 
17
17
  export const tool: Tool = {
18
18
  name: 'retrieve_customers_v1_invoices',
19
- description: 'Fetch a specific invoice for a given customer.',
19
+ description:
20
+ 'Retrieve detailed information for a specific invoice by its unique identifier. This endpoint returns comprehensive invoice data including line items, applied credits, totals, and billing period details for both finalized and draft invoices.\n\n### Use this endpoint to:\n- Display historical invoice details in customer-facing dashboards or billing portals.\n- Retrieve current month draft invoices to show customers their month-to-date spend.\n- Access finalized invoices for historical billing records and payment reconciliation.\n- Validate customer pricing and credit applications for customer support queries. \n\n### Key response fields: \nInvoice status (DRAFT, FINALIZED, VOID)\nBilling period start and end dates\nTotal amount and amount due after credits\nDetailed line items broken down by:\n- Customer and contract information\n- Invoice line item type\n- Product/service name and ID\n- Quantity consumed\n- Unit and total price \n- Time period for usage-based charges\n- Applied credits or prepaid commitments\n\n\n### Usage guidelines:\n- Draft invoices update in real-time as usage is reported and may change before finalization\n- The response includes both usage-based line items (e.g., API calls, data processed) and scheduled charges (e.g., monthly subscriptions, commitment fees)\n- Credit and commitment applications are shown as separate line items with negative amounts\n- For voided invoices, the response will indicate VOID status but retain all original line item details\n',
20
21
  inputSchema: {
21
22
  type: 'object',
22
23
  properties: {
@@ -0,0 +1,43 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { Metadata, asBinaryContentResult } from '@metronome/mcp/tools/types';
4
+
5
+ import { Tool } from '@modelcontextprotocol/sdk/types.js';
6
+ import Metronome from '@metronome/sdk';
7
+
8
+ export const metadata: Metadata = {
9
+ resource: 'v1.customers.invoices',
10
+ operation: 'read',
11
+ tags: [],
12
+ httpMethod: 'get',
13
+ httpPath: '/v1/customers/{customer_id}/invoices/{invoice_id}/pdf',
14
+ operationId: 'getInvoicePdf-v1',
15
+ };
16
+
17
+ export const tool: Tool = {
18
+ name: 'retrieve_pdf_customers_v1_invoices',
19
+ description:
20
+ 'Retrieve a PDF version of a specific invoice by its unique identifier. This endpoint generates a professionally formatted invoice document suitable for sharing with customers, accounting teams, or for record-keeping purposes.\n\n### Use this endpoint to:\n- Provide customers with downloadable or emailable copies of their invoices\n- Support accounting and finance teams with official billing documents\n- Maintain accurate records of billing transactions for audits and compliance\n\n### Key response details:\n- The response is a binary PDF file representing the full invoice\n- The PDF includes all standard invoice information such as line items, totals, billing period, and customer details\n- The document is formatted for clarity and professionalism, suitable for official use\n\n### Usage guidelines:\n- Ensure the `invoice_id` corresponds to an existing invoice for the specified `customer_id`\n- The PDF is generated on-demand; frequent requests for the same invoice may impact performance\n- Use appropriate headers to handle the binary response in your application (e.g., setting `Content-Type: application/pdf`)\n',
21
+ inputSchema: {
22
+ type: 'object',
23
+ properties: {
24
+ customer_id: {
25
+ type: 'string',
26
+ },
27
+ invoice_id: {
28
+ type: 'string',
29
+ },
30
+ },
31
+ required: ['customer_id', 'invoice_id'],
32
+ },
33
+ annotations: {
34
+ readOnlyHint: true,
35
+ },
36
+ };
37
+
38
+ export const handler = async (client: Metronome, args: Record<string, unknown> | undefined) => {
39
+ const body = args as any;
40
+ return asBinaryContentResult(await client.v1.customers.invoices.retrievePdf(body));
41
+ };
42
+
43
+ export default { metadata, tool, handler };
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'list_billable_metrics_v1_customers',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet all billable metrics for a given customer.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n name: {\n type: 'string'\n },\n aggregate: {\n type: 'string',\n description: '(DEPRECATED) use aggregation_type instead'\n },\n aggregate_keys: {\n type: 'array',\n description: '(DEPRECATED) use aggregation_key instead',\n items: {\n type: 'string'\n }\n },\n aggregation_key: {\n type: 'string',\n description: 'A key that specifies which property of the event is used to aggregate data. This key must be one of the property filter names and is not applicable when the aggregation type is \\'count\\'.'\n },\n aggregation_type: {\n type: 'string',\n description: 'Specifies the type of aggregation performed on matching events.',\n enum: [ 'COUNT',\n 'LATEST',\n 'MAX',\n 'SUM',\n 'UNIQUE'\n ]\n },\n archived_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the billable metric was archived. If not provided, the billable metric is not archived.',\n format: 'date-time'\n },\n custom_fields: {\n type: 'object',\n additionalProperties: true\n },\n event_type_filter: {\n $ref: '#/$defs/event_type_filter'\n },\n filter: {\n type: 'object',\n description: '(DEPRECATED) use property_filters & event_type_filter instead',\n additionalProperties: true\n },\n group_by: {\n type: 'array',\n description: '(DEPRECATED) use group_keys instead',\n items: {\n type: 'string',\n description: 'A list of keys that can be used to additionally segment the values of the billable metric when making usage queries'\n }\n },\n group_keys: {\n type: 'array',\n description: 'Property names that are used to group usage costs on an invoice. Each entry represents a set of properties used to slice events into distinct buckets.',\n items: {\n type: 'array',\n items: {\n type: 'string'\n }\n }\n },\n property_filters: {\n type: 'array',\n description: 'A list of filters to match events to this billable metric. Each filter defines a rule on an event property. All rules must pass for the event to match the billable metric.',\n items: {\n $ref: '#/$defs/property_filter'\n }\n },\n sql: {\n type: 'string',\n description: 'The SQL query associated with the billable metric'\n }\n },\n required: [ 'id',\n 'name'\n ]\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n event_type_filter: {\n type: 'object',\n description: 'An optional filtering rule to match the \\'event_type\\' property of an event.',\n properties: {\n in_values: {\n type: 'array',\n description: 'A list of event types that are explicitly included in the billable metric. If specified, only events of these types will match the billable metric. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n },\n not_in_values: {\n type: 'array',\n description: 'A list of event types that are explicitly excluded from the billable metric. If specified, events of these types will not match the billable metric. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n }\n }\n },\n property_filter: {\n type: 'object',\n properties: {\n name: {\n type: 'string',\n description: 'The name of the event property.'\n },\n exists: {\n type: 'boolean',\n description: 'Determines whether the property must exist in the event. If true, only events with this property will pass the filter. If false, only events without this property will pass the filter. If null or omitted, the existence of the property is optional.'\n },\n in_values: {\n type: 'array',\n description: 'Specifies the allowed values for the property to match an event. An event will pass the filter only if its property value is included in this list. If undefined, all property values will pass the filter. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n },\n not_in_values: {\n type: 'array',\n description: 'Specifies the values that prevent an event from matching the filter. An event will not pass the filter if its property value is included in this list. If null or empty, all property values will pass the filter. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n }\n },\n required: [ 'name'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet all billable metrics available for a specific customer. Supports pagination and filtering by current plan status or archived metrics. Use this endpoint to see which metrics are being tracked for billing calculations for a given customer.\n\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n $ref: '#/$defs/customer_list_billable_metrics_response'\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n customer_list_billable_metrics_response: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n name: {\n type: 'string'\n },\n aggregate: {\n type: 'string',\n description: '(DEPRECATED) use aggregation_type instead'\n },\n aggregate_keys: {\n type: 'array',\n description: '(DEPRECATED) use aggregation_key instead',\n items: {\n type: 'string'\n }\n },\n aggregation_key: {\n type: 'string',\n description: 'A key that specifies which property of the event is used to aggregate data. This key must be one of the property filter names and is not applicable when the aggregation type is \\'count\\'.'\n },\n aggregation_type: {\n type: 'string',\n description: 'Specifies the type of aggregation performed on matching events.',\n enum: [ 'COUNT',\n 'LATEST',\n 'MAX',\n 'SUM',\n 'UNIQUE'\n ]\n },\n archived_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the billable metric was archived. If not provided, the billable metric is not archived.',\n format: 'date-time'\n },\n custom_fields: {\n type: 'object',\n description: 'Custom fields to be added eg. { \"key1\": \"value1\", \"key2\": \"value2\" }',\n additionalProperties: true\n },\n event_type_filter: {\n $ref: '#/$defs/event_type_filter'\n },\n filter: {\n type: 'object',\n description: '(DEPRECATED) use property_filters & event_type_filter instead',\n additionalProperties: true\n },\n group_by: {\n type: 'array',\n description: '(DEPRECATED) use group_keys instead',\n items: {\n type: 'string',\n description: 'A list of keys that can be used to additionally segment the values of the billable metric when making usage queries'\n }\n },\n group_keys: {\n type: 'array',\n description: 'Property names that are used to group usage costs on an invoice. Each entry represents a set of properties used to slice events into distinct buckets.',\n items: {\n type: 'array',\n items: {\n type: 'string'\n }\n }\n },\n property_filters: {\n type: 'array',\n description: 'A list of filters to match events to this billable metric. Each filter defines a rule on an event property. All rules must pass for the event to match the billable metric.',\n items: {\n $ref: '#/$defs/property_filter'\n }\n },\n sql: {\n type: 'string',\n description: 'The SQL query associated with the billable metric'\n }\n },\n required: [ 'id',\n 'name'\n ]\n },\n event_type_filter: {\n type: 'object',\n description: 'An optional filtering rule to match the \\'event_type\\' property of an event.',\n properties: {\n in_values: {\n type: 'array',\n description: 'A list of event types that are explicitly included in the billable metric. If specified, only events of these types will match the billable metric. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n },\n not_in_values: {\n type: 'array',\n description: 'A list of event types that are explicitly excluded from the billable metric. If specified, events of these types will not match the billable metric. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n }\n }\n },\n property_filter: {\n type: 'object',\n properties: {\n name: {\n type: 'string',\n description: 'The name of the event property.'\n },\n exists: {\n type: 'boolean',\n description: 'Determines whether the property must exist in the event. If true, only events with this property will pass the filter. If false, only events without this property will pass the filter. If null or omitted, the existence of the property is optional.'\n },\n in_values: {\n type: 'array',\n description: 'Specifies the allowed values for the property to match an event. An event will pass the filter only if its property value is included in this list. If undefined, all property values will pass the filter. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n },\n not_in_values: {\n type: 'array',\n description: 'Specifies the values that prevent an event from matching the filter. An event will not pass the filter if its property value is included in this list. If null or empty, all property values will pass the filter. Must be non-empty if present.',\n items: {\n type: 'string'\n }\n }\n },\n required: [ 'name'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'list_costs_v1_customers',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nFetch daily pending costs for the specified customer, broken down by credit type and line items. Note: this is not supported for customers whose plan includes a UNIQUE-type billable metric.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n credit_types: {\n type: 'object',\n additionalProperties: true\n },\n end_timestamp: {\n type: 'string',\n format: 'date-time'\n },\n start_timestamp: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'credit_types',\n 'end_timestamp',\n 'start_timestamp'\n ]\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ]\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nFetch daily pending costs for the specified customer, broken down by credit type and line items. Note: this is not supported for customers whose plan includes a UNIQUE-type billable metric.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n $ref: '#/$defs/customer_list_costs_response'\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n customer_list_costs_response: {\n type: 'object',\n properties: {\n credit_types: {\n type: 'object',\n additionalProperties: true\n },\n end_timestamp: {\n type: 'string',\n format: 'date-time'\n },\n start_timestamp: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'credit_types',\n 'end_timestamp',\n 'start_timestamp'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'list_v1_customers',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList all customers.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n $ref: '#/$defs/customer_detail'\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n customer_detail: {\n type: 'object',\n properties: {\n id: {\n type: 'string',\n description: 'the Metronome ID of the customer'\n },\n created_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the customer was created.',\n format: 'date-time'\n },\n custom_fields: {\n type: 'object',\n additionalProperties: true\n },\n customer_config: {\n type: 'object',\n properties: {\n salesforce_account_id: {\n type: 'string',\n description: 'The Salesforce account ID for the customer'\n }\n },\n required: [ 'salesforce_account_id'\n ]\n },\n external_id: {\n type: 'string',\n description: '(deprecated, use ingest_aliases instead) the first ID (Metronome or ingest alias) that can be used in usage events'\n },\n ingest_aliases: {\n type: 'array',\n description: 'aliases for this customer that can be used instead of the Metronome customer ID in usage events',\n items: {\n type: 'string'\n }\n },\n name: {\n type: 'string'\n },\n archived_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the customer was archived. Null if the customer is active.',\n format: 'date-time'\n },\n current_billable_status: {\n type: 'object',\n description: 'This field\\'s availability is dependent on your client\\'s configuration.',\n properties: {\n value: {\n type: 'string',\n enum: [ 'billable',\n 'unbillable'\n ]\n },\n effective_at: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'value'\n ]\n }\n },\n required: [ 'id',\n 'created_at',\n 'custom_fields',\n 'customer_config',\n 'external_id',\n 'ingest_aliases',\n 'name'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGets a paginated list of all customers in your Metronome account. Use this endpoint to browse your customer base, implement customer search functionality, or sync customer data with external systems. Returns customer details including IDs, names, and configuration settings. Supports filtering and pagination parameters for efficient data retrieval.\n\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n $ref: '#/$defs/customer_detail'\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n customer_detail: {\n type: 'object',\n properties: {\n id: {\n type: 'string',\n description: 'the Metronome ID of the customer'\n },\n created_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the customer was created.',\n format: 'date-time'\n },\n custom_fields: {\n type: 'object',\n description: 'Custom fields to be added eg. { \"key1\": \"value1\", \"key2\": \"value2\" }',\n additionalProperties: true\n },\n customer_config: {\n type: 'object',\n properties: {\n salesforce_account_id: {\n type: 'string',\n description: 'The Salesforce account ID for the customer'\n }\n },\n required: [ 'salesforce_account_id'\n ]\n },\n external_id: {\n type: 'string',\n description: '(deprecated, use ingest_aliases instead) the first ID (Metronome or ingest alias) that can be used in usage events'\n },\n ingest_aliases: {\n type: 'array',\n description: 'aliases for this customer that can be used instead of the Metronome customer ID in usage events',\n items: {\n type: 'string'\n }\n },\n name: {\n type: 'string'\n },\n updated_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the customer was last updated.',\n format: 'date-time'\n },\n archived_at: {\n type: 'string',\n description: 'RFC 3339 timestamp indicating when the customer was archived. Null if the customer is active.',\n format: 'date-time'\n },\n current_billable_status: {\n type: 'object',\n description: 'This field\\'s availability is dependent on your client\\'s configuration.',\n properties: {\n value: {\n type: 'string',\n enum: [ 'billable',\n 'unbillable'\n ]\n },\n effective_at: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'value'\n ]\n }\n },\n required: [ 'id',\n 'created_at',\n 'custom_fields',\n 'customer_config',\n 'external_id',\n 'ingest_aliases',\n 'name',\n 'updated_at'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'retrieve_customers_v1_named_schedules',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet a named schedule for the given customer. This endpoint's availability is dependent on your client's configuration.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n starting_at: {\n type: 'string',\n format: 'date-time'\n },\n value: {\n type: 'object',\n additionalProperties: true\n },\n ending_before: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'starting_at',\n 'value'\n ]\n }\n }\n },\n required: [ 'data'\n ]\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet a named schedule for the given customer. This endpoint's availability is dependent on your client's configuration.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/named_schedule_retrieve_response',\n $defs: {\n named_schedule_retrieve_response: {\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n starting_at: {\n type: 'string',\n format: 'date-time'\n },\n value: {\n type: 'object',\n additionalProperties: true\n },\n ending_before: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'starting_at',\n 'value'\n ]\n }\n }\n },\n required: [ 'data'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'add_customers_v1_plans',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nAssociate an existing customer with a plan for a specified date range. See the [price adjustments documentation](https://plans-docs.metronome.com/pricing/managing-plans/#price-adjustments) for details on the price adjustments.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ],\n $defs: {\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nAssociate an existing customer with a plan for a specified date range. See the [price adjustments documentation](https://plans-docs.metronome.com/pricing/managing-plans/#price-adjustments) for details on the price adjustments.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/plan_add_response',\n $defs: {\n plan_add_response: {\n type: 'object',\n properties: {\n data: {\n $ref: '#/$defs/id'\n }\n },\n required: [ 'data'\n ]\n },\n id: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n }\n },\n required: [ 'id'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'end_customers_v1_plans',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nChange the end date of a customer's plan.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {}\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nChange the end date of a customer's plan.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/plan_end_response',\n $defs: {\n plan_end_response: {\n type: 'object',\n properties: {}\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'list_customers_v1_plans',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList the given customer's plans in reverse-chronological order.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string',\n description: 'the ID of the customer plan'\n },\n custom_fields: {\n type: 'object',\n additionalProperties: true\n },\n plan_description: {\n type: 'string'\n },\n plan_id: {\n type: 'string',\n description: 'the ID of the plan'\n },\n plan_name: {\n type: 'string'\n },\n starting_on: {\n type: 'string',\n format: 'date-time'\n },\n ending_before: {\n type: 'string',\n format: 'date-time'\n },\n net_payment_terms_days: {\n type: 'number'\n },\n trial_info: {\n type: 'object',\n properties: {\n ending_before: {\n type: 'string',\n format: 'date-time'\n },\n spending_caps: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n amount: {\n type: 'number'\n },\n amount_remaining: {\n type: 'number'\n },\n credit_type: {\n $ref: '#/$defs/credit_type_data'\n }\n },\n required: [ 'amount',\n 'amount_remaining',\n 'credit_type'\n ]\n }\n }\n },\n required: [ 'ending_before',\n 'spending_caps'\n ]\n }\n },\n required: [ 'id',\n 'custom_fields',\n 'plan_description',\n 'plan_id',\n 'plan_name',\n 'starting_on'\n ]\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n credit_type_data: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n name: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'name'\n ]\n }\n }\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList the given customer's plans in reverse-chronological order.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n $ref: '#/$defs/plan_list_response'\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n plan_list_response: {\n type: 'object',\n properties: {\n id: {\n type: 'string',\n description: 'the ID of the customer plan'\n },\n custom_fields: {\n type: 'object',\n description: 'Custom fields to be added eg. { \"key1\": \"value1\", \"key2\": \"value2\" }',\n additionalProperties: true\n },\n plan_description: {\n type: 'string'\n },\n plan_id: {\n type: 'string',\n description: 'the ID of the plan'\n },\n plan_name: {\n type: 'string'\n },\n starting_on: {\n type: 'string',\n format: 'date-time'\n },\n ending_before: {\n type: 'string',\n format: 'date-time'\n },\n net_payment_terms_days: {\n type: 'number'\n },\n trial_info: {\n type: 'object',\n properties: {\n ending_before: {\n type: 'string',\n format: 'date-time'\n },\n spending_caps: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n amount: {\n type: 'number'\n },\n amount_remaining: {\n type: 'number'\n },\n credit_type: {\n $ref: '#/$defs/credit_type_data'\n }\n },\n required: [ 'amount',\n 'amount_remaining',\n 'credit_type'\n ]\n }\n }\n },\n required: [ 'ending_before',\n 'spending_caps'\n ]\n }\n },\n required: [ 'id',\n 'custom_fields',\n 'plan_description',\n 'plan_id',\n 'plan_name',\n 'starting_on'\n ]\n },\n credit_type_data: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n name: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'name'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {
@@ -18,7 +18,7 @@ export const metadata: Metadata = {
18
18
  export const tool: Tool = {
19
19
  name: 'list_price_adjustments_customers_v1_plans',
20
20
  description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nLists a customer plans adjustments. See the [price adjustments documentation](https://plans-docs.metronome.com/pricing/managing-plans/#price-adjustments) for details.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n charge_id: {\n type: 'string'\n },\n charge_type: {\n type: 'string',\n enum: [ 'usage',\n 'fixed',\n 'composite',\n 'minimum',\n 'seat'\n ]\n },\n prices: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n adjustment_type: {\n type: 'string',\n description: 'Determines how the value will be applied.',\n enum: [ 'fixed',\n 'quantity',\n 'percentage',\n 'override'\n ]\n },\n tier: {\n type: 'number',\n description: 'Used in pricing tiers. Indicates at what metric value the price applies.'\n },\n value: {\n type: 'number'\n }\n },\n required: [ 'adjustment_type'\n ]\n }\n },\n start_period: {\n type: 'number'\n },\n quantity: {\n type: 'number'\n }\n },\n required: [ 'charge_id',\n 'charge_type',\n 'prices',\n 'start_period'\n ]\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ]\n}\n```",
21
+ "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nLists a customer plans adjustments. See the [price adjustments documentation](https://plans-docs.metronome.com/pricing/managing-plans/#price-adjustments) for details.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n data: {\n type: 'array',\n items: {\n $ref: '#/$defs/plan_list_price_adjustments_response'\n }\n },\n next_page: {\n type: 'string'\n }\n },\n required: [ 'data',\n 'next_page'\n ],\n $defs: {\n plan_list_price_adjustments_response: {\n type: 'object',\n properties: {\n charge_id: {\n type: 'string'\n },\n charge_type: {\n type: 'string',\n enum: [ 'usage',\n 'fixed',\n 'composite',\n 'minimum',\n 'seat'\n ]\n },\n prices: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n adjustment_type: {\n type: 'string',\n description: 'Determines how the value will be applied.',\n enum: [ 'fixed',\n 'quantity',\n 'percentage',\n 'override'\n ]\n },\n tier: {\n type: 'number',\n description: 'Used in pricing tiers. Indicates at what metric value the price applies.'\n },\n value: {\n type: 'number'\n }\n },\n required: [ 'adjustment_type'\n ]\n }\n },\n start_period: {\n type: 'number'\n },\n quantity: {\n type: 'number'\n }\n },\n required: [ 'charge_id',\n 'charge_type',\n 'prices',\n 'start_period'\n ]\n }\n }\n}\n```",
22
22
  inputSchema: {
23
23
  type: 'object',
24
24
  properties: {