@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
JavaScript
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"]}