@vandenberghinc/volt 1.1.26 → 1.1.28

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