UNPKG

@cute-dw/core

Version:

This TypeScript library is the main part of a more powerfull package designed for the fast WEB software development. The cornerstone of the library is the **DataStore** class, which might be useful when you need a full control of the data, but do not need

122 lines 14.6 kB
import { Injectable, InjectionToken } from '@angular/core'; import { debounceTime, filter, Subject } from 'rxjs'; import { DateFormat } from '../util/i18n/text/DateFormat'; import { SimpleDateFormat } from '../util/i18n/text/SimpleDateFormat'; import * as i0 from "@angular/core"; export const LOGGER = new InjectionToken("logger"); export var LogLevel; (function (LogLevel) { LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG"; LogLevel[LogLevel["INFO"] = 1] = "INFO"; LogLevel[LogLevel["LOG"] = 2] = "LOG"; LogLevel[LogLevel["WARN"] = 3] = "WARN"; LogLevel[LogLevel["ERROR"] = 4] = "ERROR"; LogLevel[LogLevel["FATAL"] = 5] = "FATAL"; })(LogLevel || (LogLevel = {})); var LoggerEvents; (function (LoggerEvents) { LoggerEvents[LoggerEvents["Flush"] = 1] = "Flush"; })(LoggerEvents || (LoggerEvents = {})); /** * A logging service class that is able to send logs to the browser console and to the server URL address */ export class LogService { constructor() { this.logLevel = LogLevel.INFO; this.serverLogLevel = LogLevel.WARN; this.useServer = false; this._buffer = []; this._flush = new Subject(); this._dateFormat = new SimpleDateFormat(DateFormat.ISODATETIMETZ); this._subscription = this._flush .pipe(debounceTime(5000), filter((event) => event === LoggerEvents.Flush)) .subscribe(() => this.flushBuffer()); } static getLogger(name) { let logger = this._map.get(name); if (!logger) { logger = new LogService(); logger.name = name; this._map.set(name, logger); } return logger; } flushBuffer() { const data = this._buffer.splice(0); if (data.length === 0) { return; } const body = "[" + data .map((entry) => this.buildLogString(entry)) .reduce((json, entry) => (json += entry + ","), '') + "]"; const xobj = new XMLHttpRequest(); xobj.onerror = (err) => console.error(err); xobj.open('POST', this.serverEndPoint, true); xobj.send(body); } buildLogString(entry) { return JSON.stringify(entry); } debug(message) { this.logMessage(LogLevel.DEBUG, message); } log(message) { this.logMessage(LogLevel.LOG, message); } info(message) { this.logMessage(LogLevel.INFO, message); } warn(message) { this.logMessage(LogLevel.WARN, message); } error(message) { this.logMessage(LogLevel.ERROR, message); } fatal(message) { this.logMessage(LogLevel.FATAL, message); } logMessage(level, message) { const timestamp = this._dateFormat.format(Date.now()); if (this.useServer && this.serverEndPoint) { if (level >= this.serverLogLevel) { this._buffer.push({ timestamp, level, message }); this._flush.next(LoggerEvents.Flush); } } else if (level >= this.logLevel) { const msg = `${timestamp} ${this.name} ${LogLevel[level]}: ${message}`; switch (level) { case LogLevel.DEBUG: console.debug(msg); break; case LogLevel.INFO: console.info(msg); break; case LogLevel.WARN: console.warn(msg); break; case LogLevel.ERROR: case LogLevel.FATAL: console.error(msg); break; default: console.log(msg); } } } destroy() { this._subscription.unsubscribe(); } } LogService._map = new Map(); LogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: LogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); LogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: LogService, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: LogService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: function () { return []; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"log.service.js","sourceRoot":"","sources":["../../../../../projects/cute-core/src/lib/services/log.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, InjectionToken } from '@angular/core';\nimport { debounceTime, filter, Subject, Subscription } from 'rxjs';\nimport { DateFormat } from '../util/i18n/text/DateFormat';\nimport { SimpleDateFormat } from '../util/i18n/text/SimpleDateFormat';\n\nexport const LOGGER = new InjectionToken<LogService>(\"logger\");\n\nexport enum LogLevel {\n  DEBUG,\n  INFO,\n  LOG,\n  WARN,\n  ERROR,\n  FATAL\n}\n\nenum LoggerEvents {\n  Flush = 1\n}\n\ninterface LogEntry {\n  timestamp: string;\n  level: LogLevel;\n  message: string;\n  data?: any;\n}\n\n/**\n * A logging service class that is able to send logs to the browser console and to the server URL address\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class LogService {\n\n  private static _map = new Map<string, LogService>();\n\n\n  logLevel: LogLevel = LogLevel.INFO;\n  serverLogLevel: LogLevel = LogLevel.WARN;\n  serverEndPoint: string | undefined;\n\n  name?: string;\n  useServer: boolean = false;\n\n  private _buffer: LogEntry[] = [];\n  private _flush = new Subject<LoggerEvents>();\n  private _dateFormat = new SimpleDateFormat(DateFormat.ISODATETIMETZ);\n  private _subscription: Subscription;\n\n  constructor() {\n    this._subscription = this._flush\n      .pipe(\n        debounceTime(5000),\n        filter((event) => event === LoggerEvents.Flush))\n      .subscribe(\n        () => this.flushBuffer()\n      );\n  }\n\n  static getLogger(name: string): LogService {\n    let logger: LogService | undefined = this._map.get(name);\n    if (!logger) {\n      logger = new LogService();\n      logger.name = name;\n      this._map.set(name, logger);\n    }\n    return logger;\n  }\n\n  private flushBuffer() {\n    const data = this._buffer.splice(0);\n\n    if (data.length === 0) {\n      return;\n    }\n\n    const body = \"[\"\n                  + data\n                    .map((entry) => this.buildLogString(entry))\n                    .reduce((json, entry) => (json += entry + \",\"), '')\n                  + \"]\";\n\n    const xobj = new XMLHttpRequest();\n    xobj.onerror = (err) => console.error(err);\n    xobj.open('POST', this.serverEndPoint!, true);\n    xobj.send(body);\n\n  }\n\n  protected buildLogString(entry: LogEntry): string {\n    return JSON.stringify(entry);\n  }\n\n  debug(message: string) {\n    this.logMessage(LogLevel.DEBUG, message);\n  }\n\n  log(message: string) {\n    this.logMessage(LogLevel.LOG, message);\n  }\n\n  info(message: string) {\n    this.logMessage(LogLevel.INFO, message);\n  }\n\n  warn(message: string) {\n    this.logMessage(LogLevel.WARN, message);\n  }\n\n  error(message: string) {\n    this.logMessage(LogLevel.ERROR, message);\n  }\n\n  fatal(message: string) {\n    this.logMessage(LogLevel.FATAL, message);\n  }\n\n  logMessage(level: LogLevel, message: string) {\n    const timestamp = this._dateFormat.format(Date.now());\n    if (this.useServer && this.serverEndPoint) {\n      if (level >= this.serverLogLevel) {\n        this._buffer.push({ timestamp, level, message });\n        this._flush.next(LoggerEvents.Flush);\n      }\n    } else if (level >= this.logLevel) {\n      const msg = `${timestamp} ${this.name} ${LogLevel[level]}: ${message}`;\n      switch (level) {\n        case LogLevel.DEBUG:  console.debug(msg); break;\n        case LogLevel.INFO:   console.info(msg);  break;\n        case LogLevel.WARN:   console.warn(msg);  break;\n        case LogLevel.ERROR:\n        case LogLevel.FATAL:  console.error(msg); break;\n        default:\n          console.log(msg);\n      }\n    }\n  }\n\n  destroy() {\n    this._subscription.unsubscribe();\n  }\n\n}\n"]}