@vandenberghinc/volt 1.2.6 → 1.2.8

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 (472) hide show
  1. package/.libris/config.json +82 -0
  2. package/backend/dist/cjs/backend/src/blacklist.d.ts +12 -0
  3. package/backend/dist/cjs/backend/src/blacklist.js +78 -0
  4. package/backend/dist/cjs/backend/src/cli.d.ts +2 -0
  5. package/backend/dist/cjs/backend/src/cli.js +198 -0
  6. package/backend/dist/cjs/backend/src/database/collection.d.ts +1765 -0
  7. package/backend/dist/cjs/backend/src/database/collection.js +3301 -0
  8. package/backend/dist/cjs/backend/src/database/database.d.ts +92 -0
  9. package/backend/dist/cjs/backend/src/database/database.js +170 -0
  10. package/backend/dist/cjs/backend/src/database/document.d.ts +1 -0
  11. package/backend/dist/cjs/backend/src/database/document.js +15 -0
  12. package/backend/dist/cjs/backend/src/database/filters/filters.d.ts +6 -0
  13. package/backend/dist/cjs/backend/src/database/filters/filters.js +15 -0
  14. package/backend/dist/cjs/backend/src/database/filters/strict_filter.d.ts +223 -0
  15. package/backend/dist/cjs/backend/src/database/filters/strict_filter.js +15 -0
  16. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.d.ts +1 -0
  17. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.js +443 -0
  18. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.d.ts +1 -0
  19. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.js +15 -0
  20. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.d.ts +50 -0
  21. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.js +15 -0
  22. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.d.ts +76 -0
  23. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.js +15 -0
  24. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.d.ts +75 -0
  25. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.js +15 -0
  26. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.d.ts +219 -0
  27. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.js +15 -0
  28. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.d.ts +165 -0
  29. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.js +15 -0
  30. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.d.ts +5 -0
  31. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.js +355 -0
  32. package/backend/dist/cjs/backend/src/database/flatten.d.ts +78 -0
  33. package/backend/dist/cjs/backend/src/database/flatten.js +53 -0
  34. package/backend/dist/cjs/backend/src/database/flatten_test.d.ts +1 -0
  35. package/backend/dist/cjs/backend/src/database/flatten_test.js +175 -0
  36. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.d.ts +533 -0
  37. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.js +1046 -0
  38. package/backend/dist/cjs/backend/src/database/quota/quota.d.ts +551 -0
  39. package/backend/dist/cjs/backend/src/database/quota/quota.js +1108 -0
  40. package/backend/dist/cjs/backend/src/database/quota/quota_v1.d.ts +534 -0
  41. package/backend/dist/cjs/backend/src/database/quota/quota_v1.js +1087 -0
  42. package/backend/dist/cjs/backend/src/database/quota/safe_int.d.ts +412 -0
  43. package/backend/dist/cjs/backend/src/database/quota/safe_int.js +745 -0
  44. package/backend/dist/cjs/backend/src/endpoint.d.ts +346 -0
  45. package/backend/dist/cjs/backend/src/endpoint.js +468 -0
  46. package/backend/dist/cjs/backend/src/errors/index.d.ts +7 -0
  47. package/backend/dist/cjs/backend/src/errors/index.js +25 -0
  48. package/backend/dist/cjs/backend/src/errors/internal_external.d.ts +52 -0
  49. package/backend/dist/cjs/backend/src/errors/internal_external.js +95 -0
  50. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.d.ts +41 -0
  51. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.js +47 -0
  52. package/backend/dist/cjs/backend/src/errors/system_error.d.ts +261 -0
  53. package/backend/dist/cjs/backend/src/errors/system_error.js +436 -0
  54. package/backend/dist/cjs/backend/src/events.d.ts +97 -0
  55. package/backend/dist/cjs/backend/src/events.js +15 -0
  56. package/backend/dist/cjs/backend/src/frontend.d.ts +13 -0
  57. package/backend/dist/cjs/backend/src/frontend.js +56 -0
  58. package/backend/dist/cjs/backend/src/image_endpoint.d.ts +44 -0
  59. package/backend/dist/cjs/backend/src/image_endpoint.js +185 -0
  60. package/backend/dist/cjs/backend/src/index.d.ts +23 -0
  61. package/backend/dist/cjs/backend/src/index.js +70 -0
  62. package/backend/dist/cjs/backend/src/logger.d.ts +5 -0
  63. package/backend/dist/cjs/backend/src/logger.js +15 -0
  64. package/backend/dist/cjs/backend/src/meta.d.ts +112 -0
  65. package/backend/dist/cjs/backend/src/meta.js +181 -0
  66. package/backend/dist/cjs/backend/src/payments/paddle.d.ts +329 -0
  67. package/backend/dist/cjs/backend/src/payments/paddle.js +1996 -0
  68. package/backend/dist/cjs/backend/src/payments/stripe/checkout.d.ts +113 -0
  69. package/backend/dist/cjs/backend/src/payments/stripe/checkout.js +295 -0
  70. package/backend/dist/cjs/backend/src/payments/stripe/customers.d.ts +17 -0
  71. package/backend/dist/cjs/backend/src/payments/stripe/customers.js +164 -0
  72. package/backend/dist/cjs/backend/src/payments/stripe/error.d.ts +74 -0
  73. package/backend/dist/cjs/backend/src/payments/stripe/error.js +64 -0
  74. package/backend/dist/cjs/backend/src/payments/stripe/events.d.ts +155 -0
  75. package/backend/dist/cjs/backend/src/payments/stripe/events.js +15 -0
  76. package/backend/dist/cjs/backend/src/payments/stripe/meters.d.ts +105 -0
  77. package/backend/dist/cjs/backend/src/payments/stripe/meters.js +230 -0
  78. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.d.ts +58 -0
  79. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.js +109 -0
  80. package/backend/dist/cjs/backend/src/payments/stripe/products.d.ts +519 -0
  81. package/backend/dist/cjs/backend/src/payments/stripe/products.js +650 -0
  82. package/backend/dist/cjs/backend/src/payments/stripe/stripe.d.ts +215 -0
  83. package/backend/dist/cjs/backend/src/payments/stripe/stripe.js +468 -0
  84. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.d.ts +172 -0
  85. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.js +557 -0
  86. package/backend/dist/cjs/backend/src/payments/stripe/utils.d.ts +63 -0
  87. package/backend/dist/cjs/backend/src/payments/stripe/utils.js +118 -0
  88. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.d.ts +105 -0
  89. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.js +627 -0
  90. package/backend/dist/cjs/backend/src/plugins/browser.d.ts +1 -0
  91. package/backend/dist/cjs/backend/src/plugins/browser.js +15 -0
  92. package/backend/dist/cjs/backend/src/plugins/communication.d.ts +70 -0
  93. package/backend/dist/cjs/backend/src/plugins/communication.js +196 -0
  94. package/backend/dist/cjs/backend/src/plugins/mail/mail.d.ts +255 -0
  95. package/backend/dist/cjs/backend/src/plugins/mail/mail.js +381 -0
  96. package/backend/dist/cjs/backend/src/plugins/mail/ui.d.ts +297 -0
  97. package/backend/dist/cjs/backend/src/plugins/mail/ui.js +1370 -0
  98. package/backend/dist/cjs/backend/src/plugins/pdf.d.ts +1 -0
  99. package/backend/dist/cjs/backend/src/plugins/pdf.js +1456 -0
  100. package/backend/dist/cjs/backend/src/plugins/thread_monitor.d.ts +18 -0
  101. package/backend/dist/cjs/backend/src/plugins/thread_monitor.js +116 -0
  102. package/backend/dist/cjs/backend/src/rate_limit.d.ts +148 -0
  103. package/backend/dist/cjs/backend/src/rate_limit.js +543 -0
  104. package/backend/dist/cjs/backend/src/route.d.ts +39 -0
  105. package/backend/dist/cjs/backend/src/route.js +172 -0
  106. package/backend/dist/cjs/backend/src/server.d.ts +502 -0
  107. package/backend/dist/cjs/backend/src/server.js +1710 -0
  108. package/backend/dist/cjs/backend/src/server.old.d.ts +594 -0
  109. package/backend/dist/cjs/backend/src/server.old.js +2058 -0
  110. package/backend/dist/cjs/backend/src/splash_screen.d.ts +93 -0
  111. package/backend/dist/cjs/backend/src/splash_screen.js +119 -0
  112. package/backend/dist/cjs/backend/src/status.d.ts +89 -0
  113. package/backend/dist/cjs/backend/src/status.js +211 -0
  114. package/backend/dist/cjs/backend/src/stream.d.ts +494 -0
  115. package/backend/dist/cjs/backend/src/stream.js +1370 -0
  116. package/backend/dist/cjs/backend/src/users.d.ts +926 -0
  117. package/backend/dist/cjs/backend/src/users.js +2223 -0
  118. package/backend/dist/cjs/backend/src/utils.d.ts +22 -0
  119. package/backend/dist/cjs/backend/src/utils.js +626 -0
  120. package/backend/dist/cjs/backend/src/view.d.ts +115 -0
  121. package/backend/dist/cjs/backend/src/view.js +519 -0
  122. package/backend/dist/cjs/backend/src/vinc.d.ts +6 -0
  123. package/backend/dist/cjs/backend/src/vinc.js +40 -0
  124. package/backend/dist/cjs/backend/src/volt.d.ts +24 -0
  125. package/backend/dist/cjs/backend/src/volt.js +72 -0
  126. package/backend/dist/cjs/frontend/src/modules/request.d.ts +70 -0
  127. package/backend/dist/cjs/frontend/src/modules/request.js +99 -0
  128. package/backend/dist/cjs/package.json +1 -0
  129. package/backend/dist/esm/backend/src/blacklist.d.ts +12 -0
  130. package/backend/dist/esm/backend/src/blacklist.js +52 -0
  131. package/backend/dist/esm/backend/src/cli.d.ts +2 -0
  132. package/backend/dist/esm/backend/src/cli.js +211 -0
  133. package/backend/dist/esm/backend/src/database/collection.d.ts +1765 -0
  134. package/backend/dist/esm/backend/src/database/collection.js +3779 -0
  135. package/backend/dist/esm/backend/src/database/database.d.ts +92 -0
  136. package/backend/dist/esm/backend/src/database/database.js +214 -0
  137. package/backend/dist/esm/backend/src/database/document.d.ts +1 -0
  138. package/backend/dist/esm/backend/src/database/document.js +558 -0
  139. package/backend/dist/esm/backend/src/database/filters/filters.d.ts +6 -0
  140. package/backend/dist/esm/backend/src/database/filters/filters.js +1 -0
  141. package/backend/dist/esm/backend/src/database/filters/strict_filter.d.ts +223 -0
  142. package/backend/dist/esm/backend/src/database/filters/strict_filter.js +3 -0
  143. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.d.ts +1 -0
  144. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.js +505 -0
  145. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.d.ts +1 -0
  146. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.js +712 -0
  147. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.d.ts +50 -0
  148. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.js +5 -0
  149. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.d.ts +76 -0
  150. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.js +44 -0
  151. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.d.ts +75 -0
  152. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.js +5 -0
  153. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.d.ts +219 -0
  154. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.js +1 -0
  155. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.d.ts +165 -0
  156. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.js +5 -0
  157. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.d.ts +5 -0
  158. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.js +415 -0
  159. package/backend/dist/esm/backend/src/database/flatten.d.ts +78 -0
  160. package/backend/dist/esm/backend/src/database/flatten.js +22 -0
  161. package/backend/dist/esm/backend/src/database/flatten_test.d.ts +1 -0
  162. package/backend/dist/esm/backend/src/database/flatten_test.js +174 -0
  163. package/backend/dist/esm/backend/src/database/quota/quoata_v2.d.ts +533 -0
  164. package/backend/dist/esm/backend/src/database/quota/quoata_v2.js +1155 -0
  165. package/backend/dist/esm/backend/src/database/quota/quota.d.ts +551 -0
  166. package/backend/dist/esm/backend/src/database/quota/quota.js +1219 -0
  167. package/backend/dist/esm/backend/src/database/quota/quota_v1.d.ts +534 -0
  168. package/backend/dist/esm/backend/src/database/quota/quota_v1.js +1242 -0
  169. package/backend/dist/esm/backend/src/database/quota/safe_int.d.ts +412 -0
  170. package/backend/dist/esm/backend/src/database/quota/safe_int.js +810 -0
  171. package/backend/dist/esm/backend/src/endpoint.d.ts +346 -0
  172. package/backend/dist/esm/backend/src/endpoint.js +479 -0
  173. package/backend/dist/esm/backend/src/errors/index.d.ts +7 -0
  174. package/backend/dist/esm/backend/src/errors/index.js +7 -0
  175. package/backend/dist/esm/backend/src/errors/internal_external.d.ts +52 -0
  176. package/backend/dist/esm/backend/src/errors/internal_external.js +86 -0
  177. package/backend/dist/esm/backend/src/errors/invalid_usage_error.d.ts +41 -0
  178. package/backend/dist/esm/backend/src/errors/invalid_usage_error.js +33 -0
  179. package/backend/dist/esm/backend/src/errors/system_error.d.ts +261 -0
  180. package/backend/dist/esm/backend/src/errors/system_error.js +444 -0
  181. package/backend/dist/esm/backend/src/events.d.ts +97 -0
  182. package/backend/dist/esm/backend/src/events.js +5 -0
  183. package/backend/dist/esm/backend/src/frontend.d.ts +13 -0
  184. package/backend/dist/esm/backend/src/frontend.js +23 -0
  185. package/backend/dist/esm/backend/src/image_endpoint.d.ts +44 -0
  186. package/backend/dist/esm/backend/src/image_endpoint.js +196 -0
  187. package/backend/dist/esm/backend/src/index.d.ts +23 -0
  188. package/backend/dist/esm/backend/src/index.js +26 -0
  189. package/backend/dist/esm/backend/src/logger.d.ts +5 -0
  190. package/backend/dist/esm/backend/src/logger.js +8 -0
  191. package/backend/dist/esm/backend/src/meta.d.ts +112 -0
  192. package/backend/dist/esm/backend/src/meta.js +152 -0
  193. package/backend/dist/esm/backend/src/payments/paddle.d.ts +329 -0
  194. package/backend/dist/esm/backend/src/payments/paddle.js +2276 -0
  195. package/backend/dist/esm/backend/src/payments/stripe/checkout.d.ts +113 -0
  196. package/backend/dist/esm/backend/src/payments/stripe/checkout.js +356 -0
  197. package/backend/dist/esm/backend/src/payments/stripe/customers.d.ts +17 -0
  198. package/backend/dist/esm/backend/src/payments/stripe/customers.js +193 -0
  199. package/backend/dist/esm/backend/src/payments/stripe/error.d.ts +74 -0
  200. package/backend/dist/esm/backend/src/payments/stripe/error.js +51 -0
  201. package/backend/dist/esm/backend/src/payments/stripe/events.d.ts +155 -0
  202. package/backend/dist/esm/backend/src/payments/stripe/events.js +5 -0
  203. package/backend/dist/esm/backend/src/payments/stripe/meters.d.ts +105 -0
  204. package/backend/dist/esm/backend/src/payments/stripe/meters.js +318 -0
  205. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.d.ts +58 -0
  206. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.js +135 -0
  207. package/backend/dist/esm/backend/src/payments/stripe/products.d.ts +519 -0
  208. package/backend/dist/esm/backend/src/payments/stripe/products.js +896 -0
  209. package/backend/dist/esm/backend/src/payments/stripe/stripe.d.ts +215 -0
  210. package/backend/dist/esm/backend/src/payments/stripe/stripe.js +464 -0
  211. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.d.ts +172 -0
  212. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.js +754 -0
  213. package/backend/dist/esm/backend/src/payments/stripe/utils.d.ts +63 -0
  214. package/backend/dist/esm/backend/src/payments/stripe/utils.js +131 -0
  215. package/backend/dist/esm/backend/src/payments/stripe/webhooks.d.ts +105 -0
  216. package/backend/dist/esm/backend/src/payments/stripe/webhooks.js +752 -0
  217. package/backend/dist/esm/backend/src/plugins/browser.d.ts +1 -0
  218. package/backend/dist/esm/backend/src/plugins/browser.js +170 -0
  219. package/backend/dist/esm/backend/src/plugins/communication.d.ts +70 -0
  220. package/backend/dist/esm/backend/src/plugins/communication.js +169 -0
  221. package/backend/dist/esm/backend/src/plugins/mail/mail.d.ts +255 -0
  222. package/backend/dist/esm/backend/src/plugins/mail/mail.js +396 -0
  223. package/backend/dist/esm/backend/src/plugins/mail/ui.d.ts +297 -0
  224. package/backend/dist/esm/backend/src/plugins/mail/ui.js +1400 -0
  225. package/backend/dist/esm/backend/src/plugins/pdf.d.ts +1 -0
  226. package/backend/dist/esm/backend/src/plugins/pdf.js +1694 -0
  227. package/backend/dist/esm/backend/src/plugins/thread_monitor.d.ts +18 -0
  228. package/backend/dist/esm/backend/src/plugins/thread_monitor.js +120 -0
  229. package/backend/dist/esm/backend/src/rate_limit.d.ts +148 -0
  230. package/backend/dist/esm/backend/src/rate_limit.js +667 -0
  231. package/backend/dist/esm/backend/src/route.d.ts +39 -0
  232. package/backend/dist/esm/backend/src/route.js +222 -0
  233. package/backend/dist/esm/backend/src/server.d.ts +502 -0
  234. package/backend/dist/esm/backend/src/server.js +2031 -0
  235. package/backend/dist/esm/backend/src/server.old.d.ts +594 -0
  236. package/backend/dist/esm/backend/src/server.old.js +2630 -0
  237. package/backend/dist/esm/backend/src/splash_screen.d.ts +93 -0
  238. package/backend/dist/esm/backend/src/splash_screen.js +156 -0
  239. package/backend/dist/esm/backend/src/status.d.ts +89 -0
  240. package/backend/dist/esm/backend/src/status.js +213 -0
  241. package/backend/dist/esm/backend/src/stream.d.ts +494 -0
  242. package/backend/dist/esm/backend/src/stream.js +1611 -0
  243. package/backend/dist/esm/backend/src/users.d.ts +926 -0
  244. package/backend/dist/esm/backend/src/users.js +2423 -0
  245. package/backend/dist/esm/backend/src/utils.d.ts +22 -0
  246. package/backend/dist/esm/backend/src/utils.js +463 -0
  247. package/backend/dist/esm/backend/src/view.d.ts +115 -0
  248. package/backend/dist/esm/backend/src/view.js +584 -0
  249. package/backend/dist/esm/backend/src/vinc.d.ts +6 -0
  250. package/backend/dist/esm/backend/src/vinc.js +6 -0
  251. package/backend/dist/esm/backend/src/volt.d.ts +24 -0
  252. package/backend/dist/esm/backend/src/volt.js +27 -0
  253. package/backend/dist/esm/frontend/src/modules/request.d.ts +70 -0
  254. package/backend/dist/esm/frontend/src/modules/request.js +117 -0
  255. package/backend/old/file_watcher.ts +359 -0
  256. package/backend/old/request.deprc.js +626 -0
  257. package/backend/old/response.deprc.js +354 -0
  258. package/frontend/dist/backend/src/database/collection.d.ts +1765 -0
  259. package/frontend/dist/backend/src/database/collection.js +3779 -0
  260. package/frontend/dist/backend/src/database/database.d.ts +92 -0
  261. package/frontend/dist/backend/src/database/database.js +214 -0
  262. package/frontend/dist/backend/src/database/filters/filters.d.ts +6 -0
  263. package/frontend/dist/backend/src/database/filters/filters.js +1 -0
  264. package/frontend/dist/backend/src/database/filters/strict_filter.d.ts +223 -0
  265. package/frontend/dist/backend/src/database/filters/strict_filter.js +3 -0
  266. package/frontend/dist/backend/src/database/filters/strict_update_filter.d.ts +165 -0
  267. package/frontend/dist/backend/src/database/filters/strict_update_filter.js +5 -0
  268. package/frontend/dist/backend/src/database/flatten.d.ts +78 -0
  269. package/frontend/dist/backend/src/database/flatten.js +22 -0
  270. package/frontend/dist/backend/src/endpoint.d.ts +346 -0
  271. package/frontend/dist/backend/src/endpoint.js +479 -0
  272. package/frontend/dist/backend/src/errors/index.d.ts +7 -0
  273. package/frontend/dist/backend/src/errors/index.js +7 -0
  274. package/frontend/dist/backend/src/errors/internal_external.d.ts +52 -0
  275. package/frontend/dist/backend/src/errors/internal_external.js +86 -0
  276. package/frontend/dist/backend/src/errors/invalid_usage_error.d.ts +41 -0
  277. package/frontend/dist/backend/src/errors/invalid_usage_error.js +33 -0
  278. package/frontend/dist/backend/src/errors/system_error.d.ts +261 -0
  279. package/frontend/dist/backend/src/errors/system_error.js +444 -0
  280. package/frontend/dist/backend/src/events.d.ts +97 -0
  281. package/frontend/dist/backend/src/events.js +5 -0
  282. package/frontend/dist/backend/src/frontend.d.ts +13 -0
  283. package/frontend/dist/backend/src/frontend.js +23 -0
  284. package/frontend/dist/backend/src/image_endpoint.d.ts +44 -0
  285. package/frontend/dist/backend/src/image_endpoint.js +196 -0
  286. package/frontend/dist/backend/src/meta.d.ts +112 -0
  287. package/frontend/dist/backend/src/meta.js +152 -0
  288. package/frontend/dist/backend/src/payments/paddle.d.ts +329 -0
  289. package/frontend/dist/backend/src/payments/paddle.js +2276 -0
  290. package/frontend/dist/backend/src/payments/stripe/checkout.d.ts +113 -0
  291. package/frontend/dist/backend/src/payments/stripe/checkout.js +356 -0
  292. package/frontend/dist/backend/src/payments/stripe/customers.d.ts +17 -0
  293. package/frontend/dist/backend/src/payments/stripe/customers.js +193 -0
  294. package/frontend/dist/backend/src/payments/stripe/error.d.ts +74 -0
  295. package/frontend/dist/backend/src/payments/stripe/error.js +51 -0
  296. package/frontend/dist/backend/src/payments/stripe/events.d.ts +155 -0
  297. package/frontend/dist/backend/src/payments/stripe/events.js +5 -0
  298. package/frontend/dist/backend/src/payments/stripe/meters.d.ts +105 -0
  299. package/frontend/dist/backend/src/payments/stripe/meters.js +318 -0
  300. package/frontend/dist/backend/src/payments/stripe/payment_methods.d.ts +58 -0
  301. package/frontend/dist/backend/src/payments/stripe/payment_methods.js +135 -0
  302. package/frontend/dist/backend/src/payments/stripe/products.d.ts +519 -0
  303. package/frontend/dist/backend/src/payments/stripe/products.js +896 -0
  304. package/frontend/dist/backend/src/payments/stripe/stripe.d.ts +215 -0
  305. package/frontend/dist/backend/src/payments/stripe/stripe.js +464 -0
  306. package/frontend/dist/backend/src/payments/stripe/subscriptions.d.ts +172 -0
  307. package/frontend/dist/backend/src/payments/stripe/subscriptions.js +754 -0
  308. package/frontend/dist/backend/src/payments/stripe/utils.d.ts +63 -0
  309. package/frontend/dist/backend/src/payments/stripe/utils.js +131 -0
  310. package/frontend/dist/backend/src/payments/stripe/webhooks.d.ts +105 -0
  311. package/frontend/dist/backend/src/payments/stripe/webhooks.js +752 -0
  312. package/frontend/dist/backend/src/plugins/mail/mail.d.ts +255 -0
  313. package/frontend/dist/backend/src/plugins/mail/mail.js +396 -0
  314. package/frontend/dist/backend/src/plugins/mail/ui.d.ts +297 -0
  315. package/frontend/dist/backend/src/plugins/mail/ui.js +1400 -0
  316. package/frontend/dist/backend/src/rate_limit.d.ts +148 -0
  317. package/frontend/dist/backend/src/rate_limit.js +667 -0
  318. package/frontend/dist/backend/src/route.d.ts +39 -0
  319. package/frontend/dist/backend/src/route.js +222 -0
  320. package/frontend/dist/backend/src/server.d.ts +502 -0
  321. package/frontend/dist/backend/src/server.js +2031 -0
  322. package/frontend/dist/backend/src/splash_screen.d.ts +93 -0
  323. package/frontend/dist/backend/src/splash_screen.js +156 -0
  324. package/frontend/dist/backend/src/status.d.ts +89 -0
  325. package/frontend/dist/backend/src/status.js +213 -0
  326. package/frontend/dist/backend/src/stream.d.ts +494 -0
  327. package/frontend/dist/backend/src/stream.js +1611 -0
  328. package/frontend/dist/backend/src/users.d.ts +926 -0
  329. package/frontend/dist/backend/src/users.js +2423 -0
  330. package/frontend/dist/backend/src/utils.d.ts +22 -0
  331. package/frontend/dist/backend/src/utils.js +463 -0
  332. package/frontend/dist/backend/src/view.d.ts +115 -0
  333. package/frontend/dist/backend/src/view.js +584 -0
  334. package/frontend/dist/frontend/src/css/adyen.css +92 -0
  335. package/frontend/dist/frontend/src/css/volt.css +75 -0
  336. package/frontend/dist/frontend/src/elements/base.d.ts +3743 -0
  337. package/frontend/dist/frontend/src/elements/base.js +12151 -0
  338. package/frontend/dist/frontend/src/elements/module.d.ts +95 -0
  339. package/frontend/dist/frontend/src/elements/module.js +216 -0
  340. package/frontend/dist/frontend/src/elements/register_element.d.ts +3 -0
  341. package/frontend/dist/frontend/src/elements/register_element.js +22 -0
  342. package/frontend/dist/frontend/src/elements/resize_query_manager.d.ts +0 -0
  343. package/frontend/dist/frontend/src/elements/resize_query_manager.js +150 -0
  344. package/frontend/dist/frontend/src/elements/types.d.ts +52 -0
  345. package/frontend/dist/frontend/src/elements/types.js +5 -0
  346. package/frontend/dist/frontend/src/index.d.ts +21 -0
  347. package/frontend/dist/frontend/src/index.js +29 -0
  348. package/frontend/dist/frontend/src/modules/attachment.d.ts +126 -0
  349. package/frontend/dist/frontend/src/modules/attachment.js +306 -0
  350. package/frontend/dist/frontend/src/modules/auth.d.ts +44 -0
  351. package/frontend/dist/frontend/src/modules/auth.js +80 -0
  352. package/frontend/dist/frontend/src/modules/color.d.ts +160 -0
  353. package/frontend/dist/frontend/src/modules/color.js +316 -0
  354. package/frontend/dist/frontend/src/modules/compression.d.ts +39 -0
  355. package/frontend/dist/frontend/src/modules/compression.js +102 -0
  356. package/frontend/dist/frontend/src/modules/cookies.d.ts +44 -0
  357. package/frontend/dist/frontend/src/modules/cookies.js +143 -0
  358. package/frontend/dist/frontend/src/modules/events.d.ts +31 -0
  359. package/frontend/dist/frontend/src/modules/events.js +79 -0
  360. package/frontend/dist/frontend/src/modules/google.d.ts +23 -0
  361. package/frontend/dist/frontend/src/modules/google.js +52 -0
  362. package/frontend/dist/frontend/src/modules/meta.d.ts +14 -0
  363. package/frontend/dist/frontend/src/modules/meta.js +48 -0
  364. package/frontend/dist/frontend/src/modules/paddle.d.ts +1207 -0
  365. package/frontend/dist/frontend/src/modules/paddle.js +2594 -0
  366. package/frontend/dist/frontend/src/modules/request.d.ts +70 -0
  367. package/frontend/dist/frontend/src/modules/request.js +117 -0
  368. package/frontend/dist/frontend/src/modules/settings.d.ts +3 -0
  369. package/frontend/dist/frontend/src/modules/settings.js +5 -0
  370. package/frontend/dist/frontend/src/modules/statics.d.ts +21 -0
  371. package/frontend/dist/frontend/src/modules/statics.js +43 -0
  372. package/frontend/dist/frontend/src/modules/stripe/cart.d.ts +112 -0
  373. package/frontend/dist/frontend/src/modules/stripe/cart.js +321 -0
  374. package/frontend/dist/frontend/src/modules/stripe/checkout.d.ts +7 -0
  375. package/frontend/dist/frontend/src/modules/stripe/checkout.js +37 -0
  376. package/frontend/dist/frontend/src/modules/stripe/index.m.d.ts +6 -0
  377. package/frontend/dist/frontend/src/modules/stripe/index.m.js +6 -0
  378. package/frontend/dist/frontend/src/modules/stripe/payments.d.ts +58 -0
  379. package/frontend/dist/frontend/src/modules/stripe/payments.js +92 -0
  380. package/frontend/dist/frontend/src/modules/support.d.ts +30 -0
  381. package/frontend/dist/frontend/src/modules/support.js +53 -0
  382. package/frontend/dist/frontend/src/modules/theme.d.ts +133 -0
  383. package/frontend/dist/frontend/src/modules/theme.js +406 -0
  384. package/frontend/dist/frontend/src/modules/themes.d.ts +12 -0
  385. package/frontend/dist/frontend/src/modules/themes.js +22 -0
  386. package/frontend/dist/frontend/src/modules/user.d.ts +164 -0
  387. package/frontend/dist/frontend/src/modules/user.js +270 -0
  388. package/frontend/dist/frontend/src/modules/utils.d.ts +176 -0
  389. package/frontend/dist/frontend/src/modules/utils.js +569 -0
  390. package/frontend/dist/frontend/src/types/gradient.d.ts +29 -0
  391. package/frontend/dist/frontend/src/types/gradient.js +79 -0
  392. package/frontend/dist/frontend/src/ui/border_button.d.ts +94 -0
  393. package/frontend/dist/frontend/src/ui/border_button.js +228 -0
  394. package/frontend/dist/frontend/src/ui/button.d.ts +241 -0
  395. package/frontend/dist/frontend/src/ui/button.js +682 -0
  396. package/frontend/dist/frontend/src/ui/canvas.d.ts +138 -0
  397. package/frontend/dist/frontend/src/ui/canvas.js +444 -0
  398. package/frontend/dist/frontend/src/ui/checkbox.d.ts +74 -0
  399. package/frontend/dist/frontend/src/ui/checkbox.js +321 -0
  400. package/frontend/dist/frontend/src/ui/code.d.ts +235 -0
  401. package/frontend/dist/frontend/src/ui/code.js +1007 -0
  402. package/frontend/dist/frontend/src/ui/context_menu.d.ts +36 -0
  403. package/frontend/dist/frontend/src/ui/context_menu.js +205 -0
  404. package/frontend/dist/frontend/src/ui/css.d.ts +16 -0
  405. package/frontend/dist/frontend/src/ui/css.js +48 -0
  406. package/frontend/dist/frontend/src/ui/divider.d.ts +15 -0
  407. package/frontend/dist/frontend/src/ui/divider.js +78 -0
  408. package/frontend/dist/frontend/src/ui/dropdown.d.ts +176 -0
  409. package/frontend/dist/frontend/src/ui/dropdown.js +481 -0
  410. package/frontend/dist/frontend/src/ui/for_each.d.ts +37 -0
  411. package/frontend/dist/frontend/src/ui/for_each.js +92 -0
  412. package/frontend/dist/frontend/src/ui/form.d.ts +34 -0
  413. package/frontend/dist/frontend/src/ui/form.js +233 -0
  414. package/frontend/dist/frontend/src/ui/frame_modes.d.ts +37 -0
  415. package/frontend/dist/frontend/src/ui/frame_modes.js +108 -0
  416. package/frontend/dist/frontend/src/ui/google_map.d.ts +24 -0
  417. package/frontend/dist/frontend/src/ui/google_map.js +106 -0
  418. package/frontend/dist/frontend/src/ui/gradient.d.ts +25 -0
  419. package/frontend/dist/frontend/src/ui/gradient.js +131 -0
  420. package/frontend/dist/frontend/src/ui/image.d.ts +111 -0
  421. package/frontend/dist/frontend/src/ui/image.js +576 -0
  422. package/frontend/dist/frontend/src/ui/input.d.ts +392 -0
  423. package/frontend/dist/frontend/src/ui/input.js +1201 -0
  424. package/frontend/dist/frontend/src/ui/link.d.ts +25 -0
  425. package/frontend/dist/frontend/src/ui/link.js +140 -0
  426. package/frontend/dist/frontend/src/ui/list.d.ts +37 -0
  427. package/frontend/dist/frontend/src/ui/list.js +170 -0
  428. package/frontend/dist/frontend/src/ui/loader_button.d.ts +80 -0
  429. package/frontend/dist/frontend/src/ui/loader_button.js +193 -0
  430. package/frontend/dist/frontend/src/ui/loaders.d.ts +57 -0
  431. package/frontend/dist/frontend/src/ui/loaders.js +157 -0
  432. package/frontend/dist/frontend/src/ui/popup.d.ts +94 -0
  433. package/frontend/dist/frontend/src/ui/popup.js +510 -0
  434. package/frontend/dist/frontend/src/ui/pseudo.d.ts +44 -0
  435. package/frontend/dist/frontend/src/ui/pseudo.js +154 -0
  436. package/frontend/dist/frontend/src/ui/scroller.d.ts +105 -0
  437. package/frontend/dist/frontend/src/ui/scroller.js +1253 -0
  438. package/frontend/dist/frontend/src/ui/slider.d.ts +45 -0
  439. package/frontend/dist/frontend/src/ui/slider.js +217 -0
  440. package/frontend/dist/frontend/src/ui/spacer.d.ts +15 -0
  441. package/frontend/dist/frontend/src/ui/spacer.js +78 -0
  442. package/frontend/dist/frontend/src/ui/span.d.ts +15 -0
  443. package/frontend/dist/frontend/src/ui/span.js +73 -0
  444. package/frontend/dist/frontend/src/ui/stack.d.ts +66 -0
  445. package/frontend/dist/frontend/src/ui/stack.js +335 -0
  446. package/frontend/dist/frontend/src/ui/steps.d.ts +131 -0
  447. package/frontend/dist/frontend/src/ui/steps.js +308 -0
  448. package/frontend/dist/frontend/src/ui/style.d.ts +17 -0
  449. package/frontend/dist/frontend/src/ui/style.js +73 -0
  450. package/frontend/dist/frontend/src/ui/switch.d.ts +69 -0
  451. package/frontend/dist/frontend/src/ui/switch.js +357 -0
  452. package/frontend/dist/frontend/src/ui/table.d.ts +100 -0
  453. package/frontend/dist/frontend/src/ui/table.js +405 -0
  454. package/frontend/dist/frontend/src/ui/tabs.d.ts +111 -0
  455. package/frontend/dist/frontend/src/ui/tabs.js +424 -0
  456. package/frontend/dist/frontend/src/ui/text.d.ts +15 -0
  457. package/frontend/dist/frontend/src/ui/text.js +83 -0
  458. package/frontend/dist/frontend/src/ui/title.d.ts +91 -0
  459. package/frontend/dist/frontend/src/ui/title.js +272 -0
  460. package/frontend/dist/frontend/src/ui/ui.d.ts +35 -0
  461. package/frontend/dist/frontend/src/ui/ui.js +38 -0
  462. package/frontend/dist/frontend/src/ui/view.d.ts +15 -0
  463. package/frontend/dist/frontend/src/ui/view.js +88 -0
  464. package/frontend/dist/frontend/src/volt.d.ts +20 -0
  465. package/frontend/dist/frontend/src/volt.js +27 -0
  466. package/frontend/examples/theme/theme.ts +58 -0
  467. package/frontend/tools/bundle_d_ts.js +71 -0
  468. package/frontend/tools/convert_to_jsdoc_input.txt +9452 -0
  469. package/frontend/tools/convert_to_jsdoc_output.txt +7626 -0
  470. package/frontend/tools/convert_to_jsdoc_tmp.js +345 -0
  471. package/frontend/tools/scan_mixed_imports.js +69 -0
  472. package/package.json +1 -5
@@ -0,0 +1,1108 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var stdin_exports = {};
19
+ __export(stdin_exports, {
20
+ QuotaManager: () => QuotaManager
21
+ });
22
+ module.exports = __toCommonJS(stdin_exports);
23
+ var import_system_error = require("../../errors/system_error.js");
24
+ var import_collection = require("../collection.js");
25
+ var import_errors = require("../../errors/index.js");
26
+ var import_safe_int = require("./safe_int.js");
27
+ class QuotaManager {
28
+ // ----------------------------------------------------------------
29
+ // Attributes
30
+ // ----------------------------------------------------------------
31
+ /** The collection for database operations. */
32
+ collection;
33
+ /** The system error options. */
34
+ system_error;
35
+ /**
36
+ * Construct a new quota manager with a specific quota type.
37
+ *
38
+ * @throws {InvalidUsageError} If {@link QuotaManager.Opts.collection} is already initialized and does not have the correct index.
39
+ * If the passed collection has manually assigned fields for {@link Collection.record_version} or {@link Collection.on_transform_version}.
40
+ * If the passed collection is transaction based.
41
+ *
42
+ * @docs
43
+ */
44
+ constructor(opts) {
45
+ this.collection = opts.server.db.collection({
46
+ name: opts.collection.name,
47
+ ttl: opts.collection.ttl,
48
+ indexes: [
49
+ { key: "id", unique: true, forced: true },
50
+ { key: "uid", forced: true }
51
+ ],
52
+ unique: true,
53
+ persist_transformed_on_load: "replace",
54
+ record_version: 1
55
+ // on_transform_version() {}
56
+ });
57
+ this.system_error = opts.system_error;
58
+ }
59
+ // ----------------------------------------------------------------
60
+ // Private utility methods.
61
+ // ----------------------------------------------------------------
62
+ /**
63
+ * Helper to create consistent query objects for MongoDB.
64
+ */
65
+ create_db_query(query) {
66
+ return { uid: query.uid, id: query.id };
67
+ }
68
+ /**
69
+ * Format a compact, human-readable quota identifier for logs and error messages.
70
+ *
71
+ * @param query An object carrying the `uid` and `id` fields.
72
+ * @returns A stable identifier of the form `<uid>:<id>`.
73
+ */
74
+ format_quota_id(query) {
75
+ return `${query.uid}:${query.id}`;
76
+ }
77
+ /**
78
+ * Clamp a bigint to a minimum of 0n.
79
+ */
80
+ static clamp_min0(v) {
81
+ return v > 0n ? v : 0n;
82
+ }
83
+ /**
84
+ * Compute remaining capacity, clamped to [0, +inf).
85
+ */
86
+ static remaining(max, usage) {
87
+ return max > usage ? max - usage : 0n;
88
+ }
89
+ /**
90
+ * Compute percentage used in [0, 100] (2 decimals), based on bigint usage/max.
91
+ */
92
+ static percentage_used(usage, max) {
93
+ if (max > 0n) {
94
+ const scaled = usage * 10000n / max;
95
+ const capped = scaled < 0n ? 0n : scaled > 10000n ? 10000n : scaled;
96
+ return Number(capped) / 100;
97
+ }
98
+ return usage > 0n ? 100 : 0;
99
+ }
100
+ /**
101
+ * Multiply a bigint by a floating ratio, returning a bigint.
102
+ * - For positive values, rounds up (ceil) to avoid underestimation.
103
+ * - For negative values, rounds down (floor).
104
+ */
105
+ static mul_bigint_ratio(value, ratio) {
106
+ if (ratio === 1)
107
+ return value;
108
+ if (!Number.isFinite(ratio)) {
109
+ throw new Error(`Invalid ratio: ${ratio}`);
110
+ }
111
+ if (ratio <= 0)
112
+ throw new Error(`Invalid ratio: ${ratio}. Must be > 0.`);
113
+ if (Number.isInteger(ratio)) {
114
+ if (!Number.isSafeInteger(ratio)) {
115
+ throw new Error(`Invalid ratio: ${ratio}. Integer ratio must be a safe integer.`);
116
+ }
117
+ return value * BigInt(ratio);
118
+ }
119
+ const SCALE_NUM = 1e9;
120
+ const SCALE = 1000000000n;
121
+ const scaled_float = ratio * SCALE_NUM;
122
+ if (!Number.isFinite(scaled_float) || Math.abs(scaled_float) > Number.MAX_SAFE_INTEGER) {
123
+ throw new Error(`Invalid ratio: ${ratio}. Too large for fixed-point scaling at 1e9 precision.`);
124
+ }
125
+ const scaled_int = Math.round(scaled_float);
126
+ if (!Number.isSafeInteger(scaled_int)) {
127
+ throw new Error(`Invalid ratio scaling: ratio=${ratio}, scaled=${scaled_int}.`);
128
+ }
129
+ const scaled_ratio = BigInt(scaled_int);
130
+ const product = value * scaled_ratio;
131
+ let q = product / SCALE;
132
+ const r = product % SCALE;
133
+ if (r !== 0n) {
134
+ if (value > 0n) {
135
+ q += 1n;
136
+ } else if (value < 0n) {
137
+ q -= 1n;
138
+ }
139
+ }
140
+ return q;
141
+ }
142
+ // ----------------------------------------------------------------
143
+ // Database operation methods.
144
+ // ----------------------------------------------------------------
145
+ /**
146
+ * Get current quota status without modifying it.
147
+ *
148
+ * @note The `opts.retry` field defaults to `25`.
149
+ * @note System load errors are not saved inside this function.
150
+ *
151
+ * @param query The quota identifier arguments.
152
+ * @param opts Additional load options.
153
+ *
154
+ * @returns A load result depending on `opts`, see {@link Collection.LoadResult}
155
+ *
156
+ * @throws {Collection.NotFoundError} When `opts.throw !== false` and the quota does not exist.
157
+ * @throws {Collection.LoadError} When `opts.throw !== false` and a database error was encountered during the load operation.
158
+ * @throws {Collection.InvalidUsageError} When `opts.throw !== false` and the query is invalid.
159
+ *
160
+ * @docs
161
+ */
162
+ async get(query, opts) {
163
+ const val_err = QuotaManager.Query.validate(query);
164
+ if (val_err) {
165
+ const err = new import_errors.InvalidUsageError({
166
+ message: `Invalid quota: ${val_err}`,
167
+ reason: "invalid_quota",
168
+ field: "quota"
169
+ });
170
+ if (opts?.throw ?? true)
171
+ throw err;
172
+ return err;
173
+ }
174
+ if (opts) {
175
+ opts = { retry: 25, ...opts };
176
+ return this.collection.load(this.create_db_query(query), opts);
177
+ } else {
178
+ return this.collection.load(this.create_db_query(query), { retry: 25 });
179
+ }
180
+ }
181
+ /**
182
+ * Get current quota status without modifying it.
183
+ *
184
+ * @param query The quota identifier arguments.
185
+ * @param opts Additional load options, see {@link Collection.LoadOpts}.
186
+ *
187
+ * @returns An object containing error or status information,
188
+ * see {@link QuotaManager.GetStatusResult}
189
+ *
190
+ * @docs
191
+ */
192
+ async get_status(query, opts) {
193
+ const now_sec = Math.floor(Date.now() / 1e3);
194
+ const db_query = this.create_db_query(query);
195
+ const val_err = QuotaManager.Query.validate(query);
196
+ if (val_err) {
197
+ return {
198
+ found: false,
199
+ reason: "invalid_query",
200
+ error: `Invalid query: ${val_err}`
201
+ };
202
+ }
203
+ const loaded_quota = await this.collection.load(db_query, { retry: 25, throw: false, timeout: opts?.timeout });
204
+ if (loaded_quota instanceof import_collection.Collection.NotFoundError) {
205
+ return {
206
+ found: false,
207
+ reason: "not_found",
208
+ error: `Quota not found: ${this.format_quota_id(query)} for user ${query.uid}`
209
+ };
210
+ }
211
+ if (loaded_quota instanceof Error) {
212
+ import_system_error.SystemError.create_detach({
213
+ owner: "volt.QuotaManager",
214
+ collection: this.system_error?.collection,
215
+ logger: this.system_error?.logger,
216
+ message: "Failed to load quota in get_status().",
217
+ details: {
218
+ quota_id: this.format_quota_id(query),
219
+ uid: query.uid,
220
+ original_error: loaded_quota?.message ?? String(loaded_quota)
221
+ }
222
+ });
223
+ return {
224
+ found: false,
225
+ reason: "system_error",
226
+ error: `Encountered an unknown error while loading quota: ${this.format_quota_id(query)} for user ${query.uid}.`
227
+ };
228
+ }
229
+ const needs_reset = now_sec >= loaded_quota.start + loaded_quota.interval;
230
+ const effective_usage = needs_reset ? 0n : loaded_quota.usage;
231
+ const time_until_reset = needs_reset ? 0 : Math.max(0, loaded_quota.start + loaded_quota.interval - now_sec);
232
+ const remaining = QuotaManager.remaining(loaded_quota.max, effective_usage);
233
+ const percentage_used = QuotaManager.percentage_used(effective_usage, loaded_quota.max);
234
+ return {
235
+ found: true,
236
+ quota: needs_reset ? { ...loaded_quota, usage: 0n, start: now_sec } : loaded_quota,
237
+ remaining,
238
+ percentage_used,
239
+ needs_reset,
240
+ time_until_reset
241
+ };
242
+ }
243
+ /**
244
+ * List all quotas for a user, optionally filtered by type.
245
+ *
246
+ * @param uid The user identifier.
247
+ * @param type Optional quota type filter.
248
+ * @returns List of quotas with their current status.
249
+ *
250
+ * @docs
251
+ */
252
+ async list({ uid, timeout }) {
253
+ const now_sec = Math.floor(Date.now() / 1e3);
254
+ const listed = [];
255
+ await this.collection.list({ uid }, {
256
+ timeout,
257
+ retry: 5,
258
+ callback: (q) => {
259
+ const needs_reset = now_sec >= q.start + q.interval;
260
+ const effective_usage = needs_reset ? 0n : q.usage;
261
+ const percentage_used = QuotaManager.percentage_used(effective_usage, q.max);
262
+ listed.push({
263
+ quota: needs_reset ? { ...q, usage: 0n, start: now_sec } : q,
264
+ remaining: QuotaManager.remaining(q.max, effective_usage),
265
+ percentage_used,
266
+ needs_reset
267
+ });
268
+ }
269
+ });
270
+ return listed;
271
+ }
272
+ /**
273
+ * Update or save quota configuration (`max`, `interval`) for an existing quota document,
274
+ * automatically creating the document if it does not exist.
275
+ *
276
+ * This method never resets runtime fields on existing documents:
277
+ * - On update: only `max` and `interval` are changed.
278
+ * - On insert: `usage` is initialized to `0` and `start` to the current UNIX timestamp (seconds).
279
+ *
280
+ * @param quota The configuration document (identity + {@link Quota.Opts}). Fields `usage` and `start`
281
+ * are forbidden at the type level and ignored defensively at runtime.
282
+ * @param opts Additional save options; see {@link Collection.SaveOpts}.
283
+ *
284
+ * @note The `opts.throw` field defaults to `true`.
285
+ *
286
+ * @returns The updated (or newly created) quota document, or an error-like result depending on `opts.throw`.
287
+ * See {@link Collection.SaveResult}.
288
+ *
289
+ * @throws {InvalidUsageError} When `opts.throw !== false` and validation fails.
290
+ * @throws {Collection.SaveError} When `opts.throw !== false` and a database error occurs during the save operation.
291
+ *
292
+ * @docs
293
+ */
294
+ async set(quota, opts) {
295
+ const val_err = QuotaManager.Document.Opts.validate(quota, this.collection);
296
+ if (val_err) {
297
+ const err = new import_errors.InvalidUsageError({
298
+ message: `Invalid quota: ${val_err}`,
299
+ reason: "invalid_quota",
300
+ field: "quota"
301
+ });
302
+ if (opts?.throw ?? true)
303
+ throw err;
304
+ return err;
305
+ }
306
+ const now_sec = Math.floor(Date.now() / 1e3);
307
+ const save_opts = {
308
+ return: true,
309
+ upsert: true,
310
+ retry: 25,
311
+ throw: opts?.throw ?? true,
312
+ timeout: opts?.timeout
313
+ };
314
+ return await this.collection.save(this.create_db_query(quota), {
315
+ $set: {
316
+ max: quota.max,
317
+ interval: quota.interval
318
+ },
319
+ $setOnInsert: {
320
+ usage: 0n,
321
+ start: now_sec
322
+ }
323
+ }, save_opts);
324
+ }
325
+ /**
326
+ * Reset quota usage to zero & timestamp to the current unix timestamp for the specified quota.
327
+ *
328
+ * @param query The quota identifier, see {@link QuotaManager.Query}.
329
+ * @param opts Additional save options, see {@link Collection.SaveOpts}
330
+ *
331
+ * @note The `opts.throw` field defaults to the default value of {@link Collection.SaveOpts.throw}.
332
+ *
333
+ * @returns The updated quota document after resetting quota or an error depending on `throw`.
334
+ * See {@link Collection.SaveResult}.
335
+ *
336
+ * @throws {Collection.NotFoundError} When `opts.throw !== false` and the quota does not exist.
337
+ * @throws {Collection.SaveError} When `opts.throw !== false` and a database error was encountered during the save operation.
338
+ * @throws {Collection.InvalidUsageError} When `opts.throw !== false` and the query is invalid.
339
+ *
340
+ * @docs
341
+ */
342
+ async reset_usage(query, opts) {
343
+ const query_err = QuotaManager.Query.validate(query);
344
+ if (query_err) {
345
+ const err = new import_errors.InvalidUsageError({
346
+ message: `Invalid quota query: ${query_err}`,
347
+ reason: "invalid_query",
348
+ field: "query"
349
+ });
350
+ if (opts?.throw ?? true)
351
+ throw err;
352
+ return err;
353
+ }
354
+ const save_opts = {
355
+ return: true,
356
+ upsert: false,
357
+ retry: 25,
358
+ throw: opts?.throw,
359
+ timeout: opts?.timeout
360
+ };
361
+ return await this.collection.save(this.create_db_query(query), {
362
+ $set: {
363
+ usage: 0n,
364
+ start: Math.floor(Date.now() / 1e3)
365
+ }
366
+ }, save_opts);
367
+ }
368
+ /**
369
+ * Delete all quotas for a user.
370
+ *
371
+ * @docs
372
+ */
373
+ async delete_by_user({ uid }) {
374
+ await this.collection.delete_many({ uid }, { retry: 25 });
375
+ }
376
+ // ----------------------------------------------------------------
377
+ // Quota limiting.
378
+ // ----------------------------------------------------------------
379
+ /**
380
+ * Validate the required {@link limit_helper} parameters.
381
+ * @note Parameter `requested_usage` may be a negative number.
382
+ *
383
+ * @docs
384
+ */
385
+ validate_limit_helper_params({ requested_usage, safety_ratio, query, upsert }) {
386
+ if (safety_ratio !== void 0) {
387
+ if (!Number.isFinite(safety_ratio) || safety_ratio < 1) {
388
+ return {
389
+ success: false,
390
+ status: "invalid_usage",
391
+ error: `Invalid 'safety_ratio' value: ${safety_ratio}. Must be finite and >= 1.`
392
+ };
393
+ }
394
+ const SCALE_NUM = 1e9;
395
+ const scaled = safety_ratio * SCALE_NUM;
396
+ if (!Number.isFinite(scaled) || Math.abs(scaled) > Number.MAX_SAFE_INTEGER) {
397
+ return {
398
+ success: false,
399
+ status: "invalid_usage",
400
+ error: `Invalid 'safety_ratio' value: ${safety_ratio}. Too large for safe fixed-point scaling.`
401
+ };
402
+ }
403
+ }
404
+ const val_err = QuotaManager.Query.validate(query);
405
+ if (val_err) {
406
+ return {
407
+ success: false,
408
+ status: "invalid_usage",
409
+ error: `Invalid quota query: ${val_err}`
410
+ };
411
+ }
412
+ if (upsert) {
413
+ const record = {
414
+ ...upsert,
415
+ ...query
416
+ };
417
+ const val_err2 = QuotaManager.Document.Opts.validate(record, this.collection);
418
+ if (val_err2) {
419
+ return {
420
+ success: false,
421
+ status: "invalid_usage",
422
+ error: `Invalid quota upsert: ${val_err2}`
423
+ };
424
+ }
425
+ }
426
+ }
427
+ /**
428
+ * Validates quota limits and atomically increments usage if within bounds.
429
+ * Handles interval resets automatically in a single database operation.
430
+ *
431
+ * @warning Ensure the quota exists in the database, or define `upsert` to create it when needed.
432
+ *
433
+ * @note This automatically increments the quota usage with the requested usage when `perform_increment` is true.
434
+ * When `perform_increment` is false, it only validates availability without modifying the database.
435
+ *
436
+ * @returns Success with updated quota info or validation/error details.
437
+ *
438
+ * @docs
439
+ *
440
+ */
441
+ async limit_helper({ query, requested_usage, upsert, safety_ratio = 1, check_limit = true, perform_increment = true, collection }) {
442
+ const val_input_res = this.validate_limit_helper_params({
443
+ requested_usage,
444
+ safety_ratio,
445
+ upsert,
446
+ query
447
+ });
448
+ if (val_input_res)
449
+ return val_input_res;
450
+ const safety_usage = QuotaManager.mul_bigint_ratio(requested_usage, safety_ratio);
451
+ const now_sec = Math.floor(Date.now() / 1e3);
452
+ const db_query = this.create_db_query(query);
453
+ if (check_limit) {
454
+ if (perform_increment) {
455
+ const result = await collection.save({
456
+ ...db_query,
457
+ $expr: {
458
+ $and: [
459
+ { $lt: [now_sec, { $add: ["$start", "$interval"] }] },
460
+ { $lte: [{ $add: ["$usage", requested_usage] }, "$max"] },
461
+ { $lte: [{ $add: ["$usage", safety_usage] }, "$max"] },
462
+ { $gte: [{ $add: ["$usage", requested_usage] }, 0n] }
463
+ ]
464
+ }
465
+ }, { $inc: { usage: requested_usage } }, { return: true, upsert: false, retry: 25, throw: false });
466
+ if (!(result instanceof Error)) {
467
+ return {
468
+ success: true,
469
+ status: "success",
470
+ quota: result,
471
+ remaining: QuotaManager.remaining(result.max, result.usage),
472
+ was_reset: false
473
+ };
474
+ }
475
+ } else {
476
+ const result = await collection.load({
477
+ ...db_query,
478
+ $expr: {
479
+ $and: [
480
+ { $lt: [now_sec, { $add: ["$start", "$interval"] }] },
481
+ { $lte: [{ $add: ["$usage", requested_usage] }, "$max"] },
482
+ { $lte: [{ $add: ["$usage", safety_usage] }, "$max"] },
483
+ { $gte: [{ $add: ["$usage", requested_usage] }, 0n] }
484
+ ]
485
+ }
486
+ }, { retry: 25, throw: false });
487
+ if (!(result instanceof Error)) {
488
+ return {
489
+ success: true,
490
+ status: "success",
491
+ quota: result,
492
+ remaining: QuotaManager.remaining(result.max, result.usage),
493
+ was_reset: false
494
+ };
495
+ }
496
+ }
497
+ } else {
498
+ if (perform_increment) {
499
+ const result = await collection.save({
500
+ ...db_query,
501
+ $expr: {
502
+ $and: [
503
+ { $lt: [now_sec, { $add: ["$start", "$interval"] }] },
504
+ { $gte: [{ $add: ["$usage", requested_usage] }, 0n] }
505
+ ]
506
+ }
507
+ }, { $inc: { usage: requested_usage } }, { return: true, upsert: false, throw: false, retry: 25 });
508
+ if (!(result instanceof Error)) {
509
+ return {
510
+ success: true,
511
+ status: "success",
512
+ quota: result,
513
+ remaining: QuotaManager.remaining(result.max, result.usage),
514
+ was_reset: false
515
+ };
516
+ }
517
+ }
518
+ }
519
+ let current = await collection.load(db_query, { retry: 25, throw: false });
520
+ if (current instanceof Error) {
521
+ if (!(current instanceof import_collection.Collection.NotFoundError)) {
522
+ import_system_error.SystemError.create_detach({
523
+ owner: "volt.QuotaManager",
524
+ collection: this.system_error?.collection,
525
+ logger: this.system_error?.logger,
526
+ message: `Encountered an unknown error while loading quota '${this.format_quota_id(query)}' for user '${query.uid}'`,
527
+ details: {
528
+ query,
529
+ requested_usage,
530
+ upsert,
531
+ safety_ratio,
532
+ check_limit,
533
+ perform_increment,
534
+ is_transaction: collection instanceof import_collection.TransactionCollection,
535
+ original_error: current?.message ?? String(current)
536
+ }
537
+ });
538
+ return {
539
+ success: false,
540
+ status: "system_error",
541
+ error: `Encountered an unknown error while loading quota '${this.format_quota_id(query)}' for user '${query.uid}'`
542
+ };
543
+ }
544
+ if (!upsert) {
545
+ return {
546
+ success: false,
547
+ status: "not_found",
548
+ error: `Quota not found '${this.format_quota_id(query)}' for user '${query.uid}'`
549
+ };
550
+ }
551
+ if (!perform_increment) {
552
+ const would_exceed_actual = requested_usage > upsert.max;
553
+ const would_exceed_ratio = safety_usage > upsert.max;
554
+ if (check_limit && (would_exceed_actual || would_exceed_ratio)) {
555
+ return {
556
+ success: false,
557
+ status: "would_exceed",
558
+ error: `Requested usage (${requested_usage}, safety=${safety_usage}) exceeds fresh-window maximum (${upsert.max}).`,
559
+ remaining: upsert.max
560
+ };
561
+ }
562
+ const virtual_doc = {
563
+ uid: query.uid,
564
+ id: query.id,
565
+ max: upsert.max,
566
+ interval: upsert.interval,
567
+ start: now_sec,
568
+ usage: QuotaManager.clamp_min0(requested_usage)
569
+ };
570
+ return {
571
+ success: true,
572
+ status: "success",
573
+ quota: virtual_doc,
574
+ remaining: QuotaManager.remaining(virtual_doc.max, virtual_doc.usage),
575
+ was_reset: false
576
+ };
577
+ }
578
+ const doc_record = {
579
+ uid: query.uid,
580
+ id: query.id,
581
+ max: upsert.max,
582
+ interval: upsert.interval,
583
+ start: now_sec,
584
+ usage: QuotaManager.clamp_min0(requested_usage)
585
+ };
586
+ const created = await collection.set(db_query, doc_record, { return: true, upsert: true, throw: false, retry: 25 });
587
+ if (created instanceof Error) {
588
+ import_system_error.SystemError.create_detach({
589
+ owner: "volt.QuotaManager",
590
+ collection: this.system_error?.collection,
591
+ logger: this.system_error?.logger,
592
+ message: `Failed to create quota '${this.format_quota_id(query)}' for user '${query.uid}'`,
593
+ details: {
594
+ query,
595
+ requested_usage,
596
+ upsert,
597
+ safety_ratio,
598
+ check_limit,
599
+ perform_increment,
600
+ is_transaction: collection instanceof import_collection.TransactionCollection,
601
+ original_error: created?.message ?? String(created)
602
+ }
603
+ });
604
+ return {
605
+ success: false,
606
+ status: "system_error",
607
+ error: `Failed to create quota '${this.format_quota_id(query)}' for user '${query.uid}'`
608
+ };
609
+ }
610
+ current = created;
611
+ }
612
+ const interval_expired = now_sec >= current.start + current.interval;
613
+ if (interval_expired) {
614
+ if (check_limit) {
615
+ const would_exceed_actual = requested_usage > current.max;
616
+ const would_exceed_ratio = safety_usage > current.max;
617
+ if (would_exceed_actual || would_exceed_ratio) {
618
+ return {
619
+ success: false,
620
+ status: "would_exceed",
621
+ error: `Requested usage (${requested_usage}, safety=${safety_usage}) exceeds fresh-window maximum (${current.max}).`,
622
+ quota: current,
623
+ remaining: current.max
624
+ };
625
+ }
626
+ }
627
+ if (!perform_increment) {
628
+ const view_after_reset = { ...current, usage: 0n, start: now_sec };
629
+ return {
630
+ success: true,
631
+ status: "success",
632
+ quota: view_after_reset,
633
+ remaining: QuotaManager.remaining(view_after_reset.max, view_after_reset.usage),
634
+ was_reset: false
635
+ };
636
+ }
637
+ const new_usage = QuotaManager.clamp_min0(requested_usage);
638
+ const reset_result = await collection.save({
639
+ ...db_query,
640
+ // optimistic lock against concurrent reset
641
+ start: current.start
642
+ }, {
643
+ $set: {
644
+ usage: new_usage,
645
+ start: now_sec
646
+ }
647
+ }, { return: true, upsert: false, throw: false, retry: 25 });
648
+ if (!(reset_result instanceof Error)) {
649
+ return {
650
+ success: true,
651
+ status: "success",
652
+ quota: reset_result,
653
+ remaining: QuotaManager.remaining(reset_result.max, reset_result.usage),
654
+ was_reset: true
655
+ };
656
+ }
657
+ import_system_error.SystemError.create_detach({
658
+ owner: "volt.QuotaManager",
659
+ collection: this.system_error?.collection,
660
+ logger: this.system_error?.logger,
661
+ message: `Race condition detected after maximum retries.`,
662
+ details: {
663
+ query,
664
+ requested_usage,
665
+ upsert,
666
+ safety_ratio,
667
+ check_limit,
668
+ perform_increment,
669
+ is_transaction: collection instanceof import_collection.TransactionCollection
670
+ }
671
+ });
672
+ return {
673
+ success: false,
674
+ status: "system_error",
675
+ error: `Race condition detected after maximum retries.`,
676
+ quota: current,
677
+ remaining: QuotaManager.remaining(current.max, current.usage)
678
+ };
679
+ }
680
+ if (check_limit) {
681
+ if (!perform_increment) {
682
+ if (current.usage > current.max) {
683
+ return {
684
+ success: false,
685
+ status: "exceeded",
686
+ error: `Quota usage '${current.usage}' has already exceeded maximum quota '${current.max}'`,
687
+ quota: current,
688
+ remaining: QuotaManager.remaining(current.max, current.usage)
689
+ };
690
+ }
691
+ const would_exceed_actual2 = current.usage + requested_usage > current.max;
692
+ const would_exceed_ratio2 = current.usage + safety_usage > current.max;
693
+ if (would_exceed_actual2 || would_exceed_ratio2) {
694
+ return {
695
+ success: false,
696
+ status: "would_exceed",
697
+ error: `Requested usage (${requested_usage}, safety=${safety_usage}) would exceed remaining quota.`,
698
+ quota: current,
699
+ remaining: QuotaManager.remaining(current.max, current.usage)
700
+ };
701
+ }
702
+ return {
703
+ success: true,
704
+ status: "success",
705
+ quota: current,
706
+ remaining: QuotaManager.remaining(current.max, current.usage),
707
+ was_reset: false
708
+ };
709
+ }
710
+ if (current.usage + requested_usage < 0n) {
711
+ const clamp_result = await collection.save({
712
+ ...db_query,
713
+ start: current.start
714
+ // optimistic lock in the same window
715
+ }, { $set: { usage: 0n } }, { return: true, upsert: false, throw: false, retry: 25 });
716
+ if (!(clamp_result instanceof Error)) {
717
+ return {
718
+ success: true,
719
+ status: "success",
720
+ quota: clamp_result,
721
+ remaining: QuotaManager.remaining(clamp_result.max, clamp_result.usage),
722
+ was_reset: false
723
+ };
724
+ }
725
+ import_system_error.SystemError.create_detach({
726
+ owner: "volt.QuotaManager",
727
+ collection: this.system_error?.collection,
728
+ logger: this.system_error?.logger,
729
+ message: `Failed to clamp usage to zero for query '${this.format_quota_id(query)}'.`,
730
+ details: {
731
+ query,
732
+ requested_usage,
733
+ upsert,
734
+ safety_ratio,
735
+ check_limit,
736
+ perform_increment,
737
+ is_transaction: collection instanceof import_collection.TransactionCollection
738
+ }
739
+ });
740
+ return {
741
+ success: false,
742
+ status: "system_error",
743
+ error: `Failed to clamp usage to zero for query '${this.format_quota_id(query)}'.`,
744
+ quota: current,
745
+ remaining: QuotaManager.remaining(current.max, current.usage)
746
+ };
747
+ }
748
+ if (current.usage > current.max) {
749
+ return {
750
+ success: false,
751
+ status: "exceeded",
752
+ error: `Quota usage '${current.usage}' has already exceeded maximum quota '${current.max}'`,
753
+ quota: current,
754
+ remaining: QuotaManager.remaining(current.max, current.usage)
755
+ };
756
+ }
757
+ const would_exceed_actual = current.usage + requested_usage > current.max;
758
+ const would_exceed_ratio = current.usage + safety_usage > current.max;
759
+ if (would_exceed_actual || would_exceed_ratio) {
760
+ return {
761
+ success: false,
762
+ status: "would_exceed",
763
+ error: `Requested usage (${requested_usage}, safety=${safety_usage}) would exceed remaining quota.`,
764
+ quota: current,
765
+ remaining: QuotaManager.remaining(current.max, current.usage)
766
+ };
767
+ }
768
+ const inc_result = await collection.save({
769
+ ...db_query,
770
+ start: current.start,
771
+ $expr: { $gte: [{ $add: ["$usage", requested_usage] }, 0n] }
772
+ }, { $inc: { usage: requested_usage } }, { return: true, upsert: false, throw: false, retry: 25 });
773
+ if (!(inc_result instanceof Error)) {
774
+ return {
775
+ success: true,
776
+ status: "success",
777
+ quota: inc_result,
778
+ remaining: QuotaManager.remaining(inc_result.max, inc_result.usage),
779
+ was_reset: false
780
+ };
781
+ }
782
+ import_system_error.SystemError.create_detach({
783
+ owner: "volt.QuotaManager",
784
+ collection: this.system_error?.collection,
785
+ logger: this.system_error?.logger,
786
+ message: `Failed to update quota for query '${this.format_quota_id(query)}'.`,
787
+ details: {
788
+ query,
789
+ requested_usage,
790
+ upsert,
791
+ safety_ratio,
792
+ check_limit,
793
+ perform_increment,
794
+ is_transaction: collection instanceof import_collection.TransactionCollection
795
+ }
796
+ });
797
+ return {
798
+ success: false,
799
+ status: "system_error",
800
+ error: `Failed to update quota for query '${this.format_quota_id(query)}'.`,
801
+ quota: current,
802
+ remaining: QuotaManager.remaining(current.max, current.usage)
803
+ };
804
+ } else {
805
+ if (!perform_increment) {
806
+ const needs_reset = now_sec >= current.start + current.interval;
807
+ const effective_usage = needs_reset ? 0n : current.usage;
808
+ const view_quota = needs_reset ? { ...current, usage: 0n, start: now_sec } : current;
809
+ return {
810
+ success: true,
811
+ status: "success",
812
+ quota: view_quota,
813
+ remaining: QuotaManager.remaining(view_quota.max, effective_usage),
814
+ was_reset: false
815
+ };
816
+ }
817
+ const inc_result = await collection.save({
818
+ ...db_query,
819
+ start: current.start,
820
+ $expr: { $gte: [{ $add: ["$usage", requested_usage] }, 0n] }
821
+ }, { $inc: { usage: requested_usage } }, { return: true, upsert: false, throw: false, retry: 25 });
822
+ if (!(inc_result instanceof Error)) {
823
+ return {
824
+ success: true,
825
+ status: "success",
826
+ quota: inc_result,
827
+ remaining: QuotaManager.remaining(inc_result.max, inc_result.usage),
828
+ was_reset: false
829
+ };
830
+ }
831
+ const clamp_result = await collection.save({ ...db_query, start: current.start }, { $set: { usage: 0n } }, { return: true, upsert: false, throw: false, retry: 25 });
832
+ if (!(clamp_result instanceof Error)) {
833
+ return {
834
+ success: true,
835
+ status: "success",
836
+ quota: clamp_result,
837
+ remaining: QuotaManager.remaining(clamp_result.max, clamp_result.usage),
838
+ was_reset: false
839
+ };
840
+ }
841
+ import_system_error.SystemError.create_detach({
842
+ owner: "volt.QuotaManager",
843
+ collection: this.system_error?.collection,
844
+ logger: this.system_error?.logger,
845
+ message: `Failed to update quota for query '${this.format_quota_id(query)}'.`,
846
+ details: {
847
+ query,
848
+ requested_usage,
849
+ upsert,
850
+ safety_ratio,
851
+ check_limit,
852
+ perform_increment,
853
+ is_transaction: collection instanceof import_collection.TransactionCollection
854
+ }
855
+ });
856
+ return {
857
+ success: false,
858
+ status: "system_error",
859
+ error: `Failed to update quota for query '${this.format_quota_id(query)}'.`,
860
+ quota: current,
861
+ remaining: QuotaManager.remaining(current.max, current.usage)
862
+ };
863
+ }
864
+ }
865
+ /**
866
+ * Validate quota limits and, optionally, atomically increment usage if within bounds.
867
+ * Handles interval resets automatically in a single database operation.
868
+ *
869
+ * @warning Ensure the quota exists in the database, or provide `upsert` to create it when needed.
870
+ *
871
+ * @param perform_increment When `true` (default), performs the atomic increment. When `false`,
872
+ * executes a dry-run validation without modifying the database.
873
+ *
874
+ * @note Negative `requested_usage` is not allowed. Use {@link increment} for decrements.
875
+ *
876
+ * @returns On success, returns the (possibly updated) quota and remaining capacity; on failure,
877
+ * returns a diagnostic indicating why the request was rejected.
878
+ *
879
+ * @docs
880
+ */
881
+ async limit({ query, requested_usage, upsert, safety_ratio, perform_increment = true }) {
882
+ if (requested_usage < 0n) {
883
+ return {
884
+ success: false,
885
+ status: "invalid_usage",
886
+ error: `Negative requested_usage (${requested_usage}) is not allowed in 'limit'. Use 'increment' for decrements.`
887
+ };
888
+ }
889
+ return this.limit_helper({
890
+ query,
891
+ requested_usage,
892
+ upsert,
893
+ safety_ratio,
894
+ collection: this.collection,
895
+ check_limit: true,
896
+ perform_increment
897
+ });
898
+ }
899
+ /**
900
+ * Increment the usage on a quota.
901
+ *
902
+ * @warning This does not check for quota limits.
903
+ * @warning Ensure the quota exists in the database, or define `upsert` to create it when needed.
904
+ *
905
+ * @note This function allows for negative `requested_usage` values.
906
+ *
907
+ * @returns The updated quota record or a diagnostic if the quota was not found in the database or if the max retries have been exceeded.
908
+ *
909
+ * @docs
910
+ */
911
+ async increment({ query, requested_usage, upsert }) {
912
+ return this.limit_helper({
913
+ query,
914
+ requested_usage,
915
+ upsert,
916
+ collection: this.collection,
917
+ check_limit: false,
918
+ perform_increment: true
919
+ });
920
+ }
921
+ /**
922
+ * Validates multiple quota limits and atomically increments usage if within bounds.
923
+ * Handles interval resets automatically in a single database operation.
924
+ *
925
+ * This transaction based operation only commits changes if all quotas pass validation.
926
+ *
927
+ * @warning Ensure the quota exists in the database.
928
+ *
929
+ * @note This function does not allow for negative usage values, use {@link increment} for decrements.
930
+ * @note This automatically increments the quota usage with the requested usage.
931
+ *
932
+ * @param limits The quota limits to validate and increment upon success, or roll back upon failure.
933
+ *
934
+ * @returns Success with updated quota info or validation/error details.
935
+ *
936
+ * @docs
937
+ */
938
+ async batch_limit({ limits }) {
939
+ if (limits.length === 0) {
940
+ throw new Error("No limits provided for batch_limit");
941
+ }
942
+ for (const item of limits) {
943
+ if (item.requested_usage < 0n) {
944
+ return {
945
+ success: false,
946
+ status: "invalid_usage",
947
+ failed_query: item.query,
948
+ error: `Negative 'requested_usage' (${item.requested_usage}) is not allowed in 'batch_limit'. Use 'increment' for decrements.`
949
+ };
950
+ }
951
+ const val_input_res = this.validate_limit_helper_params({
952
+ requested_usage: item.requested_usage,
953
+ safety_ratio: item.safety_ratio,
954
+ upsert: item.upsert,
955
+ query: item.query
956
+ });
957
+ if (val_input_res) {
958
+ return {
959
+ success: false,
960
+ status: val_input_res.status,
961
+ failed_query: item.query,
962
+ error: val_input_res.error
963
+ };
964
+ }
965
+ }
966
+ const transaction = await this.collection.start_transaction();
967
+ const results = [];
968
+ let active_limit = limits[0];
969
+ try {
970
+ for (const limit of limits) {
971
+ active_limit = limit;
972
+ const result = await this.limit_helper({
973
+ query: limit.query,
974
+ requested_usage: limit.requested_usage,
975
+ upsert: limit.upsert,
976
+ collection: transaction,
977
+ safety_ratio: limit.safety_ratio,
978
+ check_limit: limit.check_limit ?? true,
979
+ perform_increment: limit.perform_increment ?? true
980
+ });
981
+ if (!result.success) {
982
+ await transaction.abort();
983
+ return {
984
+ ...result,
985
+ failed_query: limit.query
986
+ };
987
+ }
988
+ results.push(result);
989
+ }
990
+ } catch (error) {
991
+ await transaction.abort();
992
+ import_system_error.SystemError.create_detach({
993
+ owner: "volt.QuotaManager",
994
+ collection: this.system_error?.collection,
995
+ logger: this.system_error?.logger,
996
+ message: `Transaction failed: ${error instanceof Error ? error.message : String(error)}`,
997
+ details: {
998
+ failed_query: active_limit.query,
999
+ is_transaction: true
1000
+ }
1001
+ });
1002
+ return {
1003
+ success: false,
1004
+ status: "system_error",
1005
+ failed_query: active_limit.query,
1006
+ error: `Transaction failed: ${error instanceof Error ? error.message : String(error)}`
1007
+ };
1008
+ }
1009
+ try {
1010
+ await transaction.commit();
1011
+ } catch (error) {
1012
+ await transaction.abort();
1013
+ import_system_error.SystemError.create_detach({
1014
+ owner: "volt.QuotaManager",
1015
+ collection: this.system_error?.collection,
1016
+ logger: this.system_error?.logger,
1017
+ message: `Transaction commit failed: ${error instanceof Error ? error.message : String(error)}`,
1018
+ details: {
1019
+ failed_query: active_limit.query,
1020
+ is_transaction: true
1021
+ }
1022
+ });
1023
+ return {
1024
+ success: false,
1025
+ status: "system_error",
1026
+ failed_query: active_limit.query,
1027
+ error: `Transaction commit failed: ${error instanceof Error ? error.message : String(error)}`
1028
+ };
1029
+ }
1030
+ return {
1031
+ success: true,
1032
+ status: "success",
1033
+ results
1034
+ };
1035
+ }
1036
+ }
1037
+ (function(QuotaManager2) {
1038
+ let Query;
1039
+ (function(Query2) {
1040
+ function validate(query) {
1041
+ if (!query.uid?.trim()) {
1042
+ return "Invalid uid: must be a non-empty string.";
1043
+ }
1044
+ if (!query.id?.trim()) {
1045
+ return "Invalid id: must be a non-empty string.";
1046
+ }
1047
+ }
1048
+ Query2.validate = validate;
1049
+ })(Query = QuotaManager2.Query || (QuotaManager2.Query = {}));
1050
+ ;
1051
+ let Quota;
1052
+ (function(Quota2) {
1053
+ let Opts;
1054
+ (function(Opts2) {
1055
+ Opts2.Schema = {
1056
+ max: {
1057
+ type: "bigint",
1058
+ required: true
1059
+ },
1060
+ interval: {
1061
+ type: "number",
1062
+ required: true
1063
+ }
1064
+ };
1065
+ function validate(quota, collection) {
1066
+ if (typeof quota.max !== "bigint" || quota.max <= 0n) {
1067
+ return `Invalid quota 'max': ${String(quota.max)}. Must be a positive bigint.`;
1068
+ }
1069
+ if (typeof quota.interval !== "number" || quota.interval <= 0 || !Number.isFinite(quota.interval)) {
1070
+ return `Invalid quota 'interval': ${quota.interval}. Must be positive and finite.`;
1071
+ } else if (collection.ttl != null && quota.interval * 1e3 >= collection.ttl) {
1072
+ return `Invalid quota 'interval': ${quota.interval}. Must be less than the collection TTL of ${Math.ceil(collection.ttl / 1e3)} seconds.`;
1073
+ }
1074
+ }
1075
+ Opts2.validate = validate;
1076
+ })(Opts = Quota2.Opts || (Quota2.Opts = {}));
1077
+ function to_nano(q, opts) {
1078
+ if (q == null)
1079
+ return void 0;
1080
+ else if (typeof q === "number" || typeof q === "bigint") {
1081
+ return new import_safe_int.SafeInt(q, { from_scale: import_safe_int.SafeInt.Scale.Base, to_scale: import_safe_int.SafeInt.Scale.Nano, round: opts?.round }).value();
1082
+ }
1083
+ return {
1084
+ max: new import_safe_int.SafeInt(q.max, { from_scale: import_safe_int.SafeInt.Scale.Base, to_scale: import_safe_int.SafeInt.Scale.Nano, round: opts?.round }).value(),
1085
+ interval: q.interval
1086
+ };
1087
+ }
1088
+ Quota2.to_nano = to_nano;
1089
+ })(Quota = QuotaManager2.Quota || (QuotaManager2.Quota = {}));
1090
+ let Document;
1091
+ (function(Document2) {
1092
+ let Opts;
1093
+ (function(Opts2) {
1094
+ function validate(quota, collection) {
1095
+ let e;
1096
+ if (e = Query.validate(quota))
1097
+ return e;
1098
+ if (e = Quota.Opts.validate(quota, collection))
1099
+ return e;
1100
+ }
1101
+ Opts2.validate = validate;
1102
+ })(Opts = Document2.Opts || (Document2.Opts = {}));
1103
+ })(Document = QuotaManager2.Document || (QuotaManager2.Document = {}));
1104
+ })(QuotaManager || (QuotaManager = {}));
1105
+ // Annotate the CommonJS export names for ESM import in node:
1106
+ 0 && (module.exports = {
1107
+ QuotaManager
1108
+ });