@buenojs/bueno 0.8.9 → 0.8.11

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 (708) hide show
  1. package/README.md +1 -1
  2. package/dist/cache/index.d.ts +187 -0
  3. package/dist/cache/index.d.ts.map +1 -0
  4. package/dist/cache/index.js +595 -0
  5. package/dist/cache/index.js.map +1 -0
  6. package/dist/cli/bin.d.ts +8 -0
  7. package/dist/cli/bin.d.ts.map +1 -0
  8. package/dist/cli/bin.js +9 -9
  9. package/dist/cli/bin.js.map +1 -0
  10. package/dist/cli/commands/add-frontend.d.ts +7 -0
  11. package/dist/cli/commands/add-frontend.d.ts.map +1 -0
  12. package/dist/cli/commands/add-frontend.js +376 -0
  13. package/dist/cli/commands/add-frontend.js.map +1 -0
  14. package/dist/cli/commands/build.d.ts +7 -0
  15. package/dist/cli/commands/build.d.ts.map +1 -0
  16. package/dist/cli/commands/build.js +347 -0
  17. package/dist/cli/commands/build.js.map +1 -0
  18. package/dist/cli/commands/dev.d.ts +7 -0
  19. package/dist/cli/commands/dev.d.ts.map +1 -0
  20. package/dist/cli/commands/dev.js +205 -0
  21. package/dist/cli/commands/dev.js.map +1 -0
  22. package/dist/cli/commands/generate.d.ts +7 -0
  23. package/dist/cli/commands/generate.d.ts.map +1 -0
  24. package/dist/cli/commands/generate.js +491 -0
  25. package/dist/cli/commands/generate.js.map +1 -0
  26. package/dist/cli/commands/help.d.ts +7 -0
  27. package/dist/cli/commands/help.d.ts.map +1 -0
  28. package/dist/cli/commands/help.js +51 -0
  29. package/dist/cli/commands/help.js.map +1 -0
  30. package/dist/cli/commands/index.d.ts +59 -0
  31. package/dist/cli/commands/index.d.ts.map +1 -0
  32. package/dist/cli/commands/index.js +77 -0
  33. package/dist/cli/commands/index.js.map +1 -0
  34. package/dist/cli/commands/migration.d.ts +7 -0
  35. package/dist/cli/commands/migration.d.ts.map +1 -0
  36. package/dist/cli/commands/migration.js +295 -0
  37. package/dist/cli/commands/migration.js.map +1 -0
  38. package/dist/cli/commands/new.d.ts +7 -0
  39. package/dist/cli/commands/new.d.ts.map +1 -0
  40. package/dist/cli/commands/new.js +641 -0
  41. package/dist/cli/commands/new.js.map +1 -0
  42. package/dist/cli/commands/start.d.ts +7 -0
  43. package/dist/cli/commands/start.d.ts.map +1 -0
  44. package/dist/cli/commands/start.js +171 -0
  45. package/dist/cli/commands/start.js.map +1 -0
  46. package/dist/cli/core/args.d.ts +61 -0
  47. package/dist/cli/core/args.d.ts.map +1 -0
  48. package/dist/cli/core/args.js +224 -0
  49. package/dist/cli/core/args.js.map +1 -0
  50. package/dist/cli/core/console.d.ts +135 -0
  51. package/dist/cli/core/console.d.ts.map +1 -0
  52. package/dist/cli/core/console.js +268 -0
  53. package/dist/cli/core/console.js.map +1 -0
  54. package/dist/cli/core/index.d.ts +10 -0
  55. package/dist/cli/core/index.d.ts.map +1 -0
  56. package/dist/cli/core/index.js +10 -0
  57. package/dist/cli/core/index.js.map +1 -0
  58. package/dist/cli/core/prompt.d.ts +63 -0
  59. package/dist/cli/core/prompt.d.ts.map +1 -0
  60. package/dist/cli/core/prompt.js +338 -0
  61. package/dist/cli/core/prompt.js.map +1 -0
  62. package/dist/cli/core/spinner.d.ts +111 -0
  63. package/dist/cli/core/spinner.d.ts.map +1 -0
  64. package/dist/cli/core/spinner.js +208 -0
  65. package/dist/cli/core/spinner.js.map +1 -0
  66. package/dist/cli/index.d.ts +47 -0
  67. package/dist/cli/index.d.ts.map +1 -0
  68. package/dist/cli/index.js +127 -0
  69. package/dist/cli/index.js.map +1 -0
  70. package/dist/cli/templates/database/index.d.ts +24 -0
  71. package/dist/cli/templates/database/index.d.ts.map +1 -0
  72. package/dist/cli/templates/database/index.js +49 -0
  73. package/dist/cli/templates/database/index.js.map +1 -0
  74. package/dist/cli/templates/database/mysql.d.ts +6 -0
  75. package/dist/cli/templates/database/mysql.d.ts.map +1 -0
  76. package/dist/cli/templates/database/mysql.js +12 -0
  77. package/dist/cli/templates/database/mysql.js.map +1 -0
  78. package/dist/cli/templates/database/none.d.ts +8 -0
  79. package/dist/cli/templates/database/none.d.ts.map +1 -0
  80. package/dist/cli/templates/database/none.js +14 -0
  81. package/dist/cli/templates/database/none.js.map +1 -0
  82. package/dist/cli/templates/database/postgresql.d.ts +6 -0
  83. package/dist/cli/templates/database/postgresql.d.ts.map +1 -0
  84. package/dist/cli/templates/database/postgresql.js +12 -0
  85. package/dist/cli/templates/database/postgresql.js.map +1 -0
  86. package/dist/cli/templates/database/sqlite.d.ts +6 -0
  87. package/dist/cli/templates/database/sqlite.d.ts.map +1 -0
  88. package/dist/cli/templates/database/sqlite.js +12 -0
  89. package/dist/cli/templates/database/sqlite.js.map +1 -0
  90. package/dist/cli/templates/deploy.d.ts +41 -0
  91. package/dist/cli/templates/deploy.d.ts.map +1 -0
  92. package/dist/cli/templates/deploy.js +278 -0
  93. package/dist/cli/templates/deploy.js.map +1 -0
  94. package/dist/cli/templates/docker.d.ts +30 -0
  95. package/dist/cli/templates/docker.d.ts.map +1 -0
  96. package/dist/cli/templates/docker.js +298 -0
  97. package/dist/cli/templates/docker.js.map +1 -0
  98. package/dist/cli/templates/frontend/index.d.ts +25 -0
  99. package/dist/cli/templates/frontend/index.d.ts.map +1 -0
  100. package/dist/cli/templates/frontend/index.js +40 -0
  101. package/dist/cli/templates/frontend/index.js.map +1 -0
  102. package/dist/cli/templates/frontend/none.d.ts +8 -0
  103. package/dist/cli/templates/frontend/none.d.ts.map +1 -0
  104. package/dist/cli/templates/frontend/none.js +15 -0
  105. package/dist/cli/templates/frontend/none.js.map +1 -0
  106. package/dist/cli/templates/frontend/react.d.ts +6 -0
  107. package/dist/cli/templates/frontend/react.d.ts.map +1 -0
  108. package/dist/cli/templates/frontend/react.js +139 -0
  109. package/dist/cli/templates/frontend/react.js.map +1 -0
  110. package/dist/cli/templates/frontend/solid.d.ts +6 -0
  111. package/dist/cli/templates/frontend/solid.d.ts.map +1 -0
  112. package/dist/cli/templates/frontend/solid.js +133 -0
  113. package/dist/cli/templates/frontend/solid.js.map +1 -0
  114. package/dist/cli/templates/frontend/svelte.d.ts +6 -0
  115. package/dist/cli/templates/frontend/svelte.d.ts.map +1 -0
  116. package/dist/cli/templates/frontend/svelte.js +130 -0
  117. package/dist/cli/templates/frontend/svelte.js.map +1 -0
  118. package/dist/cli/templates/frontend/vue.d.ts +6 -0
  119. package/dist/cli/templates/frontend/vue.d.ts.map +1 -0
  120. package/dist/cli/templates/frontend/vue.js +129 -0
  121. package/dist/cli/templates/frontend/vue.js.map +1 -0
  122. package/dist/cli/templates/generators/index.d.ts +29 -0
  123. package/dist/cli/templates/generators/index.d.ts.map +1 -0
  124. package/dist/cli/templates/generators/index.js +308 -0
  125. package/dist/cli/templates/generators/index.js.map +1 -0
  126. package/dist/cli/templates/generators/types.d.ts +32 -0
  127. package/dist/cli/templates/generators/types.d.ts.map +1 -0
  128. package/dist/cli/templates/generators/types.js +21 -0
  129. package/dist/cli/templates/generators/types.js.map +1 -0
  130. package/dist/cli/templates/index.d.ts +12 -0
  131. package/dist/cli/templates/index.d.ts.map +1 -0
  132. package/dist/cli/templates/index.js +18 -0
  133. package/dist/cli/templates/index.js.map +1 -0
  134. package/dist/cli/templates/project/api.d.ts +6 -0
  135. package/dist/cli/templates/project/api.d.ts.map +1 -0
  136. package/dist/cli/templates/project/api.js +79 -0
  137. package/dist/cli/templates/project/api.js.map +1 -0
  138. package/dist/cli/templates/project/default.d.ts +6 -0
  139. package/dist/cli/templates/project/default.d.ts.map +1 -0
  140. package/dist/cli/templates/project/default.js +136 -0
  141. package/dist/cli/templates/project/default.js.map +1 -0
  142. package/dist/cli/templates/project/fullstack.d.ts +14 -0
  143. package/dist/cli/templates/project/fullstack.d.ts.map +1 -0
  144. package/dist/cli/templates/project/fullstack.js +19 -0
  145. package/dist/cli/templates/project/fullstack.js.map +1 -0
  146. package/dist/cli/templates/project/index.d.ts +26 -0
  147. package/dist/cli/templates/project/index.d.ts.map +1 -0
  148. package/dist/cli/templates/project/index.js +60 -0
  149. package/dist/cli/templates/project/index.js.map +1 -0
  150. package/dist/cli/templates/project/minimal.d.ts +6 -0
  151. package/dist/cli/templates/project/minimal.d.ts.map +1 -0
  152. package/dist/cli/templates/project/minimal.js +43 -0
  153. package/dist/cli/templates/project/minimal.js.map +1 -0
  154. package/dist/cli/templates/project/types.d.ts +80 -0
  155. package/dist/cli/templates/project/types.d.ts.map +1 -0
  156. package/dist/cli/templates/project/types.js +7 -0
  157. package/dist/cli/templates/project/types.js.map +1 -0
  158. package/dist/cli/templates/project/website.d.ts +8 -0
  159. package/dist/cli/templates/project/website.d.ts.map +1 -0
  160. package/dist/cli/templates/project/website.js +312 -0
  161. package/dist/cli/templates/project/website.js.map +1 -0
  162. package/dist/cli/utils/fs.d.ts +137 -0
  163. package/dist/cli/utils/fs.d.ts.map +1 -0
  164. package/dist/cli/utils/fs.js +350 -0
  165. package/dist/cli/utils/fs.js.map +1 -0
  166. package/dist/cli/utils/index.d.ts +9 -0
  167. package/dist/cli/utils/index.d.ts.map +1 -0
  168. package/dist/cli/utils/index.js +9 -0
  169. package/dist/cli/utils/index.js.map +1 -0
  170. package/dist/cli/utils/strings.d.ts +86 -0
  171. package/dist/cli/utils/strings.d.ts.map +1 -0
  172. package/dist/cli/utils/strings.js +190 -0
  173. package/dist/cli/utils/strings.js.map +1 -0
  174. package/dist/cli/utils/version.d.ts +15 -0
  175. package/dist/cli/utils/version.d.ts.map +1 -0
  176. package/dist/cli/utils/version.js +38 -0
  177. package/dist/cli/utils/version.js.map +1 -0
  178. package/dist/config/env-validation.d.ts +49 -0
  179. package/dist/config/env-validation.d.ts.map +1 -0
  180. package/dist/config/env-validation.js +77 -0
  181. package/dist/config/env-validation.js.map +1 -0
  182. package/dist/config/env.d.ts +167 -0
  183. package/dist/config/env.d.ts.map +1 -0
  184. package/dist/config/env.js +392 -0
  185. package/dist/config/env.js.map +1 -0
  186. package/dist/config/index.d.ts +168 -0
  187. package/dist/config/index.d.ts.map +1 -0
  188. package/dist/config/index.js +329 -0
  189. package/dist/config/index.js.map +1 -0
  190. package/dist/config/loader.d.ts +81 -0
  191. package/dist/config/loader.d.ts.map +1 -0
  192. package/dist/config/loader.js +242 -0
  193. package/dist/config/loader.js.map +1 -0
  194. package/dist/config/merge.d.ts +66 -0
  195. package/dist/config/merge.d.ts.map +1 -0
  196. package/dist/config/merge.js +226 -0
  197. package/dist/config/merge.js.map +1 -0
  198. package/dist/config/types.d.ts +322 -0
  199. package/dist/config/types.d.ts.map +1 -0
  200. package/dist/config/types.js +443 -0
  201. package/dist/config/types.js.map +1 -0
  202. package/dist/config/validation.d.ts +100 -0
  203. package/dist/config/validation.d.ts.map +1 -0
  204. package/dist/config/validation.js +548 -0
  205. package/dist/config/validation.js.map +1 -0
  206. package/dist/container/forward-ref.d.ts +116 -0
  207. package/dist/container/forward-ref.d.ts.map +1 -0
  208. package/dist/container/forward-ref.js +105 -0
  209. package/dist/container/forward-ref.js.map +1 -0
  210. package/dist/container/index.d.ts +95 -0
  211. package/dist/container/index.d.ts.map +1 -0
  212. package/dist/container/index.js.map +1 -0
  213. package/dist/context/index.d.ts +143 -0
  214. package/dist/context/index.d.ts.map +1 -0
  215. package/dist/context/index.js.map +1 -0
  216. package/dist/database/index.d.ts +219 -0
  217. package/dist/database/index.d.ts.map +1 -0
  218. package/dist/database/index.js.map +1 -0
  219. package/dist/database/migrations/index.d.ts +151 -0
  220. package/dist/database/migrations/index.d.ts.map +1 -0
  221. package/dist/database/migrations/index.js +258 -0
  222. package/dist/database/migrations/index.js.map +1 -0
  223. package/dist/database/orm/builder.d.ts +122 -0
  224. package/dist/database/orm/builder.d.ts.map +1 -0
  225. package/dist/database/orm/builder.js +355 -0
  226. package/dist/database/orm/builder.js.map +1 -0
  227. package/dist/database/orm/casts/index.d.ts +16 -0
  228. package/dist/database/orm/casts/index.d.ts.map +1 -0
  229. package/dist/database/orm/casts/index.js +131 -0
  230. package/dist/database/orm/casts/index.js.map +1 -0
  231. package/dist/database/orm/casts/types.d.ts +16 -0
  232. package/dist/database/orm/casts/types.d.ts.map +1 -0
  233. package/dist/database/orm/casts/types.js +5 -0
  234. package/dist/database/orm/casts/types.js.map +1 -0
  235. package/dist/database/orm/compiler.d.ts +90 -0
  236. package/dist/database/orm/compiler.d.ts.map +1 -0
  237. package/dist/database/orm/compiler.js +218 -0
  238. package/dist/database/orm/compiler.js.map +1 -0
  239. package/dist/database/orm/hooks/index.d.ts +53 -0
  240. package/dist/database/orm/hooks/index.d.ts.map +1 -0
  241. package/dist/database/orm/hooks/index.js +81 -0
  242. package/dist/database/orm/hooks/index.js.map +1 -0
  243. package/dist/database/orm/index.d.ts +21 -0
  244. package/dist/database/orm/index.d.ts.map +1 -0
  245. package/dist/database/orm/index.js +23 -0
  246. package/dist/database/orm/index.js.map +1 -0
  247. package/dist/database/orm/model-registry.d.ts +33 -0
  248. package/dist/database/orm/model-registry.d.ts.map +1 -0
  249. package/dist/database/orm/model-registry.js +49 -0
  250. package/dist/database/orm/model-registry.js.map +1 -0
  251. package/dist/database/orm/model.d.ts +245 -0
  252. package/dist/database/orm/model.d.ts.map +1 -0
  253. package/dist/database/orm/model.js +599 -0
  254. package/dist/database/orm/model.js.map +1 -0
  255. package/dist/database/orm/relationships/base.d.ts +69 -0
  256. package/dist/database/orm/relationships/base.d.ts.map +1 -0
  257. package/dist/database/orm/relationships/base.js +84 -0
  258. package/dist/database/orm/relationships/base.js.map +1 -0
  259. package/dist/database/orm/relationships/belongs-to-many.d.ts +47 -0
  260. package/dist/database/orm/relationships/belongs-to-many.d.ts.map +1 -0
  261. package/dist/database/orm/relationships/belongs-to-many.js +136 -0
  262. package/dist/database/orm/relationships/belongs-to-many.js.map +1 -0
  263. package/dist/database/orm/relationships/belongs-to.d.ts +17 -0
  264. package/dist/database/orm/relationships/belongs-to.d.ts.map +1 -0
  265. package/dist/database/orm/relationships/belongs-to.js +38 -0
  266. package/dist/database/orm/relationships/belongs-to.js.map +1 -0
  267. package/dist/database/orm/relationships/has-many.d.ts +14 -0
  268. package/dist/database/orm/relationships/has-many.d.ts.map +1 -0
  269. package/dist/database/orm/relationships/has-many.js +35 -0
  270. package/dist/database/orm/relationships/has-many.js.map +1 -0
  271. package/dist/database/orm/relationships/has-one.d.ts +14 -0
  272. package/dist/database/orm/relationships/has-one.d.ts.map +1 -0
  273. package/dist/database/orm/relationships/has-one.js +32 -0
  274. package/dist/database/orm/relationships/has-one.js.map +1 -0
  275. package/dist/database/orm/relationships/index.d.ts +10 -0
  276. package/dist/database/orm/relationships/index.d.ts.map +1 -0
  277. package/dist/database/orm/relationships/index.js +9 -0
  278. package/dist/database/orm/relationships/index.js.map +1 -0
  279. package/dist/database/orm/scopes/index.d.ts +36 -0
  280. package/dist/database/orm/scopes/index.d.ts.map +1 -0
  281. package/dist/database/orm/scopes/index.js +47 -0
  282. package/dist/database/orm/scopes/index.js.map +1 -0
  283. package/dist/database/schema/index.d.ts +155 -0
  284. package/dist/database/schema/index.d.ts.map +1 -0
  285. package/dist/database/schema/index.js +401 -0
  286. package/dist/database/schema/index.js.map +1 -0
  287. package/dist/frontend/api-routes.d.ts +189 -0
  288. package/dist/frontend/api-routes.d.ts.map +1 -0
  289. package/dist/frontend/api-routes.js +548 -0
  290. package/dist/frontend/api-routes.js.map +1 -0
  291. package/dist/frontend/bundler.d.ts +99 -0
  292. package/dist/frontend/bundler.d.ts.map +1 -0
  293. package/dist/frontend/bundler.js +555 -0
  294. package/dist/frontend/bundler.js.map +1 -0
  295. package/dist/frontend/console-client.d.ts +11 -0
  296. package/dist/frontend/console-client.d.ts.map +1 -0
  297. package/dist/frontend/console-client.js +414 -0
  298. package/dist/frontend/console-client.js.map +1 -0
  299. package/dist/frontend/console-stream.d.ts +138 -0
  300. package/dist/frontend/console-stream.d.ts.map +1 -0
  301. package/dist/frontend/console-stream.js +535 -0
  302. package/dist/frontend/console-stream.js.map +1 -0
  303. package/dist/frontend/dev-server.d.ts +174 -0
  304. package/dist/frontend/dev-server.d.ts.map +1 -0
  305. package/dist/frontend/dev-server.js +735 -0
  306. package/dist/frontend/dev-server.js.map +1 -0
  307. package/dist/frontend/file-router.d.ts +170 -0
  308. package/dist/frontend/file-router.d.ts.map +1 -0
  309. package/dist/frontend/file-router.js +531 -0
  310. package/dist/frontend/file-router.js.map +1 -0
  311. package/dist/frontend/frameworks/index.d.ts +41 -0
  312. package/dist/frontend/frameworks/index.d.ts.map +1 -0
  313. package/dist/frontend/frameworks/index.js +87 -0
  314. package/dist/frontend/frameworks/index.js.map +1 -0
  315. package/dist/frontend/frameworks/react.d.ts +32 -0
  316. package/dist/frontend/frameworks/react.d.ts.map +1 -0
  317. package/dist/frontend/frameworks/react.js +66 -0
  318. package/dist/frontend/frameworks/react.js.map +1 -0
  319. package/dist/frontend/frameworks/solid.d.ts +42 -0
  320. package/dist/frontend/frameworks/solid.d.ts.map +1 -0
  321. package/dist/frontend/frameworks/solid.js +84 -0
  322. package/dist/frontend/frameworks/solid.js.map +1 -0
  323. package/dist/frontend/frameworks/svelte.d.ts +57 -0
  324. package/dist/frontend/frameworks/svelte.d.ts.map +1 -0
  325. package/dist/frontend/frameworks/svelte.js +90 -0
  326. package/dist/frontend/frameworks/svelte.js.map +1 -0
  327. package/dist/frontend/frameworks/vue.d.ts +36 -0
  328. package/dist/frontend/frameworks/vue.d.ts.map +1 -0
  329. package/dist/frontend/frameworks/vue.js +72 -0
  330. package/dist/frontend/frameworks/vue.js.map +1 -0
  331. package/dist/frontend/hmr-client.d.ts +22 -0
  332. package/dist/frontend/hmr-client.d.ts.map +1 -0
  333. package/dist/frontend/hmr-client.js +654 -0
  334. package/dist/frontend/hmr-client.js.map +1 -0
  335. package/dist/frontend/hmr.d.ts +185 -0
  336. package/dist/frontend/hmr.d.ts.map +1 -0
  337. package/dist/frontend/hmr.js +619 -0
  338. package/dist/frontend/hmr.js.map +1 -0
  339. package/dist/frontend/index.d.ts +34 -0
  340. package/dist/frontend/index.d.ts.map +1 -0
  341. package/dist/frontend/index.js.map +1 -0
  342. package/dist/frontend/islands.d.ts +135 -0
  343. package/dist/frontend/islands.d.ts.map +1 -0
  344. package/dist/frontend/islands.js +455 -0
  345. package/dist/frontend/islands.js.map +1 -0
  346. package/dist/frontend/isr.d.ts +143 -0
  347. package/dist/frontend/isr.d.ts.map +1 -0
  348. package/dist/frontend/isr.js +440 -0
  349. package/dist/frontend/isr.js.map +1 -0
  350. package/dist/frontend/layout.d.ts +140 -0
  351. package/dist/frontend/layout.d.ts.map +1 -0
  352. package/dist/frontend/layout.js +392 -0
  353. package/dist/frontend/layout.js.map +1 -0
  354. package/dist/frontend/ssr/react.d.ts +118 -0
  355. package/dist/frontend/ssr/react.d.ts.map +1 -0
  356. package/dist/frontend/ssr/react.js +373 -0
  357. package/dist/frontend/ssr/react.js.map +1 -0
  358. package/dist/frontend/ssr/solid.d.ts +141 -0
  359. package/dist/frontend/ssr/solid.d.ts.map +1 -0
  360. package/dist/frontend/ssr/solid.js +440 -0
  361. package/dist/frontend/ssr/solid.js.map +1 -0
  362. package/dist/frontend/ssr/svelte.d.ts +158 -0
  363. package/dist/frontend/ssr/svelte.d.ts.map +1 -0
  364. package/dist/frontend/ssr/svelte.js +439 -0
  365. package/dist/frontend/ssr/svelte.js.map +1 -0
  366. package/dist/frontend/ssr/vue.d.ts +161 -0
  367. package/dist/frontend/ssr/vue.d.ts.map +1 -0
  368. package/dist/frontend/ssr/vue.js +385 -0
  369. package/dist/frontend/ssr/vue.js.map +1 -0
  370. package/dist/frontend/ssr.d.ts +147 -0
  371. package/dist/frontend/ssr.d.ts.map +1 -0
  372. package/dist/frontend/ssr.js +609 -0
  373. package/dist/frontend/ssr.js.map +1 -0
  374. package/dist/frontend/types.d.ts +1902 -0
  375. package/dist/frontend/types.d.ts.map +1 -0
  376. package/dist/frontend/types.js +8 -0
  377. package/dist/frontend/types.js.map +1 -0
  378. package/dist/graphql/built-in-engine.d.ts +36 -0
  379. package/dist/graphql/built-in-engine.d.ts.map +1 -0
  380. package/dist/graphql/built-in-engine.js +443 -0
  381. package/dist/graphql/built-in-engine.js.map +1 -0
  382. package/dist/graphql/context-builder.d.ts +44 -0
  383. package/dist/graphql/context-builder.d.ts.map +1 -0
  384. package/dist/graphql/context-builder.js +91 -0
  385. package/dist/graphql/context-builder.js.map +1 -0
  386. package/dist/graphql/decorators.d.ts +162 -0
  387. package/dist/graphql/decorators.d.ts.map +1 -0
  388. package/dist/graphql/decorators.js +291 -0
  389. package/dist/graphql/decorators.js.map +1 -0
  390. package/dist/graphql/execution-pipeline.d.ts +67 -0
  391. package/dist/graphql/execution-pipeline.d.ts.map +1 -0
  392. package/dist/graphql/execution-pipeline.js +127 -0
  393. package/dist/graphql/execution-pipeline.js.map +1 -0
  394. package/dist/graphql/graphql-module.d.ts +70 -0
  395. package/dist/graphql/graphql-module.d.ts.map +1 -0
  396. package/dist/graphql/graphql-module.js +442 -0
  397. package/dist/graphql/graphql-module.js.map +1 -0
  398. package/dist/graphql/index.d.ts +48 -0
  399. package/dist/graphql/index.d.ts.map +1 -0
  400. package/dist/graphql/index.js.map +1 -0
  401. package/dist/graphql/metadata.d.ts +37 -0
  402. package/dist/graphql/metadata.d.ts.map +1 -0
  403. package/dist/graphql/metadata.js +130 -0
  404. package/dist/graphql/metadata.js.map +1 -0
  405. package/dist/graphql/schema-builder.d.ts +34 -0
  406. package/dist/graphql/schema-builder.d.ts.map +1 -0
  407. package/dist/graphql/schema-builder.js +251 -0
  408. package/dist/graphql/schema-builder.js.map +1 -0
  409. package/dist/graphql/subscription-handler.d.ts +47 -0
  410. package/dist/graphql/subscription-handler.d.ts.map +1 -0
  411. package/dist/graphql/subscription-handler.js +201 -0
  412. package/dist/graphql/subscription-handler.js.map +1 -0
  413. package/dist/graphql/types.d.ts +252 -0
  414. package/dist/graphql/types.d.ts.map +1 -0
  415. package/dist/graphql/types.js +28 -0
  416. package/dist/graphql/types.js.map +1 -0
  417. package/dist/health/index.d.ts +176 -0
  418. package/dist/health/index.d.ts.map +1 -0
  419. package/dist/health/index.js.map +1 -0
  420. package/dist/i18n/engine.d.ts +105 -0
  421. package/dist/i18n/engine.d.ts.map +1 -0
  422. package/dist/i18n/engine.js +248 -0
  423. package/dist/i18n/engine.js.map +1 -0
  424. package/dist/i18n/index.d.ts +13 -0
  425. package/dist/i18n/index.d.ts.map +1 -0
  426. package/dist/i18n/index.js.map +1 -0
  427. package/dist/i18n/loader.d.ts +79 -0
  428. package/dist/i18n/loader.d.ts.map +1 -0
  429. package/dist/i18n/loader.js +192 -0
  430. package/dist/i18n/loader.js.map +1 -0
  431. package/dist/i18n/middleware.d.ts +96 -0
  432. package/dist/i18n/middleware.d.ts.map +1 -0
  433. package/dist/i18n/middleware.js +126 -0
  434. package/dist/i18n/middleware.js.map +1 -0
  435. package/dist/i18n/negotiator.d.ts +84 -0
  436. package/dist/i18n/negotiator.d.ts.map +1 -0
  437. package/dist/i18n/negotiator.js +139 -0
  438. package/dist/i18n/negotiator.js.map +1 -0
  439. package/dist/i18n/types.d.ts +129 -0
  440. package/dist/i18n/types.d.ts.map +1 -0
  441. package/dist/i18n/types.js +8 -0
  442. package/dist/i18n/types.js.map +1 -0
  443. package/dist/index.d.ts +48 -0
  444. package/dist/index.d.ts.map +1 -0
  445. package/dist/index.js.map +1 -0
  446. package/dist/jobs/drivers/memory.d.ts +38 -0
  447. package/dist/jobs/drivers/memory.d.ts.map +1 -0
  448. package/dist/jobs/drivers/memory.js +246 -0
  449. package/dist/jobs/drivers/memory.js.map +1 -0
  450. package/dist/jobs/drivers/redis.d.ts +34 -0
  451. package/dist/jobs/drivers/redis.d.ts.map +1 -0
  452. package/dist/jobs/drivers/redis.js +355 -0
  453. package/dist/jobs/drivers/redis.js.map +1 -0
  454. package/dist/jobs/index.d.ts +12 -0
  455. package/dist/jobs/index.d.ts.map +1 -0
  456. package/dist/jobs/index.js.map +1 -0
  457. package/dist/jobs/queue.d.ts +93 -0
  458. package/dist/jobs/queue.d.ts.map +1 -0
  459. package/dist/jobs/queue.js +233 -0
  460. package/dist/jobs/queue.js.map +1 -0
  461. package/dist/jobs/types.d.ts +193 -0
  462. package/dist/jobs/types.d.ts.map +1 -0
  463. package/dist/jobs/types.js +8 -0
  464. package/dist/jobs/types.js.map +1 -0
  465. package/dist/jobs/worker.d.ts +91 -0
  466. package/dist/jobs/worker.d.ts.map +1 -0
  467. package/dist/jobs/worker.js +300 -0
  468. package/dist/jobs/worker.js.map +1 -0
  469. package/dist/lock/index.d.ts +141 -0
  470. package/dist/lock/index.d.ts.map +1 -0
  471. package/dist/lock/index.js.map +1 -0
  472. package/dist/logger/index.d.ts +156 -0
  473. package/dist/logger/index.d.ts.map +1 -0
  474. package/dist/logger/index.js.map +1 -0
  475. package/dist/logger/transports/index.d.ts +371 -0
  476. package/dist/logger/transports/index.d.ts.map +1 -0
  477. package/dist/logger/transports/index.js +740 -0
  478. package/dist/logger/transports/index.js.map +1 -0
  479. package/dist/metrics/index.d.ts +163 -0
  480. package/dist/metrics/index.d.ts.map +1 -0
  481. package/dist/metrics/index.js.map +1 -0
  482. package/dist/middleware/built-in.d.ts +50 -0
  483. package/dist/middleware/built-in.d.ts.map +1 -0
  484. package/dist/middleware/built-in.js +220 -0
  485. package/dist/middleware/built-in.js.map +1 -0
  486. package/dist/middleware/index.d.ts +40 -0
  487. package/dist/middleware/index.d.ts.map +1 -0
  488. package/dist/middleware/index.js.map +1 -0
  489. package/dist/migrations/index.d.ts +48 -0
  490. package/dist/migrations/index.d.ts.map +1 -0
  491. package/dist/migrations/index.js +3 -0
  492. package/dist/migrations/index.js.map +1 -0
  493. package/dist/modules/filters.d.ts +150 -0
  494. package/dist/modules/filters.d.ts.map +1 -0
  495. package/dist/modules/filters.js +338 -0
  496. package/dist/modules/filters.js.map +1 -0
  497. package/dist/modules/guards.d.ts +188 -0
  498. package/dist/modules/guards.d.ts.map +1 -0
  499. package/dist/modules/guards.js +278 -0
  500. package/dist/modules/guards.js.map +1 -0
  501. package/dist/modules/index.d.ts +266 -0
  502. package/dist/modules/index.d.ts.map +1 -0
  503. package/dist/modules/index.js.map +1 -0
  504. package/dist/modules/interceptors.d.ts +242 -0
  505. package/dist/modules/interceptors.d.ts.map +1 -0
  506. package/dist/modules/interceptors.js +407 -0
  507. package/dist/modules/interceptors.js.map +1 -0
  508. package/dist/modules/lazy.d.ts +187 -0
  509. package/dist/modules/lazy.d.ts.map +1 -0
  510. package/dist/modules/lazy.js +305 -0
  511. package/dist/modules/lazy.js.map +1 -0
  512. package/dist/modules/lifecycle.d.ts +221 -0
  513. package/dist/modules/lifecycle.d.ts.map +1 -0
  514. package/dist/modules/lifecycle.js +314 -0
  515. package/dist/modules/lifecycle.js.map +1 -0
  516. package/dist/modules/metadata.d.ts +32 -0
  517. package/dist/modules/metadata.d.ts.map +1 -0
  518. package/dist/modules/metadata.js +59 -0
  519. package/dist/modules/metadata.js.map +1 -0
  520. package/dist/modules/pipes.d.ts +287 -0
  521. package/dist/modules/pipes.d.ts.map +1 -0
  522. package/dist/modules/pipes.js +443 -0
  523. package/dist/modules/pipes.js.map +1 -0
  524. package/dist/notification/channels/base.d.ts +32 -0
  525. package/dist/notification/channels/base.d.ts.map +1 -0
  526. package/dist/notification/channels/base.js +37 -0
  527. package/dist/notification/channels/base.js.map +1 -0
  528. package/dist/notification/channels/email.d.ts +37 -0
  529. package/dist/notification/channels/email.d.ts.map +1 -0
  530. package/dist/notification/channels/email.js +85 -0
  531. package/dist/notification/channels/email.js.map +1 -0
  532. package/dist/notification/channels/push.d.ts +37 -0
  533. package/dist/notification/channels/push.d.ts.map +1 -0
  534. package/dist/notification/channels/push.js +84 -0
  535. package/dist/notification/channels/push.js.map +1 -0
  536. package/dist/notification/channels/sms.d.ts +37 -0
  537. package/dist/notification/channels/sms.d.ts.map +1 -0
  538. package/dist/notification/channels/sms.js +83 -0
  539. package/dist/notification/channels/sms.js.map +1 -0
  540. package/dist/notification/channels/whatsapp.d.ts +37 -0
  541. package/dist/notification/channels/whatsapp.d.ts.map +1 -0
  542. package/dist/notification/channels/whatsapp.js +81 -0
  543. package/dist/notification/channels/whatsapp.js.map +1 -0
  544. package/dist/notification/index.d.ts +15 -0
  545. package/dist/notification/index.d.ts.map +1 -0
  546. package/dist/notification/index.js.map +1 -0
  547. package/dist/notification/service.d.ts +100 -0
  548. package/dist/notification/service.d.ts.map +1 -0
  549. package/dist/notification/service.js +279 -0
  550. package/dist/notification/service.js.map +1 -0
  551. package/dist/notification/types.d.ts +253 -0
  552. package/dist/notification/types.d.ts.map +1 -0
  553. package/dist/notification/types.js +14 -0
  554. package/dist/notification/types.js.map +1 -0
  555. package/dist/observability/__tests__/observability.test.d.ts +2 -0
  556. package/dist/observability/__tests__/observability.test.d.ts.map +1 -0
  557. package/dist/observability/__tests__/observability.test.js +404 -0
  558. package/dist/observability/__tests__/observability.test.js.map +1 -0
  559. package/dist/observability/breadcrumbs.d.ts +48 -0
  560. package/dist/observability/breadcrumbs.d.ts.map +1 -0
  561. package/dist/observability/breadcrumbs.js +97 -0
  562. package/dist/observability/breadcrumbs.js.map +1 -0
  563. package/dist/observability/index.d.ts +95 -0
  564. package/dist/observability/index.d.ts.map +1 -0
  565. package/dist/observability/index.js.map +1 -0
  566. package/dist/observability/interceptor.d.ts +19 -0
  567. package/dist/observability/interceptor.d.ts.map +1 -0
  568. package/dist/observability/interceptor.js +67 -0
  569. package/dist/observability/interceptor.js.map +1 -0
  570. package/dist/observability/service.d.ts +101 -0
  571. package/dist/observability/service.d.ts.map +1 -0
  572. package/dist/observability/service.js +249 -0
  573. package/dist/observability/service.js.map +1 -0
  574. package/dist/observability/trace.d.ts +21 -0
  575. package/dist/observability/trace.d.ts.map +1 -0
  576. package/dist/observability/trace.js +35 -0
  577. package/dist/observability/trace.js.map +1 -0
  578. package/dist/observability/types.d.ts +172 -0
  579. package/dist/observability/types.d.ts.map +1 -0
  580. package/dist/observability/types.js +8 -0
  581. package/dist/observability/types.js.map +1 -0
  582. package/dist/openapi/decorators.d.ts +173 -0
  583. package/dist/openapi/decorators.d.ts.map +1 -0
  584. package/dist/openapi/decorators.js +276 -0
  585. package/dist/openapi/decorators.js.map +1 -0
  586. package/dist/openapi/document-builder.d.ts +82 -0
  587. package/dist/openapi/document-builder.d.ts.map +1 -0
  588. package/dist/openapi/document-builder.js +228 -0
  589. package/dist/openapi/document-builder.js.map +1 -0
  590. package/dist/openapi/index.d.ts +48 -0
  591. package/dist/openapi/index.d.ts.map +1 -0
  592. package/dist/openapi/index.js.map +1 -0
  593. package/dist/openapi/metadata.d.ts +36 -0
  594. package/dist/openapi/metadata.d.ts.map +1 -0
  595. package/dist/openapi/metadata.js +78 -0
  596. package/dist/openapi/metadata.js.map +1 -0
  597. package/dist/openapi/route-scanner.d.ts +34 -0
  598. package/dist/openapi/route-scanner.d.ts.map +1 -0
  599. package/dist/openapi/route-scanner.js +174 -0
  600. package/dist/openapi/route-scanner.js.map +1 -0
  601. package/dist/openapi/schema-generator.d.ts +53 -0
  602. package/dist/openapi/schema-generator.d.ts.map +1 -0
  603. package/dist/openapi/schema-generator.js +236 -0
  604. package/dist/openapi/schema-generator.js.map +1 -0
  605. package/dist/openapi/swagger-module.d.ts +57 -0
  606. package/dist/openapi/swagger-module.d.ts.map +1 -0
  607. package/dist/openapi/swagger-module.js +143 -0
  608. package/dist/openapi/swagger-module.js.map +1 -0
  609. package/dist/openapi/types.d.ts +344 -0
  610. package/dist/openapi/types.d.ts.map +1 -0
  611. package/dist/openapi/types.js +7 -0
  612. package/dist/openapi/types.js.map +1 -0
  613. package/dist/orm/index.d.ts +10 -0
  614. package/dist/orm/index.d.ts.map +1 -0
  615. package/dist/orm/index.js.map +1 -0
  616. package/dist/router/index.d.ts +73 -0
  617. package/dist/router/index.d.ts.map +1 -0
  618. package/dist/router/index.js.map +1 -0
  619. package/dist/router/linear.d.ts +54 -0
  620. package/dist/router/linear.d.ts.map +1 -0
  621. package/dist/router/linear.js +261 -0
  622. package/dist/router/linear.js.map +1 -0
  623. package/dist/router/regex.d.ts +49 -0
  624. package/dist/router/regex.d.ts.map +1 -0
  625. package/dist/router/regex.js +201 -0
  626. package/dist/router/regex.js.map +1 -0
  627. package/dist/router/tree.d.ts +112 -0
  628. package/dist/router/tree.d.ts.map +1 -0
  629. package/dist/router/tree.js +360 -0
  630. package/dist/router/tree.js.map +1 -0
  631. package/dist/rpc/index.d.ts +321 -0
  632. package/dist/rpc/index.d.ts.map +1 -0
  633. package/dist/rpc/index.js.map +1 -0
  634. package/dist/schema/index.d.ts +10 -0
  635. package/dist/schema/index.d.ts.map +1 -0
  636. package/dist/schema/index.js.map +1 -0
  637. package/dist/security/index.d.ts +126 -0
  638. package/dist/security/index.d.ts.map +1 -0
  639. package/dist/security/index.js +309 -0
  640. package/dist/security/index.js.map +1 -0
  641. package/dist/ssg/index.d.ts +73 -0
  642. package/dist/ssg/index.d.ts.map +1 -0
  643. package/dist/ssg/index.js +464 -0
  644. package/dist/ssg/index.js.map +1 -0
  645. package/dist/storage/index.d.ts +99 -0
  646. package/dist/storage/index.d.ts.map +1 -0
  647. package/dist/storage/index.js +338 -0
  648. package/dist/storage/index.js.map +1 -0
  649. package/dist/telemetry/index.d.ts +376 -0
  650. package/dist/telemetry/index.d.ts.map +1 -0
  651. package/dist/telemetry/index.js.map +1 -0
  652. package/dist/template/index.d.ts +7 -0
  653. package/dist/template/index.d.ts.map +1 -0
  654. package/dist/template/index.js.map +1 -0
  655. package/dist/templates/engine.d.ts +60 -0
  656. package/dist/templates/engine.d.ts.map +1 -0
  657. package/dist/templates/engine.js +177 -0
  658. package/dist/templates/engine.js.map +1 -0
  659. package/dist/templates/index.d.ts +9 -0
  660. package/dist/templates/index.d.ts.map +1 -0
  661. package/dist/templates/index.js.map +1 -0
  662. package/dist/templates/loader.d.ts +45 -0
  663. package/dist/templates/loader.d.ts.map +1 -0
  664. package/dist/templates/loader.js +274 -0
  665. package/dist/templates/loader.js.map +1 -0
  666. package/dist/templates/renderers/markdown.d.ts +46 -0
  667. package/dist/templates/renderers/markdown.d.ts.map +1 -0
  668. package/dist/templates/renderers/markdown.js +181 -0
  669. package/dist/templates/renderers/markdown.js.map +1 -0
  670. package/dist/templates/renderers/simple.d.ts +35 -0
  671. package/dist/templates/renderers/simple.d.ts.map +1 -0
  672. package/dist/templates/renderers/simple.js +245 -0
  673. package/dist/templates/renderers/simple.js.map +1 -0
  674. package/dist/templates/types.d.ts +138 -0
  675. package/dist/templates/types.d.ts.map +1 -0
  676. package/dist/templates/types.js +8 -0
  677. package/dist/templates/types.js.map +1 -0
  678. package/dist/testing/index.d.ts +539 -0
  679. package/dist/testing/index.d.ts.map +1 -0
  680. package/dist/testing/index.js.map +1 -0
  681. package/dist/types/index.d.ts +116 -0
  682. package/dist/types/index.d.ts.map +1 -0
  683. package/dist/types/index.js.map +1 -0
  684. package/dist/validation/index.d.ts +89 -0
  685. package/dist/validation/index.d.ts.map +1 -0
  686. package/dist/validation/index.js +276 -0
  687. package/dist/validation/index.js.map +1 -0
  688. package/dist/validation/schemas.d.ts +283 -0
  689. package/dist/validation/schemas.d.ts.map +1 -0
  690. package/dist/validation/schemas.js +407 -0
  691. package/dist/validation/schemas.js.map +1 -0
  692. package/dist/websocket/index.d.ts +252 -0
  693. package/dist/websocket/index.d.ts.map +1 -0
  694. package/dist/websocket/index.js +749 -0
  695. package/dist/websocket/index.js.map +1 -0
  696. package/llms.txt +1 -1
  697. package/package.json +3 -3
  698. package/src/cli/commands/new.ts +1 -1
  699. package/src/cli/templates/frontend/react.ts +1 -1
  700. package/src/cli/templates/frontend/solid.ts +1 -1
  701. package/src/cli/templates/frontend/svelte.ts +1 -1
  702. package/src/cli/templates/frontend/vue.ts +1 -1
  703. package/src/cli/templates/project/default.ts +1 -1
  704. package/src/cli/templates/project/website.ts +3 -3
  705. package/src/database/migrations/index.ts +8 -0
  706. package/src/migrations/index.ts +40 -1
  707. package/src/types/index.ts +1 -1
  708. package/tsconfig.json +2 -6
@@ -0,0 +1,300 @@
1
+ /**
2
+ * Job Worker
3
+ *
4
+ * Production-grade worker for processing background jobs.
5
+ * Designed to run in a separate process/worker.
6
+ * Supports graceful shutdown and exponential backoff polling.
7
+ */
8
+ import { MemoryJobQueueDriver } from "./drivers/memory";
9
+ import { RedisJobQueueDriver } from "./drivers/redis";
10
+ // ============= Job Worker Class =============
11
+ export class JobWorker {
12
+ driver;
13
+ handlers = new Map();
14
+ handlerRegistry = [];
15
+ eventListeners = new Map();
16
+ isRunning = false;
17
+ pollInterval;
18
+ concurrency;
19
+ jobTimeout;
20
+ maxBackoffDelay = 30000; // 30 seconds max backoff
21
+ currentBackoff = 0;
22
+ inFlightJobs = new Set();
23
+ shutdownTimeout = 10000; // 10 seconds to drain
24
+ constructor(config = {}) {
25
+ // Instantiate appropriate driver
26
+ const driver = config.driver ?? "memory";
27
+ if (driver === "redis") {
28
+ if (!config.url) {
29
+ throw new Error("Redis URL is required for Redis driver");
30
+ }
31
+ this.driver = new RedisJobQueueDriver(config);
32
+ }
33
+ else {
34
+ this.driver = new MemoryJobQueueDriver(config);
35
+ }
36
+ this.pollInterval = config.pollInterval ?? 1000;
37
+ this.concurrency = config.concurrency ?? 10;
38
+ this.jobTimeout = config.jobTimeout ?? 300000; // 5 minutes default
39
+ }
40
+ /**
41
+ * Initialize the worker (connect to backend)
42
+ */
43
+ async init() {
44
+ await this.driver.connect();
45
+ }
46
+ /**
47
+ * Register a handler for a job type
48
+ * Supports wildcards: "email.*" matches "email.welcome", "email.reset", etc.
49
+ */
50
+ handle(pattern, handler) {
51
+ this.handlers.set(pattern, handler);
52
+ // Calculate specificity for wildcard matching (longer = more specific)
53
+ const specificity = pattern.split(".").length;
54
+ const entry = { pattern, handler, specificity };
55
+ // Insert in order of specificity (highest first)
56
+ const index = this.handlerRegistry.findIndex((e) => e.specificity < specificity);
57
+ if (index >= 0) {
58
+ this.handlerRegistry.splice(index, 0, entry);
59
+ }
60
+ else {
61
+ this.handlerRegistry.push(entry);
62
+ }
63
+ }
64
+ /**
65
+ * Remove a handler
66
+ */
67
+ unhandle(pattern) {
68
+ this.handlers.delete(pattern);
69
+ const index = this.handlerRegistry.findIndex((e) => e.pattern === pattern);
70
+ if (index >= 0) {
71
+ this.handlerRegistry.splice(index, 1);
72
+ }
73
+ }
74
+ /**
75
+ * Listen for worker events
76
+ */
77
+ on(eventType, listener) {
78
+ if (!this.eventListeners.has(eventType)) {
79
+ this.eventListeners.set(eventType, new Set());
80
+ }
81
+ this.eventListeners.get(eventType).add(listener);
82
+ }
83
+ /**
84
+ * Stop listening for events
85
+ */
86
+ off(eventType, listener) {
87
+ this.eventListeners.get(eventType)?.delete(listener);
88
+ }
89
+ /**
90
+ * Emit a worker event
91
+ */
92
+ _emitEvent(eventType, job) {
93
+ const listeners = this.eventListeners.get(eventType);
94
+ if (!listeners)
95
+ return;
96
+ const event = {
97
+ type: eventType,
98
+ job,
99
+ timestamp: new Date(),
100
+ };
101
+ for (const listener of listeners) {
102
+ try {
103
+ listener(event);
104
+ }
105
+ catch (error) {
106
+ console.error(`Error in ${eventType} listener:`, error);
107
+ }
108
+ }
109
+ }
110
+ /**
111
+ * Find the best matching handler for a job
112
+ */
113
+ findHandler(jobName) {
114
+ for (const entry of this.handlerRegistry) {
115
+ if (this._patternMatches(entry.pattern, jobName)) {
116
+ return entry.handler;
117
+ }
118
+ }
119
+ return null;
120
+ }
121
+ /**
122
+ * Check if a pattern matches a job name (supports wildcards)
123
+ */
124
+ _patternMatches(pattern, jobName) {
125
+ if (pattern === jobName)
126
+ return true;
127
+ // Handle wildcards: "email.*" matches "email.welcome"
128
+ if (pattern.endsWith(".*")) {
129
+ const prefix = pattern.slice(0, -2); // Remove ".*"
130
+ return jobName.startsWith(prefix + ".");
131
+ }
132
+ return false;
133
+ }
134
+ /**
135
+ * Start the worker (blocks until stopped)
136
+ */
137
+ async start() {
138
+ this.isRunning = true;
139
+ console.log("[JobWorker] Starting worker process");
140
+ // Handle signals for graceful shutdown
141
+ const handleSignal = async () => {
142
+ await this.stop();
143
+ };
144
+ process.on("SIGTERM", handleSignal);
145
+ process.on("SIGINT", handleSignal);
146
+ try {
147
+ await this._pollLoop();
148
+ }
149
+ finally {
150
+ process.removeListener("SIGTERM", handleSignal);
151
+ process.removeListener("SIGINT", handleSignal);
152
+ }
153
+ }
154
+ /**
155
+ * Main polling loop
156
+ */
157
+ async _pollLoop() {
158
+ while (this.isRunning) {
159
+ try {
160
+ const availableSlots = this.concurrency - this.inFlightJobs.size;
161
+ if (availableSlots > 0) {
162
+ const jobs = await this.driver.claim(availableSlots, this.jobTimeout);
163
+ if (jobs.length > 0) {
164
+ // Reset backoff on successful claim
165
+ this.currentBackoff = 0;
166
+ // Process jobs concurrently
167
+ for (const job of jobs) {
168
+ this._processJob(job).catch((error) => {
169
+ console.error(`[JobWorker] Unhandled error processing job ${job.id}:`, error);
170
+ });
171
+ }
172
+ }
173
+ else {
174
+ // No jobs, increase backoff
175
+ this.currentBackoff = Math.min((this.currentBackoff || this.pollInterval) * 1.5, this.maxBackoffDelay);
176
+ }
177
+ }
178
+ // Sleep before next poll
179
+ const delay = this.currentBackoff || this.pollInterval;
180
+ await new Promise((resolve) => setTimeout(resolve, delay));
181
+ }
182
+ catch (error) {
183
+ console.error("[JobWorker] Error in polling loop:", error);
184
+ // Backoff on error
185
+ this.currentBackoff = Math.min((this.currentBackoff || this.pollInterval) * 1.5, this.maxBackoffDelay);
186
+ await new Promise((resolve) => setTimeout(resolve, this.currentBackoff));
187
+ }
188
+ }
189
+ }
190
+ /**
191
+ * Process a single job
192
+ */
193
+ async _processJob(job) {
194
+ this.inFlightJobs.add(job.id);
195
+ try {
196
+ const handler = this.findHandler(job.name);
197
+ if (!handler) {
198
+ console.warn(`[JobWorker] No handler found for job type: ${job.name}`);
199
+ await this.driver.complete(job.id);
200
+ return;
201
+ }
202
+ this._emitEvent("started", job);
203
+ // Execute handler with timeout
204
+ const timeoutPromise = new Promise((_, reject) => setTimeout(() => reject(new Error(`Job timeout after ${this.jobTimeout}ms`)), this.jobTimeout));
205
+ const handlerPromise = handler(job);
206
+ await Promise.race([handlerPromise, timeoutPromise]);
207
+ this._emitEvent("completed", job);
208
+ await this.driver.complete(job.id);
209
+ }
210
+ catch (error) {
211
+ const errorMsg = error instanceof Error ? error.message : String(error);
212
+ const stackTrace = error instanceof Error ? error.stack : undefined;
213
+ // Determine if we should retry
214
+ if (job.attempts < job.maxRetries) {
215
+ // Exponential backoff: 1s, 2s, 4s, 8s, etc. (capped at 1 hour)
216
+ const delaySeconds = Math.min(Math.pow(2, job.attempts), 3600);
217
+ const delayMs = delaySeconds * 1000;
218
+ this._emitEvent("retried", job);
219
+ await this.driver.scheduleRetry(job.id, delayMs, errorMsg);
220
+ console.warn(`[JobWorker] Job ${job.id} failed (attempt ${job.attempts}/${job.maxRetries}): ${errorMsg}. Retrying in ${delaySeconds}s`);
221
+ }
222
+ else {
223
+ this._emitEvent("failed", job);
224
+ await this.driver.fail(job.id, errorMsg, stackTrace);
225
+ console.error(`[JobWorker] Job ${job.id} failed permanently: ${errorMsg}`);
226
+ }
227
+ }
228
+ finally {
229
+ this.inFlightJobs.delete(job.id);
230
+ }
231
+ }
232
+ /**
233
+ * Stop the worker gracefully
234
+ * Waits for in-flight jobs to complete before shutdown
235
+ */
236
+ async stop() {
237
+ if (!this.isRunning)
238
+ return;
239
+ console.log("[JobWorker] Shutting down gracefully...");
240
+ this.isRunning = false;
241
+ // Wait for in-flight jobs to complete
242
+ const startTime = Date.now();
243
+ while (this.inFlightJobs.size > 0 &&
244
+ Date.now() - startTime < this.shutdownTimeout) {
245
+ await new Promise((resolve) => setTimeout(resolve, 100));
246
+ }
247
+ if (this.inFlightJobs.size > 0) {
248
+ console.warn(`[JobWorker] Force shutdown with ${this.inFlightJobs.size} jobs still in flight`);
249
+ }
250
+ else {
251
+ console.log("[JobWorker] All jobs completed, shutting down");
252
+ }
253
+ await this.driver.disconnect();
254
+ }
255
+ /**
256
+ * Get the number of jobs currently being processed
257
+ */
258
+ getInFlightCount() {
259
+ return this.inFlightJobs.size;
260
+ }
261
+ /**
262
+ * Get queue metrics
263
+ */
264
+ async getMetrics() {
265
+ return this.driver.getMetrics();
266
+ }
267
+ /**
268
+ * Check if worker is running
269
+ */
270
+ isActive() {
271
+ return this.isRunning;
272
+ }
273
+ }
274
+ // ============= Worker CLI Entry Point =============
275
+ /**
276
+ * Create and start a worker from config
277
+ * Useful for CLI commands like: bueno queue:worker
278
+ */
279
+ export async function startWorker(config) {
280
+ const worker = new JobWorker(config);
281
+ // Log metrics periodically
282
+ const metricsInterval = setInterval(async () => {
283
+ if (worker.isActive()) {
284
+ const metrics = await worker.getMetrics();
285
+ console.log("[JobWorker] Metrics:", {
286
+ pending: metrics.pending,
287
+ processing: metrics.processing,
288
+ processed: metrics.processed,
289
+ failed: metrics.failed,
290
+ avgLatency: `${Math.round(metrics.avgLatency)}ms`,
291
+ });
292
+ }
293
+ }, 30000);
294
+ await worker.init();
295
+ process.on("exit", () => {
296
+ clearInterval(metricsInterval);
297
+ });
298
+ await worker.start();
299
+ }
300
+ //# sourceMappingURL=worker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"worker.js","sourceRoot":"","sources":["../../src/jobs/worker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,141 @@
1
+ /**
2
+ * Distributed Locking
3
+ *
4
+ * Redis-based distributed locks with in-memory fallback.
5
+ * Uses Bun 1.3+ native Redis client for production.
6
+ *
7
+ * Implementation based on Redis SET NX PX pattern with Lua scripts
8
+ * for safe lock release and extension.
9
+ */
10
+ export interface LockConfig {
11
+ driver?: "redis" | "memory";
12
+ url?: string;
13
+ keyPrefix?: string;
14
+ defaultTTL?: number;
15
+ retryCount?: number;
16
+ retryDelay?: number;
17
+ autoExtend?: boolean;
18
+ }
19
+ export interface LockOptions {
20
+ ttl?: number;
21
+ retryCount?: number;
22
+ retryDelay?: number;
23
+ }
24
+ export interface Lock {
25
+ key: string;
26
+ value: string;
27
+ acquired: boolean;
28
+ acquiredAt: number;
29
+ ttl: number;
30
+ expiresAt: number;
31
+ }
32
+ export interface LockHandle {
33
+ /** Whether the lock was successfully acquired */
34
+ acquired: boolean;
35
+ /** Release the lock */
36
+ release: () => Promise<boolean>;
37
+ /** Extend the lock TTL */
38
+ extend: (ttl?: number) => Promise<boolean>;
39
+ /** Check if lock is still held */
40
+ isValid: () => Promise<boolean>;
41
+ /** Get remaining TTL in milliseconds */
42
+ getRemainingTTL: () => Promise<number>;
43
+ /** The lock key */
44
+ key: string;
45
+ /** The lock value (unique identifier) */
46
+ value: string;
47
+ }
48
+ export declare class DistributedLock {
49
+ private driver;
50
+ private driverType;
51
+ private keyPrefix;
52
+ private defaultTTL;
53
+ private defaultRetryCount;
54
+ private defaultRetryDelay;
55
+ private _isConnected;
56
+ constructor(config?: LockConfig);
57
+ /**
58
+ * Connect to the lock backend (Redis only)
59
+ */
60
+ connect(): Promise<void>;
61
+ /**
62
+ * Disconnect from the lock backend
63
+ */
64
+ disconnect(): Promise<void>;
65
+ /**
66
+ * Check if connected
67
+ */
68
+ get isConnected(): boolean;
69
+ /**
70
+ * Get the driver type
71
+ */
72
+ getDriverType(): "redis" | "memory";
73
+ /**
74
+ * Generate a unique lock value
75
+ */
76
+ private generateLockValue;
77
+ /**
78
+ * Try to acquire a lock without retry
79
+ */
80
+ private tryAcquire;
81
+ /**
82
+ * Acquire a lock
83
+ * Returns a LockHandle that can be used to release or extend the lock
84
+ */
85
+ acquire(key: string, options?: LockOptions): Promise<LockHandle>;
86
+ /**
87
+ * Acquire a lock and execute a function
88
+ * Automatically releases the lock when done
89
+ */
90
+ withLock<T>(key: string, fn: (lock: LockHandle) => Promise<T>, options?: LockOptions): Promise<T>;
91
+ /**
92
+ * Acquire a lock with automatic extension for long-running operations
93
+ */
94
+ withAutoExtend<T>(key: string, fn: (lock: LockHandle) => Promise<T>, options?: LockOptions): Promise<T>;
95
+ /**
96
+ * Try to acquire a lock without waiting
97
+ * Returns immediately whether the lock was acquired
98
+ */
99
+ tryLock(key: string, options?: LockOptions): Promise<LockHandle>;
100
+ /**
101
+ * Check if a lock exists (anyone holds it)
102
+ */
103
+ isLocked(key: string): Promise<boolean>;
104
+ /**
105
+ * Force release a lock (dangerous - use with caution)
106
+ * This will release the lock regardless of ownership
107
+ */
108
+ forceRelease(key: string): Promise<void>;
109
+ private sleep;
110
+ }
111
+ export declare class LockAcquireError extends Error {
112
+ constructor(message: string);
113
+ }
114
+ export declare class LockTimeoutError extends Error {
115
+ constructor(message: string);
116
+ }
117
+ /**
118
+ * Create a distributed lock instance
119
+ */
120
+ export declare function createDistributedLock(config?: LockConfig): DistributedLock;
121
+ /**
122
+ * Create a Redis-based distributed lock
123
+ */
124
+ export declare function createRedisLock(url: string, options?: Omit<LockConfig, "driver" | "url">): DistributedLock;
125
+ /**
126
+ * Create an in-memory lock (for development/testing)
127
+ */
128
+ export declare function createMemoryLock(): DistributedLock;
129
+ /**
130
+ * Get the default lock instance
131
+ */
132
+ export declare function getDefaultLock(): DistributedLock;
133
+ /**
134
+ * Set the default lock instance
135
+ */
136
+ export declare function setDefaultLock(lock: DistributedLock): void;
137
+ /**
138
+ * Acquire a lock using the default instance
139
+ */
140
+ export declare function lock<T>(key: string, fn: () => Promise<T>, options?: LockOptions): Promise<T>;
141
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/lock/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/lock/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,156 @@
1
+ /**
2
+ * Structured Logging System
3
+ *
4
+ * Provides structured logging with JSON output, log levels,
5
+ * context-aware logging, and performance metrics.
6
+ */
7
+ export type LogLevel = "debug" | "info" | "warn" | "error" | "fatal";
8
+ export interface LogEntry {
9
+ level: LogLevel;
10
+ message: string;
11
+ timestamp: string;
12
+ context?: Record<string, unknown>;
13
+ error?: {
14
+ name: string;
15
+ message: string;
16
+ stack?: string;
17
+ };
18
+ duration?: number;
19
+ [key: string]: unknown;
20
+ }
21
+ export interface LoggerConfig {
22
+ level?: LogLevel;
23
+ pretty?: boolean;
24
+ timestamp?: boolean;
25
+ context?: Record<string, unknown>;
26
+ output?: "console" | "stdout" | ((entry: LogEntry) => void);
27
+ }
28
+ export interface LoggerContext {
29
+ requestId?: string;
30
+ userId?: string;
31
+ method?: string;
32
+ path?: string;
33
+ [key: string]: unknown;
34
+ }
35
+ export declare class Logger {
36
+ private level;
37
+ private pretty;
38
+ private timestamp;
39
+ private context;
40
+ private output;
41
+ constructor(config?: LoggerConfig);
42
+ /**
43
+ * Check if a log level should be logged
44
+ */
45
+ private shouldLog;
46
+ /**
47
+ * Serialize log entry to JSON
48
+ */
49
+ private serialize;
50
+ /**
51
+ * Pretty print log entry
52
+ */
53
+ private prettyPrint;
54
+ /**
55
+ * Create a log entry
56
+ */
57
+ private createEntry;
58
+ /**
59
+ * Log a debug message
60
+ */
61
+ debug(message: string, context?: Record<string, unknown>): void;
62
+ /**
63
+ * Log an info message
64
+ */
65
+ info(message: string, context?: Record<string, unknown>): void;
66
+ /**
67
+ * Log a warning message
68
+ */
69
+ warn(message: string, context?: Record<string, unknown>): void;
70
+ /**
71
+ * Log an error message
72
+ */
73
+ error(message: string, error?: Error | unknown, context?: Record<string, unknown>): void;
74
+ /**
75
+ * Log a fatal message
76
+ */
77
+ fatal(message: string, error?: Error | unknown, context?: Record<string, unknown>): void;
78
+ /**
79
+ * Create a child logger with additional context
80
+ */
81
+ child(context: Record<string, unknown>): Logger;
82
+ /**
83
+ * Set log level
84
+ */
85
+ setLevel(level: LogLevel): void;
86
+ /**
87
+ * Add context to the logger
88
+ */
89
+ addContext(context: Record<string, unknown>): void;
90
+ /**
91
+ * Time a function
92
+ */
93
+ time<T>(label: string, fn: () => T | Promise<T>): Promise<T>;
94
+ /**
95
+ * Create a timer
96
+ */
97
+ startTimer(label: string): () => number;
98
+ }
99
+ export interface RequestLogContext {
100
+ requestId?: string;
101
+ method: string;
102
+ path: string;
103
+ query?: string;
104
+ ip?: string;
105
+ userAgent?: string;
106
+ userId?: string;
107
+ }
108
+ export interface ResponseLogContext extends RequestLogContext {
109
+ statusCode: number;
110
+ duration: number;
111
+ contentLength?: number;
112
+ }
113
+ /**
114
+ * Create a request logger middleware
115
+ */
116
+ export declare function createRequestLogger(logger: Logger): (ctx: unknown, next: () => Promise<unknown>) => Promise<unknown>;
117
+ export declare class PerformanceLogger {
118
+ private logger;
119
+ private metrics;
120
+ constructor(logger: Logger);
121
+ /**
122
+ * Record a metric
123
+ */
124
+ record(name: string, value: number): void;
125
+ /**
126
+ * Get metric statistics
127
+ */
128
+ stats(name: string): {
129
+ count: number;
130
+ min: number;
131
+ max: number;
132
+ avg: number;
133
+ p99: number;
134
+ } | null;
135
+ /**
136
+ * Log all metrics
137
+ */
138
+ logMetrics(): void;
139
+ /**
140
+ * Clear all metrics
141
+ */
142
+ clear(): void;
143
+ }
144
+ /**
145
+ * Get the default logger instance
146
+ */
147
+ export declare function getLogger(): Logger;
148
+ /**
149
+ * Set the default logger instance
150
+ */
151
+ export declare function setLogger(logger: Logger): void;
152
+ /**
153
+ * Create a new logger
154
+ */
155
+ export declare function createLogger(config?: LoggerConfig): Logger;
156
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/logger/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/logger/index.ts"],"names":[],"mappings":"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"}