@zintrust/core 0.1.39 → 0.1.41

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 (475) hide show
  1. package/bin/zintrust-main.d.ts.map +1 -1
  2. package/bin/zintrust-main.js +22 -1
  3. package/package.json +8 -4
  4. package/public/error-pages/404.html +2 -2
  5. package/src/auth/Auth.js +1 -1
  6. package/src/boot/Application.d.ts +1 -16
  7. package/src/boot/Application.d.ts.map +1 -1
  8. package/src/boot/Application.js +2 -262
  9. package/src/boot/Server.d.ts +1 -1
  10. package/src/boot/Server.d.ts.map +1 -1
  11. package/src/boot/bootstrap.js +23 -9
  12. package/src/boot/registry/registerRoute.d.ts +6 -0
  13. package/src/boot/registry/registerRoute.d.ts.map +1 -0
  14. package/src/boot/registry/registerRoute.js +96 -0
  15. package/src/boot/registry/runtime.d.ts +15 -0
  16. package/src/boot/registry/runtime.d.ts.map +1 -0
  17. package/src/boot/registry/runtime.js +353 -0
  18. package/src/boot/registry/type.d.ts +25 -0
  19. package/src/boot/registry/type.d.ts.map +1 -0
  20. package/src/boot/registry/type.js +1 -0
  21. package/src/boot/registry/worker.d.ts +6 -0
  22. package/src/boot/registry/worker.d.ts.map +1 -0
  23. package/src/boot/registry/worker.js +35 -0
  24. package/src/cache/drivers/KVRemoteDriver.d.ts.map +1 -1
  25. package/src/cache/drivers/KVRemoteDriver.js +14 -1
  26. package/src/cli/CLI.d.ts.map +1 -1
  27. package/src/cli/CLI.js +82 -34
  28. package/src/cli/ErrorHandler.js +1 -1
  29. package/src/cli/commands/ContainerProxiesCommand.d.ts +5 -0
  30. package/src/cli/commands/ContainerProxiesCommand.d.ts.map +1 -0
  31. package/src/cli/commands/ContainerProxiesCommand.js +77 -0
  32. package/src/cli/commands/ContainerWorkersCommand.d.ts +5 -0
  33. package/src/cli/commands/ContainerWorkersCommand.d.ts.map +1 -0
  34. package/src/cli/commands/ContainerWorkersCommand.js +57 -0
  35. package/src/cli/commands/DeployCommand.d.ts +16 -0
  36. package/src/cli/commands/DeployCommand.d.ts.map +1 -0
  37. package/src/cli/commands/DeployCommand.js +110 -0
  38. package/src/cli/commands/DeployContainerProxiesCommand.d.ts +5 -0
  39. package/src/cli/commands/DeployContainerProxiesCommand.d.ts.map +1 -0
  40. package/src/cli/commands/DeployContainerProxiesCommand.js +27 -0
  41. package/src/cli/commands/DeployContainerWorkersCommand.d.ts +5 -0
  42. package/src/cli/commands/DeployContainerWorkersCommand.d.ts.map +1 -0
  43. package/src/cli/commands/DeployContainerWorkersCommand.js +27 -0
  44. package/src/cli/commands/DockerComposeCommandUtils.d.ts +3 -0
  45. package/src/cli/commands/DockerComposeCommandUtils.d.ts.map +1 -0
  46. package/src/cli/commands/DockerComposeCommandUtils.js +34 -0
  47. package/src/cli/commands/DoctorArchitectureCommand.d.ts +5 -0
  48. package/src/cli/commands/DoctorArchitectureCommand.d.ts.map +1 -0
  49. package/src/cli/commands/DoctorArchitectureCommand.js +54 -0
  50. package/src/cli/commands/InitContainerCommand.d.ts +5 -0
  51. package/src/cli/commands/InitContainerCommand.d.ts.map +1 -0
  52. package/src/cli/commands/InitContainerCommand.js +216 -0
  53. package/src/cli/commands/InitProducerCommand.d.ts +5 -0
  54. package/src/cli/commands/InitProducerCommand.d.ts.map +1 -0
  55. package/src/cli/commands/InitProducerCommand.js +47 -0
  56. package/src/cli/commands/InitProxyCommand.d.ts +5 -0
  57. package/src/cli/commands/InitProxyCommand.d.ts.map +1 -0
  58. package/src/cli/commands/InitProxyCommand.js +442 -0
  59. package/src/cli/commands/MongoDBProxyCommand.d.ts +5 -0
  60. package/src/cli/commands/MongoDBProxyCommand.d.ts.map +1 -0
  61. package/src/cli/commands/MongoDBProxyCommand.js +98 -0
  62. package/src/cli/commands/MySqlProxyCommand.d.ts +6 -0
  63. package/src/cli/commands/MySqlProxyCommand.d.ts.map +1 -0
  64. package/src/cli/commands/MySqlProxyCommand.js +32 -0
  65. package/src/cli/commands/PostgresProxyCommand.d.ts +6 -0
  66. package/src/cli/commands/PostgresProxyCommand.d.ts.map +1 -0
  67. package/src/cli/commands/PostgresProxyCommand.js +32 -0
  68. package/src/cli/commands/ProxyCommand.d.ts +12 -0
  69. package/src/cli/commands/ProxyCommand.d.ts.map +1 -0
  70. package/src/cli/commands/ProxyCommand.js +80 -0
  71. package/src/cli/commands/ProxyCommandUtils.d.ts +6 -0
  72. package/src/cli/commands/ProxyCommandUtils.d.ts.map +1 -0
  73. package/src/cli/commands/ProxyCommandUtils.js +38 -0
  74. package/src/cli/commands/QueueRecoveryCommand.d.ts +6 -0
  75. package/src/cli/commands/QueueRecoveryCommand.d.ts.map +1 -0
  76. package/src/cli/commands/QueueRecoveryCommand.js +513 -0
  77. package/src/cli/commands/RedisProxyCommand.d.ts +6 -0
  78. package/src/cli/commands/RedisProxyCommand.d.ts.map +1 -0
  79. package/src/cli/commands/RedisProxyCommand.js +53 -0
  80. package/src/cli/commands/SmtpProxyCommand.d.ts +6 -0
  81. package/src/cli/commands/SmtpProxyCommand.d.ts.map +1 -0
  82. package/src/cli/commands/SmtpProxyCommand.js +56 -0
  83. package/src/cli/commands/SqlProxyCommandUtils.d.ts +46 -0
  84. package/src/cli/commands/SqlProxyCommandUtils.d.ts.map +1 -0
  85. package/src/cli/commands/SqlProxyCommandUtils.js +48 -0
  86. package/src/cli/commands/SqlServerProxyCommand.d.ts +5 -0
  87. package/src/cli/commands/SqlServerProxyCommand.d.ts.map +1 -0
  88. package/src/cli/commands/SqlServerProxyCommand.js +85 -0
  89. package/src/cli/commands/StartCommand.d.ts.map +1 -1
  90. package/src/cli/commands/StartCommand.js +145 -18
  91. package/src/cli/commands/WorkerCommands.d.ts +1 -0
  92. package/src/cli/commands/WorkerCommands.d.ts.map +1 -1
  93. package/src/cli/commands/WorkerCommands.js +140 -6
  94. package/src/cli/commands/index.d.ts +2 -0
  95. package/src/cli/commands/index.d.ts.map +1 -1
  96. package/src/cli/commands/index.js +2 -0
  97. package/src/cli/commands/runner/index.d.ts +2 -2
  98. package/src/cli/commands/runner/index.d.ts.map +1 -1
  99. package/src/cli/commands/runner/index.js +15 -4
  100. package/src/cli/d1/D1SqlMigrations.d.ts.map +1 -1
  101. package/src/cli/d1/D1SqlMigrations.js +3 -0
  102. package/src/cli/index.d.ts +4 -0
  103. package/src/cli/index.d.ts.map +1 -1
  104. package/src/cli/index.js +4 -0
  105. package/src/cli/scaffolding/ProjectScaffolder.d.ts.map +1 -1
  106. package/src/cli/scaffolding/ProjectScaffolder.js +2 -0
  107. package/src/cli/scaffolding/ServiceScaffolder.d.ts.map +1 -1
  108. package/src/cli/scaffolding/ServiceScaffolder.js +1 -0
  109. package/src/cli/utils/EnvFileLoader.d.ts +2 -1
  110. package/src/cli/utils/EnvFileLoader.d.ts.map +1 -1
  111. package/src/cli/utils/EnvFileLoader.js +22 -21
  112. package/src/cli/utils/spawn.d.ts.map +1 -1
  113. package/src/cli/utils/spawn.js +17 -10
  114. package/src/cli/workers/QueueWorkRunner.js +1 -1
  115. package/src/common/ExternalServiceUtils.d.ts.map +1 -1
  116. package/src/common/ExternalServiceUtils.js +7 -2
  117. package/src/common/HealthRoutes.d.ts.map +1 -1
  118. package/src/common/HealthRoutes.js +50 -2
  119. package/src/common/RemoteSignedJson.d.ts +1 -0
  120. package/src/common/RemoteSignedJson.d.ts.map +1 -1
  121. package/src/common/RemoteSignedJson.js +39 -13
  122. package/src/common/index.d.ts +1 -0
  123. package/src/common/index.d.ts.map +1 -1
  124. package/src/common/index.js +12 -1
  125. package/src/config/FileLogWriter.d.ts.map +1 -1
  126. package/src/config/FileLogWriter.js +21 -6
  127. package/src/config/app.d.ts +4 -0
  128. package/src/config/app.d.ts.map +1 -1
  129. package/src/config/app.js +4 -0
  130. package/src/config/cache.d.ts.map +1 -1
  131. package/src/config/cache.js +22 -2
  132. package/src/config/cloudflare.d.ts +5 -1
  133. package/src/config/cloudflare.d.ts.map +1 -1
  134. package/src/config/cloudflare.js +48 -0
  135. package/src/config/database.d.ts.map +1 -1
  136. package/src/config/database.js +48 -13
  137. package/src/config/env.d.ts +90 -2
  138. package/src/config/env.d.ts.map +1 -1
  139. package/src/config/env.js +160 -18
  140. package/src/config/index.d.ts +1 -0
  141. package/src/config/index.d.ts.map +1 -1
  142. package/src/config/logger.d.ts.map +1 -1
  143. package/src/config/logger.js +60 -16
  144. package/src/config/mail.d.ts.map +1 -1
  145. package/src/config/mail.js +16 -10
  146. package/src/config/middleware.d.ts +5 -0
  147. package/src/config/middleware.d.ts.map +1 -1
  148. package/src/config/middleware.js +19 -1
  149. package/src/config/queue.d.ts.map +1 -1
  150. package/src/config/queue.js +70 -9
  151. package/src/config/redis.d.ts.map +1 -1
  152. package/src/config/redis.js +48 -13
  153. package/src/config/storage.d.ts.map +1 -1
  154. package/src/config/storage.js +1 -0
  155. package/src/config/type.d.ts +19 -0
  156. package/src/config/type.d.ts.map +1 -1
  157. package/src/config/workers.d.ts.map +1 -1
  158. package/src/config/workers.js +122 -16
  159. package/src/functions/cloudflare.d.ts.map +1 -1
  160. package/src/functions/cloudflare.js +55 -1
  161. package/src/health/StartupHealthChecks.js +1 -1
  162. package/src/http/FileUpload.d.ts +3 -2
  163. package/src/http/FileUpload.d.ts.map +1 -1
  164. package/src/http/Kernel.d.ts.map +1 -1
  165. package/src/http/Kernel.js +2 -1
  166. package/src/http/error-pages/ErrorPageRenderer.d.ts +4 -0
  167. package/src/http/error-pages/ErrorPageRenderer.d.ts.map +1 -1
  168. package/src/http/error-pages/ErrorPageRenderer.js +141 -1
  169. package/src/http/middleware/BodyParsingMiddleware.d.ts.map +1 -1
  170. package/src/http/middleware/BodyParsingMiddleware.js +33 -6
  171. package/src/index.d.ts +25 -53
  172. package/src/index.d.ts.map +1 -1
  173. package/src/index.js +30 -14
  174. package/src/microservices/ServiceAuthMiddleware.d.ts.map +1 -1
  175. package/src/microservices/ServiceAuthMiddleware.js +12 -4
  176. package/src/middleware/CsrfMiddleware.d.ts.map +1 -1
  177. package/src/middleware/CsrfMiddleware.js +39 -10
  178. package/src/middleware/ErrorHandlerMiddleware.d.ts.map +1 -1
  179. package/src/middleware/ErrorHandlerMiddleware.js +2 -1
  180. package/src/migrations/MigrationLoader.js +1 -1
  181. package/src/migrations/schema/SchemaCompiler.d.ts.map +1 -1
  182. package/src/migrations/schema/SchemaCompiler.js +6 -3
  183. package/src/node-singletons/crypto.d.ts +1 -1
  184. package/src/node-singletons/crypto.d.ts.map +1 -1
  185. package/src/node-singletons/crypto.js +1 -1
  186. package/src/node-singletons/fs.d.ts +1 -1
  187. package/src/node-singletons/fs.d.ts.map +1 -1
  188. package/src/node-singletons/path.d.ts +1 -1
  189. package/src/node-singletons/path.d.ts.map +1 -1
  190. package/src/node-singletons/path.js +1 -1
  191. package/src/node-singletons/stream.d.ts +11 -0
  192. package/src/node-singletons/stream.d.ts.map +1 -0
  193. package/src/node-singletons/stream.js +8 -0
  194. package/src/observability/OpenTelemetry.d.ts +7 -0
  195. package/src/observability/OpenTelemetry.d.ts.map +1 -1
  196. package/src/observability/OpenTelemetry.js +49 -2
  197. package/src/orm/Database.d.ts +4 -0
  198. package/src/orm/Database.d.ts.map +1 -1
  199. package/src/orm/Database.js +80 -9
  200. package/src/orm/DatabaseRuntimeRegistration.d.ts.map +1 -1
  201. package/src/orm/DatabaseRuntimeRegistration.js +2 -0
  202. package/src/orm/QueryBuilder.d.ts +1 -0
  203. package/src/orm/QueryBuilder.d.ts.map +1 -1
  204. package/src/orm/QueryBuilder.js +33 -3
  205. package/src/orm/SchemaCompiler.d.ts.map +1 -1
  206. package/src/orm/SchemaCompiler.js +6 -3
  207. package/src/orm/adapters/D1RemoteAdapter.d.ts.map +1 -1
  208. package/src/orm/adapters/D1RemoteAdapter.js +14 -1
  209. package/src/orm/adapters/MongoDBProxyAdapter.d.ts +3 -0
  210. package/src/orm/adapters/MongoDBProxyAdapter.d.ts.map +1 -0
  211. package/src/orm/adapters/MongoDBProxyAdapter.js +128 -0
  212. package/src/orm/adapters/MySQLProxyAdapter.d.ts +11 -0
  213. package/src/orm/adapters/MySQLProxyAdapter.d.ts.map +1 -0
  214. package/src/orm/adapters/MySQLProxyAdapter.js +143 -0
  215. package/src/orm/adapters/PostgreSQLProxyAdapter.d.ts +11 -0
  216. package/src/orm/adapters/PostgreSQLProxyAdapter.d.ts.map +1 -0
  217. package/src/orm/adapters/PostgreSQLProxyAdapter.js +147 -0
  218. package/src/orm/adapters/ProxyCache.d.ts +9 -0
  219. package/src/orm/adapters/ProxyCache.d.ts.map +1 -0
  220. package/src/orm/adapters/ProxyCache.js +24 -0
  221. package/src/orm/adapters/ProxySignedRequest.d.ts +11 -0
  222. package/src/orm/adapters/ProxySignedRequest.d.ts.map +1 -0
  223. package/src/orm/adapters/ProxySignedRequest.js +30 -0
  224. package/src/orm/adapters/ProxySigningPath.d.ts +3 -0
  225. package/src/orm/adapters/ProxySigningPath.d.ts.map +1 -0
  226. package/src/orm/adapters/ProxySigningPath.js +25 -0
  227. package/src/orm/adapters/SqlProxyAdapterUtils.d.ts +19 -0
  228. package/src/orm/adapters/SqlProxyAdapterUtils.d.ts.map +1 -0
  229. package/src/orm/adapters/SqlProxyAdapterUtils.js +35 -0
  230. package/src/orm/adapters/SqlServerProxyAdapter.d.ts +3 -0
  231. package/src/orm/adapters/SqlServerProxyAdapter.d.ts.map +1 -0
  232. package/src/orm/adapters/SqlServerProxyAdapter.js +146 -0
  233. package/src/performance/Optimizer.d.ts +1 -0
  234. package/src/performance/Optimizer.d.ts.map +1 -1
  235. package/src/performance/Optimizer.js +21 -8
  236. package/src/proxy/ErrorHandler.d.ts +11 -0
  237. package/src/proxy/ErrorHandler.d.ts.map +1 -0
  238. package/src/proxy/ErrorHandler.js +7 -0
  239. package/src/proxy/PoolManager.d.ts +8 -0
  240. package/src/proxy/PoolManager.d.ts.map +1 -0
  241. package/src/proxy/PoolManager.js +18 -0
  242. package/src/proxy/ProxyBackend.d.ts +18 -0
  243. package/src/proxy/ProxyBackend.d.ts.map +1 -0
  244. package/src/proxy/ProxyBackend.js +1 -0
  245. package/src/proxy/ProxyConfig.d.ts +12 -0
  246. package/src/proxy/ProxyConfig.d.ts.map +1 -0
  247. package/src/proxy/ProxyConfig.js +1 -0
  248. package/src/proxy/ProxyRegistry.d.ts +10 -0
  249. package/src/proxy/ProxyRegistry.d.ts.map +1 -0
  250. package/src/proxy/ProxyRegistry.js +11 -0
  251. package/src/proxy/ProxyServer.d.ts +21 -0
  252. package/src/proxy/ProxyServer.d.ts.map +1 -0
  253. package/src/proxy/ProxyServer.js +84 -0
  254. package/src/proxy/ProxyServerUtils.d.ts +37 -0
  255. package/src/proxy/ProxyServerUtils.d.ts.map +1 -0
  256. package/src/proxy/ProxyServerUtils.js +42 -0
  257. package/src/proxy/ProxySigningConfigResolver.d.ts +22 -0
  258. package/src/proxy/ProxySigningConfigResolver.d.ts.map +1 -0
  259. package/src/proxy/ProxySigningConfigResolver.js +24 -0
  260. package/src/proxy/ProxySigningRequest.d.ts +12 -0
  261. package/src/proxy/ProxySigningRequest.d.ts.map +1 -0
  262. package/src/proxy/ProxySigningRequest.js +31 -0
  263. package/src/proxy/RequestValidator.d.ts +15 -0
  264. package/src/proxy/RequestValidator.d.ts.map +1 -0
  265. package/src/proxy/RequestValidator.js +25 -0
  266. package/src/proxy/SigningService.d.ts +39 -0
  267. package/src/proxy/SigningService.d.ts.map +1 -0
  268. package/src/proxy/SigningService.js +107 -0
  269. package/src/proxy/SqlPayloadValidator.d.ts +13 -0
  270. package/src/proxy/SqlPayloadValidator.d.ts.map +1 -0
  271. package/src/proxy/SqlPayloadValidator.js +14 -0
  272. package/src/proxy/d1/ZintrustD1Proxy.d.ts +2 -0
  273. package/src/proxy/d1/ZintrustD1Proxy.d.ts.map +1 -0
  274. package/src/proxy/d1/ZintrustD1Proxy.js +1 -0
  275. package/src/proxy/d1/register.d.ts +2 -0
  276. package/src/proxy/d1/register.d.ts.map +1 -0
  277. package/src/proxy/d1/register.js +5 -0
  278. package/src/proxy/kv/ZintrustKvProxy.d.ts +2 -0
  279. package/src/proxy/kv/ZintrustKvProxy.d.ts.map +1 -0
  280. package/src/proxy/kv/ZintrustKvProxy.js +1 -0
  281. package/src/proxy/kv/register.d.ts +2 -0
  282. package/src/proxy/kv/register.d.ts.map +1 -0
  283. package/src/proxy/kv/register.js +5 -0
  284. package/src/proxy/mongodb/MongoDBProxyServer.d.ts +33 -0
  285. package/src/proxy/mongodb/MongoDBProxyServer.d.ts.map +1 -0
  286. package/src/proxy/mongodb/MongoDBProxyServer.js +202 -0
  287. package/src/proxy/mongodb/register.d.ts +2 -0
  288. package/src/proxy/mongodb/register.d.ts.map +1 -0
  289. package/src/proxy/mongodb/register.js +5 -0
  290. package/src/proxy/mysql/MySqlProxyServer.d.ts +14 -0
  291. package/src/proxy/mysql/MySqlProxyServer.d.ts.map +1 -0
  292. package/src/proxy/mysql/MySqlProxyServer.js +169 -0
  293. package/src/proxy/mysql/register.d.ts +2 -0
  294. package/src/proxy/mysql/register.d.ts.map +1 -0
  295. package/src/proxy/mysql/register.js +5 -0
  296. package/src/proxy/postgres/PostgresProxyServer.d.ts +14 -0
  297. package/src/proxy/postgres/PostgresProxyServer.d.ts.map +1 -0
  298. package/src/proxy/postgres/PostgresProxyServer.js +140 -0
  299. package/src/proxy/postgres/register.d.ts +2 -0
  300. package/src/proxy/postgres/register.d.ts.map +1 -0
  301. package/src/proxy/postgres/register.js +5 -0
  302. package/src/proxy/redis/RedisProxyServer.d.ts +12 -0
  303. package/src/proxy/redis/RedisProxyServer.d.ts.map +1 -0
  304. package/src/proxy/redis/RedisProxyServer.js +192 -0
  305. package/src/proxy/redis/register.d.ts +2 -0
  306. package/src/proxy/redis/register.d.ts.map +1 -0
  307. package/src/proxy/redis/register.js +5 -0
  308. package/src/proxy/smtp/SmtpProxyServer.d.ts +19 -0
  309. package/src/proxy/smtp/SmtpProxyServer.d.ts.map +1 -0
  310. package/src/proxy/smtp/SmtpProxyServer.js +289 -0
  311. package/src/proxy/smtp/register.d.ts +2 -0
  312. package/src/proxy/smtp/register.d.ts.map +1 -0
  313. package/src/proxy/smtp/register.js +5 -0
  314. package/src/proxy/sqlserver/SqlServerProxyServer.d.ts +14 -0
  315. package/src/proxy/sqlserver/SqlServerProxyServer.d.ts.map +1 -0
  316. package/src/proxy/sqlserver/SqlServerProxyServer.js +168 -0
  317. package/src/proxy/sqlserver/register.d.ts +2 -0
  318. package/src/proxy/sqlserver/register.d.ts.map +1 -0
  319. package/src/proxy/sqlserver/register.js +5 -0
  320. package/src/routes/doc.d.ts.map +1 -1
  321. package/src/routes/doc.js +16 -2
  322. package/src/routes/error.d.ts +5 -4
  323. package/src/routes/error.d.ts.map +1 -1
  324. package/src/routes/error.js +15 -13
  325. package/src/routes/errorPages.d.ts +2 -0
  326. package/src/routes/errorPages.d.ts.map +1 -1
  327. package/src/routes/errorPages.js +144 -4
  328. package/src/runtime/PluginAutoImports.d.ts +1 -0
  329. package/src/runtime/PluginAutoImports.d.ts.map +1 -1
  330. package/src/runtime/PluginAutoImports.js +94 -9
  331. package/src/runtime/RuntimeAdapter.d.ts +8 -9
  332. package/src/runtime/RuntimeAdapter.d.ts.map +1 -1
  333. package/src/runtime/RuntimeAdapter.js +120 -34
  334. package/src/runtime/RuntimeServices.d.ts +47 -0
  335. package/src/runtime/RuntimeServices.d.ts.map +1 -0
  336. package/src/runtime/RuntimeServices.js +164 -0
  337. package/src/runtime/StartupConfigFileRegistry.d.ts +4 -4
  338. package/src/runtime/StartupConfigFileRegistry.d.ts.map +1 -1
  339. package/src/runtime/StartupConfigFileRegistry.js +12 -0
  340. package/src/runtime/WorkerAdapterImports.d.ts +5 -0
  341. package/src/runtime/WorkerAdapterImports.d.ts.map +1 -0
  342. package/src/runtime/WorkerAdapterImports.js +17 -0
  343. package/src/runtime/WorkersModule.d.ts +6 -0
  344. package/src/runtime/WorkersModule.d.ts.map +1 -0
  345. package/src/runtime/WorkersModule.js +278 -0
  346. package/src/runtime/adapters/CloudflareAdapter.d.ts.map +1 -1
  347. package/src/runtime/adapters/CloudflareAdapter.js +19 -2
  348. package/src/runtime/adapters/DenoAdapter.js +1 -0
  349. package/src/runtime/adapters/FargateAdapter.js +1 -1
  350. package/src/runtime/adapters/LambdaAdapter.js +1 -1
  351. package/src/runtime/adapters/NodeServerAdapter.js +1 -1
  352. package/src/runtime/detectRuntime.d.ts +10 -0
  353. package/src/runtime/detectRuntime.d.ts.map +1 -0
  354. package/src/runtime/detectRuntime.js +57 -0
  355. package/src/runtime/useFileLoader.d.ts.map +1 -1
  356. package/src/runtime/useFileLoader.js +16 -0
  357. package/src/scripts/TemplateImportsCheck.js +2 -2
  358. package/src/scripts/TemplateSync.js +3 -4
  359. package/src/security/CsrfTokenManager.d.ts +18 -9
  360. package/src/security/CsrfTokenManager.d.ts.map +1 -1
  361. package/src/security/CsrfTokenManager.js +204 -11
  362. package/src/security/Hash.d.ts +1 -1
  363. package/src/security/Hash.d.ts.map +1 -1
  364. package/src/security/Hash.js +31 -36
  365. package/src/seeders/SeederLoader.js +1 -1
  366. package/src/session/SessionManager.d.ts +3 -0
  367. package/src/session/SessionManager.d.ts.map +1 -1
  368. package/src/session/SessionManager.js +49 -10
  369. package/src/sockets/CloudflareSocket.d.ts +24 -0
  370. package/src/sockets/CloudflareSocket.d.ts.map +1 -0
  371. package/src/sockets/CloudflareSocket.js +259 -0
  372. package/src/start.d.ts.map +1 -1
  373. package/src/start.js +1 -8
  374. package/src/templates/project/basic/app/Middleware/index.ts.tpl +1 -1
  375. package/src/templates/project/basic/src/zintrust.plugins.wg.ts.tpl +8 -0
  376. package/src/toolkit/Secrets/providers/AwsSecretsManager.d.ts.map +1 -1
  377. package/src/toolkit/Secrets/providers/AwsSecretsManager.js +4 -2
  378. package/src/tools/mail/drivers/Smtp.d.ts.map +1 -1
  379. package/src/tools/mail/drivers/Smtp.js +223 -18
  380. package/src/tools/mail/index.d.ts.map +1 -1
  381. package/src/tools/mail/index.js +5 -4
  382. package/src/tools/mail/template-loader.d.ts.map +1 -1
  383. package/src/tools/mail/template-loader.js +197 -29
  384. package/src/tools/mail/templates/auth-password-reset.d.ts +3 -0
  385. package/src/tools/mail/templates/auth-password-reset.d.ts.map +1 -0
  386. package/src/tools/mail/templates/auth-password-reset.js +231 -0
  387. package/src/tools/mail/templates/auth-welcome.d.ts +3 -0
  388. package/src/tools/mail/templates/auth-welcome.d.ts.map +1 -0
  389. package/src/tools/mail/templates/auth-welcome.js +236 -0
  390. package/src/tools/mail/templates/general.d.ts +3 -0
  391. package/src/tools/mail/templates/general.d.ts.map +1 -0
  392. package/src/tools/mail/templates/general.js +109 -0
  393. package/src/tools/mail/templates/index.js +2 -2
  394. package/src/tools/mail/templates/job-completed.d.ts +3 -0
  395. package/src/tools/mail/templates/job-completed.d.ts.map +1 -0
  396. package/src/tools/mail/templates/job-completed.js +188 -0
  397. package/src/tools/mail/templates/notifications-new-comment.d.ts +3 -0
  398. package/src/tools/mail/templates/notifications-new-comment.d.ts.map +1 -0
  399. package/src/tools/mail/templates/notifications-new-comment.js +228 -0
  400. package/src/tools/mail/templates/password-reset.d.ts +3 -0
  401. package/src/tools/mail/templates/password-reset.d.ts.map +1 -0
  402. package/src/tools/mail/templates/password-reset.js +221 -0
  403. package/src/tools/mail/templates/performance-report.d.ts +3 -0
  404. package/src/tools/mail/templates/performance-report.d.ts.map +1 -0
  405. package/src/tools/mail/templates/performance-report.js +258 -0
  406. package/src/tools/mail/templates/welcome.d.ts +3 -0
  407. package/src/tools/mail/templates/welcome.d.ts.map +1 -0
  408. package/src/tools/mail/templates/welcome.js +187 -0
  409. package/src/tools/mail/templates/worker-alert.d.ts +3 -0
  410. package/src/tools/mail/templates/worker-alert.d.ts.map +1 -0
  411. package/src/tools/mail/templates/worker-alert.js +229 -0
  412. package/src/tools/notification/Notification.js +1 -1
  413. package/src/tools/notification/testingHelpers.js +6 -5
  414. package/src/tools/queue/AdvancedQueue.js +2 -6
  415. package/src/tools/queue/IdempotencyManager.d.ts +6 -0
  416. package/src/tools/queue/IdempotencyManager.d.ts.map +1 -0
  417. package/src/tools/queue/IdempotencyManager.js +36 -0
  418. package/src/tools/queue/JobHeartbeatStore.d.ts +16 -0
  419. package/src/tools/queue/JobHeartbeatStore.d.ts.map +1 -0
  420. package/src/tools/queue/JobHeartbeatStore.js +67 -0
  421. package/src/tools/queue/JobReconciliationRunner.d.ts +16 -0
  422. package/src/tools/queue/JobReconciliationRunner.d.ts.map +1 -0
  423. package/src/tools/queue/JobReconciliationRunner.js +88 -0
  424. package/src/tools/queue/JobRecoveryDaemon.d.ts +27 -0
  425. package/src/tools/queue/JobRecoveryDaemon.d.ts.map +1 -0
  426. package/src/tools/queue/JobRecoveryDaemon.js +205 -0
  427. package/src/tools/queue/JobStateTracker.d.ts +131 -0
  428. package/src/tools/queue/JobStateTracker.d.ts.map +1 -0
  429. package/src/tools/queue/JobStateTracker.js +387 -0
  430. package/src/tools/queue/JobStateTrackerDbPersistence.d.ts +12 -0
  431. package/src/tools/queue/JobStateTrackerDbPersistence.d.ts.map +1 -0
  432. package/src/tools/queue/JobStateTrackerDbPersistence.js +148 -0
  433. package/src/tools/queue/Queue.d.ts.map +1 -1
  434. package/src/tools/queue/Queue.js +160 -16
  435. package/src/tools/queue/QueueDataRedactor.d.ts +6 -0
  436. package/src/tools/queue/QueueDataRedactor.d.ts.map +1 -0
  437. package/src/tools/queue/QueueDataRedactor.js +45 -0
  438. package/src/tools/queue/QueueExtensions.d.ts.map +1 -1
  439. package/src/tools/queue/QueueExtensions.js +2 -1
  440. package/src/tools/queue/QueueReliabilityMetrics.d.ts +38 -0
  441. package/src/tools/queue/QueueReliabilityMetrics.d.ts.map +1 -0
  442. package/src/tools/queue/QueueReliabilityMetrics.js +131 -0
  443. package/src/tools/queue/QueueReliabilityOrchestrator.d.ts +7 -0
  444. package/src/tools/queue/QueueReliabilityOrchestrator.d.ts.map +1 -0
  445. package/src/tools/queue/QueueReliabilityOrchestrator.js +59 -0
  446. package/src/tools/queue/QueueRuntimeRegistration.d.ts +1 -9
  447. package/src/tools/queue/QueueRuntimeRegistration.d.ts.map +1 -1
  448. package/src/tools/queue/QueueRuntimeRegistration.js +75 -4
  449. package/src/tools/queue/QueueTracing.d.ts +32 -0
  450. package/src/tools/queue/QueueTracing.d.ts.map +1 -0
  451. package/src/tools/queue/QueueTracing.js +151 -0
  452. package/src/tools/queue/StalledJobMonitor.d.ts +5 -0
  453. package/src/tools/queue/StalledJobMonitor.d.ts.map +1 -0
  454. package/src/tools/queue/StalledJobMonitor.js +21 -0
  455. package/src/tools/queue/TimeoutManager.d.ts +14 -0
  456. package/src/tools/queue/TimeoutManager.d.ts.map +1 -0
  457. package/src/tools/queue/TimeoutManager.js +77 -0
  458. package/src/tools/queue/drivers/Redis.d.ts +1 -0
  459. package/src/tools/queue/drivers/Redis.d.ts.map +1 -1
  460. package/src/tools/queue/drivers/Redis.js +1 -0
  461. package/src/tools/queue/index.d.ts +10 -0
  462. package/src/tools/queue/index.d.ts.map +1 -1
  463. package/src/tools/queue/index.js +10 -0
  464. package/src/tools/redis/RedisKeyManager.d.ts +3 -0
  465. package/src/tools/redis/RedisKeyManager.d.ts.map +1 -1
  466. package/src/tools/redis/RedisKeyManager.js +15 -0
  467. package/src/tools/storage/drivers/R2.d.ts +13 -0
  468. package/src/tools/storage/drivers/R2.d.ts.map +1 -1
  469. package/src/tools/storage/drivers/R2.js +29 -0
  470. package/src/zintrust.plugins.d.ts +9 -0
  471. package/src/zintrust.plugins.d.ts.map +1 -0
  472. package/src/zintrust.plugins.js +7 -0
  473. package/src/zintrust.plugins.wg.d.ts +9 -0
  474. package/src/zintrust.plugins.wg.d.ts.map +1 -0
  475. package/src/zintrust.plugins.wg.js +7 -0
@@ -0,0 +1,387 @@
1
+ import { Env } from '../../config/env.js';
2
+ import { Logger } from '../../config/logger.js';
3
+ import { QueueDataRedactor } from './QueueDataRedactor.js';
4
+ const trackedJobs = new Map();
5
+ const transitions = [];
6
+ let persistenceAdapter = null;
7
+ const getKey = (queueName, jobId) => `${queueName}:${jobId}`;
8
+ const nowIso = () => new Date().toISOString();
9
+ const isEnabled = () => Env.getBool('JOB_TRACKING_ENABLED', true);
10
+ const isPersistenceEnabled = () => Env.getBool('JOB_TRACKING_PERSISTENCE_ENABLED', false);
11
+ const toFinitePositiveInt = (value) => {
12
+ if (typeof value !== 'number' || Number.isFinite(value) === false)
13
+ return undefined;
14
+ if (value <= 0)
15
+ return undefined;
16
+ return Math.floor(value);
17
+ };
18
+ const normalizeError = (error) => {
19
+ if (error instanceof Error)
20
+ return QueueDataRedactor.redactText(error.message);
21
+ if (typeof error === 'string' && error.trim().length > 0) {
22
+ return QueueDataRedactor.redactText(error);
23
+ }
24
+ return undefined;
25
+ };
26
+ const normalizeErrorCode = (error) => {
27
+ if (error === null || error === undefined || typeof error !== 'object')
28
+ return undefined;
29
+ const raw = error.code;
30
+ if (typeof raw !== 'string')
31
+ return undefined;
32
+ const trimmed = raw.trim();
33
+ return trimmed === '' ? undefined : trimmed;
34
+ };
35
+ const pruneJobs = () => {
36
+ const maxJobs = Env.getInt('JOB_TRACKING_MAX_JOBS', 20000);
37
+ while (trackedJobs.size > maxJobs) {
38
+ const oldestKey = trackedJobs.keys().next().value;
39
+ if (oldestKey === undefined)
40
+ break;
41
+ trackedJobs.delete(oldestKey);
42
+ }
43
+ };
44
+ const appendTransition = (transition) => {
45
+ transitions.push(transition);
46
+ const maxTransitions = Env.getInt('JOB_TRACKING_MAX_TRANSITIONS', 50000);
47
+ if (transitions.length > maxTransitions) {
48
+ transitions.splice(0, transitions.length - maxTransitions);
49
+ }
50
+ };
51
+ const choose = (first, second, third) => {
52
+ if (first !== undefined)
53
+ return first;
54
+ if (second !== undefined)
55
+ return second;
56
+ return third;
57
+ };
58
+ const toEpochMs = (value) => {
59
+ if (value === undefined || value.trim().length === 0)
60
+ return null;
61
+ const parsed = new Date(value).getTime();
62
+ if (Number.isNaN(parsed))
63
+ return null;
64
+ return parsed;
65
+ };
66
+ const resolveAttempts = (existing, options) => choose(options.attempts, existing?.attempts, 0);
67
+ const resolveMaxAttempts = (existing, options) => choose(options.maxAttempts, existing?.maxAttempts);
68
+ const resolvePayload = (existing, options) => choose(options.payload, existing?.payload);
69
+ const resolveResult = (existing, options) => choose(options.result, existing?.result);
70
+ const resolveError = (existing, options) => choose(options.error, existing?.lastError);
71
+ const resolveRetryAt = (existing, options) => choose(options.retryAt, existing?.retryAt);
72
+ const resolveTimeoutAt = (existing, options) => choose(options.timeoutAt, existing?.timeoutAt);
73
+ const resolveExpectedCompletionAt = (existing, options) => choose(options.expectedCompletionAt, existing?.expectedCompletionAt);
74
+ const resolveWorkerName = (existing, options) => choose(options.workerName, existing?.workerName);
75
+ const resolveWorkerInstanceId = (existing, options) => choose(options.workerInstanceId, existing?.workerInstanceId);
76
+ const resolveWorkerRegion = (existing, options) => choose(options.workerRegion, existing?.workerRegion);
77
+ const resolveWorkerVersion = (existing, options) => choose(options.workerVersion, existing?.workerVersion);
78
+ const resolveHeartbeatAt = (existing, options) => choose(options.heartbeatAt, existing?.heartbeatAt);
79
+ const resolveLastErrorCode = (existing, options) => choose(options.lastErrorCode, existing?.lastErrorCode);
80
+ const resolveRecoveredAt = (existing, options) => choose(options.recoveredAt, existing?.recoveredAt);
81
+ const resolveIdempotencyKey = (existing, options) => choose(options.idempotencyKey, existing?.idempotencyKey);
82
+ const resolveCreatedAt = (existing, timestamp) => choose(existing?.createdAt, timestamp, timestamp);
83
+ const resolveStartedAt = (existing, options) => choose(options.startedAt, existing?.startedAt);
84
+ const resolveCompletedAt = (existing, options) => choose(options.completedAt, existing?.completedAt);
85
+ const buildRecord = (existing, queueName, jobId, toStatus, timestamp, options) => {
86
+ const resolvedOptions = options ?? {};
87
+ const attempts = resolveAttempts(existing, resolvedOptions);
88
+ const maxAttempts = resolveMaxAttempts(existing, resolvedOptions);
89
+ const payload = resolvePayload(existing, resolvedOptions);
90
+ const result = resolveResult(existing, resolvedOptions);
91
+ const lastError = resolveError(existing, resolvedOptions);
92
+ const retryAt = resolveRetryAt(existing, resolvedOptions);
93
+ const timeoutAt = resolveTimeoutAt(existing, resolvedOptions);
94
+ const expectedCompletionAt = resolveExpectedCompletionAt(existing, resolvedOptions);
95
+ const workerName = resolveWorkerName(existing, resolvedOptions);
96
+ const workerInstanceId = resolveWorkerInstanceId(existing, resolvedOptions);
97
+ const workerRegion = resolveWorkerRegion(existing, resolvedOptions);
98
+ const workerVersion = resolveWorkerVersion(existing, resolvedOptions);
99
+ const heartbeatAt = resolveHeartbeatAt(existing, resolvedOptions);
100
+ const lastErrorCode = resolveLastErrorCode(existing, resolvedOptions);
101
+ const recoveredAt = resolveRecoveredAt(existing, resolvedOptions);
102
+ const idempotencyKey = resolveIdempotencyKey(existing, resolvedOptions);
103
+ const createdAt = resolveCreatedAt(existing, timestamp);
104
+ const startedAt = resolveStartedAt(existing, resolvedOptions);
105
+ const completedAt = resolveCompletedAt(existing, resolvedOptions);
106
+ return {
107
+ jobId,
108
+ queueName,
109
+ status: toStatus,
110
+ attempts,
111
+ maxAttempts,
112
+ payload,
113
+ result,
114
+ lastError,
115
+ lastErrorCode,
116
+ retryAt,
117
+ timeoutAt,
118
+ expectedCompletionAt,
119
+ workerName,
120
+ workerInstanceId,
121
+ workerRegion,
122
+ workerVersion,
123
+ heartbeatAt,
124
+ recoveredAt,
125
+ idempotencyKey,
126
+ createdAt,
127
+ startedAt,
128
+ completedAt,
129
+ updatedAt: timestamp,
130
+ };
131
+ };
132
+ const updateStatus = (queueName, jobId, toStatus, reason, options) => {
133
+ const key = getKey(queueName, jobId);
134
+ const existing = trackedJobs.get(key);
135
+ const timestamp = nowIso();
136
+ const next = buildRecord(existing, queueName, jobId, toStatus, timestamp, options);
137
+ trackedJobs.set(key, next);
138
+ const transition = {
139
+ jobId,
140
+ queueName,
141
+ fromStatus: existing?.status ?? null,
142
+ toStatus,
143
+ reason,
144
+ timestamp,
145
+ attempts: next.attempts,
146
+ error: options?.error,
147
+ };
148
+ appendTransition(transition);
149
+ pruneJobs();
150
+ return transition;
151
+ };
152
+ const persistLatest = async (queueName, jobId, transition) => {
153
+ if (isPersistenceEnabled() === false)
154
+ return;
155
+ if (persistenceAdapter === null)
156
+ return;
157
+ const record = trackedJobs.get(getKey(queueName, jobId));
158
+ if (record === undefined)
159
+ return;
160
+ try {
161
+ await persistenceAdapter.upsertJob(record);
162
+ if (transition !== undefined) {
163
+ await persistenceAdapter.insertTransition(transition);
164
+ }
165
+ }
166
+ catch (error) {
167
+ Logger.warn('Job tracking persistence failed', { queueName, jobId, error });
168
+ }
169
+ };
170
+ export const JobStateTracker = Object.freeze({
171
+ isEnabled() {
172
+ return isEnabled();
173
+ },
174
+ async enqueued(input) {
175
+ if (isEnabled() === false)
176
+ return;
177
+ const transition = updateStatus(input.queueName, input.jobId, 'pending', 'Job enqueued', {
178
+ attempts: 0,
179
+ maxAttempts: toFinitePositiveInt(input.maxAttempts),
180
+ payload: QueueDataRedactor.sanitizePayload(input.payload),
181
+ expectedCompletionAt: input.expectedCompletionAt,
182
+ idempotencyKey: input.idempotencyKey,
183
+ });
184
+ await persistLatest(input.queueName, input.jobId, transition);
185
+ },
186
+ async started(input) {
187
+ if (isEnabled() === false)
188
+ return;
189
+ const timeoutMs = typeof input.timeoutMs === 'number' && Number.isFinite(input.timeoutMs) && input.timeoutMs > 0
190
+ ? Math.floor(input.timeoutMs)
191
+ : undefined;
192
+ const transition = updateStatus(input.queueName, input.jobId, 'active', 'Job processing started', {
193
+ attempts: toFinitePositiveInt(input.attempts) ?? 1,
194
+ startedAt: nowIso(),
195
+ expectedCompletionAt: timeoutMs === undefined ? undefined : new Date(Date.now() + timeoutMs).toISOString(),
196
+ workerName: input.workerName,
197
+ workerInstanceId: input.workerInstanceId,
198
+ workerRegion: input.workerRegion,
199
+ workerVersion: input.workerVersion,
200
+ heartbeatAt: nowIso(),
201
+ });
202
+ await persistLatest(input.queueName, input.jobId, transition);
203
+ },
204
+ async completed(input) {
205
+ if (isEnabled() === false)
206
+ return;
207
+ const reason = typeof input.processingTimeMs === 'number' && Number.isFinite(input.processingTimeMs)
208
+ ? `Job completed in ${Math.max(0, Math.floor(input.processingTimeMs))}ms`
209
+ : 'Job completed';
210
+ const transition = updateStatus(input.queueName, input.jobId, 'completed', reason, {
211
+ completedAt: nowIso(),
212
+ result: QueueDataRedactor.sanitizePayload(input.result),
213
+ retryAt: undefined,
214
+ error: undefined,
215
+ timeoutAt: undefined,
216
+ });
217
+ await persistLatest(input.queueName, input.jobId, transition);
218
+ },
219
+ async failed(input) {
220
+ if (isEnabled() === false)
221
+ return;
222
+ const errorMessage = normalizeError(input.error);
223
+ const transition = updateStatus(input.queueName, input.jobId, input.isFinal ? 'failed' : 'pending', input.isFinal ? 'Job failed permanently' : 'Job failed and scheduled for retry', {
224
+ attempts: toFinitePositiveInt(input.attempts),
225
+ error: errorMessage,
226
+ lastErrorCode: normalizeErrorCode(input.error),
227
+ retryAt: input.isFinal ? undefined : input.retryAt,
228
+ });
229
+ await persistLatest(input.queueName, input.jobId, transition);
230
+ },
231
+ async heartbeat(input) {
232
+ if (isEnabled() === false)
233
+ return;
234
+ const transition = updateStatus(input.queueName, input.jobId, 'active', 'Heartbeat updated', {
235
+ heartbeatAt: nowIso(),
236
+ workerInstanceId: input.workerInstanceId,
237
+ });
238
+ await persistLatest(input.queueName, input.jobId, transition);
239
+ },
240
+ async timedOut(input) {
241
+ if (isEnabled() === false)
242
+ return;
243
+ const transition = updateStatus(input.queueName, input.jobId, 'timeout', input.reason ?? 'Job timed out', {
244
+ timeoutAt: nowIso(),
245
+ error: normalizeError(input.error) ?? input.reason ?? 'Job timed out',
246
+ lastErrorCode: normalizeErrorCode(input.error),
247
+ });
248
+ await persistLatest(input.queueName, input.jobId, transition);
249
+ },
250
+ async stalled(input) {
251
+ if (isEnabled() === false)
252
+ return;
253
+ const transition = updateStatus(input.queueName, input.jobId, 'stalled', input.reason ?? 'Job stalled', {
254
+ error: input.reason,
255
+ });
256
+ await persistLatest(input.queueName, input.jobId, transition);
257
+ },
258
+ async pendingRecovery(input) {
259
+ if (isEnabled() === false)
260
+ return;
261
+ const transition = updateStatus(input.queueName, input.jobId, 'pending_recovery', input.reason ?? 'Job pending recovery', {
262
+ error: normalizeError(input.error) ?? input.reason,
263
+ lastErrorCode: normalizeErrorCode(input.error),
264
+ });
265
+ await persistLatest(input.queueName, input.jobId, transition);
266
+ },
267
+ async markedRecovered(input) {
268
+ if (isEnabled() === false)
269
+ return;
270
+ const transition = updateStatus(input.queueName, input.jobId, 'pending', input.reason ?? 'Job re-queued for recovery', {
271
+ recoveredAt: nowIso(),
272
+ retryAt: input.retryAt,
273
+ });
274
+ await persistLatest(input.queueName, input.jobId, transition);
275
+ },
276
+ async setTerminalStatus(input) {
277
+ if (isEnabled() === false)
278
+ return;
279
+ const transition = updateStatus(input.queueName, input.jobId, input.status, input.reason, {
280
+ error: normalizeError(input.error),
281
+ lastErrorCode: normalizeErrorCode(input.error),
282
+ completedAt: input.status === 'completed' ? nowIso() : undefined,
283
+ });
284
+ await persistLatest(input.queueName, input.jobId, transition);
285
+ },
286
+ registerPersistenceAdapter(adapter) {
287
+ persistenceAdapter = adapter;
288
+ },
289
+ clearPersistenceAdapter() {
290
+ persistenceAdapter = null;
291
+ },
292
+ get(queueName, jobId) {
293
+ return trackedJobs.get(getKey(queueName, jobId));
294
+ },
295
+ list(options) {
296
+ const filterQueueName = options?.queueName;
297
+ const filterStatus = options?.status;
298
+ const limit = typeof options?.limit === 'number' && Number.isFinite(options.limit) && options.limit > 0
299
+ ? Math.floor(options.limit)
300
+ : 100;
301
+ const rows = Array.from(trackedJobs.values())
302
+ .filter((row) => (filterQueueName === undefined ? true : row.queueName === filterQueueName))
303
+ .filter((row) => (filterStatus === undefined ? true : row.status === filterStatus))
304
+ .sort((left, right) => right.updatedAt.localeCompare(left.updatedAt));
305
+ return rows.slice(0, limit);
306
+ },
307
+ getTransitions(options) {
308
+ const filterQueueName = options?.queueName;
309
+ const filterJobId = options?.jobId;
310
+ const limit = typeof options?.limit === 'number' && Number.isFinite(options.limit) && options.limit > 0
311
+ ? Math.floor(options.limit)
312
+ : 200;
313
+ const rows = transitions
314
+ .filter((row) => (filterQueueName === undefined ? true : row.queueName === filterQueueName))
315
+ .filter((row) => (filterJobId === undefined ? true : row.jobId === filterJobId));
316
+ if (rows.length <= limit)
317
+ return [...rows];
318
+ return rows.slice(rows.length - limit);
319
+ },
320
+ listActiveOlderThan(maxAgeMs, queueName) {
321
+ const threshold = Date.now() - Math.max(0, Math.floor(maxAgeMs));
322
+ return Array.from(trackedJobs.values()).filter((row) => {
323
+ if (row.status !== 'active')
324
+ return false;
325
+ if (queueName !== undefined && row.queueName !== queueName)
326
+ return false;
327
+ const reference = toEpochMs(row.startedAt) ?? toEpochMs(row.updatedAt);
328
+ if (reference === null)
329
+ return false;
330
+ return reference <= threshold;
331
+ });
332
+ },
333
+ listPendingOlderThan(maxAgeMs, queueName) {
334
+ const threshold = Date.now() - Math.max(0, Math.floor(maxAgeMs));
335
+ return Array.from(trackedJobs.values()).filter((row) => {
336
+ if (row.status !== 'pending')
337
+ return false;
338
+ if (queueName !== undefined && row.queueName !== queueName)
339
+ return false;
340
+ const reference = toEpochMs(row.updatedAt) ?? toEpochMs(row.createdAt);
341
+ if (reference === null)
342
+ return false;
343
+ return reference <= threshold;
344
+ });
345
+ },
346
+ listRecoverable(maxAgeMs, queueName) {
347
+ const threshold = Date.now() - Math.max(0, Math.floor(maxAgeMs));
348
+ const recoverable = new Set(['pending_recovery', 'timeout', 'stalled']);
349
+ return Array.from(trackedJobs.values()).filter((row) => {
350
+ if (!recoverable.has(row.status))
351
+ return false;
352
+ if (queueName !== undefined && row.queueName !== queueName)
353
+ return false;
354
+ const reference = toEpochMs(row.updatedAt);
355
+ if (reference === null)
356
+ return false;
357
+ return reference <= threshold;
358
+ });
359
+ },
360
+ listHeartbeatExpired(maxSilenceMs, queueName) {
361
+ const threshold = Date.now() - Math.max(0, Math.floor(maxSilenceMs));
362
+ return Array.from(trackedJobs.values()).filter((row) => {
363
+ if (row.status !== 'active')
364
+ return false;
365
+ if (queueName !== undefined && row.queueName !== queueName)
366
+ return false;
367
+ const reference = toEpochMs(row.heartbeatAt) ?? toEpochMs(row.updatedAt);
368
+ if (reference === null)
369
+ return false;
370
+ return reference <= threshold;
371
+ });
372
+ },
373
+ getSummary(queueName) {
374
+ const rows = Array.from(trackedJobs.values()).filter((row) => queueName === undefined ? true : row.queueName === queueName);
375
+ return rows.reduce((acc, row) => {
376
+ const key = row.status;
377
+ acc[key] = (acc[key] ?? 0) + 1;
378
+ return acc;
379
+ }, {});
380
+ },
381
+ reset() {
382
+ trackedJobs.clear();
383
+ transitions.splice(0, transitions.length);
384
+ persistenceAdapter = null;
385
+ },
386
+ });
387
+ export default JobStateTracker;
@@ -0,0 +1,12 @@
1
+ import type { JobStateTrackerPersistenceAdapter } from './JobStateTracker';
2
+ type JobStateTrackerDbOptions = {
3
+ connectionName?: string;
4
+ jobsTable?: string;
5
+ transitionsTable?: string;
6
+ persistPayload?: boolean;
7
+ persistResult?: boolean;
8
+ };
9
+ export declare const createJobStateTrackerDbPersistence: (options?: JobStateTrackerDbOptions) => JobStateTrackerPersistenceAdapter;
10
+ export declare const autoRegisterJobStateTrackerPersistenceFromEnv: () => boolean;
11
+ export default createJobStateTrackerDbPersistence;
12
+ //# sourceMappingURL=JobStateTrackerDbPersistence.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JobStateTrackerDbPersistence.d.ts","sourceRoot":"","sources":["../../../../src/tools/queue/JobStateTrackerDbPersistence.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EACV,iCAAiC,EAGlC,MAAM,wBAAwB,CAAC;AAEhC,KAAK,wBAAwB,GAAG;IAC9B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB,CAAC;AA+FF,eAAO,MAAM,kCAAkC,GAC7C,UAAS,wBAA6B,KACrC,iCAuCF,CAAC;AAEF,eAAO,MAAM,6CAA6C,QAAO,OAsBhE,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,148 @@
1
+ import { Env } from '../../config/env.js';
2
+ import { Logger } from '../../config/logger.js';
3
+ import { ZintrustLang } from '../../lang/lang.js';
4
+ import { useDatabase } from '../../orm/Database.js';
5
+ import { JobStateTracker } from './JobStateTracker.js';
6
+ const toJson = (value) => {
7
+ if (value === undefined)
8
+ return null;
9
+ try {
10
+ return JSON.stringify(value);
11
+ }
12
+ catch {
13
+ return null;
14
+ }
15
+ };
16
+ const toSqlDateTime = (isoLike) => {
17
+ if (typeof isoLike !== 'string' || isoLike.trim().length === 0)
18
+ return null;
19
+ const parsed = new Date(isoLike);
20
+ if (Number.isNaN(parsed.getTime()))
21
+ return null;
22
+ return parsed.toISOString().slice(0, 19).replace('T', ' ');
23
+ };
24
+ const getConnectionName = (options) => {
25
+ if (options.connectionName !== undefined && options.connectionName.trim().length > 0) {
26
+ return options.connectionName.trim();
27
+ }
28
+ return Env.get('JOB_TRACKING_DB_CONNECTION', 'default');
29
+ };
30
+ const getJobsTable = (options) => {
31
+ if (options.jobsTable !== undefined && options.jobsTable.trim().length > 0) {
32
+ return options.jobsTable.trim();
33
+ }
34
+ return Env.get('JOB_TRACKING_DB_TABLE', 'zintrust_jobs');
35
+ };
36
+ const getTransitionsTable = (options) => {
37
+ if (options.transitionsTable !== undefined && options.transitionsTable.trim().length > 0) {
38
+ return options.transitionsTable.trim();
39
+ }
40
+ return Env.get('JOB_TRACKING_DB_TRANSITIONS_TABLE', 'zintrust_job_transitions');
41
+ };
42
+ const getDatabase = (connectionName) => {
43
+ try {
44
+ return useDatabase(undefined, connectionName);
45
+ }
46
+ catch (error) {
47
+ Logger.warn('Job tracking database connection is unavailable', {
48
+ connectionName,
49
+ error,
50
+ });
51
+ return null;
52
+ }
53
+ };
54
+ const serializeJobRecord = (record, options) => {
55
+ return {
56
+ job_id: record.jobId,
57
+ queue_name: record.queueName,
58
+ status: record.status,
59
+ attempts: record.attempts,
60
+ max_attempts: record.maxAttempts ?? null,
61
+ payload_json: options.persistPayload === false ? null : toJson(record.payload),
62
+ result_json: options.persistResult === false ? null : toJson(record.result),
63
+ last_error: record.lastError ?? null,
64
+ last_error_code: record.lastErrorCode ?? null,
65
+ retry_at: toSqlDateTime(record.retryAt),
66
+ timeout_at: toSqlDateTime(record.timeoutAt),
67
+ heartbeat_at: toSqlDateTime(record.heartbeatAt),
68
+ expected_completion_at: toSqlDateTime(record.expectedCompletionAt),
69
+ worker_name: record.workerName ?? null,
70
+ worker_instance_id: record.workerInstanceId ?? null,
71
+ worker_region: record.workerRegion ?? null,
72
+ worker_version: record.workerVersion ?? null,
73
+ recovered_at: toSqlDateTime(record.recoveredAt),
74
+ idempotency_key: record.idempotencyKey ?? null,
75
+ created_at: toSqlDateTime(record.createdAt),
76
+ started_at: toSqlDateTime(record.startedAt),
77
+ completed_at: toSqlDateTime(record.completedAt),
78
+ updated_at: toSqlDateTime(record.updatedAt),
79
+ };
80
+ };
81
+ const serializeTransition = (transition) => {
82
+ return {
83
+ job_id: transition.jobId,
84
+ queue_name: transition.queueName,
85
+ from_status: transition.fromStatus,
86
+ to_status: transition.toStatus,
87
+ reason: transition.reason,
88
+ attempts: transition.attempts ?? null,
89
+ error: transition.error ?? null,
90
+ transitioned_at: toSqlDateTime(transition.timestamp),
91
+ };
92
+ };
93
+ export const createJobStateTrackerDbPersistence = (options = {}) => {
94
+ const connectionName = getConnectionName(options);
95
+ const jobsTable = getJobsTable(options);
96
+ const transitionsTable = getTransitionsTable(options);
97
+ const upsertJob = async (record) => {
98
+ const db = getDatabase(connectionName);
99
+ if (db === null)
100
+ return;
101
+ const payload = serializeJobRecord(record, options);
102
+ const existing = await db
103
+ .table(jobsTable)
104
+ .where('job_id', '=', record.jobId)
105
+ .where('queue_name', '=', record.queueName)
106
+ .first();
107
+ if (existing) {
108
+ await db
109
+ .table(jobsTable)
110
+ .where('job_id', '=', record.jobId)
111
+ .where('queue_name', '=', record.queueName)
112
+ .update(payload);
113
+ return;
114
+ }
115
+ await db.table(jobsTable).insert(payload);
116
+ };
117
+ const insertTransition = async (transition) => {
118
+ const db = getDatabase(connectionName);
119
+ if (db === null)
120
+ return;
121
+ await db.table(transitionsTable).insert(serializeTransition(transition));
122
+ };
123
+ return Object.freeze({
124
+ upsertJob,
125
+ insertTransition,
126
+ });
127
+ };
128
+ export const autoRegisterJobStateTrackerPersistenceFromEnv = () => {
129
+ const trackingEnabled = Env.getBool('JOB_TRACKING_ENABLED', true);
130
+ const persistenceEnabled = Env.getBool('JOB_TRACKING_PERSISTENCE_ENABLED', false);
131
+ if (trackingEnabled === false || persistenceEnabled === false) {
132
+ JobStateTracker.clearPersistenceAdapter();
133
+ return false;
134
+ }
135
+ const driver = Env.get('JOB_TRACKING_PERSISTENCE_DRIVER', ZintrustLang.DATABASE)
136
+ .trim()
137
+ .toLowerCase();
138
+ if (driver !== ZintrustLang.DATABASE) {
139
+ Logger.warn('Unsupported job tracking persistence driver, skipping auto-registration', {
140
+ driver,
141
+ });
142
+ JobStateTracker.clearPersistenceAdapter();
143
+ return false;
144
+ }
145
+ JobStateTracker.registerPersistenceAdapter(createJobStateTrackerDbPersistence());
146
+ return true;
147
+ };
148
+ export default createJobStateTrackerDbPersistence;
@@ -1 +1 @@
1
- {"version":3,"file":"Queue.d.ts","sourceRoot":"","sources":["../../../../src/tools/queue/Queue.ts"],"names":[],"mappings":"AAKA,MAAM,MAAM,YAAY,CAAC,CAAC,GAAG,OAAO,IAAI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,CAAC,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAErF,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACjE,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IAC1E,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9C,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACvC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACrC;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAE5B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACvC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAGlB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,gBAAgB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAChC,OAAO,CAAC,EAAE;QACR,IAAI,EAAE,OAAO,GAAG,aAAa,CAAC;QAC9B,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,MAAM,CAAC,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,IAAI,CAAC,EAAE,OAAO,CAAC;IAGf,aAAa,CAAC,EAAE;QACd,EAAE,EAAE,MAAM,CAAC;QACX,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG;YAAE,SAAS,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,CAAC;KACvE,CAAC;IAGF,SAAS,CAAC,EAAE,MAAM,CAAC;IAGnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAID;;;GAGG;AACH,eAAO,MAAM,iBAAiB,QAAO,MAOpC,CAAC;AAIF,eAAO,MAAM,KAAK;mBACD,MAAM,UAAU,YAAY;aAIlC,IAAI;eAIF,MAAM,GAAG,YAAY;mBAYX,MAAM,WAAW,aAAa,eAAe,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;YAM5E,CAAC,mBACN,MAAM,eACA,MAAM,GAClB,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;eAKtB,MAAM,MAAM,MAAM,eAAe,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;kBAKpD,MAAM,eAAe,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;iBAK9C,MAAM,eAAe,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;EAI9D,CAAC;AAEH,eAAe,KAAK,CAAC"}
1
+ {"version":3,"file":"Queue.d.ts","sourceRoot":"","sources":["../../../../src/tools/queue/Queue.ts"],"names":[],"mappings":"AASA,MAAM,MAAM,YAAY,CAAC,CAAC,GAAG,OAAO,IAAI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,CAAC,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAErF,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACjE,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IAC1E,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9C,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACvC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACrC;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAE5B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACvC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAGlB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,gBAAgB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAChC,OAAO,CAAC,EAAE;QACR,IAAI,EAAE,OAAO,GAAG,aAAa,CAAC;QAC9B,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,MAAM,CAAC,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,IAAI,CAAC,EAAE,OAAO,CAAC;IAGf,aAAa,CAAC,EAAE;QACd,EAAE,EAAE,MAAM,CAAC;QACX,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG;YAAE,SAAS,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,CAAC;KACvE,CAAC;IAGF,SAAS,CAAC,EAAE,MAAM,CAAC;IAGnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAID;;;GAGG;AACH,eAAO,MAAM,iBAAiB,QAAO,MAOpC,CAAC;AA+EF,eAAO,MAAM,KAAK;mBACD,MAAM,UAAU,YAAY;aAIlC,IAAI;eAIF,MAAM,GAAG,YAAY;mBASX,MAAM,WAAW,aAAa,eAAe,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;YAkE5E,CAAC,mBACN,MAAM,eACA,MAAM,GAClB,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;eActB,MAAM,MAAM,MAAM,eAAe,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;kBAcpD,MAAM,eAAe,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;iBAc9C,MAAM,eAAe,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;EAa9D,CAAC;AAEH,eAAe,KAAK,CAAC"}