@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,171 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resolveDbExecutionRole = resolveDbExecutionRole;
|
|
4
|
+
exports.resolveMysqlEnv = resolveMysqlEnv;
|
|
5
|
+
exports.resolvePgEnv = resolvePgEnv;
|
|
6
|
+
exports.resolveSqlitePath = resolveSqlitePath;
|
|
7
|
+
exports.resolveMongoEnv = resolveMongoEnv;
|
|
8
|
+
function pickFirstDefined(env, keys, fallback) {
|
|
9
|
+
for (const key of keys) {
|
|
10
|
+
const value = env[key];
|
|
11
|
+
if (value !== undefined && value !== "") {
|
|
12
|
+
return value;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return fallback;
|
|
16
|
+
}
|
|
17
|
+
function pickFirstNumber(env, keys, fallback) {
|
|
18
|
+
const raw = pickFirstDefined(env, keys, String(fallback));
|
|
19
|
+
const parsed = Number(raw);
|
|
20
|
+
return Number.isFinite(parsed) ? parsed : fallback;
|
|
21
|
+
}
|
|
22
|
+
function pickFirstList(env, keys) {
|
|
23
|
+
const raw = pickFirstDefined(env, keys, "");
|
|
24
|
+
if (!raw)
|
|
25
|
+
return [];
|
|
26
|
+
return raw
|
|
27
|
+
.split(",")
|
|
28
|
+
.map((value) => value.trim())
|
|
29
|
+
.filter((value) => value.length > 0);
|
|
30
|
+
}
|
|
31
|
+
function resolveDbExecutionRole(env = process.env) {
|
|
32
|
+
const value = String(env.ELOQUENT_DB_ROLE ?? "runtime")
|
|
33
|
+
.trim()
|
|
34
|
+
.toLowerCase();
|
|
35
|
+
return value === "migration" ? "migration" : "runtime";
|
|
36
|
+
}
|
|
37
|
+
function resolveMysqlEnv(env = process.env, options = {}) {
|
|
38
|
+
const role = resolveDbExecutionRole(env);
|
|
39
|
+
const isTest = !!options.test;
|
|
40
|
+
const roleKey = role === "migration" ? "MIGRATION" : "RUNTIME";
|
|
41
|
+
const prefix = isTest ? "DB_TEST" : "DB";
|
|
42
|
+
const host = pickFirstDefined(env, [
|
|
43
|
+
`${prefix}_${roleKey}_HOST`,
|
|
44
|
+
`${prefix}_HOST`,
|
|
45
|
+
`DB_${roleKey}_HOST`,
|
|
46
|
+
"DB_HOST",
|
|
47
|
+
], "localhost");
|
|
48
|
+
const user = pickFirstDefined(env, [
|
|
49
|
+
`${prefix}_${roleKey}_USER`,
|
|
50
|
+
`${prefix}_USER`,
|
|
51
|
+
`DB_${roleKey}_USER`,
|
|
52
|
+
"DB_USER",
|
|
53
|
+
], "root");
|
|
54
|
+
const password = pickFirstDefined(env, [
|
|
55
|
+
`${prefix}_${roleKey}_PASSWORD`,
|
|
56
|
+
`${prefix}_PASSWORD`,
|
|
57
|
+
`DB_${roleKey}_PASSWORD`,
|
|
58
|
+
"DB_PASSWORD",
|
|
59
|
+
], "");
|
|
60
|
+
const database = pickFirstDefined(env, [
|
|
61
|
+
`${prefix}_${roleKey}_NAME`,
|
|
62
|
+
`${prefix}_${roleKey}_DB_NAME`,
|
|
63
|
+
`${prefix}_NAME`,
|
|
64
|
+
`${prefix}_DB_NAME`,
|
|
65
|
+
`DB_${roleKey}_NAME`,
|
|
66
|
+
`DB_${roleKey}_DB_NAME`,
|
|
67
|
+
"DB_NAME",
|
|
68
|
+
], isTest ? "db_test" : "eloquentjs");
|
|
69
|
+
const port = pickFirstNumber(env, [
|
|
70
|
+
`${prefix}_${roleKey}_PORT`,
|
|
71
|
+
`${prefix}_PORT`,
|
|
72
|
+
`DB_${roleKey}_PORT`,
|
|
73
|
+
"DB_PORT",
|
|
74
|
+
], 3306);
|
|
75
|
+
return {
|
|
76
|
+
host,
|
|
77
|
+
user,
|
|
78
|
+
password,
|
|
79
|
+
database,
|
|
80
|
+
port,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
function resolvePgEnv(env = process.env, options = {}) {
|
|
84
|
+
const role = resolveDbExecutionRole(env);
|
|
85
|
+
const isTest = !!options.test;
|
|
86
|
+
const roleKey = role === "migration" ? "MIGRATION" : "RUNTIME";
|
|
87
|
+
const prefix = isTest ? "PG_TEST" : "PG";
|
|
88
|
+
const host = pickFirstDefined(env, [
|
|
89
|
+
`${prefix}_${roleKey}_HOST`,
|
|
90
|
+
`${prefix}_HOST`,
|
|
91
|
+
`PG_${roleKey}_HOST`,
|
|
92
|
+
"PG_HOST",
|
|
93
|
+
], "localhost");
|
|
94
|
+
const user = pickFirstDefined(env, [
|
|
95
|
+
`${prefix}_${roleKey}_USER`,
|
|
96
|
+
`${prefix}_USER`,
|
|
97
|
+
`PG_${roleKey}_USER`,
|
|
98
|
+
"PG_USER",
|
|
99
|
+
], "postgres");
|
|
100
|
+
const password = pickFirstDefined(env, [
|
|
101
|
+
`${prefix}_${roleKey}_PASSWORD`,
|
|
102
|
+
`${prefix}_PASSWORD`,
|
|
103
|
+
`PG_${roleKey}_PASSWORD`,
|
|
104
|
+
"PG_PASSWORD",
|
|
105
|
+
], "");
|
|
106
|
+
const database = pickFirstDefined(env, [
|
|
107
|
+
`${prefix}_${roleKey}_NAME`,
|
|
108
|
+
`${prefix}_${roleKey}_DB_NAME`,
|
|
109
|
+
`${prefix}_NAME`,
|
|
110
|
+
`${prefix}_DB_NAME`,
|
|
111
|
+
`PG_${roleKey}_NAME`,
|
|
112
|
+
`PG_${roleKey}_DB_NAME`,
|
|
113
|
+
"PG_NAME",
|
|
114
|
+
"PG_DB_NAME",
|
|
115
|
+
], isTest ? "db_test_pg" : "test_db");
|
|
116
|
+
const port = pickFirstNumber(env, [
|
|
117
|
+
`${prefix}_${roleKey}_PORT`,
|
|
118
|
+
`${prefix}_PORT`,
|
|
119
|
+
`PG_${roleKey}_PORT`,
|
|
120
|
+
"PG_PORT",
|
|
121
|
+
], 5432);
|
|
122
|
+
return {
|
|
123
|
+
host,
|
|
124
|
+
user,
|
|
125
|
+
password,
|
|
126
|
+
database,
|
|
127
|
+
port,
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
function resolveSqlitePath(env = process.env, options = {}) {
|
|
131
|
+
const role = resolveDbExecutionRole(env);
|
|
132
|
+
const isTest = !!options.test;
|
|
133
|
+
const roleKey = role === "migration" ? "MIGRATION" : "RUNTIME";
|
|
134
|
+
const prefix = isTest ? "SQLITE_TEST" : "SQLITE";
|
|
135
|
+
return pickFirstDefined(env, [
|
|
136
|
+
`${prefix}_${roleKey}_PATH`,
|
|
137
|
+
`${prefix}_PATH`,
|
|
138
|
+
`SQLITE_${roleKey}_PATH`,
|
|
139
|
+
"SQLITE_PATH",
|
|
140
|
+
], isTest ? "./data.test.sqlite" : "./data.sqlite");
|
|
141
|
+
}
|
|
142
|
+
function resolveMongoEnv(env = process.env, options = {}) {
|
|
143
|
+
const role = resolveDbExecutionRole(env);
|
|
144
|
+
const isTest = !!options.test;
|
|
145
|
+
const roleKey = role === "migration" ? "MIGRATION" : "RUNTIME";
|
|
146
|
+
const prefix = isTest ? "MONGO_TEST" : "MONGO";
|
|
147
|
+
const uri = pickFirstDefined(env, [
|
|
148
|
+
`${prefix}_${roleKey}_URI`,
|
|
149
|
+
`${prefix}_URI`,
|
|
150
|
+
`MONGO_${roleKey}_URI`,
|
|
151
|
+
"MONGO_URI",
|
|
152
|
+
], "mongodb://localhost:27017");
|
|
153
|
+
const database = pickFirstDefined(env, [
|
|
154
|
+
`${prefix}_${roleKey}_DB`,
|
|
155
|
+
`${prefix}_${roleKey}_DATABASE`,
|
|
156
|
+
`${prefix}_DB`,
|
|
157
|
+
`${prefix}_DATABASE`,
|
|
158
|
+
`MONGO_${roleKey}_DB`,
|
|
159
|
+
`MONGO_${roleKey}_DATABASE`,
|
|
160
|
+
"MONGO_DB",
|
|
161
|
+
"MONGO_DATABASE",
|
|
162
|
+
], isTest ? "eloquentjs_db_test" : "eloquentjs_db");
|
|
163
|
+
const dnsServers = pickFirstList(env, [
|
|
164
|
+
`${prefix}_${roleKey}_DNS_SERVERS`,
|
|
165
|
+
`${prefix}_DNS_SERVERS`,
|
|
166
|
+
`MONGO_${roleKey}_DNS_SERVERS`,
|
|
167
|
+
"MONGO_DNS_SERVERS",
|
|
168
|
+
]);
|
|
169
|
+
return { uri, database, dnsServers };
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=dbRoleEnv.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dbRoleEnv.js","sourceRoot":"","sources":["../../src/config/dbRoleEnv.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 🧠CacheAnalytics
|
|
3
|
+
* Tracks cache hit/miss counts and dynamically tunes TTLs per model.
|
|
4
|
+
* Minimal overhead — O(1) map updates.
|
|
5
|
+
*/
|
|
6
|
+
export declare class CacheAnalytics {
|
|
7
|
+
private static stats;
|
|
8
|
+
private static adjustInterval;
|
|
9
|
+
private static minTTL;
|
|
10
|
+
private static maxTTL;
|
|
11
|
+
private static counter;
|
|
12
|
+
/**
|
|
13
|
+
* Record a cache hit.
|
|
14
|
+
*/
|
|
15
|
+
static hit(model: string, currentTTL: number): void;
|
|
16
|
+
/**
|
|
17
|
+
* Record a cache miss.
|
|
18
|
+
*/
|
|
19
|
+
static miss(model: string, currentTTL: number): void;
|
|
20
|
+
/**
|
|
21
|
+
* Initialize model stats if missing.
|
|
22
|
+
*/
|
|
23
|
+
private static ensureModel;
|
|
24
|
+
/**
|
|
25
|
+
* Check if it's time to adjust TTLs (every N operations).
|
|
26
|
+
*/
|
|
27
|
+
private static checkAdjust;
|
|
28
|
+
/**
|
|
29
|
+
* Core logic: tune TTL based on hit/miss ratio.
|
|
30
|
+
*/
|
|
31
|
+
private static adjustTTL;
|
|
32
|
+
/**
|
|
33
|
+
* Optional: expose stats for monitoring.
|
|
34
|
+
*/
|
|
35
|
+
static getStats(): {
|
|
36
|
+
model: string;
|
|
37
|
+
hits: number;
|
|
38
|
+
misses: number;
|
|
39
|
+
ttl: number;
|
|
40
|
+
lastAdjust: string;
|
|
41
|
+
}[];
|
|
42
|
+
/**
|
|
43
|
+
* Reset all collected cache analytics counters.
|
|
44
|
+
*/
|
|
45
|
+
static reset(): void;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=CacheAnalytics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheAnalytics.d.ts","sourceRoot":"","sources":["../../../src/core/cache/CacheAnalytics.ts"],"names":[],"mappings":"AACA;;;;GAIG;AASH,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAsC;IAC1D,OAAO,CAAC,MAAM,CAAC,cAAc,CAAO;IACpC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAM;IAC3B,OAAO,CAAC,MAAM,CAAC,MAAM,CAAQ;IAC7B,OAAO,CAAC,MAAM,CAAC,OAAO,CAAK;IAE3B;;OAEG;IACH,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAM5C;;OAEG;IACH,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAM7C;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,WAAW;IAW1B;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,WAAW;IAO1B;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,SAAS;IA2CxB;;OAEG;IACH,MAAM,CAAC,QAAQ;;;;;;;IAUf;;OAEG;IACH,MAAM,CAAC,KAAK,IAAI,IAAI;CAIrB"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// src/core/cache/CacheAnalytics.ts
|
|
3
|
+
/**
|
|
4
|
+
* 🧠CacheAnalytics
|
|
5
|
+
* Tracks cache hit/miss counts and dynamically tunes TTLs per model.
|
|
6
|
+
* Minimal overhead — O(1) map updates.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.CacheAnalytics = void 0;
|
|
10
|
+
class CacheAnalytics {
|
|
11
|
+
/**
|
|
12
|
+
* Record a cache hit.
|
|
13
|
+
*/
|
|
14
|
+
static hit(model, currentTTL) {
|
|
15
|
+
this.ensureModel(model, currentTTL);
|
|
16
|
+
this.stats.get(model).hits++;
|
|
17
|
+
this.checkAdjust(model);
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Record a cache miss.
|
|
21
|
+
*/
|
|
22
|
+
static miss(model, currentTTL) {
|
|
23
|
+
this.ensureModel(model, currentTTL);
|
|
24
|
+
this.stats.get(model).misses++;
|
|
25
|
+
this.checkAdjust(model);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Initialize model stats if missing.
|
|
29
|
+
*/
|
|
30
|
+
static ensureModel(model, ttl) {
|
|
31
|
+
if (!this.stats.has(model)) {
|
|
32
|
+
this.stats.set(model, {
|
|
33
|
+
hits: 0,
|
|
34
|
+
misses: 0,
|
|
35
|
+
currentTTL: ttl,
|
|
36
|
+
lastAdjust: Date.now(),
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Check if it's time to adjust TTLs (every N operations).
|
|
42
|
+
*/
|
|
43
|
+
static checkAdjust(model) {
|
|
44
|
+
this.counter++;
|
|
45
|
+
if (this.counter % this.adjustInterval === 0) {
|
|
46
|
+
this.adjustTTL(model);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Core logic: tune TTL based on hit/miss ratio.
|
|
51
|
+
*/
|
|
52
|
+
static adjustTTL(model) {
|
|
53
|
+
const stat = this.stats.get(model);
|
|
54
|
+
if (!stat)
|
|
55
|
+
return;
|
|
56
|
+
const total = stat.hits + stat.misses;
|
|
57
|
+
if (total === 0)
|
|
58
|
+
return;
|
|
59
|
+
const hitRate = stat.hits / total;
|
|
60
|
+
let newTTL = stat.currentTTL;
|
|
61
|
+
// 🧮 Adjust TTL by hit rate thresholds
|
|
62
|
+
if (hitRate > 0.8)
|
|
63
|
+
newTTL *= 1.25; // increase by 25%
|
|
64
|
+
else if (hitRate < 0.4)
|
|
65
|
+
newTTL *= 0.75; // decrease by 25%
|
|
66
|
+
// Clamp to safe bounds
|
|
67
|
+
newTTL = Math.min(this.maxTTL, Math.max(this.minTTL, Math.round(newTTL)));
|
|
68
|
+
if (newTTL !== stat.currentTTL) {
|
|
69
|
+
console.log(`[CacheAnalytics] ${model} hitRate=${(hitRate * 100).toFixed(1)}% → TTL ${stat.currentTTL}s → ${newTTL}s`);
|
|
70
|
+
stat.currentTTL = newTTL;
|
|
71
|
+
stat.lastAdjust = Date.now();
|
|
72
|
+
// Try updating model’s default TTL (if class loaded)
|
|
73
|
+
try {
|
|
74
|
+
const ModelClass = global.EloquentModels?.[model];
|
|
75
|
+
if (ModelClass) {
|
|
76
|
+
ModelClass.defaultCacheTTL = newTTL;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
catch {
|
|
80
|
+
// ignore
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// Reset counters for next cycle
|
|
84
|
+
stat.hits = 0;
|
|
85
|
+
stat.misses = 0;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Optional: expose stats for monitoring.
|
|
89
|
+
*/
|
|
90
|
+
static getStats() {
|
|
91
|
+
return Array.from(this.stats.entries()).map(([model, s]) => ({
|
|
92
|
+
model,
|
|
93
|
+
hits: s.hits,
|
|
94
|
+
misses: s.misses,
|
|
95
|
+
ttl: s.currentTTL,
|
|
96
|
+
lastAdjust: new Date(s.lastAdjust).toISOString(),
|
|
97
|
+
}));
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Reset all collected cache analytics counters.
|
|
101
|
+
*/
|
|
102
|
+
static reset() {
|
|
103
|
+
this.stats.clear();
|
|
104
|
+
this.counter = 0;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
exports.CacheAnalytics = CacheAnalytics;
|
|
108
|
+
CacheAnalytics.stats = new Map();
|
|
109
|
+
CacheAnalytics.adjustInterval = 100; // adjust every 100 cache ops
|
|
110
|
+
CacheAnalytics.minTTL = 30; // seconds
|
|
111
|
+
CacheAnalytics.maxTTL = 3600; // seconds
|
|
112
|
+
CacheAnalytics.counter = 0;
|
|
113
|
+
//# sourceMappingURL=CacheAnalytics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheAnalytics.js","sourceRoot":"","sources":["../../../src/core/cache/CacheAnalytics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export declare abstract class CacheDriver {
|
|
2
|
+
/**
|
|
3
|
+
* Return parsed value or null if not found.
|
|
4
|
+
*/
|
|
5
|
+
abstract get<T = any>(key: string): Promise<T | null>;
|
|
6
|
+
/**
|
|
7
|
+
* Store value for `ttl` seconds. ttl === 0 => no expiration.
|
|
8
|
+
*/
|
|
9
|
+
abstract set<T = any>(key: string, value: T, ttl?: number): Promise<void>;
|
|
10
|
+
/**
|
|
11
|
+
* Delete a key.
|
|
12
|
+
*/
|
|
13
|
+
abstract delete(key: string): Promise<void>;
|
|
14
|
+
/**
|
|
15
|
+
* Clear all keys (use carefully).
|
|
16
|
+
*/
|
|
17
|
+
abstract clear(): Promise<void>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=CacheDriver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheDriver.d.ts","sourceRoot":"","sources":["../../../src/core/cache/CacheDriver.ts"],"names":[],"mappings":"AACA,8BAAsB,WAAW;IAC/B;;OAEG;IACH,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAErD;;OAEG;IACH,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAEzE;;OAEG;IACH,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAE3C;;OAEG;IACH,QAAQ,CAAC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAChC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheDriver.js","sourceRoot":"","sources":["../../../src/core/cache/CacheDriver.ts"],"names":[],"mappings":";;;AAAA,gCAAgC;AAChC,MAAsB,WAAW;CAoBhC;AApBD,kCAoBC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { CacheDriver } from "./CacheDriver";
|
|
2
|
+
export declare class CacheFallbackManager {
|
|
3
|
+
private static drivers;
|
|
4
|
+
private static active;
|
|
5
|
+
private static readonly opTimeoutMs;
|
|
6
|
+
/**
|
|
7
|
+
* Register fallback chain: first = primary, last = backup
|
|
8
|
+
*/
|
|
9
|
+
static useChain(drivers: CacheDriver[]): void;
|
|
10
|
+
static getActiveDriver(): CacheDriver | null;
|
|
11
|
+
static getDrivers(): CacheDriver[];
|
|
12
|
+
private static runWithTimeout;
|
|
13
|
+
/**
|
|
14
|
+
* Try an operation on each driver in order until success.
|
|
15
|
+
*/
|
|
16
|
+
private static tryChain;
|
|
17
|
+
static get<T>(key: string): Promise<T | null>;
|
|
18
|
+
static set<T>(key: string, value: T, ttl?: number): Promise<void>;
|
|
19
|
+
static delete(key: string): Promise<void>;
|
|
20
|
+
static clear(): Promise<void>;
|
|
21
|
+
/**
|
|
22
|
+
* Clear every driver in the fallback chain (not only active/first-success).
|
|
23
|
+
*/
|
|
24
|
+
static clearAllDrivers(): Promise<Array<{
|
|
25
|
+
driver: string;
|
|
26
|
+
ok: boolean;
|
|
27
|
+
error?: string;
|
|
28
|
+
}>>;
|
|
29
|
+
static shutdownDrivers(): Promise<Array<{
|
|
30
|
+
driver: string;
|
|
31
|
+
closed: boolean;
|
|
32
|
+
error?: string;
|
|
33
|
+
}>>;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=CacheFallbackManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheFallbackManager.d.ts","sourceRoot":"","sources":["../../../src/core/cache/CacheFallbackManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,MAAM,CAAC,OAAO,CAAqB;IAC3C,OAAO,CAAC,MAAM,CAAC,MAAM,CAA4B;IACjD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAQ;IAE3C;;OAEG;IACH,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,WAAW,EAAE;IAKtC,MAAM,CAAC,eAAe,IAAI,WAAW,GAAG,IAAI;IAI5C,MAAM,CAAC,UAAU,IAAI,WAAW,EAAE;mBAIb,cAAc;IAgBnC;;OAEG;mBACkB,QAAQ;WAmBhB,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;WAItC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,SAAK,GAAG,OAAO,CAAC,IAAI,CAAC;WAItD,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;WAIlC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAInC;;OAEG;WACU,eAAe,IAAI,OAAO,CACrC,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CACvD;WA8BY,eAAe,IAAI,OAAO,CACrC,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAC3D;CA8BF"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CacheFallbackManager = void 0;
|
|
4
|
+
class CacheFallbackManager {
|
|
5
|
+
/**
|
|
6
|
+
* Register fallback chain: first = primary, last = backup
|
|
7
|
+
*/
|
|
8
|
+
static useChain(drivers) {
|
|
9
|
+
this.drivers = drivers;
|
|
10
|
+
this.active = drivers[0];
|
|
11
|
+
}
|
|
12
|
+
static getActiveDriver() {
|
|
13
|
+
return this.active;
|
|
14
|
+
}
|
|
15
|
+
static getDrivers() {
|
|
16
|
+
return [...this.drivers];
|
|
17
|
+
}
|
|
18
|
+
static async runWithTimeout(task, timeoutMs = this.opTimeoutMs) {
|
|
19
|
+
const timedTask = task
|
|
20
|
+
.then(() => ({ timedOut: false }))
|
|
21
|
+
.catch((error) => ({ timedOut: false, error }));
|
|
22
|
+
const timeoutTask = new Promise((resolve) => {
|
|
23
|
+
setTimeout(() => resolve({ timedOut: true }), timeoutMs);
|
|
24
|
+
});
|
|
25
|
+
const result = await Promise.race([timedTask, timeoutTask]);
|
|
26
|
+
return result;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Try an operation on each driver in order until success.
|
|
30
|
+
*/
|
|
31
|
+
static async tryChain(fn, onFailure) {
|
|
32
|
+
for (const driver of this.drivers) {
|
|
33
|
+
try {
|
|
34
|
+
const result = await fn(driver);
|
|
35
|
+
this.active = driver;
|
|
36
|
+
return result;
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
onFailure?.(err, driver);
|
|
40
|
+
// try next
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
throw new Error("All cache drivers failed in fallback chain.");
|
|
44
|
+
}
|
|
45
|
+
// ----------- Public unified API -----------
|
|
46
|
+
static async get(key) {
|
|
47
|
+
return this.tryChain(async (d) => await d.get(key));
|
|
48
|
+
}
|
|
49
|
+
static async set(key, value, ttl = 60) {
|
|
50
|
+
await this.tryChain(async (d) => await d.set(key, value, ttl));
|
|
51
|
+
}
|
|
52
|
+
static async delete(key) {
|
|
53
|
+
await this.tryChain(async (d) => await d.delete(key));
|
|
54
|
+
}
|
|
55
|
+
static async clear() {
|
|
56
|
+
await this.tryChain(async (d) => await d.clear());
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Clear every driver in the fallback chain (not only active/first-success).
|
|
60
|
+
*/
|
|
61
|
+
static async clearAllDrivers() {
|
|
62
|
+
const results = [];
|
|
63
|
+
for (const driver of this.drivers) {
|
|
64
|
+
const outcome = await this.runWithTimeout(driver.clear());
|
|
65
|
+
if (outcome.timedOut) {
|
|
66
|
+
results.push({
|
|
67
|
+
driver: driver.constructor.name,
|
|
68
|
+
ok: false,
|
|
69
|
+
error: `timeout after ${this.opTimeoutMs}ms`,
|
|
70
|
+
});
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
if (outcome.error) {
|
|
74
|
+
results.push({
|
|
75
|
+
driver: driver.constructor.name,
|
|
76
|
+
ok: false,
|
|
77
|
+
error: outcome.error instanceof Error
|
|
78
|
+
? outcome.error.message
|
|
79
|
+
: String(outcome.error),
|
|
80
|
+
});
|
|
81
|
+
continue;
|
|
82
|
+
}
|
|
83
|
+
results.push({ driver: driver.constructor.name, ok: true });
|
|
84
|
+
}
|
|
85
|
+
return results;
|
|
86
|
+
}
|
|
87
|
+
static async shutdownDrivers() {
|
|
88
|
+
const results = [];
|
|
89
|
+
for (const driver of this.drivers) {
|
|
90
|
+
const closable = driver;
|
|
91
|
+
try {
|
|
92
|
+
if (typeof closable.close === "function") {
|
|
93
|
+
await closable.close();
|
|
94
|
+
}
|
|
95
|
+
else if (typeof closable.disconnect === "function") {
|
|
96
|
+
await closable.disconnect();
|
|
97
|
+
}
|
|
98
|
+
else if (typeof closable.end === "function") {
|
|
99
|
+
closable.end();
|
|
100
|
+
}
|
|
101
|
+
results.push({ driver: driver.constructor.name, closed: true });
|
|
102
|
+
}
|
|
103
|
+
catch (err) {
|
|
104
|
+
results.push({
|
|
105
|
+
driver: driver.constructor.name,
|
|
106
|
+
closed: false,
|
|
107
|
+
error: err instanceof Error ? err.message : String(err),
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
return results;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
exports.CacheFallbackManager = CacheFallbackManager;
|
|
115
|
+
CacheFallbackManager.drivers = [];
|
|
116
|
+
CacheFallbackManager.active = null;
|
|
117
|
+
CacheFallbackManager.opTimeoutMs = 3000;
|
|
118
|
+
//# sourceMappingURL=CacheFallbackManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheFallbackManager.js","sourceRoot":"","sources":["../../../src/core/cache/CacheFallbackManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CacheDriver } from "./CacheDriver";
|
|
2
|
+
export declare class CacheManager {
|
|
3
|
+
private static driver;
|
|
4
|
+
static use(driver: CacheDriver): void;
|
|
5
|
+
static getDriver(): CacheDriver;
|
|
6
|
+
static get<T = any>(key: string): Promise<T | null>;
|
|
7
|
+
static set<T = any>(key: string, value: T, ttl?: number): Promise<void>;
|
|
8
|
+
static delete(key: string): Promise<void>;
|
|
9
|
+
static clear(): Promise<void>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=CacheManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheManager.d.ts","sourceRoot":"","sources":["../../../src/core/cache/CacheManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAwC;IAE7D,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW;IAI9B,MAAM,CAAC,SAAS,IAAI,WAAW;WAIlB,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;WAI5C,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,SAAK,GAAG,OAAO,CAAC,IAAI,CAAC;WAI5D,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;WAIlC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGpC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CacheManager = void 0;
|
|
4
|
+
const MemoryCacheDriver_1 = require("./drivers/MemoryCacheDriver");
|
|
5
|
+
class CacheManager {
|
|
6
|
+
static use(driver) {
|
|
7
|
+
this.driver = driver;
|
|
8
|
+
}
|
|
9
|
+
static getDriver() {
|
|
10
|
+
return this.driver;
|
|
11
|
+
}
|
|
12
|
+
static async get(key) {
|
|
13
|
+
return this.driver.get(key);
|
|
14
|
+
}
|
|
15
|
+
static async set(key, value, ttl = 60) {
|
|
16
|
+
return this.driver.set(key, value, ttl);
|
|
17
|
+
}
|
|
18
|
+
static async delete(key) {
|
|
19
|
+
return this.driver.delete(key);
|
|
20
|
+
}
|
|
21
|
+
static async clear() {
|
|
22
|
+
return this.driver.clear();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.CacheManager = CacheManager;
|
|
26
|
+
CacheManager.driver = new MemoryCacheDriver_1.MemoryCacheDriver();
|
|
27
|
+
//# sourceMappingURL=CacheManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheManager.js","sourceRoot":"","sources":["../../../src/core/cache/CacheManager.ts"],"names":[],"mappings":";;;AAEA,mEAAgE;AAEhE,MAAa,YAAY;IAGvB,MAAM,CAAC,GAAG,CAAC,MAAmB;QAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,SAAS;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,GAAG,CAAU,GAAW;QACnC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAI,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,GAAG,CAAU,GAAW,EAAE,KAAQ,EAAE,GAAG,GAAG,EAAE;QACvD,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAI,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,GAAW;QAC7B,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IAC7B,CAAC;;AAzBH,oCA0BC;AAzBgB,mBAAM,GAAgB,IAAI,qCAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 🧩 CacheRegistry
|
|
3
|
+
* Keeps track of cache keys grouped by model and group name.
|
|
4
|
+
*
|
|
5
|
+
* Example:
|
|
6
|
+
* CacheRegistry.addKey('User', 'findMany', 'User:abcd1234');
|
|
7
|
+
* CacheRegistry.getKeys('User') => ['User:abcd1234', ...]
|
|
8
|
+
*/
|
|
9
|
+
export declare class CacheRegistry {
|
|
10
|
+
private static registry;
|
|
11
|
+
/**
|
|
12
|
+
* Return aggregated registry stats for CLI/monitoring.
|
|
13
|
+
*/
|
|
14
|
+
static getStats(): {
|
|
15
|
+
models: number;
|
|
16
|
+
groups: number;
|
|
17
|
+
keys: number;
|
|
18
|
+
groupsByModel: Array<{
|
|
19
|
+
model: string;
|
|
20
|
+
groups: number;
|
|
21
|
+
keys: number;
|
|
22
|
+
}>;
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Register a cache key for a given model and group.
|
|
26
|
+
*/
|
|
27
|
+
static addKey(modelName: string, group: string, key: string): void;
|
|
28
|
+
/**
|
|
29
|
+
* Return all cache keys for a model or model+group.
|
|
30
|
+
*/
|
|
31
|
+
static getKeys(modelName: string, group?: string): string[];
|
|
32
|
+
/**
|
|
33
|
+
* Remove a specific key from the registry.
|
|
34
|
+
*/
|
|
35
|
+
static removeKey(modelName: string, group: string, key: string): void;
|
|
36
|
+
/**
|
|
37
|
+
* Clear all keys for a model (invalidate model cache).
|
|
38
|
+
*/
|
|
39
|
+
static clearModel(modelName: string): Promise<void>;
|
|
40
|
+
/**
|
|
41
|
+
* Clear a specific group within a model (e.g., "findMany" or "where").
|
|
42
|
+
*/
|
|
43
|
+
static clearGroup(modelName: string, group: string): Promise<void>;
|
|
44
|
+
/**
|
|
45
|
+
* Clear the entire registry (dangerous: wipes all caches).
|
|
46
|
+
*/
|
|
47
|
+
static clearAll(): Promise<void>;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=CacheRegistry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CacheRegistry.d.ts","sourceRoot":"","sources":["../../../src/core/cache/CacheRegistry.ts"],"names":[],"mappings":"AAGA;;;;;;;GAOG;AACH,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAuC;IAE9D;;OAEG;IACH,MAAM,CAAC,QAAQ,IAAI;QACjB,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;QACb,aAAa,EAAE,KAAK,CAAC;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KACvE;IAyBD;;OAEG;IACH,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI;IAWlE;;OAEG;IACH,MAAM,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAkB3D;;OAEG;IACH,MAAM,CAAC,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI;IAYrE;;OAEG;WACU,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAWzD;;OAEG;WACU,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYxE;;OAEG;WACU,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAIvC"}
|