UNPKG

@wocker/core

Version:
63 lines (62 loc) 2.46 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.LogService = void 0; const format_1 = require("date-fns/format"); const decorators_1 = require("../decorators"); const AppConfigService_1 = require("./AppConfigService"); const AppFileSystemService_1 = require("./AppFileSystemService"); let LogService = class LogService { constructor(appConfigService, fs) { this.appConfigService = appConfigService; this.fs = fs; } get logName() { return "ws.log"; } _log(type, ...data) { if (type === "debug" && !this.appConfigService.config.debug) { return; } const time = (0, format_1.format)(new Date(), "yyyy-MM-dd HH:mm:ss"); const logData = data.map((item) => { return typeof item !== "string" ? JSON.stringify(item) : item; }).join(" "); if (!this.fs.exists(this.logName)) { this.fs.writeFile(this.logName, ""); } this.fs.appendFile(this.logName, `[${time}] ${type}: ${logData}\n`); } debug(...data) { this._log("debug", ...data); } log(...data) { this._log("log", ...data); } info(...data) { this._log("info", ...data); } warn(...data) { this._log("warn", ...data); } error(...data) { this._log("error", ...data); } clear() { this.fs.writeFile(this.logName, ""); } }; exports.LogService = LogService; exports.LogService = LogService = __decorate([ (0, decorators_1.Injectable)("LOG_SERVICE"), __metadata("design:paramtypes", [AppConfigService_1.AppConfigService, AppFileSystemService_1.AppFileSystemService]) ], LogService);