@vandenberghinc/volt 1.2.6 → 1.2.7

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 (462) hide show
  1. package/backend/dist/cjs/backend/src/blacklist.d.ts +12 -0
  2. package/backend/dist/cjs/backend/src/blacklist.js +78 -0
  3. package/backend/dist/cjs/backend/src/cli.d.ts +2 -0
  4. package/backend/dist/cjs/backend/src/cli.js +198 -0
  5. package/backend/dist/cjs/backend/src/database/collection.d.ts +1765 -0
  6. package/backend/dist/cjs/backend/src/database/collection.js +3301 -0
  7. package/backend/dist/cjs/backend/src/database/database.d.ts +92 -0
  8. package/backend/dist/cjs/backend/src/database/database.js +170 -0
  9. package/backend/dist/cjs/backend/src/database/document.d.ts +1 -0
  10. package/backend/dist/cjs/backend/src/database/document.js +15 -0
  11. package/backend/dist/cjs/backend/src/database/filters/filters.d.ts +6 -0
  12. package/backend/dist/cjs/backend/src/database/filters/filters.js +15 -0
  13. package/backend/dist/cjs/backend/src/database/filters/strict_filter.d.ts +223 -0
  14. package/backend/dist/cjs/backend/src/database/filters/strict_filter.js +15 -0
  15. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.d.ts +1 -0
  16. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.js +443 -0
  17. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.d.ts +1 -0
  18. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.js +15 -0
  19. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.d.ts +50 -0
  20. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.js +15 -0
  21. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.d.ts +76 -0
  22. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.js +15 -0
  23. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.d.ts +75 -0
  24. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.js +15 -0
  25. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.d.ts +219 -0
  26. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.js +15 -0
  27. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.d.ts +165 -0
  28. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.js +15 -0
  29. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.d.ts +5 -0
  30. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.js +355 -0
  31. package/backend/dist/cjs/backend/src/database/flatten.d.ts +78 -0
  32. package/backend/dist/cjs/backend/src/database/flatten.js +53 -0
  33. package/backend/dist/cjs/backend/src/database/flatten_test.d.ts +1 -0
  34. package/backend/dist/cjs/backend/src/database/flatten_test.js +175 -0
  35. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.d.ts +533 -0
  36. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.js +1046 -0
  37. package/backend/dist/cjs/backend/src/database/quota/quota.d.ts +551 -0
  38. package/backend/dist/cjs/backend/src/database/quota/quota.js +1108 -0
  39. package/backend/dist/cjs/backend/src/database/quota/quota_v1.d.ts +534 -0
  40. package/backend/dist/cjs/backend/src/database/quota/quota_v1.js +1087 -0
  41. package/backend/dist/cjs/backend/src/database/quota/safe_int.d.ts +412 -0
  42. package/backend/dist/cjs/backend/src/database/quota/safe_int.js +745 -0
  43. package/backend/dist/cjs/backend/src/endpoint.d.ts +346 -0
  44. package/backend/dist/cjs/backend/src/endpoint.js +468 -0
  45. package/backend/dist/cjs/backend/src/errors/index.d.ts +7 -0
  46. package/backend/dist/cjs/backend/src/errors/index.js +25 -0
  47. package/backend/dist/cjs/backend/src/errors/internal_external.d.ts +52 -0
  48. package/backend/dist/cjs/backend/src/errors/internal_external.js +95 -0
  49. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.d.ts +41 -0
  50. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.js +47 -0
  51. package/backend/dist/cjs/backend/src/errors/system_error.d.ts +261 -0
  52. package/backend/dist/cjs/backend/src/errors/system_error.js +436 -0
  53. package/backend/dist/cjs/backend/src/events.d.ts +97 -0
  54. package/backend/dist/cjs/backend/src/events.js +15 -0
  55. package/backend/dist/cjs/backend/src/frontend.d.ts +13 -0
  56. package/backend/dist/cjs/backend/src/frontend.js +56 -0
  57. package/backend/dist/cjs/backend/src/image_endpoint.d.ts +44 -0
  58. package/backend/dist/cjs/backend/src/image_endpoint.js +185 -0
  59. package/backend/dist/cjs/backend/src/index.d.ts +23 -0
  60. package/backend/dist/cjs/backend/src/index.js +70 -0
  61. package/backend/dist/cjs/backend/src/logger.d.ts +5 -0
  62. package/backend/dist/cjs/backend/src/logger.js +15 -0
  63. package/backend/dist/cjs/backend/src/meta.d.ts +112 -0
  64. package/backend/dist/cjs/backend/src/meta.js +181 -0
  65. package/backend/dist/cjs/backend/src/payments/paddle.d.ts +329 -0
  66. package/backend/dist/cjs/backend/src/payments/paddle.js +1996 -0
  67. package/backend/dist/cjs/backend/src/payments/stripe/checkout.d.ts +113 -0
  68. package/backend/dist/cjs/backend/src/payments/stripe/checkout.js +295 -0
  69. package/backend/dist/cjs/backend/src/payments/stripe/customers.d.ts +17 -0
  70. package/backend/dist/cjs/backend/src/payments/stripe/customers.js +164 -0
  71. package/backend/dist/cjs/backend/src/payments/stripe/error.d.ts +74 -0
  72. package/backend/dist/cjs/backend/src/payments/stripe/error.js +64 -0
  73. package/backend/dist/cjs/backend/src/payments/stripe/events.d.ts +155 -0
  74. package/backend/dist/cjs/backend/src/payments/stripe/events.js +15 -0
  75. package/backend/dist/cjs/backend/src/payments/stripe/meters.d.ts +105 -0
  76. package/backend/dist/cjs/backend/src/payments/stripe/meters.js +230 -0
  77. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.d.ts +58 -0
  78. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.js +109 -0
  79. package/backend/dist/cjs/backend/src/payments/stripe/products.d.ts +519 -0
  80. package/backend/dist/cjs/backend/src/payments/stripe/products.js +650 -0
  81. package/backend/dist/cjs/backend/src/payments/stripe/stripe.d.ts +215 -0
  82. package/backend/dist/cjs/backend/src/payments/stripe/stripe.js +468 -0
  83. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.d.ts +172 -0
  84. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.js +557 -0
  85. package/backend/dist/cjs/backend/src/payments/stripe/utils.d.ts +63 -0
  86. package/backend/dist/cjs/backend/src/payments/stripe/utils.js +118 -0
  87. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.d.ts +105 -0
  88. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.js +627 -0
  89. package/backend/dist/cjs/backend/src/plugins/browser.d.ts +1 -0
  90. package/backend/dist/cjs/backend/src/plugins/browser.js +15 -0
  91. package/backend/dist/cjs/backend/src/plugins/communication.d.ts +70 -0
  92. package/backend/dist/cjs/backend/src/plugins/communication.js +196 -0
  93. package/backend/dist/cjs/backend/src/plugins/mail/mail.d.ts +255 -0
  94. package/backend/dist/cjs/backend/src/plugins/mail/mail.js +381 -0
  95. package/backend/dist/cjs/backend/src/plugins/mail/ui.d.ts +297 -0
  96. package/backend/dist/cjs/backend/src/plugins/mail/ui.js +1370 -0
  97. package/backend/dist/cjs/backend/src/plugins/pdf.d.ts +1 -0
  98. package/backend/dist/cjs/backend/src/plugins/pdf.js +1456 -0
  99. package/backend/dist/cjs/backend/src/plugins/thread_monitor.d.ts +18 -0
  100. package/backend/dist/cjs/backend/src/plugins/thread_monitor.js +116 -0
  101. package/backend/dist/cjs/backend/src/rate_limit.d.ts +148 -0
  102. package/backend/dist/cjs/backend/src/rate_limit.js +543 -0
  103. package/backend/dist/cjs/backend/src/route.d.ts +39 -0
  104. package/backend/dist/cjs/backend/src/route.js +172 -0
  105. package/backend/dist/cjs/backend/src/server.d.ts +502 -0
  106. package/backend/dist/cjs/backend/src/server.js +1710 -0
  107. package/backend/dist/cjs/backend/src/server.old.d.ts +594 -0
  108. package/backend/dist/cjs/backend/src/server.old.js +2058 -0
  109. package/backend/dist/cjs/backend/src/splash_screen.d.ts +93 -0
  110. package/backend/dist/cjs/backend/src/splash_screen.js +119 -0
  111. package/backend/dist/cjs/backend/src/status.d.ts +89 -0
  112. package/backend/dist/cjs/backend/src/status.js +211 -0
  113. package/backend/dist/cjs/backend/src/stream.d.ts +494 -0
  114. package/backend/dist/cjs/backend/src/stream.js +1370 -0
  115. package/backend/dist/cjs/backend/src/users.d.ts +926 -0
  116. package/backend/dist/cjs/backend/src/users.js +2223 -0
  117. package/backend/dist/cjs/backend/src/utils.d.ts +22 -0
  118. package/backend/dist/cjs/backend/src/utils.js +626 -0
  119. package/backend/dist/cjs/backend/src/view.d.ts +115 -0
  120. package/backend/dist/cjs/backend/src/view.js +519 -0
  121. package/backend/dist/cjs/backend/src/vinc.d.ts +6 -0
  122. package/backend/dist/cjs/backend/src/vinc.js +40 -0
  123. package/backend/dist/cjs/backend/src/volt.d.ts +24 -0
  124. package/backend/dist/cjs/backend/src/volt.js +72 -0
  125. package/backend/dist/cjs/frontend/src/modules/request.d.ts +70 -0
  126. package/backend/dist/cjs/frontend/src/modules/request.js +99 -0
  127. package/backend/dist/cjs/package.json +1 -0
  128. package/backend/dist/esm/backend/src/blacklist.d.ts +12 -0
  129. package/backend/dist/esm/backend/src/blacklist.js +52 -0
  130. package/backend/dist/esm/backend/src/cli.d.ts +2 -0
  131. package/backend/dist/esm/backend/src/cli.js +211 -0
  132. package/backend/dist/esm/backend/src/database/collection.d.ts +1765 -0
  133. package/backend/dist/esm/backend/src/database/collection.js +3779 -0
  134. package/backend/dist/esm/backend/src/database/database.d.ts +92 -0
  135. package/backend/dist/esm/backend/src/database/database.js +214 -0
  136. package/backend/dist/esm/backend/src/database/document.d.ts +1 -0
  137. package/backend/dist/esm/backend/src/database/document.js +558 -0
  138. package/backend/dist/esm/backend/src/database/filters/filters.d.ts +6 -0
  139. package/backend/dist/esm/backend/src/database/filters/filters.js +1 -0
  140. package/backend/dist/esm/backend/src/database/filters/strict_filter.d.ts +223 -0
  141. package/backend/dist/esm/backend/src/database/filters/strict_filter.js +3 -0
  142. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.d.ts +1 -0
  143. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.js +505 -0
  144. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.d.ts +1 -0
  145. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.js +712 -0
  146. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.d.ts +50 -0
  147. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.js +5 -0
  148. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.d.ts +76 -0
  149. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.js +44 -0
  150. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.d.ts +75 -0
  151. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.js +5 -0
  152. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.d.ts +219 -0
  153. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.js +1 -0
  154. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.d.ts +165 -0
  155. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.js +5 -0
  156. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.d.ts +5 -0
  157. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.js +415 -0
  158. package/backend/dist/esm/backend/src/database/flatten.d.ts +78 -0
  159. package/backend/dist/esm/backend/src/database/flatten.js +22 -0
  160. package/backend/dist/esm/backend/src/database/flatten_test.d.ts +1 -0
  161. package/backend/dist/esm/backend/src/database/flatten_test.js +174 -0
  162. package/backend/dist/esm/backend/src/database/quota/quoata_v2.d.ts +533 -0
  163. package/backend/dist/esm/backend/src/database/quota/quoata_v2.js +1155 -0
  164. package/backend/dist/esm/backend/src/database/quota/quota.d.ts +551 -0
  165. package/backend/dist/esm/backend/src/database/quota/quota.js +1219 -0
  166. package/backend/dist/esm/backend/src/database/quota/quota_v1.d.ts +534 -0
  167. package/backend/dist/esm/backend/src/database/quota/quota_v1.js +1242 -0
  168. package/backend/dist/esm/backend/src/database/quota/safe_int.d.ts +412 -0
  169. package/backend/dist/esm/backend/src/database/quota/safe_int.js +810 -0
  170. package/backend/dist/esm/backend/src/endpoint.d.ts +346 -0
  171. package/backend/dist/esm/backend/src/endpoint.js +479 -0
  172. package/backend/dist/esm/backend/src/errors/index.d.ts +7 -0
  173. package/backend/dist/esm/backend/src/errors/index.js +7 -0
  174. package/backend/dist/esm/backend/src/errors/internal_external.d.ts +52 -0
  175. package/backend/dist/esm/backend/src/errors/internal_external.js +86 -0
  176. package/backend/dist/esm/backend/src/errors/invalid_usage_error.d.ts +41 -0
  177. package/backend/dist/esm/backend/src/errors/invalid_usage_error.js +33 -0
  178. package/backend/dist/esm/backend/src/errors/system_error.d.ts +261 -0
  179. package/backend/dist/esm/backend/src/errors/system_error.js +444 -0
  180. package/backend/dist/esm/backend/src/events.d.ts +97 -0
  181. package/backend/dist/esm/backend/src/events.js +5 -0
  182. package/backend/dist/esm/backend/src/frontend.d.ts +13 -0
  183. package/backend/dist/esm/backend/src/frontend.js +23 -0
  184. package/backend/dist/esm/backend/src/image_endpoint.d.ts +44 -0
  185. package/backend/dist/esm/backend/src/image_endpoint.js +196 -0
  186. package/backend/dist/esm/backend/src/index.d.ts +23 -0
  187. package/backend/dist/esm/backend/src/index.js +26 -0
  188. package/backend/dist/esm/backend/src/logger.d.ts +5 -0
  189. package/backend/dist/esm/backend/src/logger.js +8 -0
  190. package/backend/dist/esm/backend/src/meta.d.ts +112 -0
  191. package/backend/dist/esm/backend/src/meta.js +152 -0
  192. package/backend/dist/esm/backend/src/payments/paddle.d.ts +329 -0
  193. package/backend/dist/esm/backend/src/payments/paddle.js +2276 -0
  194. package/backend/dist/esm/backend/src/payments/stripe/checkout.d.ts +113 -0
  195. package/backend/dist/esm/backend/src/payments/stripe/checkout.js +356 -0
  196. package/backend/dist/esm/backend/src/payments/stripe/customers.d.ts +17 -0
  197. package/backend/dist/esm/backend/src/payments/stripe/customers.js +193 -0
  198. package/backend/dist/esm/backend/src/payments/stripe/error.d.ts +74 -0
  199. package/backend/dist/esm/backend/src/payments/stripe/error.js +51 -0
  200. package/backend/dist/esm/backend/src/payments/stripe/events.d.ts +155 -0
  201. package/backend/dist/esm/backend/src/payments/stripe/events.js +5 -0
  202. package/backend/dist/esm/backend/src/payments/stripe/meters.d.ts +105 -0
  203. package/backend/dist/esm/backend/src/payments/stripe/meters.js +318 -0
  204. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.d.ts +58 -0
  205. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.js +135 -0
  206. package/backend/dist/esm/backend/src/payments/stripe/products.d.ts +519 -0
  207. package/backend/dist/esm/backend/src/payments/stripe/products.js +896 -0
  208. package/backend/dist/esm/backend/src/payments/stripe/stripe.d.ts +215 -0
  209. package/backend/dist/esm/backend/src/payments/stripe/stripe.js +464 -0
  210. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.d.ts +172 -0
  211. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.js +754 -0
  212. package/backend/dist/esm/backend/src/payments/stripe/utils.d.ts +63 -0
  213. package/backend/dist/esm/backend/src/payments/stripe/utils.js +131 -0
  214. package/backend/dist/esm/backend/src/payments/stripe/webhooks.d.ts +105 -0
  215. package/backend/dist/esm/backend/src/payments/stripe/webhooks.js +752 -0
  216. package/backend/dist/esm/backend/src/plugins/browser.d.ts +1 -0
  217. package/backend/dist/esm/backend/src/plugins/browser.js +170 -0
  218. package/backend/dist/esm/backend/src/plugins/communication.d.ts +70 -0
  219. package/backend/dist/esm/backend/src/plugins/communication.js +169 -0
  220. package/backend/dist/esm/backend/src/plugins/mail/mail.d.ts +255 -0
  221. package/backend/dist/esm/backend/src/plugins/mail/mail.js +396 -0
  222. package/backend/dist/esm/backend/src/plugins/mail/ui.d.ts +297 -0
  223. package/backend/dist/esm/backend/src/plugins/mail/ui.js +1400 -0
  224. package/backend/dist/esm/backend/src/plugins/pdf.d.ts +1 -0
  225. package/backend/dist/esm/backend/src/plugins/pdf.js +1694 -0
  226. package/backend/dist/esm/backend/src/plugins/thread_monitor.d.ts +18 -0
  227. package/backend/dist/esm/backend/src/plugins/thread_monitor.js +120 -0
  228. package/backend/dist/esm/backend/src/rate_limit.d.ts +148 -0
  229. package/backend/dist/esm/backend/src/rate_limit.js +667 -0
  230. package/backend/dist/esm/backend/src/route.d.ts +39 -0
  231. package/backend/dist/esm/backend/src/route.js +222 -0
  232. package/backend/dist/esm/backend/src/server.d.ts +502 -0
  233. package/backend/dist/esm/backend/src/server.js +2031 -0
  234. package/backend/dist/esm/backend/src/server.old.d.ts +594 -0
  235. package/backend/dist/esm/backend/src/server.old.js +2630 -0
  236. package/backend/dist/esm/backend/src/splash_screen.d.ts +93 -0
  237. package/backend/dist/esm/backend/src/splash_screen.js +156 -0
  238. package/backend/dist/esm/backend/src/status.d.ts +89 -0
  239. package/backend/dist/esm/backend/src/status.js +213 -0
  240. package/backend/dist/esm/backend/src/stream.d.ts +494 -0
  241. package/backend/dist/esm/backend/src/stream.js +1611 -0
  242. package/backend/dist/esm/backend/src/users.d.ts +926 -0
  243. package/backend/dist/esm/backend/src/users.js +2423 -0
  244. package/backend/dist/esm/backend/src/utils.d.ts +22 -0
  245. package/backend/dist/esm/backend/src/utils.js +463 -0
  246. package/backend/dist/esm/backend/src/view.d.ts +115 -0
  247. package/backend/dist/esm/backend/src/view.js +584 -0
  248. package/backend/dist/esm/backend/src/vinc.d.ts +6 -0
  249. package/backend/dist/esm/backend/src/vinc.js +6 -0
  250. package/backend/dist/esm/backend/src/volt.d.ts +24 -0
  251. package/backend/dist/esm/backend/src/volt.js +27 -0
  252. package/backend/dist/esm/frontend/src/modules/request.d.ts +70 -0
  253. package/backend/dist/esm/frontend/src/modules/request.js +117 -0
  254. package/frontend/dist/backend/src/database/collection.d.ts +1765 -0
  255. package/frontend/dist/backend/src/database/collection.js +3779 -0
  256. package/frontend/dist/backend/src/database/database.d.ts +92 -0
  257. package/frontend/dist/backend/src/database/database.js +214 -0
  258. package/frontend/dist/backend/src/database/filters/filters.d.ts +6 -0
  259. package/frontend/dist/backend/src/database/filters/filters.js +1 -0
  260. package/frontend/dist/backend/src/database/filters/strict_filter.d.ts +223 -0
  261. package/frontend/dist/backend/src/database/filters/strict_filter.js +3 -0
  262. package/frontend/dist/backend/src/database/filters/strict_update_filter.d.ts +165 -0
  263. package/frontend/dist/backend/src/database/filters/strict_update_filter.js +5 -0
  264. package/frontend/dist/backend/src/database/flatten.d.ts +78 -0
  265. package/frontend/dist/backend/src/database/flatten.js +22 -0
  266. package/frontend/dist/backend/src/endpoint.d.ts +346 -0
  267. package/frontend/dist/backend/src/endpoint.js +479 -0
  268. package/frontend/dist/backend/src/errors/index.d.ts +7 -0
  269. package/frontend/dist/backend/src/errors/index.js +7 -0
  270. package/frontend/dist/backend/src/errors/internal_external.d.ts +52 -0
  271. package/frontend/dist/backend/src/errors/internal_external.js +86 -0
  272. package/frontend/dist/backend/src/errors/invalid_usage_error.d.ts +41 -0
  273. package/frontend/dist/backend/src/errors/invalid_usage_error.js +33 -0
  274. package/frontend/dist/backend/src/errors/system_error.d.ts +261 -0
  275. package/frontend/dist/backend/src/errors/system_error.js +444 -0
  276. package/frontend/dist/backend/src/events.d.ts +97 -0
  277. package/frontend/dist/backend/src/events.js +5 -0
  278. package/frontend/dist/backend/src/frontend.d.ts +13 -0
  279. package/frontend/dist/backend/src/frontend.js +23 -0
  280. package/frontend/dist/backend/src/image_endpoint.d.ts +44 -0
  281. package/frontend/dist/backend/src/image_endpoint.js +196 -0
  282. package/frontend/dist/backend/src/meta.d.ts +112 -0
  283. package/frontend/dist/backend/src/meta.js +152 -0
  284. package/frontend/dist/backend/src/payments/paddle.d.ts +329 -0
  285. package/frontend/dist/backend/src/payments/paddle.js +2276 -0
  286. package/frontend/dist/backend/src/payments/stripe/checkout.d.ts +113 -0
  287. package/frontend/dist/backend/src/payments/stripe/checkout.js +356 -0
  288. package/frontend/dist/backend/src/payments/stripe/customers.d.ts +17 -0
  289. package/frontend/dist/backend/src/payments/stripe/customers.js +193 -0
  290. package/frontend/dist/backend/src/payments/stripe/error.d.ts +74 -0
  291. package/frontend/dist/backend/src/payments/stripe/error.js +51 -0
  292. package/frontend/dist/backend/src/payments/stripe/events.d.ts +155 -0
  293. package/frontend/dist/backend/src/payments/stripe/events.js +5 -0
  294. package/frontend/dist/backend/src/payments/stripe/meters.d.ts +105 -0
  295. package/frontend/dist/backend/src/payments/stripe/meters.js +318 -0
  296. package/frontend/dist/backend/src/payments/stripe/payment_methods.d.ts +58 -0
  297. package/frontend/dist/backend/src/payments/stripe/payment_methods.js +135 -0
  298. package/frontend/dist/backend/src/payments/stripe/products.d.ts +519 -0
  299. package/frontend/dist/backend/src/payments/stripe/products.js +896 -0
  300. package/frontend/dist/backend/src/payments/stripe/stripe.d.ts +215 -0
  301. package/frontend/dist/backend/src/payments/stripe/stripe.js +464 -0
  302. package/frontend/dist/backend/src/payments/stripe/subscriptions.d.ts +172 -0
  303. package/frontend/dist/backend/src/payments/stripe/subscriptions.js +754 -0
  304. package/frontend/dist/backend/src/payments/stripe/utils.d.ts +63 -0
  305. package/frontend/dist/backend/src/payments/stripe/utils.js +131 -0
  306. package/frontend/dist/backend/src/payments/stripe/webhooks.d.ts +105 -0
  307. package/frontend/dist/backend/src/payments/stripe/webhooks.js +752 -0
  308. package/frontend/dist/backend/src/plugins/mail/mail.d.ts +255 -0
  309. package/frontend/dist/backend/src/plugins/mail/mail.js +396 -0
  310. package/frontend/dist/backend/src/plugins/mail/ui.d.ts +297 -0
  311. package/frontend/dist/backend/src/plugins/mail/ui.js +1400 -0
  312. package/frontend/dist/backend/src/rate_limit.d.ts +148 -0
  313. package/frontend/dist/backend/src/rate_limit.js +667 -0
  314. package/frontend/dist/backend/src/route.d.ts +39 -0
  315. package/frontend/dist/backend/src/route.js +222 -0
  316. package/frontend/dist/backend/src/server.d.ts +502 -0
  317. package/frontend/dist/backend/src/server.js +2031 -0
  318. package/frontend/dist/backend/src/splash_screen.d.ts +93 -0
  319. package/frontend/dist/backend/src/splash_screen.js +156 -0
  320. package/frontend/dist/backend/src/status.d.ts +89 -0
  321. package/frontend/dist/backend/src/status.js +213 -0
  322. package/frontend/dist/backend/src/stream.d.ts +494 -0
  323. package/frontend/dist/backend/src/stream.js +1611 -0
  324. package/frontend/dist/backend/src/users.d.ts +926 -0
  325. package/frontend/dist/backend/src/users.js +2423 -0
  326. package/frontend/dist/backend/src/utils.d.ts +22 -0
  327. package/frontend/dist/backend/src/utils.js +463 -0
  328. package/frontend/dist/backend/src/view.d.ts +115 -0
  329. package/frontend/dist/backend/src/view.js +584 -0
  330. package/frontend/dist/frontend/src/css/adyen.css +92 -0
  331. package/frontend/dist/frontend/src/css/volt.css +75 -0
  332. package/frontend/dist/frontend/src/elements/base.d.ts +3743 -0
  333. package/frontend/dist/frontend/src/elements/base.js +12151 -0
  334. package/frontend/dist/frontend/src/elements/module.d.ts +95 -0
  335. package/frontend/dist/frontend/src/elements/module.js +216 -0
  336. package/frontend/dist/frontend/src/elements/register_element.d.ts +3 -0
  337. package/frontend/dist/frontend/src/elements/register_element.js +22 -0
  338. package/frontend/dist/frontend/src/elements/resize_query_manager.d.ts +0 -0
  339. package/frontend/dist/frontend/src/elements/resize_query_manager.js +150 -0
  340. package/frontend/dist/frontend/src/elements/types.d.ts +52 -0
  341. package/frontend/dist/frontend/src/elements/types.js +5 -0
  342. package/frontend/dist/frontend/src/index.d.ts +21 -0
  343. package/frontend/dist/frontend/src/index.js +29 -0
  344. package/frontend/dist/frontend/src/modules/attachment.d.ts +126 -0
  345. package/frontend/dist/frontend/src/modules/attachment.js +306 -0
  346. package/frontend/dist/frontend/src/modules/auth.d.ts +44 -0
  347. package/frontend/dist/frontend/src/modules/auth.js +80 -0
  348. package/frontend/dist/frontend/src/modules/color.d.ts +160 -0
  349. package/frontend/dist/frontend/src/modules/color.js +316 -0
  350. package/frontend/dist/frontend/src/modules/compression.d.ts +39 -0
  351. package/frontend/dist/frontend/src/modules/compression.js +102 -0
  352. package/frontend/dist/frontend/src/modules/cookies.d.ts +44 -0
  353. package/frontend/dist/frontend/src/modules/cookies.js +143 -0
  354. package/frontend/dist/frontend/src/modules/events.d.ts +31 -0
  355. package/frontend/dist/frontend/src/modules/events.js +79 -0
  356. package/frontend/dist/frontend/src/modules/google.d.ts +23 -0
  357. package/frontend/dist/frontend/src/modules/google.js +52 -0
  358. package/frontend/dist/frontend/src/modules/meta.d.ts +14 -0
  359. package/frontend/dist/frontend/src/modules/meta.js +48 -0
  360. package/frontend/dist/frontend/src/modules/paddle.d.ts +1207 -0
  361. package/frontend/dist/frontend/src/modules/paddle.js +2594 -0
  362. package/frontend/dist/frontend/src/modules/request.d.ts +70 -0
  363. package/frontend/dist/frontend/src/modules/request.js +117 -0
  364. package/frontend/dist/frontend/src/modules/settings.d.ts +3 -0
  365. package/frontend/dist/frontend/src/modules/settings.js +5 -0
  366. package/frontend/dist/frontend/src/modules/statics.d.ts +21 -0
  367. package/frontend/dist/frontend/src/modules/statics.js +43 -0
  368. package/frontend/dist/frontend/src/modules/stripe/cart.d.ts +112 -0
  369. package/frontend/dist/frontend/src/modules/stripe/cart.js +321 -0
  370. package/frontend/dist/frontend/src/modules/stripe/checkout.d.ts +7 -0
  371. package/frontend/dist/frontend/src/modules/stripe/checkout.js +37 -0
  372. package/frontend/dist/frontend/src/modules/stripe/index.m.d.ts +6 -0
  373. package/frontend/dist/frontend/src/modules/stripe/index.m.js +6 -0
  374. package/frontend/dist/frontend/src/modules/stripe/payments.d.ts +58 -0
  375. package/frontend/dist/frontend/src/modules/stripe/payments.js +92 -0
  376. package/frontend/dist/frontend/src/modules/support.d.ts +30 -0
  377. package/frontend/dist/frontend/src/modules/support.js +53 -0
  378. package/frontend/dist/frontend/src/modules/theme.d.ts +133 -0
  379. package/frontend/dist/frontend/src/modules/theme.js +406 -0
  380. package/frontend/dist/frontend/src/modules/themes.d.ts +12 -0
  381. package/frontend/dist/frontend/src/modules/themes.js +22 -0
  382. package/frontend/dist/frontend/src/modules/user.d.ts +164 -0
  383. package/frontend/dist/frontend/src/modules/user.js +270 -0
  384. package/frontend/dist/frontend/src/modules/utils.d.ts +176 -0
  385. package/frontend/dist/frontend/src/modules/utils.js +569 -0
  386. package/frontend/dist/frontend/src/types/gradient.d.ts +29 -0
  387. package/frontend/dist/frontend/src/types/gradient.js +79 -0
  388. package/frontend/dist/frontend/src/ui/border_button.d.ts +94 -0
  389. package/frontend/dist/frontend/src/ui/border_button.js +228 -0
  390. package/frontend/dist/frontend/src/ui/button.d.ts +241 -0
  391. package/frontend/dist/frontend/src/ui/button.js +682 -0
  392. package/frontend/dist/frontend/src/ui/canvas.d.ts +138 -0
  393. package/frontend/dist/frontend/src/ui/canvas.js +444 -0
  394. package/frontend/dist/frontend/src/ui/checkbox.d.ts +74 -0
  395. package/frontend/dist/frontend/src/ui/checkbox.js +321 -0
  396. package/frontend/dist/frontend/src/ui/code.d.ts +235 -0
  397. package/frontend/dist/frontend/src/ui/code.js +1007 -0
  398. package/frontend/dist/frontend/src/ui/context_menu.d.ts +36 -0
  399. package/frontend/dist/frontend/src/ui/context_menu.js +205 -0
  400. package/frontend/dist/frontend/src/ui/css.d.ts +16 -0
  401. package/frontend/dist/frontend/src/ui/css.js +48 -0
  402. package/frontend/dist/frontend/src/ui/divider.d.ts +15 -0
  403. package/frontend/dist/frontend/src/ui/divider.js +78 -0
  404. package/frontend/dist/frontend/src/ui/dropdown.d.ts +176 -0
  405. package/frontend/dist/frontend/src/ui/dropdown.js +481 -0
  406. package/frontend/dist/frontend/src/ui/for_each.d.ts +37 -0
  407. package/frontend/dist/frontend/src/ui/for_each.js +92 -0
  408. package/frontend/dist/frontend/src/ui/form.d.ts +34 -0
  409. package/frontend/dist/frontend/src/ui/form.js +233 -0
  410. package/frontend/dist/frontend/src/ui/frame_modes.d.ts +37 -0
  411. package/frontend/dist/frontend/src/ui/frame_modes.js +108 -0
  412. package/frontend/dist/frontend/src/ui/google_map.d.ts +24 -0
  413. package/frontend/dist/frontend/src/ui/google_map.js +106 -0
  414. package/frontend/dist/frontend/src/ui/gradient.d.ts +25 -0
  415. package/frontend/dist/frontend/src/ui/gradient.js +131 -0
  416. package/frontend/dist/frontend/src/ui/image.d.ts +111 -0
  417. package/frontend/dist/frontend/src/ui/image.js +576 -0
  418. package/frontend/dist/frontend/src/ui/input.d.ts +392 -0
  419. package/frontend/dist/frontend/src/ui/input.js +1201 -0
  420. package/frontend/dist/frontend/src/ui/link.d.ts +25 -0
  421. package/frontend/dist/frontend/src/ui/link.js +140 -0
  422. package/frontend/dist/frontend/src/ui/list.d.ts +37 -0
  423. package/frontend/dist/frontend/src/ui/list.js +170 -0
  424. package/frontend/dist/frontend/src/ui/loader_button.d.ts +80 -0
  425. package/frontend/dist/frontend/src/ui/loader_button.js +193 -0
  426. package/frontend/dist/frontend/src/ui/loaders.d.ts +57 -0
  427. package/frontend/dist/frontend/src/ui/loaders.js +157 -0
  428. package/frontend/dist/frontend/src/ui/popup.d.ts +94 -0
  429. package/frontend/dist/frontend/src/ui/popup.js +510 -0
  430. package/frontend/dist/frontend/src/ui/pseudo.d.ts +44 -0
  431. package/frontend/dist/frontend/src/ui/pseudo.js +154 -0
  432. package/frontend/dist/frontend/src/ui/scroller.d.ts +105 -0
  433. package/frontend/dist/frontend/src/ui/scroller.js +1253 -0
  434. package/frontend/dist/frontend/src/ui/slider.d.ts +45 -0
  435. package/frontend/dist/frontend/src/ui/slider.js +217 -0
  436. package/frontend/dist/frontend/src/ui/spacer.d.ts +15 -0
  437. package/frontend/dist/frontend/src/ui/spacer.js +78 -0
  438. package/frontend/dist/frontend/src/ui/span.d.ts +15 -0
  439. package/frontend/dist/frontend/src/ui/span.js +73 -0
  440. package/frontend/dist/frontend/src/ui/stack.d.ts +66 -0
  441. package/frontend/dist/frontend/src/ui/stack.js +335 -0
  442. package/frontend/dist/frontend/src/ui/steps.d.ts +131 -0
  443. package/frontend/dist/frontend/src/ui/steps.js +308 -0
  444. package/frontend/dist/frontend/src/ui/style.d.ts +17 -0
  445. package/frontend/dist/frontend/src/ui/style.js +73 -0
  446. package/frontend/dist/frontend/src/ui/switch.d.ts +69 -0
  447. package/frontend/dist/frontend/src/ui/switch.js +357 -0
  448. package/frontend/dist/frontend/src/ui/table.d.ts +100 -0
  449. package/frontend/dist/frontend/src/ui/table.js +405 -0
  450. package/frontend/dist/frontend/src/ui/tabs.d.ts +111 -0
  451. package/frontend/dist/frontend/src/ui/tabs.js +424 -0
  452. package/frontend/dist/frontend/src/ui/text.d.ts +15 -0
  453. package/frontend/dist/frontend/src/ui/text.js +83 -0
  454. package/frontend/dist/frontend/src/ui/title.d.ts +91 -0
  455. package/frontend/dist/frontend/src/ui/title.js +272 -0
  456. package/frontend/dist/frontend/src/ui/ui.d.ts +35 -0
  457. package/frontend/dist/frontend/src/ui/ui.js +38 -0
  458. package/frontend/dist/frontend/src/ui/view.d.ts +15 -0
  459. package/frontend/dist/frontend/src/ui/view.js +88 -0
  460. package/frontend/dist/frontend/src/volt.d.ts +20 -0
  461. package/frontend/dist/frontend/src/volt.js +27 -0
  462. package/package.json +7 -2
@@ -0,0 +1,926 @@
1
+ /**
2
+ * @author Daan van den Bergh
3
+ * @copyright © 2022 - 2025 Daan van den Bergh.
4
+ */
5
+ import { Mail } from "./plugins/mail/mail.js";
6
+ import { Stream } from "./stream.js";
7
+ import { Server } from "./server.js";
8
+ import { Collection } from "./database/collection.js";
9
+ import { Request } from "../../frontend/src/modules/request.js";
10
+ /**
11
+ * The user object / document.
12
+ * @nav Server
13
+ * @docs
14
+ */
15
+ export type User = {
16
+ /** The user identifier (unique index). */
17
+ uid: string;
18
+ /** The users username (unique index). */
19
+ username: string;
20
+ /** The users email address (unique index). */
21
+ email: string;
22
+ /** The users first name. */
23
+ first_name: string;
24
+ /** The users last name. */
25
+ last_name: string;
26
+ /** The hashed password. */
27
+ password: string;
28
+ /** The users phone number. */
29
+ phone_number?: string;
30
+ /** The created at unix msec timestamp. */
31
+ created_at: number;
32
+ /** The hashed api key (only defined once generated) (non unique index). */
33
+ api_key?: string;
34
+ /** The users support pin, used for support contact validation. */
35
+ support_pin: string;
36
+ /** Whether the user is activated. */
37
+ is_activated: boolean;
38
+ };
39
+ /** Nested types for the {@link User} interface */
40
+ export declare namespace User {
41
+ /**
42
+ * The frontend representation of a user.
43
+ * @docs
44
+ */
45
+ type Frontend = {
46
+ uid: string;
47
+ username: string;
48
+ email: string;
49
+ first_name: string;
50
+ last_name: string;
51
+ phone_number?: string;
52
+ created_at: number;
53
+ has_api_key: boolean;
54
+ support_pin: string;
55
+ is_activated: boolean;
56
+ };
57
+ /**
58
+ * The token object / document.
59
+ * @docs
60
+ */
61
+ type Token = {
62
+ /** The user id. */
63
+ uid: string;
64
+ /** Expiration unix timestamp */
65
+ expiration: number;
66
+ /** The hashed token. */
67
+ token: string;
68
+ /** Is token still active. */
69
+ active: boolean;
70
+ };
71
+ /**
72
+ * The token object / document.
73
+ * @docs
74
+ */
75
+ type TwoFactorAuthToken = {
76
+ /** The user id. */
77
+ uid: string;
78
+ /** Expiration unix timestamp */
79
+ expiration: number;
80
+ /** The correct 2fa code. */
81
+ code: string;
82
+ /** Is token still active. */
83
+ active: boolean;
84
+ };
85
+ }
86
+ /**
87
+ * The users class, used for user management, authentication, and user data storage.
88
+ * @note This class is accessible via `Server.users`.
89
+ * @nav Server
90
+ * @docs
91
+ */
92
+ export declare class Users {
93
+ /**
94
+ * Number of random characters after `<prefix>_<uid>_`.
95
+ * @warning If you change this, also update:
96
+ * - {@link Users.LEGACY_TOKEN_SUFFIX_LENS} to include old size(s).
97
+ * - Generators {@link _generate_api_key} and {@link _generate_token}.
98
+ * - Parser {@link _parse_uid_from_token_api_key}.
99
+ */
100
+ private static readonly TOKEN_SUFFIX_LEN;
101
+ /** Accepted legacy suffix lengths; add old sizes here when rotating. */
102
+ private static readonly LEGACY_TOKEN_SUFFIX_LENS;
103
+ /**
104
+ * Allowed characters for the random suffix.
105
+ * @warning MUST NOT include `_` (delimiter). ASCII only for fast-path validation.
106
+ */
107
+ private static readonly TOKEN_SUFFIX_CHARSET;
108
+ /**
109
+ * UID length used by the generator.
110
+ * @warning If you change this, add the old value to {@link Users.LEGACY_UID_LENGTHS}.
111
+ */
112
+ private static readonly UID_LENGTH;
113
+ /** Accepted legacy UID lengths; add old sizes here when rotating. */
114
+ private static readonly LEGACY_UID_LENGTHS;
115
+ /**
116
+ * UID character set (ASCII). MUST NOT include `_`.
117
+ */
118
+ private static readonly UID_CHARSET;
119
+ /**
120
+ * Build an ASCII allow table for fast membership checks.
121
+ * Index is charCode (0..127), value is 1 if allowed else 0.
122
+ */
123
+ private static _build_ascii_allow;
124
+ /** ASCII allow table for token suffix validation (built from TOKEN_SUFFIX_CHARSET). */
125
+ private static readonly TOKEN_SUFFIX_ALLOW;
126
+ /** ASCII allow table for UID validation (built from UID_CHARSET). */
127
+ private static readonly UID_ALLOW;
128
+ /** The parent server instance. */
129
+ private server;
130
+ /** The recipient email for support submit emails, defaults to `Server.smtp_sender`. */
131
+ private support_recipient?;
132
+ /** The avg wait time when sending 2FA codes. */
133
+ private avg_send_2fa_time;
134
+ /** The database collection for token documents. */
135
+ private _tokens_db;
136
+ /** The database collection for 2fa token documents. */
137
+ private _2fa_tokens_db;
138
+ /** The database collection for user documents. */
139
+ private _users_db;
140
+ /** Enable 2FA for user sign in. */
141
+ private enable_2fa;
142
+ /** Enable 2FA account activation for user sign up. */
143
+ private enable_account_activation;
144
+ /** The token expiration in seconds */
145
+ private token_expiration;
146
+ /** Database collection for public (read:public, write:public) user documents. */
147
+ public: Collection<{
148
+ uid: string;
149
+ query?: string;
150
+ data: Users.Endpoints.JsonValue;
151
+ }>;
152
+ /** Database collection for protected (read:public, write:private) user documents. */
153
+ protected: Collection<{
154
+ uid: string;
155
+ query?: string;
156
+ data: Users.Endpoints.JsonValue;
157
+ }>;
158
+ /** Database collection for private (read:private, write:private) user documents. */
159
+ private: Collection<{
160
+ uid: string;
161
+ query?: string;
162
+ data: Users.Endpoints.JsonValue;
163
+ }>;
164
+ /** Construct the users manager. */
165
+ constructor(opts: Users.Opts & {
166
+ _server: Server;
167
+ });
168
+ /** Generate a code. */
169
+ private _generate_code;
170
+ /**
171
+ * Generate a crypto str.
172
+ * @warning ENSURE this does not add `_` to the charset, as this is used as a delimiter for tokens/api keys.
173
+ */
174
+ private _generate_crypto_str;
175
+ /**
176
+ * Derive a key with the async `crypto.scrypt` to avoid blocking the event loop.
177
+ * Using the sync variant is CPU-bound and can stall Node’s main thread, enabling
178
+ * trivial DoS via many concurrent hash ops. The async call runs in libuv’s
179
+ * thread pool, preserving responsiveness under load with the same security.
180
+ *
181
+ * @param password - Secret/password or input buffer.
182
+ * @param salt - Per-secret random salt.
183
+ * @param keylen - Desired key length in bytes (default 64).
184
+ * @returns Promise resolving to the derived key buffer.
185
+ */
186
+ private _crypto_scrypt;
187
+ /** Hash a password. */
188
+ private _hash_password;
189
+ /** Verify a plain password vs stored hashed password. */
190
+ private _verify_password;
191
+ /** Generate a unique user ID. */
192
+ private _generate_uid;
193
+ /** Generate an API key. Format: `ak_<uid>_<suffix>` */
194
+ private _generate_api_key;
195
+ /** Generate a token. Format: `tk_<uid>_<suffix>` */
196
+ private _generate_token;
197
+ /**
198
+ * Parse the uid from `<prefix>_<uid>_<suffix>`, where prefix is `ak_` or `tk_`,
199
+ * `<uid>` passes {@link Users.is_valid_uid}, and `<suffix>`:
200
+ * - length equals {@link Users.TOKEN_SUFFIX_LEN} or a legacy size; and
201
+ * - every char is in {@link Users.TOKEN_SUFFIX_CHARSET} (ASCII).
202
+ *
203
+ * @warning If you change suffix length, add old sizes to
204
+ * {@link Users.LEGACY_TOKEN_SUFFIX_LENS}. If you change charset, update
205
+ * {@link Users.TOKEN_SUFFIX_CHARSET} (this table rebuilds automatically).
206
+ * If you change delimiters/prefixes, update this and the generators together.
207
+ */
208
+ private _parse_uid_from_token_api_key;
209
+ /**
210
+ * Validate a proposed new password against basic rules and confirmation.
211
+ * @param pass The new password to validate.
212
+ * @param verify_pass The repeated password to confirm.
213
+ * @returns An object with optional error message and invalid_fields mapping.
214
+ */
215
+ private _verify_new_pass;
216
+ /**
217
+ * Generate and persist a new auth token for the given uid.
218
+ * @param uid The user ID.
219
+ * @returns The plaintext token string.
220
+ */
221
+ _create_token(uid: string): Promise<string>;
222
+ /**
223
+ * Deactivate the current token for the given uid.
224
+ * @param uid The user ID.
225
+ */
226
+ _deactivate_token(uid: string): Promise<void>;
227
+ /**
228
+ * Create and store a short-lived 2FA token (code).
229
+ * @param uid_or_email The uid or email key used for the 2FA record.
230
+ * @param expiration Expiration in seconds from now.
231
+ * @returns The generated 2FA code.
232
+ */
233
+ _create_2fa_token(uid_or_email: string, expiration: number): Promise<string>;
234
+ /**
235
+ * Deactivate a stored 2FA token by uid/email key.
236
+ * @param uid_or_email The uid or email key used for the 2FA record.
237
+ */
238
+ _deactivate_2fa_token(uid_or_email: string): Promise<void>;
239
+ /**
240
+ * Perform authentication on a request.
241
+ * @returns An object on refusal, undefined on success.
242
+ */
243
+ _authenticate(stream: Stream): Promise<{
244
+ status: number;
245
+ headers?: {
246
+ [key: string]: string;
247
+ };
248
+ data: string;
249
+ } | undefined>;
250
+ /**
251
+ * Sign a user in, set cookies, and optionally send the success response.
252
+ * @param stream The request stream.
253
+ * @param uid The authenticated user's ID.
254
+ * @param opts Optional settings (e.g., send: false to skip sending the response).
255
+ */
256
+ _sign_in_response(stream: Stream, uid: string, opts?: {
257
+ /** Send the response (defaults to true). */
258
+ send: boolean;
259
+ }): Promise<void>;
260
+ /**
261
+ * Create the auth token cookie on the response.
262
+ * `T` is treated as a real authentication credential.
263
+ *
264
+ * @param stream The request stream.
265
+ * @param token The token string or Token object.
266
+ */
267
+ _create_token_cookie(stream: Stream, token: string | User.Token): void;
268
+ /**
269
+ * Create user cookies (ID and activation flag).
270
+ * These are user-state cookies, NOT auth credentials.
271
+ *
272
+ * @param stream The request stream.
273
+ * @param uid The user ID, or invalid to clear.
274
+ */
275
+ _create_user_cookie(stream: Stream, uid: string | null): Promise<void>;
276
+ /**
277
+ * Create non-HttpOnly cookies with detailed user info for frontend usage.
278
+ * These are UI convenience cookies only.
279
+ *
280
+ * @param stream The request stream.
281
+ * @param uid The user ID.
282
+ */
283
+ _create_detailed_user_cookie(stream: Stream, uid: string): Promise<void>;
284
+ /**
285
+ * Clear all default auth and user-related cookies.
286
+ *
287
+ * @param stream The request stream.
288
+ */
289
+ _reset_cookies(stream: Stream): void;
290
+ /** Build the base email layout used by the various transactional email builders. */
291
+ private _2fa_mail_template;
292
+ /**
293
+ * Build the 2FA verification email content.
294
+ */
295
+ private set_default_2fa_event;
296
+ /**
297
+ * Initialize default authentication, user, and support endpoints.
298
+ */
299
+ _initialize({ worker, }?: {
300
+ /** The `worker` flag passed to `Server.initialize()` */
301
+ worker?: boolean;
302
+ }): Promise<void>;
303
+ /**
304
+ * Validate a UID against ASCII charset and allowed lengths (current + legacy).
305
+ * @dev_warning
306
+ * If you change {@link Users.UID_CHARSET} or {@link Users.UID_LENGTH},
307
+ * update {@link Users.LEGACY_UID_LENGTHS} for backward compatibility.
308
+ *
309
+ * @docs
310
+ */
311
+ is_valid_uid(uid: string): boolean;
312
+ /**
313
+ * Check if a uid exists.
314
+ * @param uid The user ID to check.
315
+ * @returns True if a user with the given uid exists.
316
+ *
317
+ * @docs
318
+ */
319
+ uid_exists(uid: string): Promise<boolean>;
320
+ /**
321
+ * Check if a username exists.
322
+ * @returns Returns a boolean indicating whether the username exists or not.
323
+ * @param username The username to check.
324
+ * @example
325
+ * const exists = await server.users.username_exists("someusername");
326
+ *
327
+ * @docs
328
+ */
329
+ username_exists(username: string): Promise<boolean>;
330
+ /**
331
+ * Check if an email exists.
332
+ * @returns Returns a boolean indicating whether the email exists or not.
333
+ * @param email The email to check.
334
+ * @example
335
+ * const exists = await server.users.email_exists("some@email.com");
336
+ *
337
+ * @docs
338
+ */
339
+ email_exists(email: string): Promise<boolean>;
340
+ /**
341
+ * Check if a user account is activated.
342
+ * @returns Returns a boolean indicating whether the account is activated or not.
343
+ * @param uid The id of the user.
344
+ * @example
345
+ * const activated = await server.users.is_activated("0");
346
+ *
347
+ * @docs
348
+ */
349
+ is_activated(uid: string): Promise<boolean>;
350
+ /**
351
+ * Set the activated status of a user account.
352
+ * @param uid The user id.
353
+ * @param is_activated The boolean with the new activated status.
354
+ * @example
355
+ * await server.users.set_activated("1", true);
356
+ *
357
+ * @docs
358
+ */
359
+ set_activated(uid: string, is_activated: boolean): Promise<void>;
360
+ /**
361
+ * Create a user account. Only the hashed password will be saved.
362
+ * @returns Returns the uid of the newly created user.
363
+ * @param first_name The user's first name.
364
+ * @param last_name The user's last name.
365
+ * @param username The username of the new account.
366
+ * @param email The email of the new account.
367
+ * @param password The password of the new account.
368
+ * @param verify_password An optional second password input to check against the first input to ensure its the same.
369
+ * @param phone_number The phone number of the user account.
370
+ * @param is_activated Whether the account should be set to activated; by default `!Server.enable_account_activation`.
371
+ * @example
372
+ * const uid = await server.users.create({
373
+ * first_name: "John",
374
+ * last_name: "Doe",
375
+ * username: "johndoe",
376
+ * email: "johndoe@email.com",
377
+ * password: "HelloWorld!"
378
+ * });
379
+ *
380
+ * @docs
381
+ */
382
+ create({ first_name, last_name, username, email, password, verify_password, phone_number, is_activated, _check_username_email, }: {
383
+ first_name: string;
384
+ last_name: string;
385
+ username: string;
386
+ email: string;
387
+ password: string;
388
+ verify_password?: string;
389
+ phone_number?: string;
390
+ is_activated?: boolean;
391
+ _check_username_email?: boolean;
392
+ }): Promise<string>;
393
+ /**
394
+ * Delete a user account and associated data.
395
+ * @param uid The user id.
396
+ * @example
397
+ * await server.users.delete("0");
398
+ *
399
+ * @docs
400
+ */
401
+ delete(uid: string): Promise<void>;
402
+ /**
403
+ * Set a user's first name. Throws if uid does not exist.
404
+ * @param uid The user id.
405
+ * @param first_name The new first name.
406
+ * @example
407
+ * await server.users.set_first_name("1", "John");
408
+ *
409
+ * @docs
410
+ */
411
+ set_first_name(uid: string, first_name: string): Promise<void>;
412
+ /**
413
+ * Set a user's last name. Throws if uid does not exist.
414
+ * @param uid The user id.
415
+ * @param last_name The new last name.
416
+ * @example
417
+ * await server.users.set_last_name("1", "Doe");
418
+ *
419
+ * @docs
420
+ */
421
+ set_last_name(uid: string, last_name: string): Promise<void>;
422
+ /**
423
+ * Set a user's username. Throws if uid does not exist.
424
+ * @param uid The user id.
425
+ * @param username The new username.
426
+ * @example
427
+ * await server.users.set_username("1", "newusername");
428
+ *
429
+ * @docs
430
+ */
431
+ set_username(uid: string, username: string): Promise<void>;
432
+ /**
433
+ * Set a user's email. Throws if uid does not exist.
434
+ * @param uid The user id.
435
+ * @param email The new email.
436
+ * @example
437
+ * await server.users.set_email("1", "new@email.com");
438
+ *
439
+ * @docs
440
+ */
441
+ set_email(uid: string, email: string): Promise<void>;
442
+ /**
443
+ * Set a user's password. Throws on invalid input or unknown uid.
444
+ * @param uid The user id.
445
+ * @param password The new password.
446
+ * @example
447
+ * await server.users.set_password("1", "XXXXXX");
448
+ *
449
+ * @docs
450
+ */
451
+ set_password(uid: string, password: string, verify_password?: string): Promise<void>;
452
+ /**
453
+ * Update an existing user object.
454
+ *
455
+ * This function only updates the passed user attributes, unpresent attributes will not be deleted.
456
+ *
457
+ * If the uid does not exist an `Error` will be thrown.
458
+ *
459
+ * A password will automatically be hashed if passed.
460
+ *
461
+ * Updating the API key through this function is not allowed (wont work).
462
+ *
463
+ * @warning Does not upsert documents.
464
+ *
465
+ * @docs
466
+ */
467
+ set(uid: string, data: {
468
+ first_name?: User["first_name"];
469
+ last_name?: User["last_name"];
470
+ phone_number?: User["phone_number"];
471
+ is_activated?: User["is_activated"];
472
+ password?: User["password"];
473
+ username?: User["username"];
474
+ email?: User["email"];
475
+ }): Promise<void>;
476
+ /**
477
+ * Insert new data into an EXISTING user.
478
+ * @warning Does not upsert documents.
479
+ */
480
+ private _sys_set;
481
+ /**
482
+ * Get a user by uid. Throws if the uid does not exist.
483
+ * @returns Returns a User object.
484
+ * @param uid The user id.
485
+ * @throws {Collection.NotFoundError} If the user id does not exist.
486
+ * @example
487
+ * const user = await server.users.get("0");
488
+ *
489
+ * @docs
490
+ */
491
+ get(uid: string): Promise<User>;
492
+ /**
493
+ * Get a user by username. Throws if the username does not exist.
494
+ * @returns Returns a User object.
495
+ * @param username The username of the user to fetch.
496
+ * @throws {Collection.NotFoundError} If the username does not exist.
497
+ * @example
498
+ * const user = await server.users.get_by_username("myusername");
499
+ *
500
+ * @docs
501
+ */
502
+ get_by_username(username: string): Promise<User>;
503
+ /**
504
+ * Get a user by uid or username.
505
+ * This function can be used if you have a variable which can be both.
506
+ * Throws if the username does not exist.
507
+ * @returns Returns a User object.
508
+ * @param username The username of the user to fetch.
509
+ * @throws {Collection.NotFoundError} If the username or uid does not exist.
510
+ * @example
511
+ * const user = await server.users.get_by_username("myusername");
512
+ *
513
+ * @docs
514
+ */
515
+ get_by_uid_or_username(uid_or_username: string): Promise<User>;
516
+ /**
517
+ * Get a user by email. Throws if the email does not exist.
518
+ * @returns Returns a User object.
519
+ * @param email The email of the user to fetch.
520
+ * @throws {Collection.NotFoundError} If the email does not exist.
521
+ * @example
522
+ * const user = await server.users.get_by_email("my@email.com");
523
+ *
524
+ * @docs
525
+ */
526
+ get_by_email(email: string): Promise<User>;
527
+ /**
528
+ * Get a user by API key. Throws if invalid.
529
+ * @returns Returns a User object.
530
+ * @param api_key The API key of the user to fetch.
531
+ * @example
532
+ * const user = await server.users.get_by_api_key("XXXXXX");
533
+ *
534
+ * @docs
535
+ */
536
+ get_by_api_key(api_key: string): Promise<User>;
537
+ /**
538
+ * Get a user by token. Throws if invalid.
539
+ * @returns Returns a User object.
540
+ * @param token The authentication token of the user to fetch.
541
+ * @example
542
+ * const user = await server.users.get_by_token("XXXXXX");
543
+ *
544
+ * @docs
545
+ */
546
+ get_by_token(token: string): Promise<User>;
547
+ /**
548
+ * Get a uid by username.
549
+ * @returns Returns the uid of the username, or undefined if not found.
550
+ * @param username The username of the uid to fetch.
551
+ * @example
552
+ * const uid = await server.users.get_uid("myusername");
553
+ *
554
+ * @docs
555
+ */
556
+ get_uid(username: string): Promise<string | undefined>;
557
+ /**
558
+ * Get a uid by username.
559
+ * @returns Returns the uid of the username, or undefined if not found.
560
+ * @param username The username of the uid to fetch.
561
+ * @example
562
+ * const uid = await server.users.get_uid_by_username("myuser");
563
+ *
564
+ * @docs
565
+ */
566
+ get_uid_by_username(username: string): Promise<string | undefined>;
567
+ /**
568
+ * Get a uid by email.
569
+ * @returns Returns the uid of the email, or undefined if not found.
570
+ * @param email The email of the uid to fetch.
571
+ * @example
572
+ * const uid = await server.users.get_uid_by_email("my@email.com");
573
+ *
574
+ * @docs
575
+ */
576
+ get_uid_by_email(email: string): Promise<string | undefined>;
577
+ /**
578
+ * Get a uid by API key.
579
+ * @returns Returns the uid for the API key, or undefined if not valid.
580
+ * @param api_key The API key to parse.
581
+ * @example
582
+ * const uid = server.users.get_uid_by_api_key("XXXXXXXXXX");
583
+ *
584
+ * @docs
585
+ */
586
+ get_uid_by_api_key(api_key: string): string | undefined;
587
+ /**
588
+ * Get a uid by token.
589
+ * @returns Returns the uid for the token, or undefined if not valid.
590
+ * @param token The token to parse.
591
+ * @example
592
+ * const uid = server.users.get_uid_by_token("XXXXXXXXXX");
593
+ *
594
+ * @docs
595
+ */
596
+ get_uid_by_token(token: string): string | undefined;
597
+ /**
598
+ * Get a user's support pin by uid.
599
+ * @returns Returns the support PIN string.
600
+ * @param uid The user id.
601
+ * @example
602
+ * const pin = await server.users.get_support_pin("1");
603
+ *
604
+ * @docs
605
+ */
606
+ get_support_pin(uid: string): Promise<string>;
607
+ /**
608
+ * Generate an API key for a user and store its hash. Overwrites existing keys.
609
+ * @returns Returns the API key string (plaintext).
610
+ * @param uid The user id.
611
+ * @example
612
+ * const api_key = await server.users.generate_api_key("0");
613
+ *
614
+ * @docs
615
+ */
616
+ generate_api_key(uid: string): Promise<string>;
617
+ /**
618
+ * Check if a user has a generated API key.
619
+ * @returns Returns a boolean indicating whether the user has an API key.
620
+ * @param uid The user id.
621
+ * @throws {Collection.NotFoundError} If the user id does not exist.
622
+ * @example
623
+ * const has_api_key = await server.users.has_api_key("0");
624
+ *
625
+ * @docs
626
+ */
627
+ has_api_key(uid: string): Promise<boolean>;
628
+ /**
629
+ * Revoke the API key of a user.
630
+ * @param uid The user id.
631
+ * @example
632
+ * await server.users.revoke_api_key("0");
633
+ *
634
+ * @docs
635
+ */
636
+ revoke_api_key(uid: string): Promise<void>;
637
+ /**
638
+ * Verify a plaintext password.
639
+ * @returns Returns a boolean indicating whether the verification was successful.
640
+ * @param uid The user id.
641
+ * @param password The plaintext password.
642
+ * @example
643
+ * const success = await server.users.verify_password("1", "XXXXXX");
644
+ *
645
+ * @docs
646
+ */
647
+ verify_password(uid: string, password: string): Promise<boolean>;
648
+ /**
649
+ * Verify a plaintext API key.
650
+ * @returns Returns a boolean indicating whether the verification was successful.
651
+ * @param api_key The api key to verify.
652
+ * @example
653
+ * const success = await server.users.verify_api_key("XXXXXX");
654
+ *
655
+ * @docs
656
+ */
657
+ verify_api_key(api_key: string): Promise<boolean>;
658
+ /**
659
+ * Verify a plaintext API key by uid.
660
+ * @returns Returns a boolean indicating whether the verification was successful.
661
+ * @param uid The user id.
662
+ * @param api_key The api key to verify.
663
+ * @example
664
+ * const success = await server.users.verify_api_key_by_uid("1", "XXXXXX");
665
+ *
666
+ * @docs
667
+ */
668
+ verify_api_key_by_uid(uid: string | undefined | null, api_key: string): Promise<boolean>;
669
+ /**
670
+ * Verify a plaintext token.
671
+ * @returns Returns a boolean indicating whether the verification was successful.
672
+ * @param token The token to verify.
673
+ * @example
674
+ * const success = await server.users.verify_token("XXXXXX");
675
+ *
676
+ * @docs
677
+ */
678
+ verify_token(token: string): Promise<boolean>;
679
+ /**
680
+ * Verify a plaintext token by uid.
681
+ * @returns Returns a boolean indicating whether the verification was successful.
682
+ * @param uid The user id.
683
+ * @param token The token to verify.
684
+ * @example
685
+ * const success = await server.users.verify_token_by_uid("1", "XXXXXX");
686
+ *
687
+ * @docs
688
+ */
689
+ verify_token_by_uid(uid: string | undefined | null, token: string): Promise<boolean>;
690
+ /**
691
+ * Verify a 2FA code by user id/email key.
692
+ * @param uid The UID or email used when creating the 2FA token.
693
+ * @param code The 2FA code.
694
+ * @returns Returns undefined on success, otherwise a string describing the error.
695
+ * @example
696
+ * await server.users.verify_2fa("1", "123456");
697
+ *
698
+ * @docs
699
+ */
700
+ verify_2fa(uid: string, code: string): Promise<string | undefined>;
701
+ /**
702
+ * Send a 2FA code to a user by user id.
703
+ * By default the 2FA code will be valid for 5 minutes.
704
+ * The mail body is generated via `Server.on_2fa_mail({code, username, email, date, ip, device})`.
705
+ * @returns Returns a promise that resolves when the 2FA mail has been sent.
706
+ * @param uid The user id (or use _email with internal flow).
707
+ * @param stream The stream object from the client request.
708
+ * @param expiration The amount of seconds in which the code will expire.
709
+ * @example
710
+ * await server.users.send_2fa({ uid: "0", stream });
711
+ *
712
+ * @docs
713
+ */
714
+ send_2fa({ uid, stream, expiration, _user_agent, _username, _email, }: {
715
+ uid: string;
716
+ stream: Stream;
717
+ expiration?: number;
718
+ _user_agent?: string;
719
+ _username?: string;
720
+ _email?: string;
721
+ }): Promise<void>;
722
+ /**
723
+ * List all users.
724
+ * @returns An array of User objects.
725
+ *
726
+ * @docs
727
+ */
728
+ list(): Promise<User[]>;
729
+ }
730
+ /** Nested types for the {@link User} class. */
731
+ export declare namespace Users {
732
+ /**
733
+ * Options for constructing a {@link Users} instance.
734
+ * @docs
735
+ */
736
+ interface Opts {
737
+ /** The number of seconds a sign-in token will be valid. */
738
+ token_expiration?: number;
739
+ /** Enable 2FA for user authentication. */
740
+ enable_2fa?: boolean;
741
+ /** Enable account activation by email after a user signs up. */
742
+ enable_account_activation?: boolean;
743
+ /** The email address to send support requests to, defaults to {@link Server.Opts.smtp.sender} if defined */
744
+ support_recipient?: Mail.Address;
745
+ }
746
+ /** The types for the frontend endpoints. */
747
+ namespace Endpoints {
748
+ /** The get user endpoint. */
749
+ type GetUser = Request.Info<"GET", "/volt/api/v1/user", undefined, User.Frontend, undefined>;
750
+ /** The update user endpoint. */
751
+ type UpdateUser = Request.Info<"POST", "/volt/api/v1/user", {
752
+ first_name?: string;
753
+ last_name?: string;
754
+ phone_number?: string;
755
+ username?: string;
756
+ email?: string;
757
+ }, {
758
+ message: string;
759
+ }, undefined>;
760
+ /** The activate user endpoint. */
761
+ type ActivateUser = Request.Info<"POST", "/volt/api/v1/auth/activate", {
762
+ code: string;
763
+ }, {
764
+ message: string;
765
+ }, undefined>;
766
+ /** The change password endpoint. */
767
+ type ChangePassword = Request.Info<"POST", "/volt/api/v1/user/change_password", {
768
+ current_password: string;
769
+ password: string;
770
+ verify_password: string;
771
+ }, {
772
+ message: string;
773
+ }, undefined>;
774
+ /** The delete user endpoint. */
775
+ type DeleteUser = Request.Info<"DELETE", "/volt/api/v1/user", undefined, {
776
+ message: string;
777
+ }, undefined>;
778
+ /** The generate api key endpoint. */
779
+ type GenerateAPIKey = Request.Info<"POST", "/volt/api/v1/user/api_key", undefined, {
780
+ message: string;
781
+ api_key: string;
782
+ }, undefined>;
783
+ /** The has api key endpoint. */
784
+ type HasAPIKey = Request.Info<"GET", "/volt/api/v1/user/has_api_key", undefined, {
785
+ message: string;
786
+ has_api_key: boolean;
787
+ }, undefined>;
788
+ /** The revoke api key endpoint. */
789
+ type RevokeAPIKey = Request.Info<"DELETE", "/volt/api/v1/user/api_key", undefined, {
790
+ message: string;
791
+ }, undefined>;
792
+ /** JSON values for LoadUserData data field etc. */
793
+ type JsonValue = string | number | boolean | null | JsonArray | JsonObject;
794
+ type JsonArray = Array<JsonValue>;
795
+ type JsonObject = {
796
+ [key: string]: JsonValue;
797
+ };
798
+ const JsonValueSchemaType: readonly ["string", "number", "boolean", "null", "array", "object"];
799
+ /** The load public user data endpoint. */
800
+ type LoadUserData = Request.Info<"GET", "/volt/api/v1/user/data", {
801
+ /**
802
+ * The document query.
803
+ * @note The object form query may not include system
804
+ * reserved fields `_id`, `uid`, `query` and `data`.
805
+ */
806
+ query: string | Record<string, any>;
807
+ /**
808
+ * The default value for document field `data`,
809
+ * see {@link Collection.LoadOpts.default}.
810
+ */
811
+ default?: JsonValue;
812
+ }, {
813
+ message: string;
814
+ data: JsonValue;
815
+ }, undefined>;
816
+ /** The set public user data endpoint. */
817
+ type SetUserData = Request.Info<"POST", "/volt/api/v1/user/data", {
818
+ /**
819
+ * The document query.
820
+ * @note The object form query may not include system
821
+ * reserved fields `_id`, `uid`, `query` and `data`.
822
+ */
823
+ query: string | Record<string, any>;
824
+ /** The data to save. */
825
+ data: JsonValue;
826
+ }, {
827
+ message: string;
828
+ }, undefined>;
829
+ /** The delete public user data endpoint. */
830
+ type DeleteUserData = Request.Info<"DELETE", "/volt/api/v1/user/data", {
831
+ /**
832
+ * The document query.
833
+ * @note The object form query may not include system
834
+ * reserved fields `_id`, `uid`, `query` and `data`.
835
+ */
836
+ query: string | Record<string, any>;
837
+ /** The data to save. */
838
+ data: JsonValue;
839
+ }, {
840
+ message: string;
841
+ }, undefined>;
842
+ /** The load protected user data endpoint. */
843
+ type LoadProtectedUserData = Request.Info<"GET", "/volt/api/v1/user/data/protected", {
844
+ /**
845
+ * The document query.
846
+ * @note The object form query may not include system
847
+ * reserved fields `_id`, `uid`, `query` and `data`.
848
+ */
849
+ query: string | Record<string, any>;
850
+ /** The default value for document field `data`. */
851
+ default?: JsonValue;
852
+ }, {
853
+ message: string;
854
+ data: JsonValue;
855
+ }, undefined>;
856
+ /** The sign in endpoint. */
857
+ type SignIn = Request.Info<"POST", "/volt/api/v1/auth/signin", {
858
+ username: string;
859
+ email: string;
860
+ password: string;
861
+ code?: string;
862
+ }, {
863
+ message: string;
864
+ }, undefined>;
865
+ /** The sign up endpoint. */
866
+ type SignUp = Request.Info<"POST", "/volt/api/v1/auth/signup", {
867
+ username: string;
868
+ email: string;
869
+ first_name: string;
870
+ last_name: string;
871
+ password: string;
872
+ verify_password: string;
873
+ phone_number?: string;
874
+ code?: string;
875
+ }, {
876
+ message: string;
877
+ }, undefined>;
878
+ /** The sign out endpoint. */
879
+ type SignOut = Request.Info<"POST", "/volt/api/v1/auth/signout", undefined, {
880
+ message: string;
881
+ }, undefined>;
882
+ /** The send 2fa endpoint. */
883
+ type Send2FA = Request.Info<"POST", "/volt/api/v1/auth/2fa", {
884
+ email: string;
885
+ }, {
886
+ message: string;
887
+ }, undefined>;
888
+ /** The send forgot password endpoint. */
889
+ type ForgotPassword = Request.Info<"POST", "/volt/api/v1/auth/forgot_password", {
890
+ email: string;
891
+ password: string;
892
+ verify_password: string;
893
+ code: string;
894
+ }, {
895
+ message: string;
896
+ }, undefined>;
897
+ /** The submit support endpoint. */
898
+ type SubmitSupport = Request.Info<"POST", "/volt/api/v1/support/submit", {
899
+ /** The support subject. */
900
+ subject?: string;
901
+ /** The support type for internal purpose only. */
902
+ type?: string;
903
+ /** The user's support pin. This parameter will automatically be assigned when the user is authenticated. */
904
+ support_pin?: string;
905
+ /** The user's email. This parameter will automatically be assigned when the user is authenticated. */
906
+ email?: string;
907
+ /** The user's first name. This parameter will automatically be assigned when the user is authenticated. */
908
+ first_name?: string;
909
+ /** The user's last name. This parameter will automatically be assigned when the user is authenticated. */
910
+ last_name?: string;
911
+ /** A summary of the support request. */
912
+ summary: string;
913
+ /** A detailed description of the support request. */
914
+ detailed?: string;
915
+ /** An object with attachments, assigned as `{file_name: raw_file_data}`. */
916
+ attachments?: Mail.Attachment.RestAPI[];
917
+ }, {
918
+ message: string;
919
+ }, undefined>;
920
+ /** The get support pin endpoint. */
921
+ type GetSupportPin = Request.Info<"GET", "/volt/api/v1/support/pin", undefined, {
922
+ message: string;
923
+ pin: string;
924
+ }, undefined>;
925
+ }
926
+ }