@alpha.consultings/eloquent-orm.js 1.0.1
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/CHANGELOG.md +73 -0
- package/README.md +215 -0
- package/dist/Model.d.ts +2 -0
- package/dist/Model.d.ts.map +1 -0
- package/dist/Model.js +7 -0
- package/dist/Model.js.map +1 -0
- package/dist/cli/commands/cacheClear.d.ts +2 -0
- package/dist/cli/commands/cacheClear.d.ts.map +1 -0
- package/dist/cli/commands/cacheClear.js +69 -0
- package/dist/cli/commands/cacheClear.js.map +1 -0
- package/dist/cli/commands/cacheStats.d.ts +2 -0
- package/dist/cli/commands/cacheStats.d.ts.map +1 -0
- package/dist/cli/commands/cacheStats.js +55 -0
- package/dist/cli/commands/cacheStats.js.map +1 -0
- package/dist/cli/commands/dbSeed.d.ts +16 -0
- package/dist/cli/commands/dbSeed.d.ts.map +1 -0
- package/dist/cli/commands/dbSeed.js +201 -0
- package/dist/cli/commands/dbSeed.js.map +1 -0
- package/dist/cli/commands/dbSeedBootstrapPrecheck.d.ts +3 -0
- package/dist/cli/commands/dbSeedBootstrapPrecheck.d.ts.map +1 -0
- package/dist/cli/commands/dbSeedBootstrapPrecheck.js +8 -0
- package/dist/cli/commands/dbSeedBootstrapPrecheck.js.map +1 -0
- package/dist/cli/commands/dbSeedFresh.d.ts +14 -0
- package/dist/cli/commands/dbSeedFresh.d.ts.map +1 -0
- package/dist/cli/commands/dbSeedFresh.js +81 -0
- package/dist/cli/commands/dbSeedFresh.js.map +1 -0
- package/dist/cli/commands/demoScenario.d.ts +9 -0
- package/dist/cli/commands/demoScenario.d.ts.map +1 -0
- package/dist/cli/commands/demoScenario.js +185 -0
- package/dist/cli/commands/demoScenario.js.map +1 -0
- package/dist/cli/commands/factoryStatus.d.ts +9 -0
- package/dist/cli/commands/factoryStatus.d.ts.map +1 -0
- package/dist/cli/commands/factoryStatus.js +103 -0
- package/dist/cli/commands/factoryStatus.js.map +1 -0
- package/dist/cli/commands/makeController.d.ts +11 -0
- package/dist/cli/commands/makeController.d.ts.map +1 -0
- package/dist/cli/commands/makeController.js +61 -0
- package/dist/cli/commands/makeController.js.map +1 -0
- package/dist/cli/commands/makeFactory.d.ts +14 -0
- package/dist/cli/commands/makeFactory.d.ts.map +1 -0
- package/dist/cli/commands/makeFactory.js +183 -0
- package/dist/cli/commands/makeFactory.js.map +1 -0
- package/dist/cli/commands/makeMigration.d.ts +18 -0
- package/dist/cli/commands/makeMigration.d.ts.map +1 -0
- package/dist/cli/commands/makeMigration.js +496 -0
- package/dist/cli/commands/makeMigration.js.map +1 -0
- package/dist/cli/commands/makeModel.d.ts +20 -0
- package/dist/cli/commands/makeModel.d.ts.map +1 -0
- package/dist/cli/commands/makeModel.js +360 -0
- package/dist/cli/commands/makeModel.js.map +1 -0
- package/dist/cli/commands/makeRegistry.d.ts +7 -0
- package/dist/cli/commands/makeRegistry.d.ts.map +1 -0
- package/dist/cli/commands/makeRegistry.js +88 -0
- package/dist/cli/commands/makeRegistry.js.map +1 -0
- package/dist/cli/commands/makeScenario.d.ts +12 -0
- package/dist/cli/commands/makeScenario.d.ts.map +1 -0
- package/dist/cli/commands/makeScenario.js +639 -0
- package/dist/cli/commands/makeScenario.js.map +1 -0
- package/dist/cli/commands/makeSeed.d.ts +11 -0
- package/dist/cli/commands/makeSeed.d.ts.map +1 -0
- package/dist/cli/commands/makeSeed.js +47 -0
- package/dist/cli/commands/makeSeed.js.map +1 -0
- package/dist/cli/commands/makeService.d.ts +5 -0
- package/dist/cli/commands/makeService.d.ts.map +1 -0
- package/dist/cli/commands/makeService.js +31 -0
- package/dist/cli/commands/makeService.js.map +1 -0
- package/dist/cli/commands/migrateFresh.d.ts +14 -0
- package/dist/cli/commands/migrateFresh.d.ts.map +1 -0
- package/dist/cli/commands/migrateFresh.js +150 -0
- package/dist/cli/commands/migrateFresh.js.map +1 -0
- package/dist/cli/commands/migrateReset.d.ts +12 -0
- package/dist/cli/commands/migrateReset.d.ts.map +1 -0
- package/dist/cli/commands/migrateReset.js +28 -0
- package/dist/cli/commands/migrateReset.js.map +1 -0
- package/dist/cli/commands/migrateRollback.d.ts +10 -0
- package/dist/cli/commands/migrateRollback.d.ts.map +1 -0
- package/dist/cli/commands/migrateRollback.js +303 -0
- package/dist/cli/commands/migrateRollback.js.map +1 -0
- package/dist/cli/commands/migrateRun.d.ts +10 -0
- package/dist/cli/commands/migrateRun.d.ts.map +1 -0
- package/dist/cli/commands/migrateRun.js +301 -0
- package/dist/cli/commands/migrateRun.js.map +1 -0
- package/dist/cli/commands/migrateStatus.d.ts +8 -0
- package/dist/cli/commands/migrateStatus.d.ts.map +1 -0
- package/dist/cli/commands/migrateStatus.js +118 -0
- package/dist/cli/commands/migrateStatus.js.map +1 -0
- package/dist/cli/eloquent.d.ts +18 -0
- package/dist/cli/eloquent.d.ts.map +1 -0
- package/dist/cli/eloquent.js +187 -0
- package/dist/cli/eloquent.js.map +1 -0
- package/dist/cli/utils/ArtifactCompatibility.d.ts +10 -0
- package/dist/cli/utils/ArtifactCompatibility.d.ts.map +1 -0
- package/dist/cli/utils/ArtifactCompatibility.js +60 -0
- package/dist/cli/utils/ArtifactCompatibility.js.map +1 -0
- package/dist/cli/utils/ArtifactRoutingReport.d.ts +10 -0
- package/dist/cli/utils/ArtifactRoutingReport.d.ts.map +1 -0
- package/dist/cli/utils/ArtifactRoutingReport.js +25 -0
- package/dist/cli/utils/ArtifactRoutingReport.js.map +1 -0
- package/dist/cli/utils/ArtifactStorage.d.ts +10 -0
- package/dist/cli/utils/ArtifactStorage.d.ts.map +1 -0
- package/dist/cli/utils/ArtifactStorage.js +193 -0
- package/dist/cli/utils/ArtifactStorage.js.map +1 -0
- package/dist/cli/utils/AuditTrail.d.ts +25 -0
- package/dist/cli/utils/AuditTrail.d.ts.map +1 -0
- package/dist/cli/utils/AuditTrail.js +74 -0
- package/dist/cli/utils/AuditTrail.js.map +1 -0
- package/dist/cli/utils/CliActionRuntime.d.ts +5 -0
- package/dist/cli/utils/CliActionRuntime.d.ts.map +1 -0
- package/dist/cli/utils/CliActionRuntime.js +22 -0
- package/dist/cli/utils/CliActionRuntime.js.map +1 -0
- package/dist/cli/utils/CliBootstrapSupport.d.ts +13 -0
- package/dist/cli/utils/CliBootstrapSupport.d.ts.map +1 -0
- package/dist/cli/utils/CliBootstrapSupport.js +55 -0
- package/dist/cli/utils/CliBootstrapSupport.js.map +1 -0
- package/dist/cli/utils/CliCommandCatalog.d.ts +6 -0
- package/dist/cli/utils/CliCommandCatalog.d.ts.map +1 -0
- package/dist/cli/utils/CliCommandCatalog.js +78 -0
- package/dist/cli/utils/CliCommandCatalog.js.map +1 -0
- package/dist/cli/utils/CliCommandTargets.d.ts +8 -0
- package/dist/cli/utils/CliCommandTargets.d.ts.map +1 -0
- package/dist/cli/utils/CliCommandTargets.js +19 -0
- package/dist/cli/utils/CliCommandTargets.js.map +1 -0
- package/dist/cli/utils/CliMakeArtifactCommandRegistration.d.ts +3 -0
- package/dist/cli/utils/CliMakeArtifactCommandRegistration.d.ts.map +1 -0
- package/dist/cli/utils/CliMakeArtifactCommandRegistration.js +94 -0
- package/dist/cli/utils/CliMakeArtifactCommandRegistration.js.map +1 -0
- package/dist/cli/utils/CliMigrationCommandRegistration.d.ts +3 -0
- package/dist/cli/utils/CliMigrationCommandRegistration.d.ts.map +1 -0
- package/dist/cli/utils/CliMigrationCommandRegistration.js +195 -0
- package/dist/cli/utils/CliMigrationCommandRegistration.js.map +1 -0
- package/dist/cli/utils/CliPresentation.d.ts +2 -0
- package/dist/cli/utils/CliPresentation.d.ts.map +1 -0
- package/dist/cli/utils/CliPresentation.js +13 -0
- package/dist/cli/utils/CliPresentation.js.map +1 -0
- package/dist/cli/utils/CliProductionGuards.d.ts +11 -0
- package/dist/cli/utils/CliProductionGuards.d.ts.map +1 -0
- package/dist/cli/utils/CliProductionGuards.js +34 -0
- package/dist/cli/utils/CliProductionGuards.js.map +1 -0
- package/dist/cli/utils/CliScaffoldCommandRegistration.d.ts +3 -0
- package/dist/cli/utils/CliScaffoldCommandRegistration.d.ts.map +1 -0
- package/dist/cli/utils/CliScaffoldCommandRegistration.js +89 -0
- package/dist/cli/utils/CliScaffoldCommandRegistration.js.map +1 -0
- package/dist/cli/utils/CliSeedScenarioCommandRegistration.d.ts +3 -0
- package/dist/cli/utils/CliSeedScenarioCommandRegistration.d.ts.map +1 -0
- package/dist/cli/utils/CliSeedScenarioCommandRegistration.js +123 -0
- package/dist/cli/utils/CliSeedScenarioCommandRegistration.js.map +1 -0
- package/dist/cli/utils/CliSupportCommandRegistration.d.ts +3 -0
- package/dist/cli/utils/CliSupportCommandRegistration.d.ts.map +1 -0
- package/dist/cli/utils/CliSupportCommandRegistration.js +44 -0
- package/dist/cli/utils/CliSupportCommandRegistration.js.map +1 -0
- package/dist/cli/utils/ConsoleSilencer.d.ts +6 -0
- package/dist/cli/utils/ConsoleSilencer.d.ts.map +1 -0
- package/dist/cli/utils/ConsoleSilencer.js +25 -0
- package/dist/cli/utils/ConsoleSilencer.js.map +1 -0
- package/dist/cli/utils/ImportResolver.d.ts +16 -0
- package/dist/cli/utils/ImportResolver.d.ts.map +1 -0
- package/dist/cli/utils/ImportResolver.js +57 -0
- package/dist/cli/utils/ImportResolver.js.map +1 -0
- package/dist/cli/utils/ModelIntrospector.d.ts +33 -0
- package/dist/cli/utils/ModelIntrospector.d.ts.map +1 -0
- package/dist/cli/utils/ModelIntrospector.js +76 -0
- package/dist/cli/utils/ModelIntrospector.js.map +1 -0
- package/dist/cli/utils/PathMap.d.ts +58 -0
- package/dist/cli/utils/PathMap.d.ts.map +1 -0
- package/dist/cli/utils/PathMap.js +132 -0
- package/dist/cli/utils/PathMap.js.map +1 -0
- package/dist/cli/utils/ProductionSafety.d.ts +25 -0
- package/dist/cli/utils/ProductionSafety.d.ts.map +1 -0
- package/dist/cli/utils/ProductionSafety.js +61 -0
- package/dist/cli/utils/ProductionSafety.js.map +1 -0
- package/dist/cli/utils/ScaffoldGeneratorSupport.d.ts +16 -0
- package/dist/cli/utils/ScaffoldGeneratorSupport.d.ts.map +1 -0
- package/dist/cli/utils/ScaffoldGeneratorSupport.js +66 -0
- package/dist/cli/utils/ScaffoldGeneratorSupport.js.map +1 -0
- package/dist/cli/utils/ScenarioMorphAliasRouting.d.ts +14 -0
- package/dist/cli/utils/ScenarioMorphAliasRouting.d.ts.map +1 -0
- package/dist/cli/utils/ScenarioMorphAliasRouting.js +62 -0
- package/dist/cli/utils/ScenarioMorphAliasRouting.js.map +1 -0
- package/dist/cli/utils/SeedBootstrapPrecheck.d.ts +20 -0
- package/dist/cli/utils/SeedBootstrapPrecheck.d.ts.map +1 -0
- package/dist/cli/utils/SeedBootstrapPrecheck.js +133 -0
- package/dist/cli/utils/SeedBootstrapPrecheck.js.map +1 -0
- package/dist/cli/utils/StructuredLogger.d.ts +11 -0
- package/dist/cli/utils/StructuredLogger.d.ts.map +1 -0
- package/dist/cli/utils/StructuredLogger.js +53 -0
- package/dist/cli/utils/StructuredLogger.js.map +1 -0
- package/dist/cli/utils/TemplateEngine.d.ts +30 -0
- package/dist/cli/utils/TemplateEngine.d.ts.map +1 -0
- package/dist/cli/utils/TemplateEngine.js +165 -0
- package/dist/cli/utils/TemplateEngine.js.map +1 -0
- package/dist/cli/utils/factories/Factory.d.ts +61 -0
- package/dist/cli/utils/factories/Factory.d.ts.map +1 -0
- package/dist/cli/utils/factories/Factory.js +140 -0
- package/dist/cli/utils/factories/Factory.js.map +1 -0
- package/dist/cli/utils/factories/FactoryDisplay.d.ts +6 -0
- package/dist/cli/utils/factories/FactoryDisplay.d.ts.map +1 -0
- package/dist/cli/utils/factories/FactoryDisplay.js +26 -0
- package/dist/cli/utils/factories/FactoryDisplay.js.map +1 -0
- package/dist/cli/utils/factories/FactoryGraph.d.ts +6 -0
- package/dist/cli/utils/factories/FactoryGraph.d.ts.map +1 -0
- package/dist/cli/utils/factories/FactoryGraph.js +72 -0
- package/dist/cli/utils/factories/FactoryGraph.js.map +1 -0
- package/dist/cli/utils/factories/FactoryLoader.d.ts +16 -0
- package/dist/cli/utils/factories/FactoryLoader.d.ts.map +1 -0
- package/dist/cli/utils/factories/FactoryLoader.js +35 -0
- package/dist/cli/utils/factories/FactoryLoader.js.map +1 -0
- package/dist/cli/utils/factories/FactoryRegistry.d.ts +16 -0
- package/dist/cli/utils/factories/FactoryRegistry.d.ts.map +1 -0
- package/dist/cli/utils/factories/FactoryRegistry.js +87 -0
- package/dist/cli/utils/factories/FactoryRegistry.js.map +1 -0
- package/dist/cli/utils/fileWriter.d.ts +7 -0
- package/dist/cli/utils/fileWriter.d.ts.map +1 -0
- package/dist/cli/utils/fileWriter.js +61 -0
- package/dist/cli/utils/fileWriter.js.map +1 -0
- package/dist/cli/utils/migrations/MigrationLockStrategy.d.ts +21 -0
- package/dist/cli/utils/migrations/MigrationLockStrategy.d.ts.map +1 -0
- package/dist/cli/utils/migrations/MigrationLockStrategy.js +129 -0
- package/dist/cli/utils/migrations/MigrationLockStrategy.js.map +1 -0
- package/dist/cli/utils/migrations/MigrationTracker.d.ts +25 -0
- package/dist/cli/utils/migrations/MigrationTracker.d.ts.map +1 -0
- package/dist/cli/utils/migrations/MigrationTracker.js +279 -0
- package/dist/cli/utils/migrations/MigrationTracker.js.map +1 -0
- package/dist/cli/utils/migrations/MongoMigrationTracker.d.ts +18 -0
- package/dist/cli/utils/migrations/MongoMigrationTracker.d.ts.map +1 -0
- package/dist/cli/utils/migrations/MongoMigrationTracker.js +276 -0
- package/dist/cli/utils/migrations/MongoMigrationTracker.js.map +1 -0
- package/dist/cli/utils/resolveConnectionFlags.d.ts +14 -0
- package/dist/cli/utils/resolveConnectionFlags.d.ts.map +1 -0
- package/dist/cli/utils/resolveConnectionFlags.js +42 -0
- package/dist/cli/utils/resolveConnectionFlags.js.map +1 -0
- package/dist/cli/utils/resolveSqlConnectionFlags.d.ts +9 -0
- package/dist/cli/utils/resolveSqlConnectionFlags.d.ts.map +1 -0
- package/dist/cli/utils/resolveSqlConnectionFlags.js +23 -0
- package/dist/cli/utils/resolveSqlConnectionFlags.js.map +1 -0
- package/dist/cli/utils/typescript/BaseCommand.d.ts +15 -0
- package/dist/cli/utils/typescript/BaseCommand.d.ts.map +1 -0
- package/dist/cli/utils/typescript/BaseCommand.js +36 -0
- package/dist/cli/utils/typescript/BaseCommand.js.map +1 -0
- package/dist/cli/utils/typescript/RuntimeDetector.d.ts +16 -0
- package/dist/cli/utils/typescript/RuntimeDetector.d.ts.map +1 -0
- package/dist/cli/utils/typescript/RuntimeDetector.js +45 -0
- package/dist/cli/utils/typescript/RuntimeDetector.js.map +1 -0
- package/dist/cli/utils/typescript/TypeScriptCompiler.d.ts +25 -0
- package/dist/cli/utils/typescript/TypeScriptCompiler.d.ts.map +1 -0
- package/dist/cli/utils/typescript/TypeScriptCompiler.js +109 -0
- package/dist/cli/utils/typescript/TypeScriptCompiler.js.map +1 -0
- package/dist/cli/utils/typescript/tsRuntime.d.ts +12 -0
- package/dist/cli/utils/typescript/tsRuntime.d.ts.map +1 -0
- package/dist/cli/utils/typescript/tsRuntime.js +189 -0
- package/dist/cli/utils/typescript/tsRuntime.js.map +1 -0
- package/dist/config/database.d.ts +58 -0
- package/dist/config/database.d.ts.map +1 -0
- package/dist/config/database.js +106 -0
- package/dist/config/database.js.map +1 -0
- package/dist/config/dbRoleEnv.d.ts +31 -0
- package/dist/config/dbRoleEnv.d.ts.map +1 -0
- package/dist/config/dbRoleEnv.js +171 -0
- package/dist/config/dbRoleEnv.js.map +1 -0
- package/dist/core/cache/CacheAnalytics.d.ts +47 -0
- package/dist/core/cache/CacheAnalytics.d.ts.map +1 -0
- package/dist/core/cache/CacheAnalytics.js +113 -0
- package/dist/core/cache/CacheAnalytics.js.map +1 -0
- package/dist/core/cache/CacheDriver.d.ts +19 -0
- package/dist/core/cache/CacheDriver.d.ts.map +1 -0
- package/dist/core/cache/CacheDriver.js +8 -0
- package/dist/core/cache/CacheDriver.js.map +1 -0
- package/dist/core/cache/CacheFallbackManager.d.ts +35 -0
- package/dist/core/cache/CacheFallbackManager.d.ts.map +1 -0
- package/dist/core/cache/CacheFallbackManager.js +118 -0
- package/dist/core/cache/CacheFallbackManager.js.map +1 -0
- package/dist/core/cache/CacheManager.d.ts +11 -0
- package/dist/core/cache/CacheManager.d.ts.map +1 -0
- package/dist/core/cache/CacheManager.js +27 -0
- package/dist/core/cache/CacheManager.js.map +1 -0
- package/dist/core/cache/CacheRegistry.d.ts +49 -0
- package/dist/core/cache/CacheRegistry.d.ts.map +1 -0
- package/dist/core/cache/CacheRegistry.js +117 -0
- package/dist/core/cache/CacheRegistry.js.map +1 -0
- package/dist/core/cache/drivers/FileCacheDriver.d.ts +11 -0
- package/dist/core/cache/drivers/FileCacheDriver.d.ts.map +1 -0
- package/dist/core/cache/drivers/FileCacheDriver.js +54 -0
- package/dist/core/cache/drivers/FileCacheDriver.js.map +1 -0
- package/dist/core/cache/drivers/MemcachedCacheDriver.d.ts +15 -0
- package/dist/core/cache/drivers/MemcachedCacheDriver.d.ts.map +1 -0
- package/dist/core/cache/drivers/MemcachedCacheDriver.js +60 -0
- package/dist/core/cache/drivers/MemcachedCacheDriver.js.map +1 -0
- package/dist/core/cache/drivers/MemoryCacheDriver.d.ts +9 -0
- package/dist/core/cache/drivers/MemoryCacheDriver.d.ts.map +1 -0
- package/dist/core/cache/drivers/MemoryCacheDriver.js +33 -0
- package/dist/core/cache/drivers/MemoryCacheDriver.js.map +1 -0
- package/dist/core/cache/setupCache.d.ts +2 -0
- package/dist/core/cache/setupCache.d.ts.map +1 -0
- package/dist/core/cache/setupCache.js +38 -0
- package/dist/core/cache/setupCache.js.map +1 -0
- package/dist/core/connection/BetterSqliteConnection.d.ts +23 -0
- package/dist/core/connection/BetterSqliteConnection.d.ts.map +1 -0
- package/dist/core/connection/BetterSqliteConnection.js +33 -0
- package/dist/core/connection/BetterSqliteConnection.js.map +1 -0
- package/dist/core/connection/ConnectionFactory.d.ts +18 -0
- package/dist/core/connection/ConnectionFactory.d.ts.map +1 -0
- package/dist/core/connection/ConnectionFactory.js +111 -0
- package/dist/core/connection/ConnectionFactory.js.map +1 -0
- package/dist/core/connection/DatabaseConnection.d.ts +49 -0
- package/dist/core/connection/DatabaseConnection.d.ts.map +1 -0
- package/dist/core/connection/DatabaseConnection.js +120 -0
- package/dist/core/connection/DatabaseConnection.js.map +1 -0
- package/dist/core/connection/DriverAdapter.d.ts +23 -0
- package/dist/core/connection/DriverAdapter.d.ts.map +1 -0
- package/dist/core/connection/DriverAdapter.js +145 -0
- package/dist/core/connection/DriverAdapter.js.map +1 -0
- package/dist/core/connection/resolveConnectionName.d.ts +17 -0
- package/dist/core/connection/resolveConnectionName.d.ts.map +1 -0
- package/dist/core/connection/resolveConnectionName.js +47 -0
- package/dist/core/connection/resolveConnectionName.js.map +1 -0
- package/dist/core/model/BaseModel.d.ts +247 -0
- package/dist/core/model/BaseModel.d.ts.map +1 -0
- package/dist/core/model/BaseModel.js +165 -0
- package/dist/core/model/BaseModel.js.map +1 -0
- package/dist/core/model/BaseModelSafeFinderStatics.d.ts +33 -0
- package/dist/core/model/BaseModelSafeFinderStatics.d.ts.map +1 -0
- package/dist/core/model/BaseModelSafeFinderStatics.js +87 -0
- package/dist/core/model/BaseModelSafeFinderStatics.js.map +1 -0
- package/dist/core/model/CoreModel.d.ts +134 -0
- package/dist/core/model/CoreModel.d.ts.map +1 -0
- package/dist/core/model/CoreModel.js +541 -0
- package/dist/core/model/CoreModel.js.map +1 -0
- package/dist/core/model/CoreModelPersistenceState.d.ts +36 -0
- package/dist/core/model/CoreModelPersistenceState.d.ts.map +1 -0
- package/dist/core/model/CoreModelPersistenceState.js +141 -0
- package/dist/core/model/CoreModelPersistenceState.js.map +1 -0
- package/dist/core/model/CoreModelSafeFinderSupport.d.ts +5 -0
- package/dist/core/model/CoreModelSafeFinderSupport.d.ts.map +1 -0
- package/dist/core/model/CoreModelSafeFinderSupport.js +15 -0
- package/dist/core/model/CoreModelSafeFinderSupport.js.map +1 -0
- package/dist/core/model/CoreModelValidationEvents.d.ts +24 -0
- package/dist/core/model/CoreModelValidationEvents.d.ts.map +1 -0
- package/dist/core/model/CoreModelValidationEvents.js +45 -0
- package/dist/core/model/CoreModelValidationEvents.js.map +1 -0
- package/dist/core/model/SafeFinder.d.ts +46 -0
- package/dist/core/model/SafeFinder.d.ts.map +1 -0
- package/dist/core/model/SafeFinder.js +223 -0
- package/dist/core/model/SafeFinder.js.map +1 -0
- package/dist/core/orm/Relation.d.ts +47 -0
- package/dist/core/orm/Relation.d.ts.map +1 -0
- package/dist/core/orm/Relation.js +62 -0
- package/dist/core/orm/Relation.js.map +1 -0
- package/dist/core/orm/mixins/CastsMixin.d.ts +18 -0
- package/dist/core/orm/mixins/CastsMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/CastsMixin.js +125 -0
- package/dist/core/orm/mixins/CastsMixin.js.map +1 -0
- package/dist/core/orm/mixins/EagerLoadingMixin.d.ts +19 -0
- package/dist/core/orm/mixins/EagerLoadingMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/EagerLoadingMixin.js +137 -0
- package/dist/core/orm/mixins/EagerLoadingMixin.js.map +1 -0
- package/dist/core/orm/mixins/HooksMixin.d.ts +16 -0
- package/dist/core/orm/mixins/HooksMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/HooksMixin.js +95 -0
- package/dist/core/orm/mixins/HooksMixin.js.map +1 -0
- package/dist/core/orm/mixins/MorphRegistry.d.ts +47 -0
- package/dist/core/orm/mixins/MorphRegistry.d.ts.map +1 -0
- package/dist/core/orm/mixins/MorphRegistry.js +67 -0
- package/dist/core/orm/mixins/MorphRegistry.js.map +1 -0
- package/dist/core/orm/mixins/MorphableMixin.d.ts +29 -0
- package/dist/core/orm/mixins/MorphableMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/MorphableMixin.js +93 -0
- package/dist/core/orm/mixins/MorphableMixin.js.map +1 -0
- package/dist/core/orm/mixins/PivotHelperMixin.d.ts +26 -0
- package/dist/core/orm/mixins/PivotHelperMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/PivotHelperMixin.js +102 -0
- package/dist/core/orm/mixins/PivotHelperMixin.js.map +1 -0
- package/dist/core/orm/mixins/QueryCacheMixin.d.ts +23 -0
- package/dist/core/orm/mixins/QueryCacheMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/QueryCacheMixin.js +172 -0
- package/dist/core/orm/mixins/QueryCacheMixin.js.map +1 -0
- package/dist/core/orm/mixins/ScopeMixin.d.ts +20 -0
- package/dist/core/orm/mixins/ScopeMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/ScopeMixin.js +72 -0
- package/dist/core/orm/mixins/ScopeMixin.js.map +1 -0
- package/dist/core/orm/mixins/SerializeMixin.d.ts +44 -0
- package/dist/core/orm/mixins/SerializeMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/SerializeMixin.js +80 -0
- package/dist/core/orm/mixins/SerializeMixin.js.map +1 -0
- package/dist/core/orm/mixins/SoftDeletesMixin.d.ts +22 -0
- package/dist/core/orm/mixins/SoftDeletesMixin.d.ts.map +1 -0
- package/dist/core/orm/mixins/SoftDeletesMixin.js +146 -0
- package/dist/core/orm/mixins/SoftDeletesMixin.js.map +1 -0
- package/dist/core/orm/mixins/utils/BaseMethodResolver.d.ts +8 -0
- package/dist/core/orm/mixins/utils/BaseMethodResolver.d.ts.map +1 -0
- package/dist/core/orm/mixins/utils/BaseMethodResolver.js +26 -0
- package/dist/core/orm/mixins/utils/BaseMethodResolver.js.map +1 -0
- package/dist/core/orm/mixins/utils/HookStore.d.ts +26 -0
- package/dist/core/orm/mixins/utils/HookStore.d.ts.map +1 -0
- package/dist/core/orm/mixins/utils/HookStore.js +78 -0
- package/dist/core/orm/mixins/utils/HookStore.js.map +1 -0
- package/dist/core/orm/mixins/utils/ModelRegistry.d.ts +33 -0
- package/dist/core/orm/mixins/utils/ModelRegistry.d.ts.map +1 -0
- package/dist/core/orm/mixins/utils/ModelRegistry.js +87 -0
- package/dist/core/orm/mixins/utils/ModelRegistry.js.map +1 -0
- package/dist/core/orm/mixins/utils/modelRegistration.d.ts +9 -0
- package/dist/core/orm/mixins/utils/modelRegistration.d.ts.map +1 -0
- package/dist/core/orm/mixins/utils/modelRegistration.js +26 -0
- package/dist/core/orm/mixins/utils/modelRegistration.js.map +1 -0
- package/dist/core/orm/relations/BelongsTo.d.ts +6 -0
- package/dist/core/orm/relations/BelongsTo.d.ts.map +1 -0
- package/dist/core/orm/relations/BelongsTo.js +70 -0
- package/dist/core/orm/relations/BelongsTo.js.map +1 -0
- package/dist/core/orm/relations/BelongsToMany.d.ts +14 -0
- package/dist/core/orm/relations/BelongsToMany.d.ts.map +1 -0
- package/dist/core/orm/relations/BelongsToMany.js +245 -0
- package/dist/core/orm/relations/BelongsToMany.js.map +1 -0
- package/dist/core/orm/relations/HasMany.d.ts +6 -0
- package/dist/core/orm/relations/HasMany.d.ts.map +1 -0
- package/dist/core/orm/relations/HasMany.js +75 -0
- package/dist/core/orm/relations/HasMany.js.map +1 -0
- package/dist/core/orm/relations/HasOne.d.ts +6 -0
- package/dist/core/orm/relations/HasOne.d.ts.map +1 -0
- package/dist/core/orm/relations/HasOne.js +71 -0
- package/dist/core/orm/relations/HasOne.js.map +1 -0
- package/dist/core/orm/relations/MorphMany.d.ts +9 -0
- package/dist/core/orm/relations/MorphMany.d.ts.map +1 -0
- package/dist/core/orm/relations/MorphMany.js +107 -0
- package/dist/core/orm/relations/MorphMany.js.map +1 -0
- package/dist/core/orm/relations/MorphOne.d.ts +9 -0
- package/dist/core/orm/relations/MorphOne.d.ts.map +1 -0
- package/dist/core/orm/relations/MorphOne.js +101 -0
- package/dist/core/orm/relations/MorphOne.js.map +1 -0
- package/dist/core/orm/relations/MorphTo.d.ts +9 -0
- package/dist/core/orm/relations/MorphTo.d.ts.map +1 -0
- package/dist/core/orm/relations/MorphTo.js +85 -0
- package/dist/core/orm/relations/MorphTo.js.map +1 -0
- package/dist/core/schema/SQLDialect.d.ts +22 -0
- package/dist/core/schema/SQLDialect.d.ts.map +1 -0
- package/dist/core/schema/SQLDialect.js +38 -0
- package/dist/core/schema/SQLDialect.js.map +1 -0
- package/dist/core/schema/SchemaBlueprint.d.ts +61 -0
- package/dist/core/schema/SchemaBlueprint.d.ts.map +1 -0
- package/dist/core/schema/SchemaBlueprint.js +62 -0
- package/dist/core/schema/SchemaBlueprint.js.map +1 -0
- package/dist/core/schema/SchemaBuilder.d.ts +29 -0
- package/dist/core/schema/SchemaBuilder.d.ts.map +1 -0
- package/dist/core/schema/SchemaBuilder.js +661 -0
- package/dist/core/schema/SchemaBuilder.js.map +1 -0
- package/dist/core/schema/SchemaValidator.d.ts +23 -0
- package/dist/core/schema/SchemaValidator.d.ts.map +1 -0
- package/dist/core/schema/SchemaValidator.js +75 -0
- package/dist/core/schema/SchemaValidator.js.map +1 -0
- package/dist/core/security/AbstractSecurity.d.ts +24 -0
- package/dist/core/security/AbstractSecurity.d.ts.map +1 -0
- package/dist/core/security/AbstractSecurity.js +58 -0
- package/dist/core/security/AbstractSecurity.js.map +1 -0
- package/dist/core/security/EnvKeySecurity.d.ts +11 -0
- package/dist/core/security/EnvKeySecurity.d.ts.map +1 -0
- package/dist/core/security/EnvKeySecurity.js +46 -0
- package/dist/core/security/EnvKeySecurity.js.map +1 -0
- package/dist/core/security/NoSecurity.d.ts +10 -0
- package/dist/core/security/NoSecurity.d.ts.map +1 -0
- package/dist/core/security/NoSecurity.js +18 -0
- package/dist/core/security/NoSecurity.js.map +1 -0
- package/dist/core/security/SecretRedactor.d.ts +4 -0
- package/dist/core/security/SecretRedactor.d.ts.map +1 -0
- package/dist/core/security/SecretRedactor.js +60 -0
- package/dist/core/security/SecretRedactor.js.map +1 -0
- package/dist/core/security/SecurityContract.d.ts +13 -0
- package/dist/core/security/SecurityContract.d.ts.map +1 -0
- package/dist/core/security/SecurityContract.js +3 -0
- package/dist/core/security/SecurityContract.js.map +1 -0
- package/dist/core/security/SecurityFactory.d.ts +9 -0
- package/dist/core/security/SecurityFactory.d.ts.map +1 -0
- package/dist/core/security/SecurityFactory.js +29 -0
- package/dist/core/security/SecurityFactory.js.map +1 -0
- package/dist/core/security/index.d.ts +6 -0
- package/dist/core/security/index.d.ts.map +1 -0
- package/dist/core/security/index.js +22 -0
- package/dist/core/security/index.js.map +1 -0
- package/dist/index.d.ts +16 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +40 -0
- package/dist/index.js.map +1 -0
- package/package.json +104 -0
- package/src/cli/templates/controller.tpl +80 -0
- package/src/cli/templates/factory.tpl +14 -0
- package/src/cli/templates/migration.tpl +36 -0
- package/src/cli/templates/model-registry.tpl +16 -0
- package/src/cli/templates/model.tpl +95 -0
- package/src/cli/templates/pivot-factory.tpl +85 -0
- package/src/cli/templates/seed.tpl +20 -0
- package/src/cli/templates/service.tpl +40 -0
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.migrateRollback = migrateRollback;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
10
|
+
const ConnectionFactory_1 = require("../../core/connection/ConnectionFactory");
|
|
11
|
+
const PathMap_1 = require("../utils/PathMap");
|
|
12
|
+
const database_1 = require("../../config/database");
|
|
13
|
+
const resolveConnectionName_1 = require("../../core/connection/resolveConnectionName");
|
|
14
|
+
const MigrationTracker_1 = require("../utils/migrations/MigrationTracker");
|
|
15
|
+
const MongoMigrationTracker_1 = require("../utils/migrations/MongoMigrationTracker");
|
|
16
|
+
const tsRuntime_1 = require("../utils/typescript/tsRuntime");
|
|
17
|
+
const AuditTrail_1 = require("../utils/AuditTrail");
|
|
18
|
+
function createMongoMigrationContext(db) {
|
|
19
|
+
const collectionExists = async (name) => {
|
|
20
|
+
const rows = await db
|
|
21
|
+
.listCollections({ name }, { nameOnly: true })
|
|
22
|
+
.toArray();
|
|
23
|
+
return rows.length > 0;
|
|
24
|
+
};
|
|
25
|
+
return {
|
|
26
|
+
ensureCollection: async (name) => {
|
|
27
|
+
if (await collectionExists(name))
|
|
28
|
+
return;
|
|
29
|
+
await db.createCollection(name);
|
|
30
|
+
},
|
|
31
|
+
dropCollection: async (name) => {
|
|
32
|
+
if (!(await collectionExists(name)))
|
|
33
|
+
return;
|
|
34
|
+
await db.collection(name).drop();
|
|
35
|
+
},
|
|
36
|
+
createIndex: async (collectionName, keys, options) => {
|
|
37
|
+
await db.collection(collectionName).createIndex(keys, options ?? {});
|
|
38
|
+
},
|
|
39
|
+
dropIndex: async (collectionName, indexName) => {
|
|
40
|
+
await db.collection(collectionName).dropIndex(indexName);
|
|
41
|
+
},
|
|
42
|
+
collection: (name) => db.collection(name),
|
|
43
|
+
db,
|
|
44
|
+
query: async (sql) => {
|
|
45
|
+
if (!sql || sql.trim() === "")
|
|
46
|
+
return;
|
|
47
|
+
throw new Error("Mongo migrations do not support SQL query() calls. Use ensureCollection/createIndex/dropCollection or collection().");
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
async function getMongoConnection(connectionName) {
|
|
52
|
+
if (typeof ConnectionFactory_1.getConnection === "function") {
|
|
53
|
+
return (await (0, ConnectionFactory_1.getConnection)(connectionName));
|
|
54
|
+
}
|
|
55
|
+
// Test harness compatibility: some command-level mocks only provide getAdapter.
|
|
56
|
+
return (await ConnectionFactory_1.getAdapter(connectionName));
|
|
57
|
+
}
|
|
58
|
+
async function rollbackConnection(connectionName, isTest, step) {
|
|
59
|
+
const stepLabel = step === Number.MAX_SAFE_INTEGER ? "all" : String(step);
|
|
60
|
+
console.log(chalk_1.default.cyan(`\nRolling back migrations in ${isTest ? "TEST" : "DEVELOPMENT"} mode on "${connectionName}" (step ${stepLabel})...\n`));
|
|
61
|
+
const migrationsDir = PathMap_1.PathMap.migrations(isTest, connectionName);
|
|
62
|
+
if (!fs_1.default.existsSync(migrationsDir)) {
|
|
63
|
+
console.log(chalk_1.default.yellow(`No migrations directory found for ${connectionName}.`));
|
|
64
|
+
return true;
|
|
65
|
+
}
|
|
66
|
+
const driver = database_1.dbConfig.connections[connectionName]?.driver ?? connectionName;
|
|
67
|
+
if (driver === "mongo") {
|
|
68
|
+
const db = await getMongoConnection(connectionName);
|
|
69
|
+
console.log(chalk_1.default.gray(`Connected to ${connectionName}.`));
|
|
70
|
+
const lockOwner = `migrate:rollback:${connectionName}:${process.pid}:${Date.now()}`;
|
|
71
|
+
let lockAcquired = false;
|
|
72
|
+
let completedWithoutError = false;
|
|
73
|
+
try {
|
|
74
|
+
await (0, MongoMigrationTracker_1.ensureMigrationCollection)(db);
|
|
75
|
+
await (0, MongoMigrationTracker_1.acquireMigrationLock)(db, lockOwner);
|
|
76
|
+
lockAcquired = true;
|
|
77
|
+
const rows = (await (0, MongoMigrationTracker_1.validateMigrationHistory)(db, migrationsDir))
|
|
78
|
+
.map((row) => ({ id: row.id, name: row.name, batch: row.batch }))
|
|
79
|
+
.sort((a, b) => {
|
|
80
|
+
if (b.batch !== a.batch)
|
|
81
|
+
return b.batch - a.batch;
|
|
82
|
+
return String(b.id ?? "").localeCompare(String(a.id ?? ""));
|
|
83
|
+
});
|
|
84
|
+
if (rows.length === 0) {
|
|
85
|
+
console.log(chalk_1.default.yellow("No migrations found to roll back."));
|
|
86
|
+
completedWithoutError = true;
|
|
87
|
+
return true;
|
|
88
|
+
}
|
|
89
|
+
const targetBatches = Array.from(new Set(rows.map((r) => r.batch))).slice(0, step);
|
|
90
|
+
const toRollback = rows.filter((r) => targetBatches.includes(r.batch));
|
|
91
|
+
if (toRollback.length === 0) {
|
|
92
|
+
console.log(chalk_1.default.yellow("Nothing to roll back."));
|
|
93
|
+
completedWithoutError = true;
|
|
94
|
+
return true;
|
|
95
|
+
}
|
|
96
|
+
console.log(chalk_1.default.gray(`Rolling back ${toRollback.length} migration(s)...`));
|
|
97
|
+
let rolledBack = 0;
|
|
98
|
+
let hadRollbackError = false;
|
|
99
|
+
for (const entry of toRollback) {
|
|
100
|
+
const migrationFile = entry.name;
|
|
101
|
+
const filePath = path_1.default.join(migrationsDir, migrationFile);
|
|
102
|
+
if (!fs_1.default.existsSync(filePath)) {
|
|
103
|
+
const fallbackCollection = (0, MigrationTracker_1.getAutoGeneratedCreateTableName)(migrationFile);
|
|
104
|
+
if (fallbackCollection) {
|
|
105
|
+
try {
|
|
106
|
+
const exists = await (0, MongoMigrationTracker_1.doesCollectionExist)(db, fallbackCollection);
|
|
107
|
+
if (exists) {
|
|
108
|
+
await db.collection(fallbackCollection).drop();
|
|
109
|
+
console.log(chalk_1.default.yellow(`Fallback rollback: dropped collection "${fallbackCollection}" for missing migration file "${migrationFile}".`));
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
console.log(chalk_1.default.yellow(`Fallback rollback: collection "${fallbackCollection}" already absent for missing migration file "${migrationFile}".`));
|
|
113
|
+
}
|
|
114
|
+
await (0, MongoMigrationTracker_1.deleteAppliedMigration)(db, migrationFile);
|
|
115
|
+
rolledBack++;
|
|
116
|
+
continue;
|
|
117
|
+
}
|
|
118
|
+
catch (fallbackError) {
|
|
119
|
+
console.error(chalk_1.default.red(`Fallback rollback failed for ${migrationFile}:`));
|
|
120
|
+
console.error(fallbackError);
|
|
121
|
+
hadRollbackError = true;
|
|
122
|
+
break;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
console.error(chalk_1.default.red(`Missing file: ${migrationFile}`));
|
|
126
|
+
hadRollbackError = true;
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
try {
|
|
130
|
+
const migrationModule = (0, tsRuntime_1.loadModule)(path_1.default.resolve(filePath));
|
|
131
|
+
if (typeof migrationModule.down !== "function") {
|
|
132
|
+
console.log(chalk_1.default.gray(`No down() method: ${migrationFile}`));
|
|
133
|
+
continue;
|
|
134
|
+
}
|
|
135
|
+
console.log(chalk_1.default.gray(`Reverting: ${migrationFile}`));
|
|
136
|
+
const context = createMongoMigrationContext(db);
|
|
137
|
+
await migrationModule.down(context);
|
|
138
|
+
await (0, MongoMigrationTracker_1.deleteAppliedMigration)(db, migrationFile);
|
|
139
|
+
console.log(chalk_1.default.green(`Rolled back: ${migrationFile}`));
|
|
140
|
+
rolledBack++;
|
|
141
|
+
}
|
|
142
|
+
catch (err) {
|
|
143
|
+
console.error(chalk_1.default.red(`Error rolling back ${migrationFile}:`));
|
|
144
|
+
console.error(err);
|
|
145
|
+
hadRollbackError = true;
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
console.log(chalk_1.default.greenBright(`\n${rolledBack} migration(s) rolled back successfully.\n`));
|
|
150
|
+
completedWithoutError = !hadRollbackError;
|
|
151
|
+
return !hadRollbackError;
|
|
152
|
+
}
|
|
153
|
+
catch (err) {
|
|
154
|
+
console.error(chalk_1.default.red("Unable to read or validate migrations collection."));
|
|
155
|
+
console.error(err);
|
|
156
|
+
return false;
|
|
157
|
+
/* c8 ignore next 4 -- ts-jest/v8 records a synthetic single-location branch on this finally block */
|
|
158
|
+
}
|
|
159
|
+
finally {
|
|
160
|
+
await (0, MongoMigrationTracker_1.releaseMigrationLock)(db, lockOwner);
|
|
161
|
+
await (0, ConnectionFactory_1.closeAllConnections)();
|
|
162
|
+
console.log(chalk_1.default.gray("All database connections closed.\n"));
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
if (!["mysql", "pg", "sqlite"].includes(driver)) {
|
|
166
|
+
console.warn(chalk_1.default.yellow(`Rollback skipped: "${connectionName}" has unsupported driver "${driver}".`));
|
|
167
|
+
return true;
|
|
168
|
+
}
|
|
169
|
+
const db = await (0, ConnectionFactory_1.getAdapter)(connectionName);
|
|
170
|
+
console.log(chalk_1.default.gray(`Connected to ${connectionName}.`));
|
|
171
|
+
const lockOwner = `migrate:rollback:${connectionName}:${process.pid}:${Date.now()}`;
|
|
172
|
+
const runQuery = async (sql, params = []) => {
|
|
173
|
+
await db.execute(sql, params);
|
|
174
|
+
};
|
|
175
|
+
let lockAcquired = false;
|
|
176
|
+
let completedWithoutError = false;
|
|
177
|
+
try {
|
|
178
|
+
await (0, MigrationTracker_1.ensureMigrationTables)(db);
|
|
179
|
+
await (0, MigrationTracker_1.acquireMigrationLock)(db, lockOwner);
|
|
180
|
+
lockAcquired = true;
|
|
181
|
+
let rows = [];
|
|
182
|
+
rows = (await (0, MigrationTracker_1.validateMigrationHistory)(db, migrationsDir))
|
|
183
|
+
.map((row) => ({ id: row.id, name: row.name, batch: row.batch }))
|
|
184
|
+
/* c8 ignore next 4 -- ts-jest/v8 is not attributing this chained sort callback reliably in focused coverage */
|
|
185
|
+
.sort((a, b) => {
|
|
186
|
+
if (b.batch !== a.batch)
|
|
187
|
+
return b.batch - a.batch;
|
|
188
|
+
return (b.id ?? 0) - (a.id ?? 0);
|
|
189
|
+
});
|
|
190
|
+
if (rows.length === 0) {
|
|
191
|
+
console.log(chalk_1.default.yellow("No migrations found to roll back."));
|
|
192
|
+
completedWithoutError = true;
|
|
193
|
+
return true;
|
|
194
|
+
}
|
|
195
|
+
const targetBatches = Array.from(new Set(rows.map((r) => r.batch))).slice(0, step);
|
|
196
|
+
const toRollback = rows.filter((r) => targetBatches.includes(r.batch));
|
|
197
|
+
if (toRollback.length === 0) {
|
|
198
|
+
console.log(chalk_1.default.yellow("Nothing to roll back."));
|
|
199
|
+
completedWithoutError = true;
|
|
200
|
+
return true;
|
|
201
|
+
}
|
|
202
|
+
console.log(chalk_1.default.gray(`Rolling back ${toRollback.length} migration(s)...`));
|
|
203
|
+
let rolledBack = 0;
|
|
204
|
+
let hadRollbackError = false;
|
|
205
|
+
for (const entry of toRollback) {
|
|
206
|
+
const migrationFile = entry.name;
|
|
207
|
+
const filePath = path_1.default.join(migrationsDir, migrationFile);
|
|
208
|
+
if (!fs_1.default.existsSync(filePath)) {
|
|
209
|
+
const fallbackTable = (0, MigrationTracker_1.getAutoGeneratedCreateTableName)(migrationFile);
|
|
210
|
+
if (fallbackTable) {
|
|
211
|
+
try {
|
|
212
|
+
const exists = await (0, MigrationTracker_1.doesMigrationTableExist)(db, fallbackTable);
|
|
213
|
+
if (exists) {
|
|
214
|
+
const dropSql = driver === "pg"
|
|
215
|
+
? `DROP TABLE IF EXISTS ${db.wrapId(fallbackTable)} CASCADE;`
|
|
216
|
+
: `DROP TABLE IF EXISTS ${db.wrapId(fallbackTable)};`;
|
|
217
|
+
await runQuery(dropSql);
|
|
218
|
+
console.log(chalk_1.default.yellow(`Fallback rollback: dropped table "${fallbackTable}" for missing migration file "${migrationFile}".`));
|
|
219
|
+
}
|
|
220
|
+
else {
|
|
221
|
+
console.log(chalk_1.default.yellow(`Fallback rollback: table "${fallbackTable}" already absent for missing migration file "${migrationFile}".`));
|
|
222
|
+
}
|
|
223
|
+
await (0, MigrationTracker_1.deleteAppliedMigration)(db, migrationFile);
|
|
224
|
+
rolledBack++;
|
|
225
|
+
continue;
|
|
226
|
+
}
|
|
227
|
+
catch (fallbackError) {
|
|
228
|
+
console.error(chalk_1.default.red(`Fallback rollback failed for ${migrationFile}:`));
|
|
229
|
+
console.error(fallbackError);
|
|
230
|
+
hadRollbackError = true;
|
|
231
|
+
break;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
console.error(chalk_1.default.red(`Missing file: ${migrationFile}`));
|
|
235
|
+
hadRollbackError = true;
|
|
236
|
+
break;
|
|
237
|
+
}
|
|
238
|
+
try {
|
|
239
|
+
const migrationModule = (0, tsRuntime_1.loadModule)(path_1.default.resolve(filePath));
|
|
240
|
+
if (typeof migrationModule.down !== "function") {
|
|
241
|
+
console.log(chalk_1.default.gray(`No down() method: ${migrationFile}`));
|
|
242
|
+
continue;
|
|
243
|
+
}
|
|
244
|
+
console.log(chalk_1.default.gray(`Reverting: ${migrationFile}`));
|
|
245
|
+
await migrationModule.down({ query: runQuery });
|
|
246
|
+
await (0, MigrationTracker_1.deleteAppliedMigration)(db, migrationFile);
|
|
247
|
+
console.log(chalk_1.default.green(`Rolled back: ${migrationFile}`));
|
|
248
|
+
rolledBack++;
|
|
249
|
+
}
|
|
250
|
+
catch (err) {
|
|
251
|
+
console.error(chalk_1.default.red(`Error rolling back ${migrationFile}:`));
|
|
252
|
+
console.error(err);
|
|
253
|
+
hadRollbackError = true;
|
|
254
|
+
break;
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
console.log(chalk_1.default.greenBright(`\n${rolledBack} migration(s) rolled back successfully.\n`));
|
|
258
|
+
completedWithoutError = !hadRollbackError;
|
|
259
|
+
return !hadRollbackError;
|
|
260
|
+
}
|
|
261
|
+
catch (err) {
|
|
262
|
+
console.error(chalk_1.default.red("Unable to read or validate migrations table."));
|
|
263
|
+
console.error(err);
|
|
264
|
+
return false;
|
|
265
|
+
/* c8 ignore next 4 -- ts-jest/v8 records a synthetic single-location branch on this finally block */
|
|
266
|
+
}
|
|
267
|
+
finally {
|
|
268
|
+
await (0, MigrationTracker_1.releaseMigrationLock)(db, lockOwner, { success: completedWithoutError });
|
|
269
|
+
await (0, ConnectionFactory_1.closeAllConnections)();
|
|
270
|
+
console.log(chalk_1.default.gray("All database connections closed.\n"));
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
async function migrateRollback(options = {}) {
|
|
274
|
+
const isTest = !!options.test;
|
|
275
|
+
const step = options.allMigrations
|
|
276
|
+
? Number.MAX_SAFE_INTEGER
|
|
277
|
+
: Math.max(1, Number(options.step || 1));
|
|
278
|
+
const connectionNames = options.connectionNames && options.connectionNames.length > 0
|
|
279
|
+
? options.connectionNames
|
|
280
|
+
: [(0, resolveConnectionName_1.resolveConnectionName)(undefined, { test: isTest })];
|
|
281
|
+
let hadFailure = false;
|
|
282
|
+
const auditCommand = options.auditCommand ?? "migrate:rollback";
|
|
283
|
+
for (const connectionName of connectionNames) {
|
|
284
|
+
const success = await rollbackConnection(connectionName, isTest, step);
|
|
285
|
+
(0, AuditTrail_1.appendAuditEvent)({
|
|
286
|
+
command: auditCommand,
|
|
287
|
+
connectionName,
|
|
288
|
+
test: isTest,
|
|
289
|
+
result: success ? "success" : "failure",
|
|
290
|
+
metadata: {
|
|
291
|
+
step,
|
|
292
|
+
allMigrations: options.allMigrations === true,
|
|
293
|
+
},
|
|
294
|
+
});
|
|
295
|
+
if (!success) {
|
|
296
|
+
hadFailure = true;
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
if (hadFailure) {
|
|
300
|
+
process.exitCode = 1;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
//# sourceMappingURL=migrateRollback.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrateRollback.js","sourceRoot":"","sources":["../../../src/cli/commands/migrateRollback.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type ConnectionName } from "../../core/connection/ConnectionFactory";
|
|
2
|
+
import { resolveSqlConnectionNames, type SqlConnectionFlags } from "../utils/resolveSqlConnectionFlags";
|
|
3
|
+
export type MigrateRunOptions = {
|
|
4
|
+
connectionNames?: ConnectionName[];
|
|
5
|
+
auditCommand?: string;
|
|
6
|
+
};
|
|
7
|
+
export type MigrationConnectionFlags = SqlConnectionFlags;
|
|
8
|
+
export declare const resolveMigrationConnectionNames: typeof resolveSqlConnectionNames;
|
|
9
|
+
export declare function migrateRun(isTest?: boolean, modelName?: string, dryRun?: boolean, exitOnFinish?: boolean, options?: MigrateRunOptions): Promise<void>;
|
|
10
|
+
//# sourceMappingURL=migrateRun.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrateRun.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/migrateRun.ts"],"names":[],"mappings":"AAGA,OAAO,EAIL,KAAK,cAAc,EACpB,MAAM,yCAAyC,CAAC;AAsBjD,OAAO,EACL,yBAAyB,EACzB,KAAK,kBAAkB,EACxB,MAAM,oCAAoC,CAAC;AAI5C,MAAM,MAAM,iBAAiB,GAAG;IAC9B,eAAe,CAAC,EAAE,cAAc,EAAE,CAAC;IACnC,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,wBAAwB,GAAG,kBAAkB,CAAC;AAC1D,eAAO,MAAM,+BAA+B,kCAA4B,CAAC;AA2UzE,wBAAsB,UAAU,CAC9B,MAAM,GAAE,OAAe,EACvB,SAAS,CAAC,EAAE,MAAM,EAClB,MAAM,GAAE,OAAe,EACvB,YAAY,GAAE,OAAc,EAC5B,OAAO,GAAE,iBAAsB,GAC9B,OAAO,CAAC,IAAI,CAAC,CAkDf"}
|
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.resolveMigrationConnectionNames = void 0;
|
|
7
|
+
exports.migrateRun = migrateRun;
|
|
8
|
+
const fs_1 = __importDefault(require("fs"));
|
|
9
|
+
const path_1 = __importDefault(require("path"));
|
|
10
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
11
|
+
const ConnectionFactory_1 = require("../../core/connection/ConnectionFactory");
|
|
12
|
+
const PathMap_1 = require("../utils/PathMap");
|
|
13
|
+
const database_1 = require("../../config/database");
|
|
14
|
+
const resolveConnectionName_1 = require("../../core/connection/resolveConnectionName");
|
|
15
|
+
const MigrationTracker_1 = require("../utils/migrations/MigrationTracker");
|
|
16
|
+
const MongoMigrationTracker_1 = require("../utils/migrations/MongoMigrationTracker");
|
|
17
|
+
const tsRuntime_1 = require("../utils/typescript/tsRuntime");
|
|
18
|
+
const resolveSqlConnectionFlags_1 = require("../utils/resolveSqlConnectionFlags");
|
|
19
|
+
const AuditTrail_1 = require("../utils/AuditTrail");
|
|
20
|
+
exports.resolveMigrationConnectionNames = resolveSqlConnectionFlags_1.resolveSqlConnectionNames;
|
|
21
|
+
function createMongoMigrationContext(db, dryRun, operations) {
|
|
22
|
+
const collectionExists = async (name) => {
|
|
23
|
+
const rows = await db
|
|
24
|
+
.listCollections({ name }, { nameOnly: true })
|
|
25
|
+
.toArray();
|
|
26
|
+
return rows.length > 0;
|
|
27
|
+
};
|
|
28
|
+
return {
|
|
29
|
+
ensureCollection: async (name) => {
|
|
30
|
+
operations.count++;
|
|
31
|
+
if (dryRun) {
|
|
32
|
+
console.log(chalk_1.default.gray(`[DRY-RUN] Would ensure collection "${name}"`));
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
if (await collectionExists(name))
|
|
36
|
+
return;
|
|
37
|
+
await db.createCollection(name);
|
|
38
|
+
},
|
|
39
|
+
dropCollection: async (name) => {
|
|
40
|
+
operations.count++;
|
|
41
|
+
if (dryRun) {
|
|
42
|
+
console.log(chalk_1.default.gray(`[DRY-RUN] Would drop collection "${name}"`));
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
if (!(await collectionExists(name)))
|
|
46
|
+
return;
|
|
47
|
+
await db.collection(name).drop();
|
|
48
|
+
},
|
|
49
|
+
createIndex: async (collectionName, keys, options) => {
|
|
50
|
+
operations.count++;
|
|
51
|
+
if (dryRun) {
|
|
52
|
+
console.log(chalk_1.default.gray(`[DRY-RUN] Would create index on "${collectionName}": ${JSON.stringify({
|
|
53
|
+
keys,
|
|
54
|
+
options: options ?? {},
|
|
55
|
+
})}`));
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
await db.collection(collectionName).createIndex(keys, options ?? {});
|
|
59
|
+
},
|
|
60
|
+
dropIndex: async (collectionName, indexName) => {
|
|
61
|
+
operations.count++;
|
|
62
|
+
if (dryRun) {
|
|
63
|
+
console.log(chalk_1.default.gray(`[DRY-RUN] Would drop index "${indexName}" on "${collectionName}"`));
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
await db.collection(collectionName).dropIndex(indexName);
|
|
67
|
+
},
|
|
68
|
+
collection: (name) => db.collection(name),
|
|
69
|
+
db,
|
|
70
|
+
query: async (sql) => {
|
|
71
|
+
if (!sql || sql.trim() === "")
|
|
72
|
+
return;
|
|
73
|
+
throw new Error("Mongo migrations do not support SQL query() calls. Use ensureCollection/createIndex/dropCollection or collection().");
|
|
74
|
+
},
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
async function getMongoConnection(connectionName) {
|
|
78
|
+
if (typeof ConnectionFactory_1.getConnection === "function") {
|
|
79
|
+
return (await (0, ConnectionFactory_1.getConnection)(connectionName));
|
|
80
|
+
}
|
|
81
|
+
// Test harness compatibility: some command-level mocks only provide getAdapter.
|
|
82
|
+
return (await ConnectionFactory_1.getAdapter(connectionName));
|
|
83
|
+
}
|
|
84
|
+
async function runMigrationsForConnection(connectionName, isTest, modelName, dryRun) {
|
|
85
|
+
console.log(chalk_1.default.cyan(`\nRunning migrations in ${isTest ? "TEST" : "DEVELOPMENT"} mode on "${connectionName}"${modelName ? ` for model "${modelName}"` : ""}...\n`));
|
|
86
|
+
const migrationsDir = PathMap_1.PathMap.migrations(isTest, connectionName);
|
|
87
|
+
if (!fs_1.default.existsSync(migrationsDir)) {
|
|
88
|
+
console.log(chalk_1.default.yellow(`No migrations directory found for ${connectionName}.`));
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
if (process.env.ELOQUENT_DEBUG === "true") {
|
|
92
|
+
console.log("[migrate:run] connectionName", connectionName);
|
|
93
|
+
}
|
|
94
|
+
const driver = database_1.dbConfig.connections[connectionName]?.driver ?? connectionName;
|
|
95
|
+
if (driver === "mongo") {
|
|
96
|
+
const db = await getMongoConnection(connectionName);
|
|
97
|
+
console.log(chalk_1.default.gray(`Connected to ${connectionName}.`));
|
|
98
|
+
const lockOwner = `migrate:run:${connectionName}:${process.pid}:${Date.now()}`;
|
|
99
|
+
let completedWithoutError = false;
|
|
100
|
+
await (0, MongoMigrationTracker_1.ensureMigrationCollection)(db);
|
|
101
|
+
if (!dryRun) {
|
|
102
|
+
await (0, MongoMigrationTracker_1.acquireMigrationLock)(db, lockOwner);
|
|
103
|
+
}
|
|
104
|
+
try {
|
|
105
|
+
let files = fs_1.default
|
|
106
|
+
.readdirSync(migrationsDir)
|
|
107
|
+
.filter((f) => f.endsWith(".ts") || f.endsWith(".js"))
|
|
108
|
+
.sort();
|
|
109
|
+
if (modelName) {
|
|
110
|
+
const lower = modelName.toLowerCase();
|
|
111
|
+
files = files.filter((f) => f.includes(lower));
|
|
112
|
+
if (files.length === 0) {
|
|
113
|
+
console.log(chalk_1.default.yellow(`No migrations found for model: ${modelName}`));
|
|
114
|
+
completedWithoutError = true;
|
|
115
|
+
return true;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
const appliedRows = await (0, MongoMigrationTracker_1.validateMigrationHistory)(db, migrationsDir);
|
|
119
|
+
const executed = appliedRows.map((row) => row.name);
|
|
120
|
+
const pending = files.filter((f) => !executed.includes(f));
|
|
121
|
+
if (pending.length === 0) {
|
|
122
|
+
console.log(chalk_1.default.yellow("\nNo new migrations to run."));
|
|
123
|
+
completedWithoutError = true;
|
|
124
|
+
return true;
|
|
125
|
+
}
|
|
126
|
+
console.log(chalk_1.default.gray(`Pending migrations: ${pending.length}`));
|
|
127
|
+
const lastBatch = await (0, MongoMigrationTracker_1.readLastBatch)(db);
|
|
128
|
+
const newBatch = lastBatch + 1;
|
|
129
|
+
let applied = 0;
|
|
130
|
+
for (const file of pending) {
|
|
131
|
+
const filePath = path_1.default.join(migrationsDir, file);
|
|
132
|
+
const migrationModule = (0, tsRuntime_1.loadModule)(path_1.default.resolve(filePath));
|
|
133
|
+
if (typeof migrationModule.up !== "function") {
|
|
134
|
+
console.log(chalk_1.default.red(`Invalid migration: ${file}`));
|
|
135
|
+
continue;
|
|
136
|
+
}
|
|
137
|
+
console.log(chalk_1.default.gray(`Applying: ${file}`));
|
|
138
|
+
const operations = { count: 0 };
|
|
139
|
+
const context = createMongoMigrationContext(db, dryRun, operations);
|
|
140
|
+
await migrationModule.up(context);
|
|
141
|
+
// Keep parity with SQL behavior: skip explicit no-op migrations when no
|
|
142
|
+
// migration helper operation was used.
|
|
143
|
+
if (operations.count === 0) {
|
|
144
|
+
console.log(chalk_1.default.gray(`Skipping empty migration: ${file}`));
|
|
145
|
+
continue;
|
|
146
|
+
}
|
|
147
|
+
if (!dryRun) {
|
|
148
|
+
await (0, MongoMigrationTracker_1.recordAppliedMigration)(db, file, newBatch, (0, MigrationTracker_1.computeMigrationChecksum)(filePath));
|
|
149
|
+
}
|
|
150
|
+
console.log(chalk_1.default.green(`Migration applied: ${file}`));
|
|
151
|
+
applied++;
|
|
152
|
+
}
|
|
153
|
+
console.log(chalk_1.default.greenBright(`\n${applied} migration(s) applied successfully.`));
|
|
154
|
+
completedWithoutError = true;
|
|
155
|
+
return true;
|
|
156
|
+
}
|
|
157
|
+
catch (err) {
|
|
158
|
+
console.error(chalk_1.default.red("\nError during migration execution:"));
|
|
159
|
+
console.error(err);
|
|
160
|
+
console.warn(chalk_1.default.yellow("Rolling back partial changes..."));
|
|
161
|
+
return false;
|
|
162
|
+
/* c8 ignore next 4 -- ts-jest/v8 records a synthetic single-location branch on this finally block */
|
|
163
|
+
}
|
|
164
|
+
finally {
|
|
165
|
+
await (0, MongoMigrationTracker_1.releaseMigrationLock)(db, lockOwner);
|
|
166
|
+
await (0, ConnectionFactory_1.closeAllConnections)();
|
|
167
|
+
console.log(chalk_1.default.gray("\nAll database connections closed.\n"));
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
if (!["mysql", "pg", "sqlite"].includes(driver)) {
|
|
171
|
+
console.warn(chalk_1.default.yellow(`Skipping migrations: "${connectionName}" has unsupported driver "${driver}".`));
|
|
172
|
+
return true;
|
|
173
|
+
}
|
|
174
|
+
if (process.env.ELOQUENT_DEBUG === "true") {
|
|
175
|
+
console.log("[migrate:run] before getAdapter");
|
|
176
|
+
}
|
|
177
|
+
const db = await (0, ConnectionFactory_1.getAdapter)(connectionName);
|
|
178
|
+
if (process.env.ELOQUENT_DEBUG === "true") {
|
|
179
|
+
console.log("[migrate:run] after getAdapter");
|
|
180
|
+
}
|
|
181
|
+
console.log(chalk_1.default.gray(`Connected to ${connectionName}.`));
|
|
182
|
+
const lockOwner = `migrate:run:${connectionName}:${process.pid}:${Date.now()}`;
|
|
183
|
+
let completedWithoutError = false;
|
|
184
|
+
await (0, MigrationTracker_1.ensureMigrationTables)(db);
|
|
185
|
+
if (!dryRun) {
|
|
186
|
+
await (0, MigrationTracker_1.acquireMigrationLock)(db, lockOwner);
|
|
187
|
+
}
|
|
188
|
+
try {
|
|
189
|
+
let files = fs_1.default
|
|
190
|
+
.readdirSync(migrationsDir)
|
|
191
|
+
.filter((f) => f.endsWith(".ts") || f.endsWith(".js"))
|
|
192
|
+
.sort();
|
|
193
|
+
if (modelName) {
|
|
194
|
+
const lower = modelName.toLowerCase();
|
|
195
|
+
files = files.filter((f) => f.includes(lower));
|
|
196
|
+
if (files.length === 0) {
|
|
197
|
+
console.log(chalk_1.default.yellow(`No migrations found for model: ${modelName}`));
|
|
198
|
+
completedWithoutError = true;
|
|
199
|
+
return true;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
const appliedRows = await (0, MigrationTracker_1.validateMigrationHistory)(db, migrationsDir);
|
|
203
|
+
const executed = appliedRows.map((row) => row.name);
|
|
204
|
+
const pending = files.filter((f) => !executed.includes(f));
|
|
205
|
+
if (pending.length === 0) {
|
|
206
|
+
console.log(chalk_1.default.yellow("\nNo new migrations to run."));
|
|
207
|
+
completedWithoutError = true;
|
|
208
|
+
return true;
|
|
209
|
+
}
|
|
210
|
+
console.log(chalk_1.default.gray(`Pending migrations: ${pending.length}`));
|
|
211
|
+
const lastBatch = await (0, MigrationTracker_1.readLastBatch)(db);
|
|
212
|
+
const newBatch = lastBatch + 1;
|
|
213
|
+
let applied = 0;
|
|
214
|
+
for (const file of pending) {
|
|
215
|
+
const filePath = path_1.default.join(migrationsDir, file);
|
|
216
|
+
const migrationModule = (0, tsRuntime_1.loadModule)(path_1.default.resolve(filePath));
|
|
217
|
+
if (typeof migrationModule.up !== "function") {
|
|
218
|
+
console.log(chalk_1.default.red(`Invalid migration: ${file}`));
|
|
219
|
+
continue;
|
|
220
|
+
}
|
|
221
|
+
console.log(chalk_1.default.gray(`Applying: ${file}`));
|
|
222
|
+
let executedStatements = 0;
|
|
223
|
+
const runQuery = async (sql, params = []) => {
|
|
224
|
+
if (!sql || sql.trim() === "")
|
|
225
|
+
return;
|
|
226
|
+
executedStatements++;
|
|
227
|
+
if (dryRun) {
|
|
228
|
+
console.log(chalk_1.default.gray(`[DRY-RUN] Would execute:\n${sql}\n`));
|
|
229
|
+
return;
|
|
230
|
+
}
|
|
231
|
+
await db.execute(sql, params);
|
|
232
|
+
};
|
|
233
|
+
await migrationModule.up({ query: runQuery });
|
|
234
|
+
if (executedStatements === 0) {
|
|
235
|
+
console.log(chalk_1.default.gray(`Skipping empty migration: ${file}`));
|
|
236
|
+
continue;
|
|
237
|
+
}
|
|
238
|
+
if (!dryRun) {
|
|
239
|
+
await (0, MigrationTracker_1.recordAppliedMigration)(db, file, newBatch, (0, MigrationTracker_1.computeMigrationChecksum)(filePath));
|
|
240
|
+
}
|
|
241
|
+
console.log(chalk_1.default.green(`Migration applied: ${file}`));
|
|
242
|
+
applied++;
|
|
243
|
+
}
|
|
244
|
+
console.log(chalk_1.default.greenBright(`\n${applied} migration(s) applied successfully.`));
|
|
245
|
+
completedWithoutError = true;
|
|
246
|
+
return true;
|
|
247
|
+
}
|
|
248
|
+
catch (err) {
|
|
249
|
+
console.error(chalk_1.default.red("\nError during migration execution:"));
|
|
250
|
+
console.error(err);
|
|
251
|
+
console.warn(chalk_1.default.yellow("Rolling back partial changes..."));
|
|
252
|
+
return false;
|
|
253
|
+
/* c8 ignore next 4 -- ts-jest/v8 records a synthetic single-location branch on this finally block */
|
|
254
|
+
}
|
|
255
|
+
finally {
|
|
256
|
+
await (0, MigrationTracker_1.releaseMigrationLock)(db, lockOwner, { success: completedWithoutError });
|
|
257
|
+
await (0, ConnectionFactory_1.closeAllConnections)();
|
|
258
|
+
console.log(chalk_1.default.gray("\nAll database connections closed.\n"));
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
async function migrateRun(isTest = false, modelName, dryRun = false, exitOnFinish = true, options = {}) {
|
|
262
|
+
const exitCli = () => {
|
|
263
|
+
if (exitOnFinish && process.env.ELOQUENT_CLI === "true") {
|
|
264
|
+
setImmediate(() => process.exit(process.exitCode ?? 0));
|
|
265
|
+
}
|
|
266
|
+
};
|
|
267
|
+
if (process.env.ELOQUENT_DEBUG === "true") {
|
|
268
|
+
console.log("[migrate:run] start", {
|
|
269
|
+
isTest,
|
|
270
|
+
modelName,
|
|
271
|
+
dryRun,
|
|
272
|
+
connectionNames: options.connectionNames,
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
const connectionNames = options.connectionNames && options.connectionNames.length > 0
|
|
276
|
+
? options.connectionNames
|
|
277
|
+
: [(0, resolveConnectionName_1.resolveConnectionName)(undefined, { test: isTest })];
|
|
278
|
+
let hadFailure = false;
|
|
279
|
+
const auditCommand = options.auditCommand ?? "migrate:run";
|
|
280
|
+
for (const connectionName of connectionNames) {
|
|
281
|
+
const success = await runMigrationsForConnection(connectionName, isTest, modelName, dryRun);
|
|
282
|
+
(0, AuditTrail_1.appendAuditEvent)({
|
|
283
|
+
command: auditCommand,
|
|
284
|
+
connectionName,
|
|
285
|
+
test: isTest,
|
|
286
|
+
result: success ? "success" : "failure",
|
|
287
|
+
metadata: {
|
|
288
|
+
modelName: modelName ?? null,
|
|
289
|
+
dryRun,
|
|
290
|
+
},
|
|
291
|
+
});
|
|
292
|
+
if (!success) {
|
|
293
|
+
hadFailure = true;
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
if (hadFailure) {
|
|
297
|
+
process.exitCode = 1;
|
|
298
|
+
}
|
|
299
|
+
exitCli();
|
|
300
|
+
}
|
|
301
|
+
//# sourceMappingURL=migrateRun.js.map
|