@zintrust/core 0.1.40 → 0.1.42
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.
- package/bin/zintrust-main.d.ts.map +1 -1
- package/bin/zintrust-main.js +22 -1
- package/package.json +24 -4
- package/public/error-pages/404.html +2 -2
- package/src/auth/Auth.js +1 -1
- package/src/boot/Application.d.ts +1 -16
- package/src/boot/Application.d.ts.map +1 -1
- package/src/boot/Application.js +2 -290
- package/src/boot/Server.d.ts +1 -1
- package/src/boot/Server.d.ts.map +1 -1
- package/src/boot/bootstrap.js +50 -16
- package/src/boot/registry/registerRoute.d.ts +6 -0
- package/src/boot/registry/registerRoute.d.ts.map +1 -0
- package/src/boot/registry/registerRoute.js +96 -0
- package/src/boot/registry/runtime.d.ts +15 -0
- package/src/boot/registry/runtime.d.ts.map +1 -0
- package/src/boot/registry/runtime.js +364 -0
- package/src/boot/registry/type.d.ts +25 -0
- package/src/boot/registry/type.d.ts.map +1 -0
- package/src/boot/registry/type.js +1 -0
- package/src/boot/registry/worker.d.ts +6 -0
- package/src/boot/registry/worker.d.ts.map +1 -0
- package/src/boot/registry/worker.js +35 -0
- package/src/cache/drivers/KVRemoteDriver.d.ts.map +1 -1
- package/src/cache/drivers/KVRemoteDriver.js +14 -1
- package/src/cli/CLI.d.ts.map +1 -1
- package/src/cli/CLI.js +94 -34
- package/src/cli/ErrorHandler.js +1 -1
- package/src/cli/commands/ConfigCommand.d.ts.map +1 -1
- package/src/cli/commands/ConfigCommand.js +3 -5
- package/src/cli/commands/ContainerProxiesCommand.d.ts +5 -0
- package/src/cli/commands/ContainerProxiesCommand.d.ts.map +1 -0
- package/src/cli/commands/ContainerProxiesCommand.js +77 -0
- package/src/cli/commands/ContainerWorkersCommand.d.ts +5 -0
- package/src/cli/commands/ContainerWorkersCommand.d.ts.map +1 -0
- package/src/cli/commands/ContainerWorkersCommand.js +57 -0
- package/src/cli/commands/D1LearnCommand.d.ts +9 -0
- package/src/cli/commands/D1LearnCommand.d.ts.map +1 -0
- package/src/cli/commands/D1LearnCommand.js +143 -0
- package/src/cli/commands/D1MigrateCommand.d.ts.map +1 -1
- package/src/cli/commands/D1MigrateCommand.js +55 -16
- package/src/cli/commands/DeployCommand.d.ts +16 -0
- package/src/cli/commands/DeployCommand.d.ts.map +1 -0
- package/src/cli/commands/DeployCommand.js +110 -0
- package/src/cli/commands/DeployContainerProxiesCommand.d.ts +5 -0
- package/src/cli/commands/DeployContainerProxiesCommand.d.ts.map +1 -0
- package/src/cli/commands/DeployContainerProxiesCommand.js +27 -0
- package/src/cli/commands/DeployContainerWorkersCommand.d.ts +5 -0
- package/src/cli/commands/DeployContainerWorkersCommand.d.ts.map +1 -0
- package/src/cli/commands/DeployContainerWorkersCommand.js +27 -0
- package/src/cli/commands/DockerComposeCommandUtils.d.ts +3 -0
- package/src/cli/commands/DockerComposeCommandUtils.d.ts.map +1 -0
- package/src/cli/commands/DockerComposeCommandUtils.js +34 -0
- package/src/cli/commands/DoctorArchitectureCommand.d.ts +5 -0
- package/src/cli/commands/DoctorArchitectureCommand.d.ts.map +1 -0
- package/src/cli/commands/DoctorArchitectureCommand.js +54 -0
- package/src/cli/commands/InitContainerCommand.d.ts +5 -0
- package/src/cli/commands/InitContainerCommand.d.ts.map +1 -0
- package/src/cli/commands/InitContainerCommand.js +231 -0
- package/src/cli/commands/InitEcosystemCommand.d.ts +6 -0
- package/src/cli/commands/InitEcosystemCommand.d.ts.map +1 -0
- package/src/cli/commands/InitEcosystemCommand.js +51 -0
- package/src/cli/commands/InitProducerCommand.d.ts +5 -0
- package/src/cli/commands/InitProducerCommand.d.ts.map +1 -0
- package/src/cli/commands/InitProducerCommand.js +47 -0
- package/src/cli/commands/InitProxyCommand.d.ts +5 -0
- package/src/cli/commands/InitProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/InitProxyCommand.js +442 -0
- package/src/cli/commands/MigrateCommand.d.ts.map +1 -1
- package/src/cli/commands/MigrateCommand.js +78 -36
- package/src/cli/commands/MigrateWorkerCommand.d.ts.map +1 -1
- package/src/cli/commands/MigrateWorkerCommand.js +36 -2
- package/src/cli/commands/MongoDBProxyCommand.d.ts +5 -0
- package/src/cli/commands/MongoDBProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/MongoDBProxyCommand.js +98 -0
- package/src/cli/commands/MySqlProxyCommand.d.ts +6 -0
- package/src/cli/commands/MySqlProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/MySqlProxyCommand.js +32 -0
- package/src/cli/commands/PostgresProxyCommand.d.ts +6 -0
- package/src/cli/commands/PostgresProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/PostgresProxyCommand.js +32 -0
- package/src/cli/commands/ProxyCommand.d.ts +12 -0
- package/src/cli/commands/ProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/ProxyCommand.js +80 -0
- package/src/cli/commands/ProxyCommandUtils.d.ts +6 -0
- package/src/cli/commands/ProxyCommandUtils.d.ts.map +1 -0
- package/src/cli/commands/ProxyCommandUtils.js +38 -0
- package/src/cli/commands/PutCommand.d.ts +6 -0
- package/src/cli/commands/PutCommand.d.ts.map +1 -0
- package/src/cli/commands/PutCommand.js +173 -0
- package/src/cli/commands/QueueRecoveryCommand.d.ts +6 -0
- package/src/cli/commands/QueueRecoveryCommand.d.ts.map +1 -0
- package/src/cli/commands/QueueRecoveryCommand.js +612 -0
- package/src/cli/commands/RedisProxyCommand.d.ts +6 -0
- package/src/cli/commands/RedisProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/RedisProxyCommand.js +53 -0
- package/src/cli/commands/ScheduleListCommand.d.ts +6 -0
- package/src/cli/commands/ScheduleListCommand.d.ts.map +1 -0
- package/src/cli/commands/ScheduleListCommand.js +62 -0
- package/src/cli/commands/ScheduleRunCommand.d.ts +6 -0
- package/src/cli/commands/ScheduleRunCommand.d.ts.map +1 -0
- package/src/cli/commands/ScheduleRunCommand.js +32 -0
- package/src/cli/commands/ScheduleStartCommand.d.ts +6 -0
- package/src/cli/commands/ScheduleStartCommand.d.ts.map +1 -0
- package/src/cli/commands/ScheduleStartCommand.js +40 -0
- package/src/cli/commands/SecretsCommand.d.ts.map +1 -1
- package/src/cli/commands/SecretsCommand.js +2 -2
- package/src/cli/commands/SmtpProxyCommand.d.ts +6 -0
- package/src/cli/commands/SmtpProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/SmtpProxyCommand.js +56 -0
- package/src/cli/commands/SqlProxyCommandUtils.d.ts +46 -0
- package/src/cli/commands/SqlProxyCommandUtils.d.ts.map +1 -0
- package/src/cli/commands/SqlProxyCommandUtils.js +48 -0
- package/src/cli/commands/SqlServerProxyCommand.d.ts +5 -0
- package/src/cli/commands/SqlServerProxyCommand.d.ts.map +1 -0
- package/src/cli/commands/SqlServerProxyCommand.js +85 -0
- package/src/cli/commands/StartCommand.d.ts.map +1 -1
- package/src/cli/commands/StartCommand.js +132 -17
- package/src/cli/commands/WorkerCommands.d.ts +1 -0
- package/src/cli/commands/WorkerCommands.d.ts.map +1 -1
- package/src/cli/commands/WorkerCommands.js +140 -6
- package/src/cli/commands/index.d.ts +2 -0
- package/src/cli/commands/index.d.ts.map +1 -1
- package/src/cli/commands/index.js +2 -0
- package/src/cli/commands/runner/index.d.ts +2 -2
- package/src/cli/commands/runner/index.d.ts.map +1 -1
- package/src/cli/commands/runner/index.js +15 -4
- package/src/cli/commands/schedule/ScheduleCliSupport.d.ts +6 -0
- package/src/cli/commands/schedule/ScheduleCliSupport.d.ts.map +1 -0
- package/src/cli/commands/schedule/ScheduleCliSupport.js +55 -0
- package/src/cli/config/ConfigManager.d.ts.map +1 -1
- package/src/cli/config/ConfigManager.js +8 -1
- package/src/cli/d1/D1SqlMigrations.d.ts.map +1 -1
- package/src/cli/d1/D1SqlMigrations.js +14 -1
- package/src/cli/d1/WranglerConfig.d.ts.map +1 -1
- package/src/cli/d1/WranglerConfig.js +34 -2
- package/src/cli/index.d.ts +4 -0
- package/src/cli/index.d.ts.map +1 -1
- package/src/cli/index.js +4 -0
- package/src/cli/scaffolding/ProjectScaffolder.d.ts.map +1 -1
- package/src/cli/scaffolding/ProjectScaffolder.js +2 -0
- package/src/cli/scaffolding/ServiceScaffolder.d.ts.map +1 -1
- package/src/cli/scaffolding/ServiceScaffolder.js +1 -0
- package/src/cli/services/VersionChecker.d.ts.map +1 -1
- package/src/cli/services/VersionChecker.js +5 -1
- package/src/cli/utils/DatabaseCliUtils.d.ts.map +1 -1
- package/src/cli/utils/DatabaseCliUtils.js +6 -1
- package/src/cli/utils/EnvFileLoader.d.ts.map +1 -1
- package/src/cli/utils/EnvFileLoader.js +35 -15
- package/src/cli/workers/QueueWorkRunner.js +1 -1
- package/src/cli.d.ts +5 -0
- package/src/cli.d.ts.map +1 -0
- package/src/cli.js +4 -0
- package/src/collections/index.d.ts +2 -2
- package/src/collections/index.d.ts.map +1 -1
- package/src/collections/index.js +1 -1
- package/src/common/HealthRoutes.d.ts.map +1 -1
- package/src/common/HealthRoutes.js +50 -2
- package/src/common/RemoteSignedJson.d.ts +1 -0
- package/src/common/RemoteSignedJson.d.ts.map +1 -1
- package/src/common/RemoteSignedJson.js +81 -29
- package/src/common/index.d.ts +1 -0
- package/src/common/index.d.ts.map +1 -1
- package/src/common/index.js +12 -1
- package/src/common/utility.d.ts.map +1 -1
- package/src/common/utility.js +2 -6
- package/src/config/FileLogWriter.d.ts.map +1 -1
- package/src/config/FileLogWriter.js +21 -6
- package/src/config/app.d.ts +4 -0
- package/src/config/app.d.ts.map +1 -1
- package/src/config/app.js +4 -0
- package/src/config/cache.d.ts.map +1 -1
- package/src/config/cache.js +22 -2
- package/src/config/cloudflare.d.ts +5 -1
- package/src/config/cloudflare.d.ts.map +1 -1
- package/src/config/cloudflare.js +67 -8
- package/src/config/database.d.ts.map +1 -1
- package/src/config/database.js +48 -13
- package/src/config/env.d.ts +87 -2
- package/src/config/env.d.ts.map +1 -1
- package/src/config/env.js +158 -19
- package/src/config/index.d.ts +1 -0
- package/src/config/index.d.ts.map +1 -1
- package/src/config/mail.d.ts.map +1 -1
- package/src/config/mail.js +16 -10
- package/src/config/middleware.d.ts +5 -0
- package/src/config/middleware.d.ts.map +1 -1
- package/src/config/middleware.js +19 -1
- package/src/config/queue.d.ts.map +1 -1
- package/src/config/queue.js +70 -9
- package/src/config/redis.d.ts.map +1 -1
- package/src/config/redis.js +48 -13
- package/src/config/storage.d.ts.map +1 -1
- package/src/config/storage.js +1 -0
- package/src/config/type.d.ts +18 -0
- package/src/config/type.d.ts.map +1 -1
- package/src/config/workers.d.ts.map +1 -1
- package/src/config/workers.js +122 -16
- package/src/functions/cloudflare.d.ts.map +1 -1
- package/src/functions/cloudflare.js +55 -1
- package/src/health/StartupHealthChecks.js +1 -1
- package/src/helper/index.d.ts +225 -0
- package/src/helper/index.d.ts.map +1 -0
- package/src/helper/index.js +347 -0
- package/src/http/FileUpload.d.ts +3 -2
- package/src/http/FileUpload.d.ts.map +1 -1
- package/src/http/Kernel.d.ts.map +1 -1
- package/src/http/Kernel.js +2 -1
- package/src/http/error-pages/ErrorPageRenderer.d.ts +4 -0
- package/src/http/error-pages/ErrorPageRenderer.d.ts.map +1 -1
- package/src/http/error-pages/ErrorPageRenderer.js +141 -1
- package/src/http/middleware/BodyParsingMiddleware.d.ts.map +1 -1
- package/src/http/middleware/BodyParsingMiddleware.js +33 -6
- package/src/index.d.ts +26 -57
- package/src/index.d.ts.map +1 -1
- package/src/index.js +32 -18
- package/src/microservices/ServiceAuthMiddleware.d.ts.map +1 -1
- package/src/microservices/ServiceAuthMiddleware.js +12 -4
- package/src/middleware/CsrfMiddleware.d.ts.map +1 -1
- package/src/middleware/CsrfMiddleware.js +30 -16
- package/src/middleware/ErrorHandlerMiddleware.d.ts.map +1 -1
- package/src/middleware/ErrorHandlerMiddleware.js +2 -1
- package/src/migrations/MigrationDiscovery.d.ts.map +1 -1
- package/src/migrations/MigrationDiscovery.js +2 -1
- package/src/migrations/MigrationLoader.js +1 -1
- package/src/migrations/schema/SchemaCompiler.d.ts.map +1 -1
- package/src/migrations/schema/SchemaCompiler.js +6 -3
- package/src/node-singletons/crypto.d.ts +1 -1
- package/src/node-singletons/crypto.d.ts.map +1 -1
- package/src/node-singletons/crypto.js +1 -1
- package/src/node-singletons/fs.d.ts +1 -1
- package/src/node-singletons/fs.d.ts.map +1 -1
- package/src/node-singletons/path.d.ts +1 -1
- package/src/node-singletons/path.d.ts.map +1 -1
- package/src/node-singletons/path.js +1 -1
- package/src/node-singletons/stream.d.ts +11 -0
- package/src/node-singletons/stream.d.ts.map +1 -0
- package/src/node-singletons/stream.js +8 -0
- package/src/observability/OpenTelemetry.d.ts +7 -0
- package/src/observability/OpenTelemetry.d.ts.map +1 -1
- package/src/observability/OpenTelemetry.js +49 -2
- package/src/orm/Database.d.ts +4 -0
- package/src/orm/Database.d.ts.map +1 -1
- package/src/orm/Database.js +80 -9
- package/src/orm/DatabaseAdapter.d.ts +1 -0
- package/src/orm/DatabaseAdapter.d.ts.map +1 -1
- package/src/orm/DatabaseRuntimeRegistration.d.ts.map +1 -1
- package/src/orm/DatabaseRuntimeRegistration.js +2 -0
- package/src/orm/QueryBuilder.d.ts +1 -0
- package/src/orm/QueryBuilder.d.ts.map +1 -1
- package/src/orm/QueryBuilder.js +33 -3
- package/src/orm/SchemaCompiler.d.ts.map +1 -1
- package/src/orm/SchemaCompiler.js +6 -3
- package/src/orm/SchemaStatemenWriter.d.ts +15 -0
- package/src/orm/SchemaStatemenWriter.d.ts.map +1 -0
- package/src/orm/SchemaStatemenWriter.js +78 -0
- package/src/orm/adapters/D1Adapter.d.ts.map +1 -1
- package/src/orm/adapters/D1Adapter.js +52 -2
- package/src/orm/adapters/D1RemoteAdapter.d.ts.map +1 -1
- package/src/orm/adapters/D1RemoteAdapter.js +150 -89
- package/src/orm/adapters/MongoDBProxyAdapter.d.ts +3 -0
- package/src/orm/adapters/MongoDBProxyAdapter.d.ts.map +1 -0
- package/src/orm/adapters/MongoDBProxyAdapter.js +128 -0
- package/src/orm/adapters/MySQLProxyAdapter.d.ts +11 -0
- package/src/orm/adapters/MySQLProxyAdapter.d.ts.map +1 -0
- package/src/orm/adapters/MySQLProxyAdapter.js +162 -0
- package/src/orm/adapters/PostgreSQLProxyAdapter.d.ts +11 -0
- package/src/orm/adapters/PostgreSQLProxyAdapter.d.ts.map +1 -0
- package/src/orm/adapters/PostgreSQLProxyAdapter.js +163 -0
- package/src/orm/adapters/ProxyCache.d.ts +9 -0
- package/src/orm/adapters/ProxyCache.d.ts.map +1 -0
- package/src/orm/adapters/ProxyCache.js +24 -0
- package/src/orm/adapters/ProxySignedRequest.d.ts +11 -0
- package/src/orm/adapters/ProxySignedRequest.d.ts.map +1 -0
- package/src/orm/adapters/ProxySignedRequest.js +30 -0
- package/src/orm/adapters/ProxySigningPath.d.ts +3 -0
- package/src/orm/adapters/ProxySigningPath.d.ts.map +1 -0
- package/src/orm/adapters/ProxySigningPath.js +25 -0
- package/src/orm/adapters/SqlProxyAdapterUtils.d.ts +19 -0
- package/src/orm/adapters/SqlProxyAdapterUtils.d.ts.map +1 -0
- package/src/orm/adapters/SqlProxyAdapterUtils.js +36 -0
- package/src/orm/adapters/SqlProxyRegistryMode.d.ts +12 -0
- package/src/orm/adapters/SqlProxyRegistryMode.d.ts.map +1 -0
- package/src/orm/adapters/SqlProxyRegistryMode.js +24 -0
- package/src/orm/adapters/SqlServerProxyAdapter.d.ts +6 -0
- package/src/orm/adapters/SqlServerProxyAdapter.d.ts.map +1 -0
- package/src/orm/adapters/SqlServerProxyAdapter.js +154 -0
- package/src/orm/migrations/MigrationStore.js +1 -1
- package/src/performance/Optimizer.d.ts +1 -0
- package/src/performance/Optimizer.d.ts.map +1 -1
- package/src/performance/Optimizer.js +21 -8
- package/src/proxy/ErrorHandler.d.ts +11 -0
- package/src/proxy/ErrorHandler.d.ts.map +1 -0
- package/src/proxy/ErrorHandler.js +7 -0
- package/src/proxy/PoolManager.d.ts +8 -0
- package/src/proxy/PoolManager.d.ts.map +1 -0
- package/src/proxy/PoolManager.js +18 -0
- package/src/proxy/ProxyBackend.d.ts +18 -0
- package/src/proxy/ProxyBackend.d.ts.map +1 -0
- package/src/proxy/ProxyBackend.js +1 -0
- package/src/proxy/ProxyConfig.d.ts +12 -0
- package/src/proxy/ProxyConfig.d.ts.map +1 -0
- package/src/proxy/ProxyConfig.js +1 -0
- package/src/proxy/ProxyRegistry.d.ts +10 -0
- package/src/proxy/ProxyRegistry.d.ts.map +1 -0
- package/src/proxy/ProxyRegistry.js +11 -0
- package/src/proxy/ProxyRequestParsing.d.ts +9 -0
- package/src/proxy/ProxyRequestParsing.d.ts.map +1 -0
- package/src/proxy/ProxyRequestParsing.js +16 -0
- package/src/proxy/ProxyServer.d.ts +21 -0
- package/src/proxy/ProxyServer.d.ts.map +1 -0
- package/src/proxy/ProxyServer.js +84 -0
- package/src/proxy/ProxyServerUtils.d.ts +37 -0
- package/src/proxy/ProxyServerUtils.d.ts.map +1 -0
- package/src/proxy/ProxyServerUtils.js +42 -0
- package/src/proxy/ProxySigningConfigResolver.d.ts +22 -0
- package/src/proxy/ProxySigningConfigResolver.d.ts.map +1 -0
- package/src/proxy/ProxySigningConfigResolver.js +24 -0
- package/src/proxy/ProxySigningRequest.d.ts +12 -0
- package/src/proxy/ProxySigningRequest.d.ts.map +1 -0
- package/src/proxy/ProxySigningRequest.js +31 -0
- package/src/proxy/RequestValidator.d.ts +15 -0
- package/src/proxy/RequestValidator.d.ts.map +1 -0
- package/src/proxy/RequestValidator.js +26 -0
- package/src/proxy/SigningService.d.ts +39 -0
- package/src/proxy/SigningService.d.ts.map +1 -0
- package/src/proxy/SigningService.js +107 -0
- package/src/proxy/SqlPayloadValidator.d.ts +13 -0
- package/src/proxy/SqlPayloadValidator.d.ts.map +1 -0
- package/src/proxy/SqlPayloadValidator.js +14 -0
- package/src/proxy/SqlProxyDbOverrides.d.ts +17 -0
- package/src/proxy/SqlProxyDbOverrides.d.ts.map +1 -0
- package/src/proxy/SqlProxyDbOverrides.js +1 -0
- package/src/proxy/SqlProxyServerDeps.d.ts +12 -0
- package/src/proxy/SqlProxyServerDeps.d.ts.map +1 -0
- package/src/proxy/SqlProxyServerDeps.js +9 -0
- package/src/proxy/StatementPayloadValidator.d.ts +13 -0
- package/src/proxy/StatementPayloadValidator.d.ts.map +1 -0
- package/src/proxy/StatementPayloadValidator.js +18 -0
- package/src/proxy/StatementRegistryLoader.d.ts +2 -0
- package/src/proxy/StatementRegistryLoader.d.ts.map +1 -0
- package/src/proxy/StatementRegistryLoader.js +36 -0
- package/src/proxy/StatementRegistryResolver.d.ts +15 -0
- package/src/proxy/StatementRegistryResolver.d.ts.map +1 -0
- package/src/proxy/StatementRegistryResolver.js +34 -0
- package/src/proxy/d1/ZintrustD1Proxy.d.ts +3 -0
- package/src/proxy/d1/ZintrustD1Proxy.d.ts.map +1 -0
- package/src/proxy/d1/ZintrustD1Proxy.js +2 -0
- package/src/proxy/d1/register.d.ts +2 -0
- package/src/proxy/d1/register.d.ts.map +1 -0
- package/src/proxy/d1/register.js +5 -0
- package/src/proxy/isMutatingSql.d.ts +2 -0
- package/src/proxy/isMutatingSql.d.ts.map +1 -0
- package/src/proxy/isMutatingSql.js +12 -0
- package/src/proxy/kv/ZintrustKvProxy.d.ts +3 -0
- package/src/proxy/kv/ZintrustKvProxy.d.ts.map +1 -0
- package/src/proxy/kv/ZintrustKvProxy.js +2 -0
- package/src/proxy/kv/register.d.ts +2 -0
- package/src/proxy/kv/register.d.ts.map +1 -0
- package/src/proxy/kv/register.js +5 -0
- package/src/proxy/mongodb/MongoDBProxyServer.d.ts +33 -0
- package/src/proxy/mongodb/MongoDBProxyServer.d.ts.map +1 -0
- package/src/proxy/mongodb/MongoDBProxyServer.js +202 -0
- package/src/proxy/mongodb/register.d.ts +2 -0
- package/src/proxy/mongodb/register.d.ts.map +1 -0
- package/src/proxy/mongodb/register.js +5 -0
- package/src/proxy/mysql/MySqlProxyServer.d.ts +8 -0
- package/src/proxy/mysql/MySqlProxyServer.d.ts.map +1 -0
- package/src/proxy/mysql/MySqlProxyServer.js +202 -0
- package/src/proxy/mysql/register.d.ts +2 -0
- package/src/proxy/mysql/register.d.ts.map +1 -0
- package/src/proxy/mysql/register.js +5 -0
- package/src/proxy/postgres/PostgresProxyServer.d.ts +8 -0
- package/src/proxy/postgres/PostgresProxyServer.d.ts.map +1 -0
- package/src/proxy/postgres/PostgresProxyServer.js +178 -0
- package/src/proxy/postgres/register.d.ts +2 -0
- package/src/proxy/postgres/register.d.ts.map +1 -0
- package/src/proxy/postgres/register.js +5 -0
- package/src/proxy/redis/RedisProxyServer.d.ts +12 -0
- package/src/proxy/redis/RedisProxyServer.d.ts.map +1 -0
- package/src/proxy/redis/RedisProxyServer.js +192 -0
- package/src/proxy/redis/register.d.ts +2 -0
- package/src/proxy/redis/register.d.ts.map +1 -0
- package/src/proxy/redis/register.js +5 -0
- package/src/proxy/smtp/SmtpProxyServer.d.ts +19 -0
- package/src/proxy/smtp/SmtpProxyServer.d.ts.map +1 -0
- package/src/proxy/smtp/SmtpProxyServer.js +290 -0
- package/src/proxy/smtp/register.d.ts +2 -0
- package/src/proxy/smtp/register.d.ts.map +1 -0
- package/src/proxy/smtp/register.js +5 -0
- package/src/proxy/sqlserver/SqlServerProxyServer.d.ts +8 -0
- package/src/proxy/sqlserver/SqlServerProxyServer.d.ts.map +1 -0
- package/src/proxy/sqlserver/SqlServerProxyServer.js +203 -0
- package/src/proxy/sqlserver/register.d.ts +2 -0
- package/src/proxy/sqlserver/register.d.ts.map +1 -0
- package/src/proxy/sqlserver/register.js +5 -0
- package/src/proxy.d.ts +4 -0
- package/src/proxy.d.ts.map +1 -0
- package/src/proxy.js +3 -0
- package/src/routes/doc.d.ts.map +1 -1
- package/src/routes/doc.js +16 -2
- package/src/routes/error.d.ts +5 -4
- package/src/routes/error.d.ts.map +1 -1
- package/src/routes/error.js +15 -13
- package/src/routes/errorPages.d.ts +2 -0
- package/src/routes/errorPages.d.ts.map +1 -1
- package/src/routes/errorPages.js +144 -4
- package/src/runtime/PluginAutoImports.d.ts +1 -0
- package/src/runtime/PluginAutoImports.d.ts.map +1 -1
- package/src/runtime/PluginAutoImports.js +94 -9
- package/src/runtime/RuntimeAdapter.d.ts +8 -9
- package/src/runtime/RuntimeAdapter.d.ts.map +1 -1
- package/src/runtime/RuntimeAdapter.js +120 -34
- package/src/runtime/RuntimeServices.d.ts +47 -0
- package/src/runtime/RuntimeServices.d.ts.map +1 -0
- package/src/runtime/RuntimeServices.js +164 -0
- package/src/runtime/StartupConfigFileRegistry.d.ts +4 -4
- package/src/runtime/StartupConfigFileRegistry.d.ts.map +1 -1
- package/src/runtime/StartupConfigFileRegistry.js +12 -0
- package/src/runtime/WorkerAdapterImports.d.ts +5 -0
- package/src/runtime/WorkerAdapterImports.d.ts.map +1 -0
- package/src/runtime/WorkerAdapterImports.js +17 -0
- package/src/runtime/WorkersModule.d.ts +6 -0
- package/src/runtime/WorkersModule.d.ts.map +1 -0
- package/src/runtime/WorkersModule.js +278 -0
- package/src/runtime/adapters/CloudflareAdapter.d.ts.map +1 -1
- package/src/runtime/adapters/CloudflareAdapter.js +19 -2
- package/src/runtime/adapters/DenoAdapter.js +1 -0
- package/src/runtime/adapters/FargateAdapter.js +1 -1
- package/src/runtime/adapters/LambdaAdapter.js +1 -1
- package/src/runtime/adapters/NodeServerAdapter.js +1 -1
- package/src/runtime/detectRuntime.d.ts +10 -0
- package/src/runtime/detectRuntime.d.ts.map +1 -0
- package/src/runtime/detectRuntime.js +57 -0
- package/src/runtime/useFileLoader.d.ts.map +1 -1
- package/src/runtime/useFileLoader.js +16 -0
- package/src/scheduler/Schedule.d.ts +36 -0
- package/src/scheduler/Schedule.d.ts.map +1 -0
- package/src/scheduler/Schedule.js +197 -0
- package/src/scheduler/ScheduleHttpGateway.d.ts +8 -0
- package/src/scheduler/ScheduleHttpGateway.d.ts.map +1 -0
- package/src/scheduler/ScheduleHttpGateway.js +196 -0
- package/src/scheduler/ScheduleRunner.d.ts +6 -0
- package/src/scheduler/ScheduleRunner.d.ts.map +1 -1
- package/src/scheduler/ScheduleRunner.js +166 -29
- package/src/scheduler/SchedulerRuntime.d.ts +15 -0
- package/src/scheduler/SchedulerRuntime.d.ts.map +1 -0
- package/src/scheduler/SchedulerRuntime.js +79 -0
- package/src/scheduler/cron/Cron.d.ts +19 -0
- package/src/scheduler/cron/Cron.d.ts.map +1 -0
- package/src/scheduler/cron/Cron.js +200 -0
- package/src/scheduler/leader/SchedulerLeader.d.ts +14 -0
- package/src/scheduler/leader/SchedulerLeader.d.ts.map +1 -0
- package/src/scheduler/leader/SchedulerLeader.js +187 -0
- package/src/scheduler/state/ScheduleStateStore.d.ts +27 -0
- package/src/scheduler/state/ScheduleStateStore.d.ts.map +1 -0
- package/src/scheduler/state/ScheduleStateStore.js +27 -0
- package/src/scheduler/types.d.ts +10 -0
- package/src/scheduler/types.d.ts.map +1 -1
- package/src/schedules/index.d.ts +1 -0
- package/src/schedules/index.d.ts.map +1 -1
- package/src/schedules/index.js +1 -0
- package/src/schedules/job-tracking-cleanup.d.ts +4 -0
- package/src/schedules/job-tracking-cleanup.d.ts.map +1 -0
- package/src/schedules/job-tracking-cleanup.js +116 -0
- package/src/schedules/log-cleanup.d.ts +1 -2
- package/src/schedules/log-cleanup.d.ts.map +1 -1
- package/src/schedules/log-cleanup.js +12 -15
- package/src/scripts/TemplateImportsCheck.js +2 -2
- package/src/scripts/TemplateSync.js +3 -4
- package/src/security/CsrfTokenManager.d.ts.map +1 -1
- package/src/security/CsrfTokenManager.js +12 -0
- package/src/security/Hash.d.ts +1 -1
- package/src/security/Hash.d.ts.map +1 -1
- package/src/security/Hash.js +31 -36
- package/src/security/Sanitizer.d.ts.map +1 -1
- package/src/security/Sanitizer.js +1 -9
- package/src/security/SignedRequest.d.ts.map +1 -1
- package/src/security/SignedRequest.js +2 -2
- package/src/seeders/SeederLoader.js +1 -1
- package/src/session/SessionManager.d.ts +3 -0
- package/src/session/SessionManager.d.ts.map +1 -1
- package/src/session/SessionManager.js +49 -10
- package/src/sockets/CloudflareSocket.d.ts +24 -0
- package/src/sockets/CloudflareSocket.d.ts.map +1 -0
- package/src/sockets/CloudflareSocket.js +259 -0
- package/src/start.d.ts.map +1 -1
- package/src/start.js +1 -8
- package/src/templates/docker/docker-compose.ecosystem.yml.tpl +301 -0
- package/src/templates/docker/docker-compose.schedules.yml.tpl +84 -0
- package/src/templates/project/basic/app/Schedules/index.ts.tpl +0 -0
- package/src/templates/project/basic/config/database.ts.tpl +1 -1
- package/src/templates/project/basic/src/zintrust.plugins.wg.ts.tpl +8 -0
- package/src/toolkit/Secrets/Manifest.d.ts.map +1 -1
- package/src/toolkit/Secrets/Manifest.js +5 -7
- package/src/tools/mail/drivers/Smtp.d.ts.map +1 -1
- package/src/tools/mail/drivers/Smtp.js +229 -18
- package/src/tools/mail/index.d.ts.map +1 -1
- package/src/tools/mail/index.js +5 -4
- package/src/tools/mail/template-loader.d.ts.map +1 -1
- package/src/tools/mail/template-loader.js +197 -29
- package/src/tools/mail/templates/auth-password-reset.d.ts +3 -0
- package/src/tools/mail/templates/auth-password-reset.d.ts.map +1 -0
- package/src/tools/mail/templates/auth-password-reset.js +231 -0
- package/src/tools/mail/templates/auth-welcome.d.ts +3 -0
- package/src/tools/mail/templates/auth-welcome.d.ts.map +1 -0
- package/src/tools/mail/templates/auth-welcome.js +236 -0
- package/src/tools/mail/templates/general.d.ts +3 -0
- package/src/tools/mail/templates/general.d.ts.map +1 -0
- package/src/tools/mail/templates/general.js +109 -0
- package/src/tools/mail/templates/index.js +2 -2
- package/src/tools/mail/templates/job-completed.d.ts +3 -0
- package/src/tools/mail/templates/job-completed.d.ts.map +1 -0
- package/src/tools/mail/templates/job-completed.js +188 -0
- package/src/tools/mail/templates/notifications-new-comment.d.ts +3 -0
- package/src/tools/mail/templates/notifications-new-comment.d.ts.map +1 -0
- package/src/tools/mail/templates/notifications-new-comment.js +228 -0
- package/src/tools/mail/templates/password-reset.d.ts +3 -0
- package/src/tools/mail/templates/password-reset.d.ts.map +1 -0
- package/src/tools/mail/templates/password-reset.js +221 -0
- package/src/tools/mail/templates/performance-report.d.ts +3 -0
- package/src/tools/mail/templates/performance-report.d.ts.map +1 -0
- package/src/tools/mail/templates/performance-report.js +258 -0
- package/src/tools/mail/templates/welcome.d.ts +3 -0
- package/src/tools/mail/templates/welcome.d.ts.map +1 -0
- package/src/tools/mail/templates/welcome.js +187 -0
- package/src/tools/mail/templates/worker-alert.d.ts +3 -0
- package/src/tools/mail/templates/worker-alert.d.ts.map +1 -0
- package/src/tools/mail/templates/worker-alert.js +229 -0
- package/src/tools/notification/Notification.js +1 -1
- package/src/tools/notification/testingHelpers.js +6 -5
- package/src/tools/queue/AdvancedQueue.js +2 -6
- package/src/tools/queue/IdempotencyManager.d.ts +6 -0
- package/src/tools/queue/IdempotencyManager.d.ts.map +1 -0
- package/src/tools/queue/IdempotencyManager.js +36 -0
- package/src/tools/queue/JobHeartbeatStore.d.ts +16 -0
- package/src/tools/queue/JobHeartbeatStore.d.ts.map +1 -0
- package/src/tools/queue/JobHeartbeatStore.js +67 -0
- package/src/tools/queue/JobReconciliationRunner.d.ts +16 -0
- package/src/tools/queue/JobReconciliationRunner.d.ts.map +1 -0
- package/src/tools/queue/JobReconciliationRunner.js +56 -0
- package/src/tools/queue/JobRecoveryDaemon.d.ts +27 -0
- package/src/tools/queue/JobRecoveryDaemon.d.ts.map +1 -0
- package/src/tools/queue/JobRecoveryDaemon.js +303 -0
- package/src/tools/queue/JobStateTracker.d.ts +140 -0
- package/src/tools/queue/JobStateTracker.d.ts.map +1 -0
- package/src/tools/queue/JobStateTracker.js +409 -0
- package/src/tools/queue/JobStateTrackerDbPersistence.d.ts +12 -0
- package/src/tools/queue/JobStateTrackerDbPersistence.d.ts.map +1 -0
- package/src/tools/queue/JobStateTrackerDbPersistence.js +239 -0
- package/src/tools/queue/Queue.d.ts.map +1 -1
- package/src/tools/queue/Queue.js +160 -16
- package/src/tools/queue/QueueDataRedactor.d.ts +6 -0
- package/src/tools/queue/QueueDataRedactor.d.ts.map +1 -0
- package/src/tools/queue/QueueDataRedactor.js +45 -0
- package/src/tools/queue/QueueExtensions.d.ts.map +1 -1
- package/src/tools/queue/QueueExtensions.js +2 -1
- package/src/tools/queue/QueueReliabilityMetrics.d.ts +38 -0
- package/src/tools/queue/QueueReliabilityMetrics.d.ts.map +1 -0
- package/src/tools/queue/QueueReliabilityMetrics.js +131 -0
- package/src/tools/queue/QueueReliabilityOrchestrator.d.ts +7 -0
- package/src/tools/queue/QueueReliabilityOrchestrator.d.ts.map +1 -0
- package/src/tools/queue/QueueReliabilityOrchestrator.js +59 -0
- package/src/tools/queue/QueueRuntimeRegistration.d.ts +1 -9
- package/src/tools/queue/QueueRuntimeRegistration.d.ts.map +1 -1
- package/src/tools/queue/QueueRuntimeRegistration.js +75 -4
- package/src/tools/queue/QueueTracing.d.ts +32 -0
- package/src/tools/queue/QueueTracing.d.ts.map +1 -0
- package/src/tools/queue/QueueTracing.js +151 -0
- package/src/tools/queue/StalledJobMonitor.d.ts +5 -0
- package/src/tools/queue/StalledJobMonitor.d.ts.map +1 -0
- package/src/tools/queue/StalledJobMonitor.js +21 -0
- package/src/tools/queue/TimeoutManager.d.ts +14 -0
- package/src/tools/queue/TimeoutManager.d.ts.map +1 -0
- package/src/tools/queue/TimeoutManager.js +77 -0
- package/src/tools/queue/drivers/Redis.d.ts +1 -0
- package/src/tools/queue/drivers/Redis.d.ts.map +1 -1
- package/src/tools/queue/drivers/Redis.js +1 -0
- package/src/tools/queue/index.d.ts +10 -0
- package/src/tools/queue/index.d.ts.map +1 -1
- package/src/tools/queue/index.js +10 -0
- package/src/tools/storage/drivers/R2.d.ts +13 -0
- package/src/tools/storage/drivers/R2.d.ts.map +1 -1
- package/src/tools/storage/drivers/R2.js +29 -0
- package/src/zintrust.plugins.d.ts +9 -0
- package/src/zintrust.plugins.d.ts.map +1 -0
- package/src/zintrust.plugins.js +7 -0
- package/src/zintrust.plugins.wg.d.ts +9 -0
- package/src/zintrust.plugins.wg.d.ts.map +1 -0
- package/src/zintrust.plugins.wg.js +7 -0
|
@@ -0,0 +1,409 @@
|
|
|
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: typeof input.attempts === 'number' ? input.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
|
+
attempts: typeof input.attempts === 'number' && Number.isFinite(input.attempts)
|
|
263
|
+
? Math.max(0, Math.floor(input.attempts))
|
|
264
|
+
: undefined,
|
|
265
|
+
maxAttempts: toFinitePositiveInt(input.maxAttempts),
|
|
266
|
+
retryAt: input.retryAt,
|
|
267
|
+
error: normalizeError(input.error) ?? input.reason,
|
|
268
|
+
lastErrorCode: normalizeErrorCode(input.error),
|
|
269
|
+
});
|
|
270
|
+
await persistLatest(input.queueName, input.jobId, transition);
|
|
271
|
+
},
|
|
272
|
+
async markedRecovered(input) {
|
|
273
|
+
if (isEnabled() === false)
|
|
274
|
+
return;
|
|
275
|
+
const transition = updateStatus(input.queueName, input.jobId, 'pending', input.reason ?? 'Job re-queued for recovery', {
|
|
276
|
+
recoveredAt: nowIso(),
|
|
277
|
+
retryAt: input.retryAt,
|
|
278
|
+
});
|
|
279
|
+
await persistLatest(input.queueName, input.jobId, transition);
|
|
280
|
+
},
|
|
281
|
+
async handedOffToQueue(input) {
|
|
282
|
+
if (isEnabled() === false)
|
|
283
|
+
return;
|
|
284
|
+
const transition = updateStatus(input.queueName, input.jobId, 'enqueued', input.reason ?? 'Job handed off to queue driver', {
|
|
285
|
+
retryAt: undefined,
|
|
286
|
+
timeoutAt: undefined,
|
|
287
|
+
error: undefined,
|
|
288
|
+
});
|
|
289
|
+
await persistLatest(input.queueName, input.jobId, transition);
|
|
290
|
+
},
|
|
291
|
+
async setTerminalStatus(input) {
|
|
292
|
+
if (isEnabled() === false)
|
|
293
|
+
return;
|
|
294
|
+
const transition = updateStatus(input.queueName, input.jobId, input.status, input.reason, {
|
|
295
|
+
error: normalizeError(input.error),
|
|
296
|
+
lastErrorCode: normalizeErrorCode(input.error),
|
|
297
|
+
completedAt: input.status === 'completed' ? nowIso() : undefined,
|
|
298
|
+
});
|
|
299
|
+
await persistLatest(input.queueName, input.jobId, transition);
|
|
300
|
+
},
|
|
301
|
+
registerPersistenceAdapter(adapter) {
|
|
302
|
+
persistenceAdapter = adapter;
|
|
303
|
+
},
|
|
304
|
+
clearPersistenceAdapter() {
|
|
305
|
+
persistenceAdapter = null;
|
|
306
|
+
},
|
|
307
|
+
get(queueName, jobId) {
|
|
308
|
+
return trackedJobs.get(getKey(queueName, jobId));
|
|
309
|
+
},
|
|
310
|
+
list(options) {
|
|
311
|
+
const filterQueueName = options?.queueName;
|
|
312
|
+
const filterStatus = options?.status;
|
|
313
|
+
const limit = typeof options?.limit === 'number' && Number.isFinite(options.limit) && options.limit > 0
|
|
314
|
+
? Math.floor(options.limit)
|
|
315
|
+
: 100;
|
|
316
|
+
const rows = Array.from(trackedJobs.values())
|
|
317
|
+
.filter((row) => (filterQueueName === undefined ? true : row.queueName === filterQueueName))
|
|
318
|
+
.filter((row) => (filterStatus === undefined ? true : row.status === filterStatus))
|
|
319
|
+
.sort((left, right) => right.updatedAt.localeCompare(left.updatedAt));
|
|
320
|
+
return rows.slice(0, limit);
|
|
321
|
+
},
|
|
322
|
+
getTransitions(options) {
|
|
323
|
+
const filterQueueName = options?.queueName;
|
|
324
|
+
const filterJobId = options?.jobId;
|
|
325
|
+
const limit = typeof options?.limit === 'number' && Number.isFinite(options.limit) && options.limit > 0
|
|
326
|
+
? Math.floor(options.limit)
|
|
327
|
+
: 200;
|
|
328
|
+
const rows = transitions
|
|
329
|
+
.filter((row) => (filterQueueName === undefined ? true : row.queueName === filterQueueName))
|
|
330
|
+
.filter((row) => (filterJobId === undefined ? true : row.jobId === filterJobId));
|
|
331
|
+
if (rows.length <= limit)
|
|
332
|
+
return [...rows];
|
|
333
|
+
return rows.slice(rows.length - limit);
|
|
334
|
+
},
|
|
335
|
+
listActiveOlderThan(maxAgeMs, queueName) {
|
|
336
|
+
const threshold = Date.now() - Math.max(0, Math.floor(maxAgeMs));
|
|
337
|
+
return Array.from(trackedJobs.values()).filter((row) => {
|
|
338
|
+
if (row.status !== 'active')
|
|
339
|
+
return false;
|
|
340
|
+
if (queueName !== undefined && row.queueName !== queueName)
|
|
341
|
+
return false;
|
|
342
|
+
const reference = toEpochMs(row.startedAt) ?? toEpochMs(row.updatedAt);
|
|
343
|
+
if (reference === null)
|
|
344
|
+
return false;
|
|
345
|
+
return reference <= threshold;
|
|
346
|
+
});
|
|
347
|
+
},
|
|
348
|
+
listPendingOlderThan(maxAgeMs, queueName) {
|
|
349
|
+
const threshold = Date.now() - Math.max(0, Math.floor(maxAgeMs));
|
|
350
|
+
return Array.from(trackedJobs.values()).filter((row) => {
|
|
351
|
+
if (row.status !== 'pending')
|
|
352
|
+
return false;
|
|
353
|
+
if (queueName !== undefined && row.queueName !== queueName)
|
|
354
|
+
return false;
|
|
355
|
+
const reference = toEpochMs(row.updatedAt) ?? toEpochMs(row.createdAt);
|
|
356
|
+
if (reference === null)
|
|
357
|
+
return false;
|
|
358
|
+
return reference <= threshold;
|
|
359
|
+
});
|
|
360
|
+
},
|
|
361
|
+
listRecoverable(maxAgeMs, queueName) {
|
|
362
|
+
const threshold = Date.now() - Math.max(0, Math.floor(maxAgeMs));
|
|
363
|
+
const recoverable = new Set(['pending_recovery']);
|
|
364
|
+
return Array.from(trackedJobs.values()).filter((row) => {
|
|
365
|
+
if (!recoverable.has(row.status))
|
|
366
|
+
return false;
|
|
367
|
+
if (queueName !== undefined && row.queueName !== queueName)
|
|
368
|
+
return false;
|
|
369
|
+
// Respect scheduled retry window to avoid hot-loop recovery churn.
|
|
370
|
+
if (row.retryAt !== undefined && row.retryAt.trim().length > 0) {
|
|
371
|
+
const retryAtMs = new Date(row.retryAt).getTime();
|
|
372
|
+
if (!Number.isNaN(retryAtMs) && retryAtMs > Date.now()) {
|
|
373
|
+
return false;
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
const reference = toEpochMs(row.updatedAt);
|
|
377
|
+
if (reference === null)
|
|
378
|
+
return false;
|
|
379
|
+
return reference <= threshold;
|
|
380
|
+
});
|
|
381
|
+
},
|
|
382
|
+
listHeartbeatExpired(maxSilenceMs, queueName) {
|
|
383
|
+
const threshold = Date.now() - Math.max(0, Math.floor(maxSilenceMs));
|
|
384
|
+
return Array.from(trackedJobs.values()).filter((row) => {
|
|
385
|
+
if (row.status !== 'active')
|
|
386
|
+
return false;
|
|
387
|
+
if (queueName !== undefined && row.queueName !== queueName)
|
|
388
|
+
return false;
|
|
389
|
+
const reference = toEpochMs(row.heartbeatAt) ?? toEpochMs(row.updatedAt);
|
|
390
|
+
if (reference === null)
|
|
391
|
+
return false;
|
|
392
|
+
return reference <= threshold;
|
|
393
|
+
});
|
|
394
|
+
},
|
|
395
|
+
getSummary(queueName) {
|
|
396
|
+
const rows = Array.from(trackedJobs.values()).filter((row) => queueName === undefined ? true : row.queueName === queueName);
|
|
397
|
+
return rows.reduce((acc, row) => {
|
|
398
|
+
const key = row.status;
|
|
399
|
+
acc[key] = (acc[key] ?? 0) + 1;
|
|
400
|
+
return acc;
|
|
401
|
+
}, {});
|
|
402
|
+
},
|
|
403
|
+
reset() {
|
|
404
|
+
trackedJobs.clear();
|
|
405
|
+
transitions.splice(0, transitions.length);
|
|
406
|
+
persistenceAdapter = null;
|
|
407
|
+
},
|
|
408
|
+
});
|
|
409
|
+
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":"AAKA,OAAO,KAAK,EACV,iCAAiC,EAGlC,MAAM,wBAAwB,CAAC;AAGhC,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;AAoMF,eAAO,MAAM,kCAAkC,GAC7C,UAAS,wBAA6B,KACrC,iCAwDF,CAAC;AAEF,eAAO,MAAM,6CAA6C,QAAO,OAsBhE,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
|
|
@@ -0,0 +1,239 @@
|
|
|
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 toNonNullJson = (value) => {
|
|
17
|
+
const json = toJson(value);
|
|
18
|
+
return json ?? null;
|
|
19
|
+
};
|
|
20
|
+
const toSqlDateTime = (isoLike) => {
|
|
21
|
+
if (typeof isoLike !== 'string' || isoLike.trim().length === 0)
|
|
22
|
+
return null;
|
|
23
|
+
const parsed = new Date(isoLike);
|
|
24
|
+
if (Number.isNaN(parsed.getTime()))
|
|
25
|
+
return null;
|
|
26
|
+
return parsed.toISOString().slice(0, 19).replace('T', ' ');
|
|
27
|
+
};
|
|
28
|
+
const getConnectionName = (options) => {
|
|
29
|
+
if (options.connectionName !== undefined && options.connectionName.trim().length > 0) {
|
|
30
|
+
return options.connectionName.trim();
|
|
31
|
+
}
|
|
32
|
+
return Env.get('JOB_TRACKING_DB_CONNECTION', 'default');
|
|
33
|
+
};
|
|
34
|
+
const getJobsTable = (options) => {
|
|
35
|
+
if (options.jobsTable !== undefined && options.jobsTable.trim().length > 0) {
|
|
36
|
+
return options.jobsTable.trim();
|
|
37
|
+
}
|
|
38
|
+
return Env.get('JOB_TRACKING_DB_TABLE', 'zintrust_jobs');
|
|
39
|
+
};
|
|
40
|
+
const getTransitionsTable = (options) => {
|
|
41
|
+
if (options.transitionsTable !== undefined && options.transitionsTable.trim().length > 0) {
|
|
42
|
+
return options.transitionsTable.trim();
|
|
43
|
+
}
|
|
44
|
+
return Env.get('JOB_TRACKING_DB_TRANSITIONS_TABLE', 'zintrust_job_transitions');
|
|
45
|
+
};
|
|
46
|
+
const getDatabase = (connectionName) => {
|
|
47
|
+
try {
|
|
48
|
+
return useDatabase(undefined, connectionName);
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
Logger.warn('Job tracking database connection is unavailable', {
|
|
52
|
+
connectionName,
|
|
53
|
+
error,
|
|
54
|
+
});
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
const serializeJobRecord = (record, options) => {
|
|
59
|
+
return {
|
|
60
|
+
job_id: record.jobId,
|
|
61
|
+
queue_name: record.queueName,
|
|
62
|
+
status: record.status,
|
|
63
|
+
attempts: record.attempts,
|
|
64
|
+
max_attempts: record.maxAttempts ?? null,
|
|
65
|
+
payload_json: toNonNullJson(record.payload),
|
|
66
|
+
result_json: options.persistResult === false ? null : toJson(record.result),
|
|
67
|
+
last_error: record.lastError ?? null,
|
|
68
|
+
last_error_code: record.lastErrorCode ?? null,
|
|
69
|
+
retry_at: toSqlDateTime(record.retryAt),
|
|
70
|
+
timeout_at: toSqlDateTime(record.timeoutAt),
|
|
71
|
+
heartbeat_at: toSqlDateTime(record.heartbeatAt),
|
|
72
|
+
expected_completion_at: toSqlDateTime(record.expectedCompletionAt),
|
|
73
|
+
worker_name: record.workerName ?? null,
|
|
74
|
+
worker_instance_id: record.workerInstanceId ?? null,
|
|
75
|
+
worker_region: record.workerRegion ?? null,
|
|
76
|
+
worker_version: record.workerVersion ?? null,
|
|
77
|
+
recovered_at: toSqlDateTime(record.recoveredAt),
|
|
78
|
+
idempotency_key: record.idempotencyKey ?? null,
|
|
79
|
+
created_at: toSqlDateTime(record.createdAt),
|
|
80
|
+
started_at: toSqlDateTime(record.startedAt),
|
|
81
|
+
completed_at: toSqlDateTime(record.completedAt),
|
|
82
|
+
updated_at: toSqlDateTime(record.updatedAt),
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
const serializeJobRecordForInsert = (record, options) => {
|
|
86
|
+
const payload = serializeJobRecord(record, options);
|
|
87
|
+
// Ensure payload_json is always non-null for inserts (some schemas require NOT NULL).
|
|
88
|
+
if (payload['payload_json'] === null) {
|
|
89
|
+
payload['payload_json'] = '{}';
|
|
90
|
+
}
|
|
91
|
+
return payload;
|
|
92
|
+
};
|
|
93
|
+
const applyUpdateEntries = (update, entries) => {
|
|
94
|
+
entries.forEach((entry) => {
|
|
95
|
+
if (entry.enabled)
|
|
96
|
+
update[entry.key] = entry.value;
|
|
97
|
+
});
|
|
98
|
+
};
|
|
99
|
+
const resolveResultEntry = (record, options, base) => {
|
|
100
|
+
if (options.persistResult === false) {
|
|
101
|
+
return { key: 'result_json', enabled: true, value: null };
|
|
102
|
+
}
|
|
103
|
+
const enabled = record.result !== undefined && base['result_json'] !== null;
|
|
104
|
+
return { key: 'result_json', enabled, value: base['result_json'] };
|
|
105
|
+
};
|
|
106
|
+
const serializeJobRecordForUpdate = (record, options) => {
|
|
107
|
+
const base = serializeJobRecord(record, options);
|
|
108
|
+
const update = {
|
|
109
|
+
status: base['status'],
|
|
110
|
+
attempts: base['attempts'],
|
|
111
|
+
updated_at: base['updated_at'],
|
|
112
|
+
};
|
|
113
|
+
applyUpdateEntries(update, [
|
|
114
|
+
{ key: 'max_attempts', enabled: record.maxAttempts !== undefined, value: base['max_attempts'] },
|
|
115
|
+
resolveResultEntry(record, options, base),
|
|
116
|
+
{ key: 'last_error', enabled: record.lastError !== undefined, value: base['last_error'] },
|
|
117
|
+
{
|
|
118
|
+
key: 'last_error_code',
|
|
119
|
+
enabled: record.lastErrorCode !== undefined,
|
|
120
|
+
value: base['last_error_code'],
|
|
121
|
+
},
|
|
122
|
+
{ key: 'retry_at', enabled: record.retryAt !== undefined, value: base['retry_at'] },
|
|
123
|
+
{ key: 'timeout_at', enabled: record.timeoutAt !== undefined, value: base['timeout_at'] },
|
|
124
|
+
{ key: 'heartbeat_at', enabled: record.heartbeatAt !== undefined, value: base['heartbeat_at'] },
|
|
125
|
+
{
|
|
126
|
+
key: 'expected_completion_at',
|
|
127
|
+
enabled: record.expectedCompletionAt !== undefined,
|
|
128
|
+
value: base['expected_completion_at'],
|
|
129
|
+
},
|
|
130
|
+
{ key: 'worker_name', enabled: record.workerName !== undefined, value: base['worker_name'] },
|
|
131
|
+
{
|
|
132
|
+
key: 'worker_instance_id',
|
|
133
|
+
enabled: record.workerInstanceId !== undefined,
|
|
134
|
+
value: base['worker_instance_id'],
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
key: 'worker_region',
|
|
138
|
+
enabled: record.workerRegion !== undefined,
|
|
139
|
+
value: base['worker_region'],
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
key: 'worker_version',
|
|
143
|
+
enabled: record.workerVersion !== undefined,
|
|
144
|
+
value: base['worker_version'],
|
|
145
|
+
},
|
|
146
|
+
{ key: 'recovered_at', enabled: record.recoveredAt !== undefined, value: base['recovered_at'] },
|
|
147
|
+
{
|
|
148
|
+
key: 'idempotency_key',
|
|
149
|
+
enabled: record.idempotencyKey !== undefined,
|
|
150
|
+
value: base['idempotency_key'],
|
|
151
|
+
},
|
|
152
|
+
{ key: 'started_at', enabled: record.startedAt !== undefined, value: base['started_at'] },
|
|
153
|
+
{ key: 'completed_at', enabled: record.completedAt !== undefined, value: base['completed_at'] },
|
|
154
|
+
]);
|
|
155
|
+
return update;
|
|
156
|
+
};
|
|
157
|
+
const serializeTransition = (transition) => {
|
|
158
|
+
return {
|
|
159
|
+
job_id: transition.jobId,
|
|
160
|
+
queue_name: transition.queueName,
|
|
161
|
+
from_status: transition.fromStatus,
|
|
162
|
+
to_status: transition.toStatus,
|
|
163
|
+
reason: transition.reason,
|
|
164
|
+
attempts: transition.attempts ?? null,
|
|
165
|
+
error: transition.error ?? null,
|
|
166
|
+
transitioned_at: toSqlDateTime(transition.timestamp),
|
|
167
|
+
};
|
|
168
|
+
};
|
|
169
|
+
export const createJobStateTrackerDbPersistence = (options = {}) => {
|
|
170
|
+
const connectionName = getConnectionName(options);
|
|
171
|
+
const jobsTable = getJobsTable(options);
|
|
172
|
+
const transitionsTable = getTransitionsTable(options);
|
|
173
|
+
const persistTransitions = () => Env.getBool('JOB_TRACKING_PERSIST_TRANSITIONS_ENABLED', false);
|
|
174
|
+
const shouldInsertNewRow = (record) => {
|
|
175
|
+
// zintrust_jobs is an enqueue-fallback buffer: only jobs that failed to enqueue
|
|
176
|
+
// should be inserted into persistence. Once the job is in QUEUE_DRIVER, we only
|
|
177
|
+
// update the existing row (e.g., status=enqueued) but never create new rows.
|
|
178
|
+
return record.status === 'pending_recovery';
|
|
179
|
+
};
|
|
180
|
+
const upsertJob = async (record) => {
|
|
181
|
+
const db = getDatabase(connectionName);
|
|
182
|
+
if (db === null)
|
|
183
|
+
return;
|
|
184
|
+
const existing = await db
|
|
185
|
+
.table(jobsTable)
|
|
186
|
+
.where('job_id', '=', record.jobId)
|
|
187
|
+
.where('queue_name', '=', record.queueName)
|
|
188
|
+
.first();
|
|
189
|
+
if (existing) {
|
|
190
|
+
const existingStatus = typeof existing.status === 'string' ? existing.status.trim().toLowerCase() : '';
|
|
191
|
+
if (existingStatus === 'enqueued')
|
|
192
|
+
return;
|
|
193
|
+
const payload = serializeJobRecordForUpdate(record, options);
|
|
194
|
+
await db
|
|
195
|
+
.table(jobsTable)
|
|
196
|
+
.where('job_id', '=', record.jobId)
|
|
197
|
+
.where('queue_name', '=', record.queueName)
|
|
198
|
+
.update(payload);
|
|
199
|
+
return;
|
|
200
|
+
}
|
|
201
|
+
if (!shouldInsertNewRow(record))
|
|
202
|
+
return;
|
|
203
|
+
const payload = serializeJobRecordForInsert(record, options);
|
|
204
|
+
await db.table(jobsTable).insert(payload);
|
|
205
|
+
};
|
|
206
|
+
const insertTransition = async (transition) => {
|
|
207
|
+
if (persistTransitions() === false)
|
|
208
|
+
return;
|
|
209
|
+
const db = getDatabase(connectionName);
|
|
210
|
+
if (db === null)
|
|
211
|
+
return;
|
|
212
|
+
await db.table(transitionsTable).insert(serializeTransition(transition));
|
|
213
|
+
};
|
|
214
|
+
return Object.freeze({
|
|
215
|
+
upsertJob,
|
|
216
|
+
insertTransition,
|
|
217
|
+
});
|
|
218
|
+
};
|
|
219
|
+
export const autoRegisterJobStateTrackerPersistenceFromEnv = () => {
|
|
220
|
+
const trackingEnabled = Env.getBool('JOB_TRACKING_ENABLED', true);
|
|
221
|
+
const persistenceEnabled = Env.getBool('JOB_TRACKING_PERSISTENCE_ENABLED', false);
|
|
222
|
+
if (trackingEnabled === false || persistenceEnabled === false) {
|
|
223
|
+
JobStateTracker.clearPersistenceAdapter();
|
|
224
|
+
return false;
|
|
225
|
+
}
|
|
226
|
+
const driver = Env.get('JOB_TRACKING_PERSISTENCE_DRIVER', ZintrustLang.DATABASE)
|
|
227
|
+
.trim()
|
|
228
|
+
.toLowerCase();
|
|
229
|
+
if (driver !== ZintrustLang.DATABASE) {
|
|
230
|
+
Logger.warn('Unsupported job tracking persistence driver, skipping auto-registration', {
|
|
231
|
+
driver,
|
|
232
|
+
});
|
|
233
|
+
JobStateTracker.clearPersistenceAdapter();
|
|
234
|
+
return false;
|
|
235
|
+
}
|
|
236
|
+
JobStateTracker.registerPersistenceAdapter(createJobStateTrackerDbPersistence());
|
|
237
|
+
return true;
|
|
238
|
+
};
|
|
239
|
+
export default createJobStateTrackerDbPersistence;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Queue.d.ts","sourceRoot":"","sources":["../../../../src/tools/queue/Queue.ts"],"names":[],"mappings":"
|
|
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"}
|