@zintrust/core 0.1.19 → 0.1.21
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/README.md +10 -10
- package/bin/zintrust-main.d.ts.map +1 -1
- package/bin/zintrust-main.js +9 -0
- package/package.json +3 -2
- package/public/error-pages/404.html +145 -0
- package/public/error-pages/500.html +266 -0
- package/public/error-pages/error.css +628 -0
- package/public/error-pages/error.js +428 -0
- package/public/zintrust.svg +30 -0
- package/routes/api.d.ts.map +1 -1
- package/routes/api.js +41 -17
- package/routes/metrics.d.ts +9 -0
- package/routes/metrics.d.ts.map +1 -0
- package/routes/metrics.js +20 -0
- package/routes/openapi.d.ts +9 -0
- package/routes/openapi.d.ts.map +1 -0
- package/routes/openapi.js +76 -0
- package/src/boot/Application.d.ts +2 -2
- package/src/boot/Application.d.ts.map +1 -1
- package/src/boot/Application.js +66 -13
- package/src/boot/Server.d.ts +3 -2
- package/src/boot/Server.d.ts.map +1 -1
- package/src/boot/Server.js +39 -165
- package/src/boot/bootstrap.js +2 -0
- package/src/cache/Cache.d.ts +1 -1
- package/src/cache/Cache.d.ts.map +1 -1
- package/src/cache/CacheDriver.d.ts +4 -0
- package/src/cache/CacheDriver.d.ts.map +1 -1
- package/src/cache/drivers/KVDriver.d.ts +1 -1
- package/src/cache/drivers/KVDriver.d.ts.map +1 -1
- package/src/cache/drivers/MemoryDriver.d.ts +1 -1
- package/src/cache/drivers/MemoryDriver.d.ts.map +1 -1
- package/src/cache/drivers/MemoryDriver.js +16 -0
- package/src/cache/drivers/MongoDriver.d.ts +1 -1
- package/src/cache/drivers/MongoDriver.d.ts.map +1 -1
- package/src/cache/drivers/RedisDriver.d.ts +1 -1
- package/src/cache/drivers/RedisDriver.d.ts.map +1 -1
- package/src/cli/CLI.d.ts.map +1 -1
- package/src/cli/CLI.js +10 -4
- package/src/cli/commands/AddCommand.d.ts +2 -2
- package/src/cli/commands/AddCommand.d.ts.map +1 -1
- package/src/cli/commands/AddCommand.js +135 -58
- package/src/cli/commands/ConfigCommand.d.ts +1 -1
- package/src/cli/commands/ConfigCommand.d.ts.map +1 -1
- package/src/cli/commands/CreateCommand.d.ts +15 -0
- package/src/cli/commands/CreateCommand.d.ts.map +1 -0
- package/src/cli/commands/CreateCommand.js +143 -0
- package/src/cli/commands/D1MigrateCommand.d.ts +1 -1
- package/src/cli/commands/D1MigrateCommand.d.ts.map +1 -1
- package/src/cli/commands/D1MigrateCommand.js +16 -20
- package/src/cli/commands/DbSeedCommand.d.ts +9 -0
- package/src/cli/commands/DbSeedCommand.d.ts.map +1 -0
- package/src/cli/commands/DbSeedCommand.js +171 -0
- package/src/cli/commands/DebugCommand.d.ts +1 -1
- package/src/cli/commands/DebugCommand.d.ts.map +1 -1
- package/src/cli/commands/FixCommand.d.ts +1 -1
- package/src/cli/commands/FixCommand.d.ts.map +1 -1
- package/src/cli/commands/JwtDevCommand.d.ts +8 -0
- package/src/cli/commands/JwtDevCommand.d.ts.map +1 -0
- package/src/cli/commands/JwtDevCommand.js +114 -0
- package/src/cli/commands/KeyGenerateCommand.d.ts +1 -1
- package/src/cli/commands/KeyGenerateCommand.d.ts.map +1 -1
- package/src/cli/commands/LogsCommand.d.ts +2 -2
- package/src/cli/commands/LogsCommand.d.ts.map +1 -1
- package/src/cli/commands/LogsCommand.js +36 -2
- package/src/cli/commands/MakeMailTemplateCommand.d.ts +1 -1
- package/src/cli/commands/MakeMailTemplateCommand.d.ts.map +1 -1
- package/src/cli/commands/MakeNotificationTemplateCommand.d.ts +1 -1
- package/src/cli/commands/MakeNotificationTemplateCommand.d.ts.map +1 -1
- package/src/cli/commands/MigrateCommand.d.ts +1 -1
- package/src/cli/commands/MigrateCommand.d.ts.map +1 -1
- package/src/cli/commands/MigrateCommand.js +324 -35
- package/src/cli/commands/NewCommand.d.ts +1 -1
- package/src/cli/commands/NewCommand.d.ts.map +1 -1
- package/src/cli/commands/NewCommand.js +12 -4
- package/src/cli/commands/PluginCommand.d.ts +1 -1
- package/src/cli/commands/PluginCommand.d.ts.map +1 -1
- package/src/cli/commands/PrepareCommand.d.ts +1 -1
- package/src/cli/commands/PrepareCommand.d.ts.map +1 -1
- package/src/cli/commands/QACommand.d.ts +2 -2
- package/src/cli/commands/QACommand.d.ts.map +1 -1
- package/src/cli/commands/RoutesCommand.d.ts +10 -0
- package/src/cli/commands/RoutesCommand.d.ts.map +1 -0
- package/src/cli/commands/RoutesCommand.js +242 -0
- package/src/cli/commands/SimulateCommand.d.ts +1 -1
- package/src/cli/commands/SimulateCommand.d.ts.map +1 -1
- package/src/cli/commands/index.d.ts +3 -0
- package/src/cli/commands/index.d.ts.map +1 -1
- package/src/cli/commands/index.js +3 -0
- package/src/cli/config/ConfigManager.d.ts +1 -1
- package/src/cli/config/ConfigManager.d.ts.map +1 -1
- package/src/cli/config/ConfigValidator.d.ts +1 -1
- package/src/cli/config/ConfigValidator.d.ts.map +1 -1
- package/src/cli/config/ConfigValidator.js +1 -1
- package/src/cli/d1/D1SqlMigrations.d.ts +20 -0
- package/src/cli/d1/D1SqlMigrations.d.ts.map +1 -0
- package/src/cli/d1/D1SqlMigrations.js +229 -0
- package/src/cli/d1/WranglerConfig.d.ts +4 -0
- package/src/cli/d1/WranglerConfig.d.ts.map +1 -0
- package/src/cli/d1/WranglerConfig.js +122 -0
- package/src/cli/d1/WranglerD1.d.ts +11 -0
- package/src/cli/d1/WranglerD1.d.ts.map +1 -0
- package/src/cli/d1/WranglerD1.js +16 -0
- package/src/cli/scaffolding/ControllerGenerator.d.ts.map +1 -1
- package/src/cli/scaffolding/ControllerGenerator.js +76 -26
- package/src/cli/scaffolding/FactoryGenerator.d.ts.map +1 -1
- package/src/cli/scaffolding/FactoryGenerator.js +3 -1
- package/src/cli/scaffolding/GovernanceScaffolder.d.ts +23 -0
- package/src/cli/scaffolding/GovernanceScaffolder.d.ts.map +1 -0
- package/src/cli/scaffolding/GovernanceScaffolder.js +327 -0
- package/src/cli/scaffolding/MigrationGenerator.d.ts +10 -0
- package/src/cli/scaffolding/MigrationGenerator.d.ts.map +1 -1
- package/src/cli/scaffolding/MigrationGenerator.js +137 -51
- package/src/cli/scaffolding/ModelGenerator.js +1 -1
- package/src/cli/scaffolding/ProjectScaffolder.d.ts.map +1 -1
- package/src/cli/scaffolding/ProjectScaffolder.js +36 -4
- package/src/cli/scaffolding/RouteGenerator.d.ts.map +1 -1
- package/src/cli/scaffolding/RouteGenerator.js +79 -43
- package/src/cli/scaffolding/SeederGenerator.d.ts +5 -0
- package/src/cli/scaffolding/SeederGenerator.d.ts.map +1 -1
- package/src/cli/scaffolding/SeederGenerator.js +63 -15
- package/src/cli/scaffolding/ServiceScaffolder.d.ts.map +1 -1
- package/src/cli/scaffolding/ServiceScaffolder.js +28 -7
- package/src/cli/scaffolding/index.d.ts +2 -0
- package/src/cli/scaffolding/index.d.ts.map +1 -1
- package/src/cli/scaffolding/index.js +1 -0
- package/src/common/index.d.ts +8 -0
- package/src/common/index.d.ts.map +1 -1
- package/src/common/index.js +28 -0
- package/src/common/utility.d.ts +38 -0
- package/src/common/utility.d.ts.map +1 -0
- package/src/common/utility.js +101 -0
- package/src/config/FileLogWriter.d.ts +2 -1
- package/src/config/FileLogWriter.d.ts.map +1 -1
- package/src/config/FileLogWriter.js +83 -2
- package/src/config/app.d.ts.map +1 -1
- package/src/config/app.js +3 -1
- package/src/config/broadcast.d.ts +14 -28
- package/src/config/broadcast.d.ts.map +1 -1
- package/src/config/broadcast.js +69 -35
- package/src/config/cache.d.ts +13 -45
- package/src/config/cache.d.ts.map +1 -1
- package/src/config/cache.js +69 -25
- package/src/config/cloudflare.d.ts +1 -1
- package/src/config/cloudflare.d.ts.map +1 -1
- package/src/config/database.d.ts +22 -64
- package/src/config/database.d.ts.map +1 -1
- package/src/config/database.js +191 -37
- package/src/config/env.d.ts +12 -0
- package/src/config/env.d.ts.map +1 -1
- package/src/config/env.js +14 -0
- package/src/config/index.d.ts +33 -137
- package/src/config/index.d.ts.map +1 -1
- package/src/config/logging/KvLogger.js +1 -1
- package/src/config/logging/SlackLogger.js +2 -2
- package/src/config/mail.d.ts +19 -55
- package/src/config/mail.d.ts.map +1 -1
- package/src/config/mail.js +63 -21
- package/src/config/middleware.d.ts +44 -1
- package/src/config/middleware.d.ts.map +1 -1
- package/src/config/middleware.js +157 -5
- package/src/config/notification.d.ts +14 -27
- package/src/config/notification.d.ts.map +1 -1
- package/src/config/notification.js +82 -36
- package/src/config/queue.d.ts +21 -51
- package/src/config/queue.d.ts.map +1 -1
- package/src/config/queue.js +72 -27
- package/src/config/security.d.ts +1 -1
- package/src/config/security.js +1 -1
- package/src/config/storage.d.ts +27 -34
- package/src/config/storage.d.ts.map +1 -1
- package/src/config/storage.js +97 -56
- package/src/config/type.d.ts +13 -2
- package/src/config/type.d.ts.map +1 -1
- package/src/events/EventDispatcher.d.ts.map +1 -1
- package/src/events/EventDispatcher.js +6 -4
- package/src/exceptions/ZintrustError.d.ts +7 -0
- package/src/exceptions/ZintrustError.d.ts.map +1 -1
- package/src/exceptions/ZintrustError.js +56 -0
- package/src/features/Auth.d.ts +1 -1
- package/src/features/Auth.d.ts.map +1 -1
- package/src/features/Auth.js +3 -3
- package/src/features/Queue.js +1 -1
- package/src/functions/cloudflare.d.ts.map +1 -1
- package/src/functions/cloudflare.js +3 -14
- package/src/functions/deno.d.ts.map +1 -1
- package/src/functions/deno.js +3 -14
- package/src/functions/lambda.d.ts.map +1 -1
- package/src/functions/lambda.js +3 -14
- package/src/health/StartupHealthChecks.js +1 -1
- package/src/http/Controller.d.ts +2 -2
- package/src/http/Controller.d.ts.map +1 -1
- package/src/http/FileUpload.d.ts +68 -0
- package/src/http/FileUpload.d.ts.map +1 -0
- package/src/http/FileUpload.js +120 -0
- package/src/http/Kernel.d.ts +5 -5
- package/src/http/Kernel.d.ts.map +1 -1
- package/src/http/Kernel.js +139 -23
- package/src/http/Request.d.ts +20 -1
- package/src/http/Request.d.ts.map +1 -1
- package/src/http/Request.js +23 -0
- package/src/http/RequestContext.d.ts +6 -0
- package/src/http/RequestContext.d.ts.map +1 -1
- package/src/http/RequestContext.js +77 -1
- package/src/http/Response.d.ts +1 -1
- package/src/http/Response.d.ts.map +1 -1
- package/src/http/ValidationHelper.d.ts +78 -0
- package/src/http/ValidationHelper.d.ts.map +1 -0
- package/src/http/ValidationHelper.js +121 -0
- package/src/http/error-pages/ErrorPageRenderer.d.ts +17 -0
- package/src/http/error-pages/ErrorPageRenderer.d.ts.map +1 -0
- package/src/http/error-pages/ErrorPageRenderer.js +88 -0
- package/src/http/middleware/BodyParsingMiddleware.d.ts +12 -0
- package/src/http/middleware/BodyParsingMiddleware.d.ts.map +1 -0
- package/src/http/middleware/BodyParsingMiddleware.js +251 -0
- package/src/http/middleware/FileUploadMiddleware.d.ts +12 -0
- package/src/http/middleware/FileUploadMiddleware.d.ts.map +1 -0
- package/src/http/middleware/FileUploadMiddleware.js +74 -0
- package/src/http/parsers/BodyParsers.d.ts +32 -0
- package/src/http/parsers/BodyParsers.d.ts.map +1 -0
- package/src/http/parsers/BodyParsers.js +159 -0
- package/src/http/parsers/MultipartParser.d.ts +33 -0
- package/src/http/parsers/MultipartParser.d.ts.map +1 -0
- package/src/http/parsers/MultipartParser.js +156 -0
- package/src/http/parsers/MultipartParserRegistry.d.ts +34 -0
- package/src/http/parsers/MultipartParserRegistry.d.ts.map +1 -0
- package/src/http/parsers/MultipartParserRegistry.js +20 -0
- package/src/http/validated.d.ts +12 -0
- package/src/http/validated.d.ts.map +1 -0
- package/src/http/validated.js +41 -0
- package/src/index.d.ts +73 -12
- package/src/index.d.ts.map +1 -1
- package/src/index.js +60 -5
- package/src/microservices/PostgresAdapter.d.ts.map +1 -1
- package/src/microservices/PostgresAdapter.js +0 -1
- package/src/microservices/RequestTracingMiddleware.d.ts +2 -2
- package/src/microservices/RequestTracingMiddleware.d.ts.map +1 -1
- package/src/microservices/RequestTracingMiddleware.js +3 -0
- package/src/microservices/ServiceAuthMiddleware.d.ts +2 -2
- package/src/microservices/ServiceAuthMiddleware.d.ts.map +1 -1
- package/src/middleware/AuthMiddleware.d.ts +10 -0
- package/src/middleware/AuthMiddleware.d.ts.map +1 -0
- package/src/middleware/AuthMiddleware.js +16 -0
- package/src/middleware/CsrfMiddleware.d.ts +11 -1
- package/src/middleware/CsrfMiddleware.d.ts.map +1 -1
- package/src/middleware/CsrfMiddleware.js +33 -0
- package/src/middleware/JwtAuthMiddleware.d.ts +11 -0
- package/src/middleware/JwtAuthMiddleware.d.ts.map +1 -0
- package/src/middleware/JwtAuthMiddleware.js +73 -0
- package/src/middleware/LoggingMiddleware.d.ts.map +1 -1
- package/src/middleware/LoggingMiddleware.js +8 -3
- package/src/middleware/MiddlewareStack.d.ts +2 -2
- package/src/middleware/MiddlewareStack.d.ts.map +1 -1
- package/src/middleware/RateLimiter.d.ts +2 -2
- package/src/middleware/RateLimiter.d.ts.map +1 -1
- package/src/middleware/SanitizeBodyMiddleware.d.ts +12 -0
- package/src/middleware/SanitizeBodyMiddleware.d.ts.map +1 -0
- package/src/middleware/SanitizeBodyMiddleware.js +31 -0
- package/src/middleware/SecurityMiddleware.d.ts +1 -1
- package/src/middleware/SecurityMiddleware.d.ts.map +1 -1
- package/src/middleware/SessionMiddleware.d.ts +1 -1
- package/src/middleware/SessionMiddleware.d.ts.map +1 -1
- package/src/middleware/ValidationMiddleware.d.ts +25 -0
- package/src/middleware/ValidationMiddleware.d.ts.map +1 -0
- package/src/middleware/ValidationMiddleware.js +251 -0
- package/src/migrations/MigrationDiscovery.d.ts +5 -0
- package/src/migrations/MigrationDiscovery.d.ts.map +1 -0
- package/src/migrations/MigrationDiscovery.js +16 -0
- package/src/migrations/MigrationLoader.d.ts +5 -0
- package/src/migrations/MigrationLoader.d.ts.map +1 -0
- package/src/migrations/MigrationLoader.js +43 -0
- package/src/migrations/MigrationLock.d.ts +4 -0
- package/src/migrations/MigrationLock.d.ts.map +1 -0
- package/src/migrations/MigrationLock.js +33 -0
- package/src/migrations/Migrator.d.ts +23 -0
- package/src/migrations/Migrator.d.ts.map +1 -0
- package/src/migrations/Migrator.js +4 -0
- package/src/migrations/MigratorFactory.d.ts +25 -0
- package/src/migrations/MigratorFactory.d.ts.map +1 -0
- package/src/migrations/MigratorFactory.js +339 -0
- package/src/migrations/schema/Blueprint.d.ts +5 -0
- package/src/migrations/schema/Blueprint.d.ts.map +1 -0
- package/src/migrations/schema/Blueprint.js +189 -0
- package/src/migrations/schema/Schema.d.ts +8 -0
- package/src/migrations/schema/Schema.d.ts.map +1 -0
- package/src/migrations/schema/Schema.js +141 -0
- package/src/migrations/schema/SchemaCompiler.d.ts +20 -0
- package/src/migrations/schema/SchemaCompiler.d.ts.map +1 -0
- package/src/migrations/schema/SchemaCompiler.js +262 -0
- package/src/migrations/schema/index.d.ts +5 -0
- package/src/migrations/schema/index.d.ts.map +1 -0
- package/src/migrations/schema/index.js +3 -0
- package/src/migrations/schema/types.d.ts +86 -0
- package/src/migrations/schema/types.d.ts.map +1 -0
- package/src/migrations/schema/types.js +1 -0
- package/src/migrations/types.d.ts +45 -0
- package/src/migrations/types.d.ts.map +1 -0
- package/src/migrations/types.js +1 -0
- 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 +2 -2
- package/src/node-singletons/fs.d.ts.map +1 -1
- package/src/node-singletons/fs.js +1 -1
- package/src/node-singletons/util.d.ts +6 -0
- package/src/node-singletons/util.d.ts.map +1 -0
- package/src/node-singletons/util.js +5 -0
- package/src/node.d.ts +3 -1
- package/src/node.d.ts.map +1 -1
- package/src/node.js +6 -2
- package/src/observability/OpenTelemetry.d.ts +62 -0
- package/src/observability/OpenTelemetry.d.ts.map +1 -0
- package/src/observability/OpenTelemetry.js +167 -0
- package/src/observability/PrometheusMetrics.d.ts +25 -0
- package/src/observability/PrometheusMetrics.d.ts.map +1 -0
- package/src/observability/PrometheusMetrics.js +114 -0
- package/src/openapi/OpenApiGenerator.d.ts +68 -0
- package/src/openapi/OpenApiGenerator.d.ts.map +1 -0
- package/src/openapi/OpenApiGenerator.js +287 -0
- package/src/orm/Database.d.ts +5 -2
- package/src/orm/Database.d.ts.map +1 -1
- package/src/orm/Database.js +219 -63
- package/src/orm/DatabaseAdapter.d.ts +14 -0
- package/src/orm/DatabaseAdapter.d.ts.map +1 -1
- package/src/orm/DatabaseAdapterRegistry.d.ts.map +1 -1
- package/src/orm/DatabaseAdapterRegistry.js +3 -1
- package/src/orm/DatabaseRuntimeRegistration.d.ts.map +1 -1
- package/src/orm/DatabaseRuntimeRegistration.js +12 -0
- package/src/orm/Model.d.ts +30 -2
- package/src/orm/Model.d.ts.map +1 -1
- package/src/orm/Model.js +255 -62
- package/src/orm/QueryBuilder.d.ts +22 -1
- package/src/orm/QueryBuilder.d.ts.map +1 -1
- package/src/orm/QueryBuilder.js +406 -99
- package/src/orm/Relationships.d.ts +7 -1
- package/src/orm/Relationships.d.ts.map +1 -1
- package/src/orm/Relationships.js +18 -0
- package/src/orm/SchemaCompiler.d.ts +9 -0
- package/src/orm/SchemaCompiler.d.ts.map +1 -0
- package/src/orm/SchemaCompiler.js +145 -0
- package/src/orm/adapters/D1Adapter.d.ts +1 -1
- package/src/orm/adapters/D1Adapter.d.ts.map +1 -1
- package/src/orm/adapters/MySQLAdapter.d.ts +1 -1
- package/src/orm/adapters/MySQLAdapter.d.ts.map +1 -1
- package/src/orm/adapters/MySQLAdapter.js +88 -69
- package/src/orm/adapters/PostgreSQLAdapter.d.ts +1 -1
- package/src/orm/adapters/PostgreSQLAdapter.d.ts.map +1 -1
- package/src/orm/adapters/PostgreSQLAdapter.js +88 -69
- package/src/orm/adapters/SQLServerAdapter.d.ts +1 -1
- package/src/orm/adapters/SQLServerAdapter.d.ts.map +1 -1
- package/src/orm/adapters/SQLiteAdapter.d.ts +1 -1
- package/src/orm/adapters/SQLiteAdapter.d.ts.map +1 -1
- package/src/orm/adapters/SQLiteAdapter.js +59 -3
- package/src/orm/maintenance/SqliteMaintenance.d.ts +5 -0
- package/src/orm/maintenance/SqliteMaintenance.d.ts.map +1 -0
- package/src/orm/maintenance/SqliteMaintenance.js +14 -0
- package/src/orm/migrations/MigrationStore.d.ts +38 -0
- package/src/orm/migrations/MigrationStore.d.ts.map +1 -0
- package/src/orm/migrations/MigrationStore.js +157 -0
- package/src/performance/CodeGenerationBenchmark.d.ts.map +1 -1
- package/src/performance/Optimizer.d.ts +7 -6
- package/src/performance/Optimizer.d.ts.map +1 -1
- package/src/performance/Optimizer.js +170 -55
- package/src/profiling/MemoryProfiler.d.ts +1 -1
- package/src/profiling/MemoryProfiler.d.ts.map +1 -1
- package/src/profiling/N1Detector.d.ts +1 -1
- package/src/profiling/N1Detector.d.ts.map +1 -1
- package/src/profiling/QueryLogger.d.ts +1 -1
- package/src/profiling/QueryLogger.d.ts.map +1 -1
- package/src/profiling/RequestProfiler.d.ts +3 -3
- package/src/profiling/RequestProfiler.d.ts.map +1 -1
- package/src/routes/metrics.d.ts +2 -0
- package/src/routes/metrics.d.ts.map +1 -0
- package/src/routes/metrics.js +1 -0
- package/src/routing/CoreRoutes.d.ts +12 -0
- package/src/routing/CoreRoutes.d.ts.map +1 -0
- package/src/routing/CoreRoutes.js +151 -0
- package/src/routing/RouteRegistry.d.ts +39 -0
- package/src/routing/RouteRegistry.d.ts.map +1 -0
- package/src/routing/RouteRegistry.js +44 -0
- package/src/routing/Router.d.ts +26 -9
- package/src/routing/Router.d.ts.map +1 -1
- package/src/routing/Router.js +79 -35
- package/src/routing/common.d.ts +15 -0
- package/src/routing/common.d.ts.map +1 -0
- package/src/routing/common.js +47 -0
- package/src/routing/doc.d.ts +27 -0
- package/src/routing/doc.d.ts.map +1 -0
- package/src/routing/doc.js +110 -0
- package/src/routing/error.d.ts +21 -0
- package/src/routing/error.d.ts.map +1 -0
- package/src/routing/error.js +126 -0
- package/src/routing/errorPages.d.ts +14 -0
- package/src/routing/errorPages.d.ts.map +1 -0
- package/src/routing/errorPages.js +103 -0
- package/src/routing/publicRoot.d.ts +27 -0
- package/src/routing/publicRoot.d.ts.map +1 -0
- package/src/routing/publicRoot.js +110 -0
- package/src/runtime/PluginAutoImports.d.ts +21 -0
- package/src/runtime/PluginAutoImports.d.ts.map +1 -0
- package/src/runtime/PluginAutoImports.js +59 -0
- package/src/runtime/PluginManager.d.ts +1 -5
- package/src/runtime/PluginManager.d.ts.map +1 -1
- package/src/runtime/PluginManager.js +25 -18
- package/src/runtime/RuntimeDetector.d.ts +1 -1
- package/src/runtime/RuntimeDetector.d.ts.map +1 -1
- package/src/runtime/StartupConfigFileRegistry.d.ts +20 -0
- package/src/runtime/StartupConfigFileRegistry.d.ts.map +1 -0
- package/src/runtime/StartupConfigFileRegistry.js +44 -0
- package/src/runtime/adapters/CloudflareAdapter.d.ts +1 -1
- package/src/runtime/adapters/CloudflareAdapter.d.ts.map +1 -1
- package/src/runtime/adapters/CloudflareAdapter.js +1 -1
- package/src/runtime/adapters/DenoAdapter.d.ts +1 -1
- package/src/runtime/adapters/DenoAdapter.d.ts.map +1 -1
- package/src/runtime/adapters/DenoAdapter.js +1 -1
- package/src/runtime/adapters/LambdaAdapter.d.ts +1 -1
- package/src/runtime/adapters/LambdaAdapter.d.ts.map +1 -1
- package/src/runtime/adapters/LambdaAdapter.js +1 -1
- package/src/runtime/adapters/NodeServerAdapter.d.ts +1 -1
- package/src/runtime/adapters/NodeServerAdapter.d.ts.map +1 -1
- package/src/runtime/getKernel.d.ts +9 -0
- package/src/runtime/getKernel.d.ts.map +1 -0
- package/src/runtime/getKernel.js +27 -0
- package/src/runtime/useFileLoader.d.ts +26 -0
- package/src/runtime/useFileLoader.d.ts.map +1 -0
- package/src/runtime/useFileLoader.js +188 -0
- package/src/scripts/TemplateImportsCheck.js +40 -0
- package/src/scripts/TemplateSync.js +90 -24
- package/src/security/Encryptor.d.ts.map +1 -1
- package/src/security/Encryptor.js +64 -7
- package/src/security/JwtManager.d.ts +1 -0
- package/src/security/JwtManager.d.ts.map +1 -1
- package/src/security/JwtManager.js +33 -0
- package/src/security/Sanitizer.d.ts +76 -0
- package/src/security/Sanitizer.d.ts.map +1 -0
- package/src/security/Sanitizer.js +412 -0
- package/src/security/TokenRevocation.d.ts +7 -0
- package/src/security/TokenRevocation.d.ts.map +1 -0
- package/src/security/TokenRevocation.js +57 -0
- package/src/security/XssProtection.d.ts.map +1 -1
- package/src/security/XssProtection.js +62 -14
- package/src/seeders/SeederDiscovery.d.ts +5 -0
- package/src/seeders/SeederDiscovery.d.ts.map +1 -0
- package/src/seeders/SeederDiscovery.js +21 -0
- package/src/seeders/SeederLoader.d.ts +5 -0
- package/src/seeders/SeederLoader.d.ts.map +1 -0
- package/src/seeders/SeederLoader.js +60 -0
- package/src/seeders/types.d.ts +18 -0
- package/src/seeders/types.d.ts.map +1 -0
- package/src/seeders/types.js +1 -0
- package/src/session/SessionManager.js +1 -1
- package/src/templates/adapters/MySQLAdapter.ts.tpl +109 -85
- package/src/templates/adapters/PostgreSQLAdapter.ts.tpl +129 -88
- package/src/templates/adapters/SQLServerAdapter.ts.tpl +5 -9
- package/src/templates/adapters/SQLiteAdapter.ts.tpl +78 -11
- package/src/templates/features/Queue.ts.tpl +3 -2
- package/src/templates/project/basic/app/Controllers/AuthController.ts.tpl +217 -0
- package/src/templates/project/basic/app/Controllers/UserController.ts.tpl +1 -12
- package/src/templates/project/basic/app/Types/controller.ts.tpl +46 -0
- package/src/templates/project/basic/config/FileLogWriter.ts.tpl +5 -236
- package/src/templates/project/basic/config/SecretsManager.ts.tpl +10 -447
- package/src/templates/project/basic/config/StartupConfigValidator.ts.tpl +9 -268
- package/src/templates/project/basic/config/app.ts.tpl +13 -153
- package/src/templates/project/basic/config/broadcast.ts.tpl +29 -126
- package/src/templates/project/basic/config/cache.ts.tpl +12 -70
- package/src/templates/project/basic/config/cloudflare.ts.tpl +4 -39
- package/src/templates/project/basic/config/constants.ts.tpl +9 -65
- package/src/templates/project/basic/config/database.ts.tpl +66 -123
- package/src/templates/project/basic/config/env.ts.tpl +5 -169
- package/src/templates/project/basic/config/features.ts.tpl +6 -54
- package/src/templates/project/basic/config/index.ts.tpl +8 -23
- package/src/templates/project/basic/config/logging/HttpLogger.ts.tpl +7 -114
- package/src/templates/project/basic/config/mail.ts.tpl +9 -62
- package/src/templates/project/basic/config/microservices.ts.tpl +11 -97
- package/src/templates/project/basic/config/middleware.ts.tpl +25 -43
- package/src/templates/project/basic/config/notification.ts.tpl +13 -114
- package/src/templates/project/basic/config/queue.ts.tpl +9 -40
- package/src/templates/project/basic/config/security.ts.tpl +11 -163
- package/src/templates/project/basic/config/startup.ts.tpl +10 -21
- package/src/templates/project/basic/config/storage.ts.tpl +57 -137
- package/src/templates/project/basic/config/type.ts.tpl +32 -451
- package/src/templates/project/basic/database/factories/UserFactory.ts.tpl +80 -0
- package/src/templates/project/basic/database/migrations/create_tasks_table.ts.tpl +28 -0
- package/src/templates/project/basic/database/migrations/create_users_table.ts.tpl +29 -0
- package/src/templates/project/basic/database/seeders/DatabaseSeeder.ts.tpl +19 -0
- package/src/templates/project/basic/database/seeders/UserSeeder.ts.tpl +18 -0
- package/src/templates/project/basic/database/seeders/index.ts.tpl +2 -0
- package/src/templates/project/basic/routes/api.ts.tpl +71 -33
- package/src/templates/project/basic/routes/metrics.ts.tpl +22 -0
- package/src/templates/project/basic/src/index.ts.tpl +3 -0
- package/src/templates/project/basic/tsconfig.json.tpl +12 -11
- package/src/testing/TestEnvironment.d.ts +40 -0
- package/src/testing/TestEnvironment.d.ts.map +1 -0
- package/src/testing/TestEnvironment.js +141 -0
- package/src/testing/TestHttp.d.ts +29 -0
- package/src/testing/TestHttp.d.ts.map +1 -0
- package/src/testing/TestHttp.js +96 -0
- package/src/testing/index.d.ts +5 -0
- package/src/testing/index.d.ts.map +1 -0
- package/src/testing/index.js +2 -0
- package/src/time/DateTime.d.ts +181 -0
- package/src/time/DateTime.d.ts.map +1 -0
- package/src/time/DateTime.js +300 -0
- package/src/time/index.d.ts +7 -0
- package/src/time/index.d.ts.map +1 -0
- package/src/time/index.js +5 -0
- package/src/tools/http/Http.d.ts.map +1 -1
- package/src/tools/http/Http.js +4 -0
- package/src/tools/mail/drivers/Smtp.js +1 -1
- package/src/tools/queue/drivers/InMemory.d.ts +1 -1
- package/src/tools/queue/drivers/InMemory.d.ts.map +1 -1
- package/src/tools/queue/drivers/InMemory.js +1 -1
- package/src/tools/queue/drivers/Redis.d.ts +1 -1
- package/src/tools/queue/drivers/Redis.d.ts.map +1 -1
- package/src/tools/queue/drivers/Redis.js +1 -1
- package/src/validation/ValidationError.d.ts.map +1 -1
- package/src/validation/ValidationError.js +4 -2
- package/src/validation/Validator.d.ts +49 -16
- package/src/validation/Validator.d.ts.map +1 -1
- package/src/validation/Validator.js +307 -5
- package/src/common/uuid.d.ts +0 -3
- package/src/common/uuid.d.ts.map +0 -1
- package/src/common/uuid.js +0 -30
- package/src/templates/project/basic/.env.example.tpl +0 -74
- package/src/templates/project/basic/.env.tpl +0 -166
- package/src/templates/project/basic/config/logging/KvLogger.ts.tpl +0 -181
- package/src/templates/project/basic/config/logging/SlackLogger.ts.tpl +0 -156
- package/src/templates/project/basic/database/migrations/index.ts.tpl +0 -2
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { Middleware } from './MiddlewareStack';
|
|
2
|
+
import type { ISchema, TypedSchema } from '../validation/Validator';
|
|
3
|
+
type FieldSanitizers = Readonly<Record<string, (value: unknown) => unknown>>;
|
|
4
|
+
export declare const ValidationMiddleware: Readonly<{
|
|
5
|
+
create(schema: ISchema): Middleware;
|
|
6
|
+
createBody<TSchema extends TypedSchema<unknown>>(schema: TSchema): Middleware;
|
|
7
|
+
createBodyWithSanitization<TSchema extends TypedSchema<unknown>>(schema: TSchema, sanitizers?: FieldSanitizers): Middleware;
|
|
8
|
+
createQuery<TSchema extends TypedSchema<unknown>>(schema: TSchema): Middleware;
|
|
9
|
+
createParams<TSchema extends TypedSchema<unknown>>(schema: TSchema): Middleware;
|
|
10
|
+
/**
|
|
11
|
+
* Create body validation middleware with bulletproof sanitization error handling.
|
|
12
|
+
* Automatically converts SanitizerError to 422 validation response.
|
|
13
|
+
* Recommended for authentication, user management, and financial operations.
|
|
14
|
+
*
|
|
15
|
+
* Use this when controllers apply Sanitizer methods with bulletproof=true (default).
|
|
16
|
+
* The middleware will catch SanitizerError and convert to proper validation error response.
|
|
17
|
+
*
|
|
18
|
+
* @param schema - Validation schema
|
|
19
|
+
* @param sanitizers - Optional field sanitizers to apply before validation
|
|
20
|
+
* @returns Middleware with bulletproof error handling
|
|
21
|
+
*/
|
|
22
|
+
createBodyWithBulletproofSanitization<TSchema extends TypedSchema<unknown>>(schema: TSchema, sanitizers?: FieldSanitizers): Middleware;
|
|
23
|
+
}>;
|
|
24
|
+
export {};
|
|
25
|
+
//# sourceMappingURL=ValidationMiddleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ValidationMiddleware.d.ts","sourceRoot":"","sources":["../../../src/middleware/ValidationMiddleware.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAE9D,OAAO,KAAK,EAAe,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAW/E,KAAK,eAAe,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC;AAqG7E,eAAO,MAAM,oBAAoB;mBAChB,OAAO,GAAG,UAAU;eAwBxB,OAAO,SAAS,WAAW,CAAC,OAAO,CAAC,UAAU,OAAO,GAAG,UAAU;+BA0BlD,OAAO,SAAS,WAAW,CAAC,OAAO,CAAC,UACrD,OAAO,eACF,eAAe,GAC3B,UAAU;gBA6BD,OAAO,SAAS,WAAW,CAAC,OAAO,CAAC,UAAU,OAAO,GAAG,UAAU;iBAejE,OAAO,SAAS,WAAW,CAAC,OAAO,CAAC,UAAU,OAAO,GAAG,UAAU;IAe/E;;;;;;;;;;;OAWG;0CACmC,OAAO,SAAS,WAAW,CAAC,OAAO,CAAC,UAChE,OAAO,eACF,eAAe,GAC3B,UAAU;EAqCb,CAAC"}
|
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
import { Env } from '../config/env.js';
|
|
2
|
+
import { Logger } from '../config/logger.js';
|
|
3
|
+
import { Xss } from '../security/Xss.js';
|
|
4
|
+
import { Validator } from '../validation/Validator.js';
|
|
5
|
+
const toRecord = (value) => {
|
|
6
|
+
if (typeof value !== 'object' || value === null)
|
|
7
|
+
return {};
|
|
8
|
+
if (Array.isArray(value))
|
|
9
|
+
return {};
|
|
10
|
+
return value;
|
|
11
|
+
};
|
|
12
|
+
const applyFieldSanitizers = (input, sanitizers) => {
|
|
13
|
+
if (sanitizers === undefined)
|
|
14
|
+
return input;
|
|
15
|
+
if (typeof input !== 'object' || input === null)
|
|
16
|
+
return input;
|
|
17
|
+
if (Array.isArray(input))
|
|
18
|
+
return input;
|
|
19
|
+
const record = input;
|
|
20
|
+
let changed = false;
|
|
21
|
+
const out = { ...record };
|
|
22
|
+
for (const [field, sanitizer] of Object.entries(sanitizers)) {
|
|
23
|
+
if (Object.prototype.hasOwnProperty.call(out, field) === false)
|
|
24
|
+
continue;
|
|
25
|
+
const before = out[field];
|
|
26
|
+
const after = sanitizer(before);
|
|
27
|
+
if (after !== before) {
|
|
28
|
+
out[field] = after;
|
|
29
|
+
changed = true;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return changed ? out : record;
|
|
33
|
+
};
|
|
34
|
+
const shouldLogValidationBody = () => {
|
|
35
|
+
if (Env.NODE_ENV === 'production')
|
|
36
|
+
return false;
|
|
37
|
+
return Env.getBool('ZIN_DEBUG_VALIDATION_BODY', false);
|
|
38
|
+
};
|
|
39
|
+
const safeCall = (fn) => {
|
|
40
|
+
try {
|
|
41
|
+
return fn?.();
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
return undefined;
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
const getContentType = (req) => {
|
|
48
|
+
const fromGetHeader = safeCall(() => req.getHeader?.('content-type'));
|
|
49
|
+
if (fromGetHeader !== undefined)
|
|
50
|
+
return fromGetHeader;
|
|
51
|
+
const fromHeaders = safeCall(() => req.getHeaders?.()['content-type']);
|
|
52
|
+
if (fromHeaders !== undefined)
|
|
53
|
+
return fromHeaders;
|
|
54
|
+
return req.headers?.['content-type'];
|
|
55
|
+
};
|
|
56
|
+
const logValidationBodyInput = (req, stage) => {
|
|
57
|
+
if (!shouldLogValidationBody())
|
|
58
|
+
return;
|
|
59
|
+
Logger.debug('[Validation] body input:', {
|
|
60
|
+
stage,
|
|
61
|
+
method: safeCall(() => req.getMethod()),
|
|
62
|
+
path: safeCall(() => req.getPath()),
|
|
63
|
+
contentType: getContentType(req),
|
|
64
|
+
rawBody: safeCall(() => (typeof req.getBody === 'function' ? req.getBody() : undefined)),
|
|
65
|
+
bodyRecord: req.body,
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
const toBodyRecord = (value) => toRecord(value);
|
|
69
|
+
const getBodyForValidation = (req) => {
|
|
70
|
+
const bodyRecord = toBodyRecord(req.body);
|
|
71
|
+
if (Object.keys(bodyRecord).length > 0)
|
|
72
|
+
return bodyRecord;
|
|
73
|
+
const raw = safeCall(() => req.getBody?.());
|
|
74
|
+
return toBodyRecord(raw);
|
|
75
|
+
};
|
|
76
|
+
const handleValidationError = (res, error) => {
|
|
77
|
+
// Temporary: log validation error details to help debugging failing requests.
|
|
78
|
+
// Remove this detailed debug logging once the issue is investigated.
|
|
79
|
+
Logger.warn('Validation failed');
|
|
80
|
+
try {
|
|
81
|
+
const err = error;
|
|
82
|
+
if (typeof err?.toObject === 'function') {
|
|
83
|
+
// Prefer structured debug output when available
|
|
84
|
+
try {
|
|
85
|
+
Logger.debug('[Validation] errors:', err.toObject());
|
|
86
|
+
}
|
|
87
|
+
catch {
|
|
88
|
+
// best-effort: fall back to direct log
|
|
89
|
+
Logger.debug('[Validation] errors (toObject threw):', err);
|
|
90
|
+
}
|
|
91
|
+
res.setStatus(422).json({ errors: err.toObject() });
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
// Fallback: log raw error
|
|
95
|
+
Logger.debug('[Validation] error:', err);
|
|
96
|
+
res.setStatus(400).json({ error: 'Invalid request body' });
|
|
97
|
+
}
|
|
98
|
+
catch (error_) {
|
|
99
|
+
// Ensure we don't throw while handling validation errors
|
|
100
|
+
Logger.debug('[Validation] failed to log error details:', error_);
|
|
101
|
+
res.setStatus(400).json({ error: 'Invalid request body' });
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
export const ValidationMiddleware = Object.freeze({
|
|
105
|
+
create(schema) {
|
|
106
|
+
return async (req, res, next) => {
|
|
107
|
+
const method = req.getMethod();
|
|
108
|
+
if (method === 'GET' || method === 'DELETE') {
|
|
109
|
+
await next();
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
try {
|
|
113
|
+
logValidationBodyInput(req, 'create:before-validate');
|
|
114
|
+
const bodyForValidation = getBodyForValidation(req);
|
|
115
|
+
if (Object.keys(bodyForValidation).length > 0 && Object.keys(req.body ?? {}).length === 0) {
|
|
116
|
+
safeCall(() => req.setBody?.(bodyForValidation));
|
|
117
|
+
}
|
|
118
|
+
Validator.validate(bodyForValidation, schema);
|
|
119
|
+
req.validated.body = bodyForValidation;
|
|
120
|
+
await next();
|
|
121
|
+
}
|
|
122
|
+
catch (error) {
|
|
123
|
+
handleValidationError(res, error);
|
|
124
|
+
}
|
|
125
|
+
};
|
|
126
|
+
},
|
|
127
|
+
createBody(schema) {
|
|
128
|
+
return async (req, res, next) => {
|
|
129
|
+
const method = req.getMethod();
|
|
130
|
+
if (method === 'GET' || method === 'DELETE') {
|
|
131
|
+
await next();
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
try {
|
|
135
|
+
logValidationBodyInput(req, 'createBody:before-validate');
|
|
136
|
+
const bodyForValidation = getBodyForValidation(req);
|
|
137
|
+
if (Object.keys(bodyForValidation).length > 0 && Object.keys(req.body ?? {}).length === 0) {
|
|
138
|
+
safeCall(() => req.setBody?.(bodyForValidation));
|
|
139
|
+
}
|
|
140
|
+
Validator.validate(bodyForValidation, schema);
|
|
141
|
+
req.validated.body = bodyForValidation;
|
|
142
|
+
await next();
|
|
143
|
+
}
|
|
144
|
+
catch (error) {
|
|
145
|
+
handleValidationError(res, error);
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
},
|
|
149
|
+
createBodyWithSanitization(schema, sanitizers) {
|
|
150
|
+
return async (req, res, next) => {
|
|
151
|
+
const method = req.getMethod();
|
|
152
|
+
if (method === 'GET' || method === 'DELETE') {
|
|
153
|
+
await next();
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
try {
|
|
157
|
+
const rawBody = req.getBody();
|
|
158
|
+
const xssSanitized = Xss.sanitize(rawBody ?? {});
|
|
159
|
+
const fieldSanitized = applyFieldSanitizers(xssSanitized, sanitizers);
|
|
160
|
+
const bodyForValidation = toBodyRecord(fieldSanitized);
|
|
161
|
+
safeCall(() => req.setBody?.(bodyForValidation));
|
|
162
|
+
logValidationBodyInput(req, 'createBodyWithSanitization:before-validate');
|
|
163
|
+
Validator.validate(bodyForValidation, schema);
|
|
164
|
+
req.validated.body = bodyForValidation;
|
|
165
|
+
await next();
|
|
166
|
+
}
|
|
167
|
+
catch (error) {
|
|
168
|
+
handleValidationError(res, error);
|
|
169
|
+
}
|
|
170
|
+
};
|
|
171
|
+
},
|
|
172
|
+
createQuery(schema) {
|
|
173
|
+
return async (req, res, next) => {
|
|
174
|
+
try {
|
|
175
|
+
const query = toRecord(req.getQuery());
|
|
176
|
+
Validator.validate(query, schema);
|
|
177
|
+
req.validated.query = query;
|
|
178
|
+
await next();
|
|
179
|
+
}
|
|
180
|
+
catch (error) {
|
|
181
|
+
handleValidationError(res, error);
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
},
|
|
185
|
+
createParams(schema) {
|
|
186
|
+
return async (req, res, next) => {
|
|
187
|
+
try {
|
|
188
|
+
const params = toRecord(req.getParams());
|
|
189
|
+
Validator.validate(params, schema);
|
|
190
|
+
req.validated.params = params;
|
|
191
|
+
await next();
|
|
192
|
+
}
|
|
193
|
+
catch (error) {
|
|
194
|
+
handleValidationError(res, error);
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
},
|
|
198
|
+
/**
|
|
199
|
+
* Create body validation middleware with bulletproof sanitization error handling.
|
|
200
|
+
* Automatically converts SanitizerError to 422 validation response.
|
|
201
|
+
* Recommended for authentication, user management, and financial operations.
|
|
202
|
+
*
|
|
203
|
+
* Use this when controllers apply Sanitizer methods with bulletproof=true (default).
|
|
204
|
+
* The middleware will catch SanitizerError and convert to proper validation error response.
|
|
205
|
+
*
|
|
206
|
+
* @param schema - Validation schema
|
|
207
|
+
* @param sanitizers - Optional field sanitizers to apply before validation
|
|
208
|
+
* @returns Middleware with bulletproof error handling
|
|
209
|
+
*/
|
|
210
|
+
createBodyWithBulletproofSanitization(schema, sanitizers) {
|
|
211
|
+
return async (req, res, next) => {
|
|
212
|
+
const method = req.getMethod();
|
|
213
|
+
if (method === 'GET' || method === 'DELETE') {
|
|
214
|
+
await next();
|
|
215
|
+
return;
|
|
216
|
+
}
|
|
217
|
+
try {
|
|
218
|
+
const rawBody = req.getBody();
|
|
219
|
+
const xssSanitized = Xss.sanitize(rawBody ?? {});
|
|
220
|
+
const fieldSanitized = applyFieldSanitizers(xssSanitized, sanitizers);
|
|
221
|
+
const bodyForValidation = toBodyRecord(fieldSanitized);
|
|
222
|
+
safeCall(() => req.setBody?.(bodyForValidation));
|
|
223
|
+
logValidationBodyInput(req, 'createBodyWithBulletproofSanitization:before-validate');
|
|
224
|
+
Validator.validate(bodyForValidation, schema);
|
|
225
|
+
req.validated.body = bodyForValidation;
|
|
226
|
+
await next();
|
|
227
|
+
}
|
|
228
|
+
catch (error) {
|
|
229
|
+
// Handle SanitizerError by converting to validation error format
|
|
230
|
+
if (isSanitizerError(error)) {
|
|
231
|
+
res.setStatus(422).json({
|
|
232
|
+
errors: {
|
|
233
|
+
sanitization: [error.message],
|
|
234
|
+
},
|
|
235
|
+
});
|
|
236
|
+
return;
|
|
237
|
+
}
|
|
238
|
+
handleValidationError(res, error);
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
},
|
|
242
|
+
});
|
|
243
|
+
/**
|
|
244
|
+
* Check if error is a SanitizerError
|
|
245
|
+
*/
|
|
246
|
+
function isSanitizerError(error) {
|
|
247
|
+
return (typeof error === 'object' &&
|
|
248
|
+
error !== null &&
|
|
249
|
+
'name' in error &&
|
|
250
|
+
error.name === 'SanitizerError');
|
|
251
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MigrationDiscovery.d.ts","sourceRoot":"","sources":["../../../src/migrations/MigrationDiscovery.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,kBAAkB;4BACL,MAAM,OAAO,MAAM,GAAG,MAAM;4BAI5B,MAAM,aAAa,MAAM,GAAG,MAAM,EAAE;EAQ5D,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import fs from '../node-singletons/fs.js';
|
|
2
|
+
import * as path from '../node-singletons/path.js';
|
|
3
|
+
export const MigrationDiscovery = Object.freeze({
|
|
4
|
+
resolveDir(projectRoot, dir) {
|
|
5
|
+
return path.resolve(projectRoot, dir);
|
|
6
|
+
},
|
|
7
|
+
listMigrationFiles(dir, extension) {
|
|
8
|
+
if (!fs.existsSync(dir))
|
|
9
|
+
return [];
|
|
10
|
+
const files = fs.readdirSync(dir);
|
|
11
|
+
return files
|
|
12
|
+
.filter((f) => f.endsWith(extension) && !f.startsWith('index.'))
|
|
13
|
+
.sort((a, b) => a.localeCompare(b))
|
|
14
|
+
.map((f) => path.join(dir, f));
|
|
15
|
+
},
|
|
16
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MigrationLoader.d.ts","sourceRoot":"","sources":["../../../src/migrations/MigrationLoader.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,eAAe,EAAqC,MAAM,oBAAoB,CAAC;AAwB7F,eAAO,MAAM,eAAe;mBACL,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC;EA4BtD,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { ErrorFactory } from '../exceptions/ZintrustError.js';
|
|
2
|
+
import * as path from '../node-singletons/path.js';
|
|
3
|
+
import { pathToFileURL } from 'node:url';
|
|
4
|
+
function isFunction(value) {
|
|
5
|
+
return typeof value === 'function';
|
|
6
|
+
}
|
|
7
|
+
function normalizeHandler(fn, label) {
|
|
8
|
+
if (!isFunction(fn)) {
|
|
9
|
+
throw ErrorFactory.createValidationError(`Invalid migration export: expected function for ${label}`);
|
|
10
|
+
}
|
|
11
|
+
return async (db) => {
|
|
12
|
+
// Support both (db) => Promise<void> and () => Promise<void>.
|
|
13
|
+
if (fn.length <= 0) {
|
|
14
|
+
await Promise.resolve(fn());
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
await Promise.resolve(fn(db));
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export const MigrationLoader = Object.freeze({
|
|
21
|
+
async load(filePath) {
|
|
22
|
+
const url = pathToFileURL(filePath).href;
|
|
23
|
+
const raw = (await import(url));
|
|
24
|
+
// Some tooling/transpilation paths wrap exports under `default`.
|
|
25
|
+
// Prefer direct named exports, but fall back to default export if present.
|
|
26
|
+
const mod = (raw ?? {});
|
|
27
|
+
const fallback = (mod.default ?? {});
|
|
28
|
+
const up = mod.migration?.up ?? mod.up ?? fallback.migration?.up ?? fallback.up;
|
|
29
|
+
const down = mod.migration?.down ?? mod.down ?? fallback.migration?.down ?? fallback.down;
|
|
30
|
+
if (up === undefined) {
|
|
31
|
+
throw ErrorFactory.createValidationError(`Migration '${filePath}' is missing an 'up' export`);
|
|
32
|
+
}
|
|
33
|
+
if (down === undefined) {
|
|
34
|
+
throw ErrorFactory.createValidationError(`Migration '${filePath}' is missing a 'down' export`);
|
|
35
|
+
}
|
|
36
|
+
return {
|
|
37
|
+
name: path.basename(filePath, path.extname(filePath)),
|
|
38
|
+
filePath,
|
|
39
|
+
up: normalizeHandler(up, 'up'),
|
|
40
|
+
down: normalizeHandler(down, 'down'),
|
|
41
|
+
};
|
|
42
|
+
},
|
|
43
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MigrationLock.d.ts","sourceRoot":"","sources":["../../../src/migrations/MigrationLock.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,aAAa;sBACN,MAAM,GAAG,MAAM,IAAI;EAgCrC,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { ErrorFactory } from '../exceptions/ZintrustError.js';
|
|
2
|
+
import fs from '../node-singletons/fs.js';
|
|
3
|
+
import * as path from '../node-singletons/path.js';
|
|
4
|
+
function nowIso() {
|
|
5
|
+
return new Date().toISOString();
|
|
6
|
+
}
|
|
7
|
+
export const MigrationLock = Object.freeze({
|
|
8
|
+
acquire(lockFile) {
|
|
9
|
+
fs.mkdirSync(path.dirname(lockFile), { recursive: true });
|
|
10
|
+
try {
|
|
11
|
+
const fd = fs.openSync(lockFile, 'wx');
|
|
12
|
+
fs.writeFileSync(fd, JSON.stringify({ pid: process.pid, createdAt: nowIso() }, null, 2), 'utf8');
|
|
13
|
+
fs.closeSync(fd);
|
|
14
|
+
return () => {
|
|
15
|
+
try {
|
|
16
|
+
fs.unlinkSync(lockFile);
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
// ignore
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
if (typeof error === 'object' && error !== null && 'code' in error) {
|
|
25
|
+
const code = error.code;
|
|
26
|
+
if (code === 'EEXIST') {
|
|
27
|
+
throw ErrorFactory.createCliError(`Migration lock already exists at ${lockFile}. Another migrate may be running.`);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
throw ErrorFactory.createTryCatchError('Failed to acquire migration lock', { cause: error });
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
});
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export type { LoadedMigration, MigrationHandler, MigrationModule, MigrationRecord, MigrationRecordStatus, MigrationScope, MigratorOptions, MigratorStatusRow, } from '../migrations/types';
|
|
2
|
+
export declare const Migrator: Readonly<{
|
|
3
|
+
create: (options: import("../migrations/types").MigratorOptions) => {
|
|
4
|
+
status(): Promise<import("../migrations/types").MigratorStatusRow[]>;
|
|
5
|
+
migrate(): Promise<{
|
|
6
|
+
applied: number;
|
|
7
|
+
pending: number;
|
|
8
|
+
appliedNames: string[];
|
|
9
|
+
}>;
|
|
10
|
+
rollbackLastBatch(steps: number): Promise<{
|
|
11
|
+
rolledBack: number;
|
|
12
|
+
}>;
|
|
13
|
+
resetAll(): Promise<{
|
|
14
|
+
rolledBack: number;
|
|
15
|
+
}>;
|
|
16
|
+
fresh(): Promise<{
|
|
17
|
+
applied: number;
|
|
18
|
+
pending: number;
|
|
19
|
+
appliedNames: string[];
|
|
20
|
+
}>;
|
|
21
|
+
};
|
|
22
|
+
}>;
|
|
23
|
+
//# sourceMappingURL=Migrator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Migrator.d.ts","sourceRoot":"","sources":["../../../src/migrations/Migrator.ts"],"names":[],"mappings":"AAEA,YAAY,EACV,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,eAAe,EACf,qBAAqB,EACrB,cAAc,EACd,eAAe,EACf,iBAAiB,GAClB,MAAM,oBAAoB,CAAC;AAE5B,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;EAEnB,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { MigratorOptions, MigratorStatusRow } from '../migrations/types';
|
|
2
|
+
type MigratorApi = {
|
|
3
|
+
status(): Promise<MigratorStatusRow[]>;
|
|
4
|
+
migrate(): Promise<{
|
|
5
|
+
applied: number;
|
|
6
|
+
pending: number;
|
|
7
|
+
appliedNames: string[];
|
|
8
|
+
}>;
|
|
9
|
+
rollbackLastBatch(steps: number): Promise<{
|
|
10
|
+
rolledBack: number;
|
|
11
|
+
}>;
|
|
12
|
+
resetAll(): Promise<{
|
|
13
|
+
rolledBack: number;
|
|
14
|
+
}>;
|
|
15
|
+
fresh(): Promise<{
|
|
16
|
+
applied: number;
|
|
17
|
+
pending: number;
|
|
18
|
+
appliedNames: string[];
|
|
19
|
+
}>;
|
|
20
|
+
};
|
|
21
|
+
export declare const MigratorFactory: Readonly<{
|
|
22
|
+
create(options: MigratorOptions): MigratorApi;
|
|
23
|
+
}>;
|
|
24
|
+
export {};
|
|
25
|
+
//# sourceMappingURL=MigratorFactory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MigratorFactory.d.ts","sourceRoot":"","sources":["../../../src/migrations/MigratorFactory.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAIV,eAAe,EACf,iBAAiB,EAClB,MAAM,oBAAoB,CAAC;AAU5B,KAAK,WAAW,GAAG;IACjB,MAAM,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC,CAAC;IACvC,OAAO,IAAI,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IACjF,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAClE,QAAQ,IAAI,OAAO,CAAC;QAAE,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC5C,KAAK,IAAI,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;CAChF,CAAC;AA8aF,eAAO,MAAM,eAAe;oBACV,eAAe,GAAG,WAAW;EAW7C,CAAC"}
|