| "use strict"; | 
| Object.defineProperty(exports, "__esModule", { value: true }); | 
| var PlatformTools_1 = require("../platform/PlatformTools"); | 
| /** | 
|  * Performs logging of the events in TypeORM via debug library. | 
|  */ | 
| var DebugLogger = /** @class */ (function () { | 
|     function DebugLogger() { | 
|         this.debug = PlatformTools_1.PlatformTools.load("debug"); | 
|         this.debugQueryLog = this.debug("typeorm:query:log"); | 
|         this.debugQueryError = this.debug("typeorm:query:error"); | 
|         this.debugQuerySlow = this.debug("typeorm:query:slow"); | 
|         this.debugSchemaBuild = this.debug("typeorm:schema"); | 
|         this.debugMigration = this.debug("typeorm:migration"); | 
|         this.debugLog = this.debug("typeorm:log"); | 
|         this.debugInfo = this.debug("typeorm:info"); | 
|         this.debugWarn = this.debug("typeorm:warn"); | 
|     } | 
|     /** | 
|      * Logs query and parameters used in it. | 
|      */ | 
|     DebugLogger.prototype.logQuery = function (query, parameters, queryRunner) { | 
|         if (this.debugQueryLog.enabled) { | 
|             this.debugQueryLog(PlatformTools_1.PlatformTools.highlightSql(query) + ";"); | 
|             if (parameters && parameters.length) { | 
|                 this.debugQueryLog("parameters:", parameters); | 
|             } | 
|         } | 
|     }; | 
|     /** | 
|      * Logs query that failed. | 
|      */ | 
|     DebugLogger.prototype.logQueryError = function (error, query, parameters, queryRunner) { | 
|         if (this.debugQueryError.enabled) { | 
|             this.debugQueryError(PlatformTools_1.PlatformTools.highlightSql(query) + ";"); | 
|             if (parameters && parameters.length) { | 
|                 this.debugQueryError("parameters:", parameters); | 
|             } | 
|             this.debugQueryError("error: ", error); | 
|         } | 
|     }; | 
|     /** | 
|      * Logs query that is slow. | 
|      */ | 
|     DebugLogger.prototype.logQuerySlow = function (time, query, parameters, queryRunner) { | 
|         if (this.debugQuerySlow.enabled) { | 
|             this.debugQuerySlow(PlatformTools_1.PlatformTools.highlightSql(query) + ";"); | 
|             if (parameters && parameters.length) { | 
|                 this.debugQuerySlow("parameters:", parameters); | 
|             } | 
|             this.debugQuerySlow("execution time:", time); | 
|         } | 
|     }; | 
|     /** | 
|      * Logs events from the schema build process. | 
|      */ | 
|     DebugLogger.prototype.logSchemaBuild = function (message, queryRunner) { | 
|         if (this.debugSchemaBuild.enabled) { | 
|             this.debugSchemaBuild(message); | 
|         } | 
|     }; | 
|     /** | 
|      * Logs events from the migration run process. | 
|      */ | 
|     DebugLogger.prototype.logMigration = function (message, queryRunner) { | 
|         if (this.debugMigration.enabled) { | 
|             this.debugMigration(message); | 
|         } | 
|     }; | 
|     /** | 
|      * Perform logging using given logger. | 
|      * Log has its own level and message. | 
|      */ | 
|     DebugLogger.prototype.log = function (level, message, queryRunner) { | 
|         switch (level) { | 
|             case "log": | 
|                 if (this.debugLog.enabled) { | 
|                     this.debugLog(message); | 
|                 } | 
|                 break; | 
|             case "info": | 
|                 if (this.debugInfo.enabled) { | 
|                     this.debugInfo(message); | 
|                 } | 
|                 break; | 
|             case "warn": | 
|                 if (this.debugWarn.enabled) { | 
|                     this.debugWarn(message); | 
|                 } | 
|                 break; | 
|         } | 
|     }; | 
|     return DebugLogger; | 
| }()); | 
| exports.DebugLogger = DebugLogger; | 
|   | 
| //# sourceMappingURL=DebugLogger.js.map |