@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,402 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2025 - 2025 Daan van den Bergh. All rights reserved.
4
+ */
5
+ // External imports.
6
+ import * as vlib from "@vandenberghinc/vlib";
7
+ /**
8
+ * The system error.
9
+ * Used to indicate a fatal system error that should not occur and should be reported to developers.
10
+ * When created, it is logged and (optionally) persisted to the configured collection.
11
+ */
12
+ export class SystemError extends Error {
13
+ /**
14
+ * The default logger to dump messages to.
15
+ * This can either be `console` or a custom logger such as `FileLogger`.
16
+ *
17
+ * This logger is shared across all system errors,
18
+ * unless a specific logger is passed to the {@link SystemError.Opts} constructor options.
19
+ */
20
+ static logger = console;
21
+ /**
22
+ * The default collection to save the error to.
23
+ *
24
+ * This collection is shared across all system errors,
25
+ * unless a specific collection is passed to the {@link SystemError.Opts} constructor options.
26
+ *
27
+ * @warning
28
+ * If both {@link SystemError.collection} and field {@link SystemError.Opts.collection} are undefined,
29
+ * the error will not be saved to the database.
30
+ *
31
+ * @note Ensure a database index is created for field `id`.
32
+ */
33
+ static collection;
34
+ /**
35
+ * Set a collection that will be used as default to save system errors to.
36
+ *
37
+ * @param collection The collection options to use.
38
+ */
39
+ static set_collection(opts) {
40
+ SystemError.collection = opts.server.db.collection({
41
+ name: opts.name,
42
+ ttl: opts.ttl,
43
+ indexes: [
44
+ { keys: { id: 1 }, unique: true, forced: true }
45
+ ],
46
+ record_version: 1,
47
+ });
48
+ }
49
+ /**
50
+ * The generated identifier length (characters) for error IDs.
51
+ * Defaults to 256 to preserve existing behavior; tune per database constraints.
52
+ */
53
+ static id_length = 256;
54
+ /**
55
+ * The maximum length for the stringified {@link SystemError.details} field when saved to the database collection as a string.
56
+ * The `details` field is stringified when it (a) contains cycles or non-plain structures, or (b) its full JSON size exceeds
57
+ * {@link SystemError.max_details_length}. Otherwise, the redacted plain object/array is stored.
58
+ */
59
+ static max_details_length = 10_000;
60
+ /**
61
+ * A unique id for this error instance.
62
+ * Unique to this system error instance.
63
+ */
64
+ id;
65
+ /** The attached message. */
66
+ message;
67
+ /** The attached details. */
68
+ details;
69
+ /** A nested error cause. */
70
+ cause;
71
+ /** The collection to save the error to. */
72
+ collection;
73
+ /**
74
+ * The logger to dump messages to.
75
+ * Defaults to static attribute {@link SystemError.logger}.
76
+ */
77
+ logger;
78
+ /**
79
+ * An optional owner field.
80
+ * For instance system errors saved by the {@link QuotaManager} have an owner of `volt.QuotaManager`.
81
+ */
82
+ owner;
83
+ /** The creation timestamp in milliseconds since Unix epoch. */
84
+ timestamp;
85
+ /** The captured stacktrace of the creation of the system error. */
86
+ trace;
87
+ /** A cache for the result of format({ colored: true }). */
88
+ _format_colored;
89
+ /** A cache for the result of format({ colored: false }). */
90
+ _format_non_colored;
91
+ /**
92
+ * Private constructor.
93
+ * Use {@link SystemError.create} or {@link SystemError.create_detach} to create a new system error.
94
+ */
95
+ constructor(opts) {
96
+ super(opts.message);
97
+ // Ensures `instanceof SystemError` works in all transpilation targets.
98
+ Object.setPrototypeOf(this, new.target.prototype);
99
+ // Attributes.
100
+ this.message = opts.message;
101
+ this.details = opts.details;
102
+ this.collection = opts.collection ?? SystemError.collection;
103
+ this.logger = opts.logger ?? SystemError.logger;
104
+ this.owner = opts.owner;
105
+ // Define 'cause' as non-enumerable to avoid accidental leakage on serialization.
106
+ if (opts.cause) {
107
+ Object.defineProperty(this, "cause", {
108
+ value: opts.cause,
109
+ enumerable: false,
110
+ configurable: true,
111
+ writable: true,
112
+ });
113
+ }
114
+ // Generate an id.
115
+ this.id = vlib.String.random(SystemError.id_length, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789");
116
+ // Set error instance name.
117
+ this.name = "SystemError";
118
+ // Add timestamp.
119
+ this.timestamp = Date.now();
120
+ /** Capture a robust stack trace at the point of creation (cross-env safe). */
121
+ const holder = { name: "X", message: "Y" };
122
+ let prev_limit;
123
+ try {
124
+ // Feature-detect Node API.
125
+ const has_capture = typeof Error.captureStackTrace === "function";
126
+ const has_limit = typeof Error.stackTraceLimit === "number";
127
+ if (has_limit) {
128
+ prev_limit = Error.stackTraceLimit;
129
+ Error.stackTraceLimit = 35;
130
+ }
131
+ if (has_capture) {
132
+ Error.captureStackTrace(holder, this.constructor);
133
+ }
134
+ else {
135
+ // Fallback: use current error stack
136
+ holder.stack = this.stack;
137
+ }
138
+ }
139
+ finally {
140
+ if (typeof prev_limit === "number") {
141
+ Error.stackTraceLimit = prev_limit;
142
+ }
143
+ }
144
+ this.trace = (holder.stack || "")
145
+ .split("\n")
146
+ .slice(1)
147
+ .map((line) => line.trim());
148
+ // Dont log from here, log from create or create_detach.
149
+ // Perhaps we also want to create a constructor for loaded sys errs later.
150
+ }
151
+ /** Construct a system error & save it to the database. */
152
+ static async create(opts) {
153
+ const error = new SystemError(opts);
154
+ error.logger.error(error.format({ colored: false }));
155
+ if (error.collection) {
156
+ await error.collection.set({ id: error.id }, error.document(), { retry: 25, });
157
+ }
158
+ return error;
159
+ }
160
+ /**
161
+ * Construct a system error & save it to the database.
162
+ * This is a synchronous version of the create method.
163
+ * Beware that this does not join the async save operation,
164
+ * Instead it detaches and catches and logs any errors that occur during saving
165
+ */
166
+ static create_detach(opts) {
167
+ const error = new SystemError(opts);
168
+ error.logger.error(error.format({ colored: false }));
169
+ if (error.collection) {
170
+ void error.collection.set({ id: error.id }, error.document(), { retry: 25 }).catch((e) => {
171
+ try {
172
+ error.logger.error(`Failed to save system error to database: ${e instanceof Error ? e.message : String(e)}\n` + error.format({ colored: false }));
173
+ }
174
+ catch (_) { /** ignore */ }
175
+ });
176
+ }
177
+ return error;
178
+ }
179
+ /**
180
+ * Get the error as a database document.
181
+ *
182
+ * @returns A plain object representing the system error for database storage.
183
+ */
184
+ document() {
185
+ const doc = {
186
+ id: this.id,
187
+ message: this.message,
188
+ timestamp: this.timestamp,
189
+ trace: this.trace,
190
+ stack: this.stack,
191
+ format: vlib.String.truncate(this.format({ colored: false }), 10_000),
192
+ };
193
+ if (this.details) {
194
+ try {
195
+ doc.details = this.prepare_details_for_db();
196
+ }
197
+ catch (e) {
198
+ doc.details = `Encountered an error while processing details: ${e instanceof Error ? e.message : String(e)}`;
199
+ }
200
+ }
201
+ if (this.owner != null) {
202
+ doc.owner = this.owner;
203
+ }
204
+ if (this.cause) {
205
+ doc.error = {
206
+ name: this.cause.name,
207
+ message: this.cause.message,
208
+ stack: this.cause.stack,
209
+ };
210
+ }
211
+ return doc;
212
+ }
213
+ /**
214
+ * Format the error as a string.
215
+ * @param colored Present the formatted error with colors to make it more visually pleasing.
216
+ * Defaults to `false`.
217
+ * @returns A string representation of the system error.
218
+ */
219
+ format({ colored = false } = {}) {
220
+ if (colored && this._format_colored)
221
+ return this._format_colored;
222
+ else if (!colored && this._format_non_colored)
223
+ return this._format_non_colored;
224
+ try {
225
+ const green = (m) => colored ? vlib.Color.green(m) : m;
226
+ const lines = [
227
+ `SystemError: ${this.message}`,
228
+ ];
229
+ if (this.trace) {
230
+ lines.push(...this.trace.map(l => ` ${l}`));
231
+ }
232
+ lines.push(` error_id: ${green('"' + this.id + '"')}`);
233
+ if (this.owner != null) {
234
+ lines.push(` owner: ${green('"' + this.owner + '"')}`);
235
+ }
236
+ let details;
237
+ try {
238
+ details = vlib.Object.stringify(this.redact_secrets(this.details), {
239
+ indent: 2,
240
+ start_indent: 1,
241
+ colored: colored,
242
+ max_length: 1000,
243
+ });
244
+ }
245
+ catch (e) {
246
+ details = `Encountered an error while processing details: ${e instanceof Error ? e.message : String(e)}`;
247
+ }
248
+ lines.push(` created_at: ${green('"' + new Date(this.timestamp).toISOString() + '"')}`, ` details: ${details}`);
249
+ if (this.cause) {
250
+ lines.push(` nested error:`, ...(this.cause?.stack ?? this.cause.toString()).split("\n")
251
+ .map(line => ` ${line.trim()}`));
252
+ }
253
+ if (colored) {
254
+ return this._format_colored = lines.join("\n");
255
+ }
256
+ else {
257
+ return this._format_non_colored = lines.join("\n");
258
+ }
259
+ }
260
+ catch (e) {
261
+ return `Encountered an error while formatting the system error: ${e instanceof Error ? e.message : String(e)}`;
262
+ }
263
+ }
264
+ /**
265
+ * Convert the error to a string without ANSI colors to avoid leaking escape codes into sinks
266
+ * (e.g., files, JSON logs) that assume plain text.
267
+ * @returns Non-colored string representation of the error.
268
+ */
269
+ toString() {
270
+ return this.format({ colored: false });
271
+ }
272
+ // ----------------------------------------------------------
273
+ // Private methods.
274
+ /**
275
+ * Detect a plain object (no custom prototype, not an array).
276
+ * @param v - The value to test.
277
+ */
278
+ is_plain_object(v) {
279
+ if (v === null || typeof v !== "object" || Array.isArray(v))
280
+ return false;
281
+ const proto = Object.getPrototypeOf(v);
282
+ return proto === Object.prototype || proto === null;
283
+ }
284
+ /**
285
+ * Inspect and prepare the details for safe storage in `SystemError.Document.details`.
286
+ *
287
+ * @returns
288
+ * - `undefined` if no details were defined.
289
+ * - A string if (a) the value contains circular references, (b) it is not a plain object / array,
290
+ * or (c) the full stringified representation exceeds {@link SystemError.max_details_length}.
291
+ * - Otherwise, the redacted raw object is returned.
292
+ */
293
+ prepare_details_for_db() {
294
+ if (!this.details)
295
+ return undefined;
296
+ /**
297
+ * Recursively verify JSON-safety and detect cycles using path-level tracking.
298
+ * @param val - The value to traverse.
299
+ * @param in_path - WeakSet to track the current recursion path for cycles.
300
+ */
301
+ const is_json_safe = (val, in_path = new WeakSet()) => {
302
+ if (val == null)
303
+ return true;
304
+ const t = typeof val;
305
+ if (t === "undefined" || t === "boolean" || t === "number" || t === "string")
306
+ return true;
307
+ if (t === "function" || t === "symbol" || t === "bigint")
308
+ return false;
309
+ if (val instanceof String || val instanceof Date)
310
+ return true;
311
+ if (typeof val === "object") {
312
+ const obj = val;
313
+ if (in_path.has(obj))
314
+ return false; // cycle
315
+ in_path.add(obj);
316
+ if (Array.isArray(obj)) {
317
+ for (const item of obj) {
318
+ if (!is_json_safe(item, in_path)) {
319
+ in_path.delete(obj);
320
+ return false;
321
+ }
322
+ }
323
+ in_path.delete(obj);
324
+ return true;
325
+ }
326
+ if (this.is_plain_object(obj)) {
327
+ for (const v of Object.values(obj)) {
328
+ if (!is_json_safe(v, in_path)) {
329
+ in_path.delete(obj);
330
+ return false;
331
+ }
332
+ }
333
+ in_path.delete(obj);
334
+ return true;
335
+ }
336
+ in_path.delete(obj);
337
+ return false; // Non-plain object (Map/Set/RegExp/etc.)
338
+ }
339
+ return false;
340
+ };
341
+ // Redact early (never mutate the original).
342
+ const redacted = this.redact_secrets(this.details);
343
+ // If structurally unsafe => stringify (capped).
344
+ if (!is_json_safe(redacted)) {
345
+ return vlib.Object.stringify(redacted, {
346
+ colored: false,
347
+ max_length: SystemError.max_details_length,
348
+ });
349
+ }
350
+ // Measure the *full* length (no cap) to decide storage shape.
351
+ // Measure the *full* length (no cap) to decide storage shape.
352
+ let full_string;
353
+ try {
354
+ full_string = JSON.stringify(redacted);
355
+ }
356
+ catch (_) {
357
+ // Extremely defensive fallback; should not execute after JSON-safety verification.
358
+ full_string = vlib.Object.stringify(redacted, { colored: false });
359
+ }
360
+ if (full_string.length > SystemError.max_details_length) {
361
+ // Persist as a truncated string to enforce the size budget.
362
+ return vlib.String.truncate(full_string, SystemError.max_details_length);
363
+ }
364
+ // Safe & within budget: store as object.
365
+ return redacted;
366
+ }
367
+ /**
368
+ * Deep-clone arrays/plain objects and redact sensitive keys (best-effort).
369
+ * Does not mutate the source object.
370
+ * Uses a null-prototype object & explicit property definitions to prevent prototype pollution via magic keys.
371
+ * @param input - The value to clone & redact.
372
+ * @returns A redacted deep clone of the input.
373
+ */
374
+ redact_secrets(input) {
375
+ const sensitive = /^(password|pass|secret|api[_-]?key|token|access[_-]?token|refresh[_-]?token|authorization|auth|cookie|session|private[_-]?key|client[_-]?secret)$/i;
376
+ const define_plain = (obj, key, value) => {
377
+ Object.defineProperty(obj, key, { value, enumerable: true, writable: true, configurable: true });
378
+ };
379
+ const clone = (val) => {
380
+ if (val == null)
381
+ return val;
382
+ if (Array.isArray(val))
383
+ return val.map(clone);
384
+ if (this.is_plain_object(val)) {
385
+ const out = Object.create(null);
386
+ for (const [k, v] of Object.entries(val)) {
387
+ if (sensitive.test(k)) {
388
+ define_plain(out, k, "[REDACTED]");
389
+ }
390
+ else {
391
+ define_plain(out, k, clone(v));
392
+ }
393
+ }
394
+ return out;
395
+ }
396
+ // Leave other types as-is.
397
+ return val;
398
+ };
399
+ return clone(input);
400
+ }
401
+ }
402
+ ;
@@ -0,0 +1,54 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh.
4
+ */
5
+ import * as vlib from "@vandenberghinc/vlib";
6
+ import { User } from "./users.js";
7
+ /** All events and their callback types. */
8
+ export type Events = {
9
+ /**
10
+ * Add an (async) callback executed at the end of `server.start()`. The callback may take arguments `({forked <boolean>})`.
11
+ * @example
12
+ * ...
13
+ * server.on("start", opts => console.log("Hello World!"));
14
+ */
15
+ start: (opts: {
16
+ forked: boolean;
17
+ }) => void | Promise<void>;
18
+ /**
19
+ * Set an (async) callback which will be executed at the start of `server.stop()`.
20
+ * @example
21
+ * ...
22
+ * server.on("stop", () => console.log("Hello World!"));
23
+ */
24
+ stop: () => void | Promise<void>;
25
+ /**
26
+ * Set an (async) callback which will be executed at the start of `server.initialize()`.
27
+ * @example
28
+ * ...
29
+ * server.on("initialize", () => console.log("Hello World!"));
30
+ */
31
+ initialize: () => void | Promise<void>;
32
+ /**
33
+ * This callback is executed when a user is created.
34
+ * @note Errors thrown in this callback will be logged but ignored.
35
+ */
36
+ create_user: (opts: {
37
+ user: User;
38
+ }) => void | Promise<void>;
39
+ /**
40
+ * This callback is executed when a user is deleted.
41
+ * @note Errors thrown in this callback will be logged but ignored.
42
+ */
43
+ delete_user: (opts: {
44
+ user: User;
45
+ }) => void | Promise<void>;
46
+ };
47
+ /** Event name. */
48
+ export type EventName = vlib.EventName<Events>;
49
+ /** Event callback. */
50
+ export type EventCallback<N extends EventName> = vlib.EventCallback<Events, N>;
51
+ /** Event parameters. */
52
+ export type EventParams<N extends EventName> = vlib.EventParams<Events, N>;
53
+ /** Event result type. */
54
+ export type EventResult<N extends EventName> = vlib.EventResult<Events, N>;
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh.
4
+ */
5
+ export {};
@@ -6,7 +6,7 @@ export const Frontend = {
6
6
  /** CSS exports. */
7
7
  css: {
8
8
  /** The default volt css export. */
9
- volt: __dirname + "/../../../frontend/src/css/volt.css",
9
+ volt: __dirname + "/../../../../../frontend/src/css/volt.css",
10
10
  }
11
11
  };
12
12
  export default Frontend;
@@ -1,6 +1,21 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
+ */
1
5
  import * as vlib from "@vandenberghinc/vlib";
2
6
  import { Endpoint } from "./endpoint.js";
3
7
  import { RateLimitGroup } from "./rate_limit.js";
8
+ /**
9
+ * All static images are served through the `ImageEndpoint`.
10
+ *
11
+ * The image endpoint accepts three optional query parameters when retrieving the image to transform the image.
12
+ * - `type` string: The input type.
13
+ * - `width` number: The height of the image as a number `100` or percentage `50%` / `0.5x`. The aspect ratio will be maintained when `height` is undefined.
14
+ * - `height` number: The width of the image as a number `100` or percentage `50%` / `0.5x`. The aspect ratio will be maintained when `width` is undefined.
15
+ * - `aspect_ratio` boolean: Maintain the aspect ratio when only one resizing dimension has been defined.
16
+ * @docs
17
+ * @nav Backend/Endpoints
18
+ */
4
19
  declare class ImageEndpoint extends Endpoint implements Endpoint {
5
20
  static cache_in_memory: boolean;
6
21
  static supported_images: string[];
@@ -19,6 +34,6 @@ declare class ImageEndpoint extends Endpoint implements Endpoint {
19
34
  });
20
35
  transform(type?: string | null, width?: number | string | null, height?: number | string | null, aspect_ratio?: string | boolean | null): Promise<Buffer>;
21
36
  get_aspect_ratio(): Promise<string | null>;
22
- _clear_cache(): void;
37
+ private _clear_cache;
23
38
  }
24
39
  export { ImageEndpoint };
@@ -1,28 +1,24 @@
1
- /*
2
- * Author: Daan van den Bergh
3
- * Copyright: © 2022 - 2024 Daan van den Bergh.
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
4
  */
5
5
  // ---------------------------------------------------------
6
6
  // Libraries.
7
7
  import sharp from 'sharp';
8
8
  import { Endpoint } from "./endpoint.js";
9
- import { logger } from "./logger.js";
10
- const { log, error } = logger;
11
9
  // ---------------------------------------------------------
12
10
  // ImageEndpoint.
13
11
  // Supports resizing and editing formats.
14
- /* @docs:
15
- @nav: Backend
16
- @chapter: Endpoints
17
- @title: Image Endpoint
18
- @description:
19
- All static images are served through the `ImageEndpoint`.
20
-
21
- The image endpoint accepts three optional query parameters when retrieving the image to transform the image.
22
- - `type` string: The input type.
23
- - `width` number: The height of the image as a number `100` or percentage `50%` / `0.5x`. The aspect ratio will be maintained when `height` is undefined.
24
- - `height` number: The width of the image as a number `100` or percentage `50%` / `0.5x`. The aspect ratio will be maintained when `width` is undefined.
25
- - `aspect_ratio` boolean: Maintain the aspect ratio when only one resizing dimension has been defined.
12
+ /**
13
+ * All static images are served through the `ImageEndpoint`.
14
+ *
15
+ * The image endpoint accepts three optional query parameters when retrieving the image to transform the image.
16
+ * - `type` string: The input type.
17
+ * - `width` number: The height of the image as a number `100` or percentage `50%` / `0.5x`. The aspect ratio will be maintained when `height` is undefined.
18
+ * - `height` number: The width of the image as a number `100` or percentage `50%` / `0.5x`. The aspect ratio will be maintained when `width` is undefined.
19
+ * - `aspect_ratio` boolean: Maintain the aspect ratio when only one resizing dimension has been defined.
20
+ * @docs
21
+ * @nav Backend/Endpoints
26
22
  */
27
23
  class ImageEndpoint extends Endpoint {
28
24
  // Cache the original and transformed image data in memory.
@@ -60,7 +56,7 @@ class ImageEndpoint extends Endpoint {
60
56
  "aspect_ratio": { type: "string", default: null },
61
57
  },
62
58
  rate_limit,
63
- _static_path: path.str(),
59
+ file_path: path,
64
60
  _is_static,
65
61
  });
66
62
  // Attributes.
@@ -186,11 +182,11 @@ class ImageEndpoint extends Endpoint {
186
182
  // Get aspect ratio.
187
183
  async get_aspect_ratio() {
188
184
  try {
189
- const metadata = await sharp(this._static_path).metadata();
185
+ const metadata = await sharp(this.file_path?.str()).metadata();
190
186
  return `${metadata.width} / ${metadata.height}`;
191
187
  }
192
188
  catch (err) {
193
- error(`Unable to determine the aspect ratio of image ${this._static_path}: `, err);
189
+ this.server?.log.error(`Unable to determine the aspect ratio of image ${this.file_path}: `, err);
194
190
  return null;
195
191
  }
196
192
  }
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
+ */
5
+ export {};
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
+ */
5
+ export {};
6
+ // export const log = new vlib.logging.FileLogger({
7
+ // level: 0,
8
+ // });
@@ -0,0 +1,64 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
+ */
5
+ /** Nested types for the {@link Meta} class. */
6
+ export declare namespace Meta {
7
+ /** Constructor options. */
8
+ interface Opts {
9
+ /** The author's name. */
10
+ author?: string;
11
+ /** The page's title. */
12
+ title?: string;
13
+ /** The page's description. */
14
+ description?: string;
15
+ /** The page's image source. */
16
+ image?: string;
17
+ /** The robots rules. */
18
+ robots?: string;
19
+ /** The used charset. */
20
+ charset?: string;
21
+ /** The viewport settings. */
22
+ viewport?: string;
23
+ /** The url to the favicon. */
24
+ favicon?: string;
25
+ }
26
+ }
27
+ /**
28
+ * The js view meta information class.
29
+ * @nav: Backend/Endpoints
30
+ */
31
+ export declare class Meta {
32
+ author?: string;
33
+ title?: string;
34
+ description?: string;
35
+ image?: string;
36
+ robots: string;
37
+ charset: string;
38
+ viewport: string;
39
+ favicon: string;
40
+ constructor({ author, title, description, image, robots, charset, viewport, favicon, }?: Meta.Opts);
41
+ /**
42
+ * Create a copy of the current meta object without any references.
43
+ * @param override - The <Type>Meta</Type> constructor arguments to override.
44
+ * @docs
45
+ */
46
+ copy(override?: Partial<Meta.Opts>): Meta;
47
+ /**
48
+ * Set value funcs that return the current object.
49
+ * @return: Returns the current <Type>Meta</Type> object.
50
+ * @funcs 8
51
+ * @docs
52
+ */
53
+ set_author(value: string | undefined): this;
54
+ set_title(value: string | undefined): this;
55
+ set_description(value: string | undefined): this;
56
+ set_image(value: string | undefined): this;
57
+ set_robots(value: string): this;
58
+ set_charset(value: string): this;
59
+ set_viewport(value: string): this;
60
+ set_favicon(value: string): this;
61
+ obj(): Meta.Opts;
62
+ build_html(domain?: string | null): string;
63
+ }
64
+ export default Meta;