badmfck-api-server 2.6.1 → 2.6.3

Sign up to get free protection for your applications and to get access to all the features.
@@ -47,6 +47,9 @@ export declare const REQ_HTTP_SERVER: Req<void, {
47
47
  http: http.Server;
48
48
  }>;
49
49
  export declare const REQ_INTERNAL_CALL: Req<HTTPRequestVO, IError | any>;
50
+ export declare const REQ_MONITOR_USERS: Req<{
51
+ authorization: string;
52
+ }, any>;
50
53
  export declare function Initializer(services: IBaseService[]): Promise<void>;
51
54
  export declare class APIService extends BaseService {
52
55
  private static nextLogID;
@@ -26,7 +26,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
26
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.APIService = exports.Initializer = exports.REQ_INTERNAL_CALL = exports.REQ_HTTP_SERVER = exports.REQ_HTTP_REQUESTS_COUNT = exports.REQ_HTTP_LOG = exports.REQ_CREATE_NET_LOG = exports.getDefaultOptions = void 0;
29
+ exports.APIService = exports.Initializer = exports.REQ_MONITOR_USERS = exports.REQ_INTERNAL_CALL = exports.REQ_HTTP_SERVER = exports.REQ_HTTP_REQUESTS_COUNT = exports.REQ_HTTP_LOG = exports.REQ_CREATE_NET_LOG = exports.getDefaultOptions = void 0;
30
30
  const express_1 = __importDefault(require("express"));
31
31
  const BaseService_1 = require("./BaseService");
32
32
  const cors_1 = __importDefault(require("cors"));
@@ -43,6 +43,8 @@ const os_1 = __importDefault(require("os"));
43
43
  const Liveness_1 = require("./routes/Liveness");
44
44
  const Readiness_1 = require("./routes/Readiness");
45
45
  const http_1 = __importDefault(require("http"));
46
+ const MysqlService_1 = require("./MysqlService");
47
+ const StatService_1 = require("./StatService");
46
48
  function getDefaultOptions() {
47
49
  return {
48
50
  port: 8091,
@@ -69,9 +71,11 @@ exports.REQ_HTTP_LOG = new badmfck_signal_1.Req(undefined, "REQ_HTTP_LOG");
69
71
  exports.REQ_HTTP_REQUESTS_COUNT = new badmfck_signal_1.Req(undefined, "REQ_HTTP_REQUESTS_COUNT");
70
72
  exports.REQ_HTTP_SERVER = new badmfck_signal_1.Req(undefined, "REQ_HTTP_SERVER");
71
73
  exports.REQ_INTERNAL_CALL = new badmfck_signal_1.Req(undefined, "REQ_INTERNAL_CALL");
74
+ exports.REQ_MONITOR_USERS = new badmfck_signal_1.Req(undefined, "REQ_MONITOR_USERS");
72
75
  const activeServices = [];
73
76
  const entryPoints = [];
74
77
  async function Initializer(services) {
78
+ services.push(new StatService_1.StatService());
75
79
  for (let i of services) {
76
80
  await i.init();
77
81
  activeServices.push(i.getName());
@@ -83,7 +87,7 @@ async function Initializer(services) {
83
87
  exports.Initializer = Initializer;
84
88
  class APIService extends BaseService_1.BaseService {
85
89
  static nextLogID = 0;
86
- version = "2.6.1";
90
+ version = "2.6.3";
87
91
  options;
88
92
  monitor;
89
93
  monitorIndexFile;
@@ -105,9 +109,19 @@ class APIService extends BaseService_1.BaseService {
105
109
  console.warn("Service Monitor initialized");
106
110
  console.warn("monitor links:");
107
111
  for (let i of this.options.monitor) {
108
- const hash = crypto_1.default.createHash("sha256").update(i.login + i.password).digest().toString("hex");
109
- console.warn(i.login + " -> /sm-" + hash);
112
+ const hash = crypto_1.default.createHash("sha256").update(i.login + i.password + this.version).digest().toString("hex");
113
+ console.warn("Monitor link for: " + i.login + " -> /sm-" + hash);
110
114
  }
115
+ exports.REQ_MONITOR_USERS.listener = async (req) => {
116
+ const result = [];
117
+ if (this.options.monitor) {
118
+ for (let i of this.options.monitor) {
119
+ const hash = crypto_1.default.createHash("sha256").update(i.login + i.password).digest().toString("hex");
120
+ result.push(hash);
121
+ }
122
+ }
123
+ return result;
124
+ };
111
125
  }
112
126
  this.options.endpoints.push(new Liveness_1.Liveness(this.started), new Readiness_1.Readiness(this.started));
113
127
  exports.REQ_HTTP_REQUESTS_COUNT.listener = async () => this.requestsCount;
@@ -248,7 +262,9 @@ class APIService extends BaseService_1.BaseService {
248
262
  details = e.message;
249
263
  stack = [e];
250
264
  }
251
- this.sendResponse(req.get("Referer") ?? "", res, { error: { code: 10002, message: "Internal server error", stack: stack, details: `${e}` }, data: null, httpStatus: 500 }, tme, ep, log, httpRequest);
265
+ if ((0, MysqlService_1.isMysqlError)(e))
266
+ details = e.message;
267
+ this.sendResponse(req.get("Referer") ?? "", res, { error: { code: 10002, message: "Internal server error", stack: stack, details: details }, data: null, httpStatus: 500 }, tme, ep, log, httpRequest);
252
268
  return;
253
269
  }
254
270
  }
@@ -383,8 +399,6 @@ class APIService extends BaseService_1.BaseService {
383
399
  if (err) {
384
400
  if (log)
385
401
  log.error = "Can't send file: " + data.file;
386
- if (this.options.onError)
387
- this.options.onError("Can't send file: " + data.file, err);
388
402
  if (this.monitor && data.endpoint)
389
403
  this.monitor.registrateAPIError(data.endpoint);
390
404
  this.sendResponse(ref, res, {
@@ -419,8 +433,11 @@ class APIService extends BaseService_1.BaseService {
419
433
  res.send(data);
420
434
  if (log)
421
435
  log.response = this.checkDataLength(data);
422
- if (data.error && this.monitor)
436
+ if (data.error && this.monitor) {
423
437
  this.monitor.registrateAPIError(data.endpoint);
438
+ if (log)
439
+ log.error = data.error.message;
440
+ }
424
441
  }
425
442
  }
426
443
  }
@@ -433,8 +450,13 @@ class APIService extends BaseService_1.BaseService {
433
450
  this.monitor.registrateError(data.endpoint);
434
451
  }
435
452
  }
436
- if (this.options.onNetworkLog && log)
437
- this.options.onNetworkLog(log);
453
+ if (log && log.error && this.options.onError) {
454
+ this.options.onError(log.error);
455
+ }
456
+ else {
457
+ if (this.options.onNetworkLog && log)
458
+ this.options.onNetworkLog(log);
459
+ }
438
460
  }
439
461
  checkDataLength(data, result, lvl) {
440
462
  if (!lvl)
@@ -461,4 +483,4 @@ class APIService extends BaseService_1.BaseService {
461
483
  }
462
484
  }
463
485
  exports.APIService = APIService;
464
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"APIService.js","sourceRoot":"","sources":["../../src/apiServer/APIService.ts"],"names":[],"mappings":"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","sourcesContent":["import express, { Application, Response } from 'express'\nimport { BaseService, IBaseService } from './BaseService'\nimport cors from 'cors'\nimport { IncomingMessage } from 'http'\nimport { BaseEndpoint, IBaseEndpoint } from './BaseEndpoint'\nimport DefaultErrors, { ErrorUtils } from './structures/DefaultErrors'\nimport { HTTPRequestVO, IError, TransferPacketVO } from './structures/Interfaces'\nimport {Req} from \"badmfck-signal\"\nimport { logCrit, logError, logInfo } from './LogService'\nimport { Monitor } from './monitor/Monitor'\nimport path from \"path\"\nimport crypto from \"crypto\";\nimport fs from \"fs\"\nimport fileUpload from 'express-fileupload'\nimport os from \"os\"\nimport { Liveness } from './routes/Liveness'\nimport { Readiness } from './routes/Readiness'\nimport http from 'http'\nimport { HttpStatusCode } from 'axios'\n\nexport interface APIServiceNetworkLogItem{\t\n\tid:number,\n\tcreated:number,\n\ttime:number,\n\treferer?:string,\n\trequest:{[key:string]:any},\n\tresponse:{[key:string]:any}\n\terror?:string|null\n}\n\nexport interface APIServiceOptions{\n\tport:number,\n\tbaseEndPoint:string // \"/api/\"\n\tcorsHostWhiteList:string[],\n\tendpoints:IBaseEndpoint[],\n\tjsonLimit:string // \"10mb\"\n\tonNetworkLog?:((log:APIServiceNetworkLogItem)=>void)|null\n\tonError?:((...rest:any[])=>void)|null\n\tisProductionEnvironment:boolean,\n\tinterceptor?:IBaseEndpoint,\n\tpostproducer?:(req:HTTPRequestVO|undefined|null,res:Response,data:TransferPacketVO<any>,requestTime:number,endpoint?:string,log?:APIServiceNetworkLogItem|null)=>Promise<TransferPacketVO>\n\tpreproducer?:(req:HTTPRequestVO|undefined|null)=>any\n\t\n\tmonitor?:{login:string,password:string}[]\n\t//deployment?:{login:string,password:string}\n\tappVersion?:string\n\n\tfileTempDir:string;\n\tfileLimit:number // b\n}\n\nexport function getDefaultOptions():APIServiceOptions{\n\treturn {\n\t\tport: 8091,\n\t\tbaseEndPoint: '/api/',\n\t\tcorsHostWhiteList: [\n\t\t\t'http://localhost:3000',\n\t\t],\n\t\tendpoints: [],\n\t\tjsonLimit:\"10mb\",\n\t\tonNetworkLog: function (log: APIServiceNetworkLogItem): void {\n\t\t\tlogInfo(\"${APIService.js}\",log)\n\t\t},\n\t\tonError:function(err:any){\n\t\t\tlogError(\"${APIService.js}\",err);\n\t\t},\n\t\tisProductionEnvironment:false,\n\t\tfileLimit:50*1024*1024,\n\t\tfileTempDir:path.resolve(os.tmpdir(),\"fileTempDir\")\n\t}\n}\n\nexport const REQ_CREATE_NET_LOG:Req<void,APIServiceNetworkLogItem> = new Req(undefined,\"REQ_CREATE_NET_LOG\");\nexport const REQ_HTTP_LOG:Req<void,APIServiceNetworkLogItem[]> = new Req(undefined,\"REQ_HTTP_LOG\");\nexport const REQ_HTTP_REQUESTS_COUNT:Req<void,number> = new Req(undefined,\"REQ_HTTP_REQUESTS_COUNT\");\nexport const REQ_HTTP_SERVER:Req<void,{express:Application,http:http.Server}> = new Req(undefined,\"REQ_HTTP_SERVER\");\nexport const REQ_INTERNAL_CALL:Req<HTTPRequestVO,IError|any> = new Req(undefined,\"REQ_INTERNAL_CALL\");\n\n\nconst activeServices:String[]=[]\nconst entryPoints:String[]=[]\n\nexport async function Initializer(services:IBaseService[]){\n    for (let i of services) { await i.init();activeServices.push(i.getName()) }\n    for (let i of services) { i.applicationReady() }\n}\n\nexport class APIService extends BaseService {\n\n\t// NET LOG\n\tprivate static nextLogID=0;\n\tprivate version = \"2.6.1\"\n\tprivate options:APIServiceOptions;\n\tprivate monitor?:Monitor\n\tprivate monitorIndexFile?:Buffer\n\tprivate started:Date = new Date();\n\tprivate requestsCount=0;\n\tprivate server=http\n\n\tnetLog:APIServiceNetworkLogItem[]=[];\n\n\tconstructor(options?:APIServiceOptions|null) {\n\t\tsuper('HTTP Service')\n\t\tthis.options=options ?? getDefaultOptions();\n\t\tif(!this.options.corsHostWhiteList)\n\t\t\tthis.options.corsHostWhiteList=[];\n\t\tconst self = \"http://localhost:\"+this.options.port;\n\t\tif(!this.options.corsHostWhiteList.find(val=>val===self))\n\t\t\tthis.options.corsHostWhiteList.push()\n\n\t\tif(this.options.monitor && this.options.monitor.length>0){\n\t\t\tthis.monitor=new Monitor();\n\t\t\tthis.options.endpoints.push(this.monitor)\n\t\t\tconsole.warn(\"Service Monitor initialized\")\n\t\t\tconsole.warn(\"monitor links:\")\n\t\t\tfor(let i of this.options.monitor){\n\t\t\t\tconst hash = crypto.createHash(\"sha256\").update(i.login+i.password).digest().toString(\"hex\")\n\t\t\t\tconsole.warn(i.login+\" -> /sm-\"+hash)\t\t\t\t\t\t\n\t\t\t}\n\t\t}\n\n\t\t// create liveness, readiness\n\t\tthis.options.endpoints.push(new Liveness(this.started),new Readiness(this.started))\n\t\tREQ_HTTP_REQUESTS_COUNT.listener = async () => this.requestsCount;\n\t}\n\n\n\toverride async init(): Promise<void> {\n\n\t\tREQ_HTTP_LOG.listener=async ignore=>this.netLog;\n\t\tREQ_CREATE_NET_LOG.listener = async ignore=>{\n\t\t\tconst log:APIServiceNetworkLogItem = {\n\t\t\t\tcreated: +new Date(),\n\t\t\t\ttime: 0,\n\t\t\t\trequest: {},\n\t\t\t\tresponse: {},\n\t\t\t\terror:null,\n\t\t\t\tid: APIService.nextLogID++\n\t\t\t}\n\t\t\tthis.netLog.push(log)\n\t\t\tif(this.netLog.length>1000)\n\t\t\t\tthis.netLog.shift()\n\t\t\treturn log;\n\t\t}\n\n\t\t// internal call\n\t\tREQ_INTERNAL_CALL.listener = async (req)=>{\n\t\t\tfor(let i of this.options.endpoints){\n\t\t\t\tif(!i || !i.endpoints)\n\t\t\t\t\tcontinue;\n\t\t\t\tfor(let j of i.endpoints){\n\t\t\t\t\tlet ep = BaseEndpoint.getEntryPoint()+j.endpoint;\n\t\t\t\t\tep = ep.replaceAll(\"//\",\"/\")\n\t\t\t\t\tif(ep === req.endpoint){\n\t\t\t\t\t\treq.internalCall=true;\n\t\t\t\t\t\tconst response = await i.execute(req)\n\t\t\t\t\t\tif(response.error)\n\t\t\t\t\t\t\treturn response.error;\n\t\t\t\t\t\treturn response.data;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn {error:DefaultErrors.UNKNOWN_REQUEST,data:null,httpStatus:404}\n\t\t}\n\n\t\t// initialize express\n\t\tconst app = express()\n\t\tconst server = http.createServer(app);\n\n\t\tREQ_HTTP_SERVER.listener = async ignore=>{return {express:app,http:server}};\n\n\t\tif(this.options.isProductionEnvironment)\n\t\t\tapp.set(\"env\",'production');\n\n\t\tapp.use(express.json({ limit: '10mb' })) // for parsing application/json\n\t\tapp.use(express.urlencoded({ limit: '10mb', extended: true })) // for parsing application/x-www-form-urlencoded\n\n\t\tapp.use(fileUpload({\n\t\t\tlimitHandler: (req, res, next)=>{\n\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{\n\t\t\t\t\terror:DefaultErrors.FILE_TOO_LARGE,\n\t\t\t\t\tdata:null,\n\t\t\t\t\thttpStatus:413,\n\t\t\t\t},+new Date(),req.path);\n\t\t\t},\n\t\t\tlimits: { fileSize: this.options.fileLimit },\n\t\t\tuseTempFiles: true,\n\t\t\turiDecodeFileNames: true,\n\t\t\ttempFileDir: this.options.fileTempDir,\n\t\t\t//safeFileNames: true,\n\t\t\tabortOnLimit:true\n\t\t}))\n\n\t\tapp.use(async (err:any,req:any,resp:any,next:any)=>{\n\t\t\t\n\t\t\tif(!err){\n\t\t\t\tnext();\n\t\t\t\treturn\n\t\t\t}\n\t\t\t\t//request start time\n\t\t\tconst tme = +new Date();\n\t\t\tconst log = await REQ_CREATE_NET_LOG.request();\n\t\t\tlog.request={\n\t\t\t\tmethod:req.method,\n\t\t\t\tdata:\"\",\n\t\t\t\tparams:req.params\n\t\t\t}\n\n\t\t\tlet responseError=DefaultErrors.UNKNOWN_REQUEST;\n\t\t\tif (typeof err === \"object\" && err.status === 400 && 'body' in err && err.type === 'entity.parse.failed') {\n\t\t\t\tresponseError = DefaultErrors.JSON_MALFORMED\n\t\t\t}\n      \n\n\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",resp,{\n\t\t\t\terror:responseError,\n\t\t\t\tdata:null,\n\t\t\t\thttpStatus:400\n\t\t\t},tme,\"\",log)\n\n\t\t})\n\n\t\tconst corsOptions = {\n\t\t\torigin: (origin: any, callback: any) => {\n\t\t\t\tconst originIsWhitelisted = this.options.corsHostWhiteList.includes(origin)\n\t\t\t\tcallback(null, originIsWhitelisted)\n\t\t\t},\n\t\t\tcredentials: true\n\t\t}\n\t\tapp.use(cors(corsOptions))\n\n\t\t// registrate endpoints\n\t\tBaseEndpoint.setEntryPoint(this.options.baseEndPoint)\n\t\t\n\t\tfor(let i of this.options.endpoints){\n\t\t\tawait i.init();\n\t\t\tif(!i.endpoints)\n\t\t\t\tcontinue;\n\t\t\tfor(let j of i.endpoints){\n\t\t\t\tlet ep = BaseEndpoint.getEntryPoint()+j.endpoint;\n\t\t\t\tep = ep.replaceAll(\"//\",\"/\")\n\t\t\t\t\n\n\t\t\t\t// incoming request\n\t\t\t\tapp.all(ep,async (req,res)=>{\n\t\t\t\t\tthis.requestsCount++;\n\t\t\t\t\tconst tme = +new Date();\n\t\t\t\t\tlet log:APIServiceNetworkLogItem|null = null;\n\t\t\t\t\tif(!i.ignoreHttpLogging){\n\t\t\t\t\t\tlog = await REQ_CREATE_NET_LOG.request();\n\t\t\t\t\t\tlog.request={\n\t\t\t\t\t\t\turl:req.url,\n\t\t\t\t\t\t\tmethod:req.method,\n\t\t\t\t\t\t\tdata:this.checkDataLength(req.body),\n\t\t\t\t\t\t\tparams:this.checkDataLength(req.params)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tconst execute = async ()=>{\n\n\t\t\t\t\t\tconst body = req.body;\n\t\t\t\t\t\tif(req.query && typeof req.query === \"object\"){\n\t\t\t\t\t\t\tfor(let i in req.query){\n\t\t\t\t\t\t\t\tbody[i]=req.query[i];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tconst httpRequest:HTTPRequestVO = {\n\t\t\t\t\t\t\traw:req as IncomingMessage,\n\t\t\t\t\t\t\tmethod:req.method,\n\t\t\t\t\t\t\tdata:req.body,\n\t\t\t\t\t\t\tparams:req.params,\n\t\t\t\t\t\t\theaders:req.headers as any,\n\t\t\t\t\t\t\tendpoint:ep,\n\t\t\t\t\t\t\tfiles:req.files ?? null,\n\t\t\t\t\t\t\treferer:req.get(\"Referer\"),\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif(this.options.preproducer){\n\t\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\tconst preproducerResult = await this.options.preproducer(httpRequest);\n\t\t\t\t\t\t\tif(preproducerResult)\n\t\t\t\t\t\t\t\thttpRequest.preproducerResult = preproducerResult;\n\t\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\t\tlet details=`${e}`\n\t\t\t\t\t\t\t\tlet stack:IError[]|undefined=undefined;\n\t\t\t\t\t\t\t\tif(ErrorUtils.isError(e)){\n\t\t\t\t\t\t\t\t\tdetails=(e as any).message\n\t\t\t\t\t\t\t\t\tstack = [e as any];\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{error:{code:10002,message:\"Internal server error\",stack:stack,details:`${e}`},data:null,httpStatus:500},tme,ep,log,httpRequest);\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet result\n\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\t// Execute interceptor if exists\n\t\t\t\t\t\t\tif(!j.ignoreInterceptor){\n\t\t\t\t\t\t\t\tlet interceptorResult;\n\t\t\t\t\t\t\t\tif(this.options.interceptor){\n\t\t\t\t\t\t\t\t\tinterceptorResult=await this.options.interceptor.execute(httpRequest);\n\t\t\t\t\t\t\t\t\tif(interceptorResult.error && !j.allowInterceptorError){\n\t\t\t\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,interceptorResult,tme,ep,log,httpRequest);\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\thttpRequest.interceptorResult = interceptorResult\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// Precheck\n\t\t\t\t\t\t\tif(i === this.monitor)\n\t\t\t\t\t\t\t\thttpRequest.precheck={data:this.options.monitor}\n\n\t\t\t\t\t\t\tconst precheck=await i.precheck(httpRequest)\n\t\t\t\t\t\t\tif(precheck && precheck.error){\n\t\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,precheck,tme,ep,log,httpRequest);\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\thttpRequest.precheck=precheck;\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t// If interceptor has no errors, execute main handler\n\t\t\t\t\t\t\tresult = await i.execute(httpRequest)\n\t\t\t\t\t\t\t \n\t\t\t\t\t\t}catch(e){\n\n\t\t\t\t\t\t\tconsole.error(e);\n\t\t\t\t\t\t\tif(this.options.onError)\n\t\t\t\t\t\t\t\tthis.options.onError(e)\n\t\t\t\t\t\t\tif(this.monitor)\n\t\t\t\t\t\t\t\tthis.monitor.registrateFatalError(ep);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t// check if error is IError\n\t\t\t\t\t\t\tlet data:TransferPacketVO = {\n\t\t\t\t\t\t\t\terror:{\n\t\t\t\t\t\t\t\t\tcode:10002,\n\t\t\t\t\t\t\t\t\tmessage:\"Internal server error\",\n\t\t\t\t\t\t\t\t\thttpStatus:500,\n\t\t\t\t\t\t\t\t\tdetails:`${e}`\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif(ErrorUtils.isError(e))\n\t\t\t\t\t\t\t\tdata = {error:e as IError}\n\n\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,data,tme,ep,log,httpRequest);\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,result,tme,ep,log,httpRequest);\n\t\t\t\t\t}\n\n\t\t\t\t\texecute()\n\t\t\t\t});// handle incoming request\n\n\t\t\t}\n\t\t}\n\n\t\n\n\t\t// final handler\n\t\tapp.use((req, res, next) => {\n\t\t\t\n\t\t\tconst tme = +new Date()\n\n\t\t\tif(this.monitor && this.options && this.options.monitor){\n\t\t\t\t//check if requesting monitor\n\t\t\t\tif(req.method===\"GET\"){\n\t\t\t\t\t\n\t\t\t\t\tlet monitorRequest=false;\n\t\t\t\t\tfor(let i of this.options.monitor){\n\t\t\t\t\t\tconst hash = crypto.createHash(\"sha256\").update(i.login+i.password).digest().toString(\"hex\")\n\t\t\t\t\t\tif(req.originalUrl.endsWith(\"/sm-\"+hash)){\n\t\t\t\t\t\t\tmonitorRequest=true;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif(monitorRequest){\n\t\t\t\t\t\t// send index Thu, 16 Nov 2023 23:33:35 GMT\n\t\t\t\t\t\tconst date = new Date();\n\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\tif(!this.monitorIndexFile)\n\t\t\t\t\t\t\tthis.monitorIndexFile = fs.readFileSync(path.resolve(__dirname,\"monitor\",\"index.html\"));\n\t\t\t\t\t\t\tres.setHeader(\"Content-Type\",\"text/html\")\n\t\t\t\t\t\t\tres.setHeader(\"Content-Length\",this.monitorIndexFile.byteLength)\n\t\t\t\t\t\t\tres.status(200).send(this.monitorIndexFile);\n\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{\n\t\t\t\t\t\t\t\terror:{\n\t\t\t\t\t\t\t\t\tcode:10002,\n\t\t\t\t\t\t\t\t\tmessage:\"Internal server error\",\n\t\t\t\t\t\t\t\t\tdetails:`${e}`\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tdata:null,\n\t\t\t\t\t\t\t\thttpStatus:500\n\t\t\t\t\t\t\t},tme,req.path);\t\t\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t\n\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{\n\t\t\t\terror:DefaultErrors.UNKNOWN_REQUEST,\n\t\t\t\tdata:null,\n\t\t\t\thttpStatus:404\n\t\t\t},tme,req.path);\n\t\t})\n\n\t\tserver.listen(this.options.port, () => {\n\t\t\tlogCrit('${APIService.js}','API Service started at: '+this.options.port+\", with base endpoint:\"+this.options.baseEndPoint+\", ver.: \"+this.version)\n\t\t})\n\n\t\t/*app.listen(this.options.port, () => {\n\t\t\tlogCrit('${APIService.js}','API Service started at: '+this.options.port+\", with base endpoint:\"+this.options.baseEndPoint+\", ver.: \"+this.version)\n\t\t})*/\n\t}\n\n\tasync sendResponse(ref:string,res:Response,data:TransferPacketVO<any>,requestTime:number,endpoint?:string,log?:APIServiceNetworkLogItem|null,req?:HTTPRequestVO){\n\n\t\tif(this.options.postproducer){\n\t\t\ttry{\n\t\t\t\tdata = await this.options.postproducer(req,res,data,requestTime,endpoint,log);\n\t\t\t}catch(e){\n\t\t\t\tlogError(\"Postproducer error\",e)\n\t\t\t}\n\t\t}\n\n\t\tif(ErrorUtils.isError(data))\n\t\t\tdata = {error:data as IError,data:null}\n\t\t\n        data.responseTime = (+new Date()) - requestTime;\n        data.core = this.version\n        data.endpoint = endpoint ?? \"no_endpoint\"\n\t\t\n\t\tif(this.options.appVersion)\n\t\t\tdata.version=this.options.appVersion\n\n\t\t\n\t\tif(log){\n\t\t\tlog.time = data.responseTime\n\t\t\tlog.referer=ref;\n\t\t}\n\n\t\tif(this.monitor)\n\t\t\tthis.monitor.registrateResponse(data.endpoint,data.responseTime)\n\n        if(res.destroyed || res.closed){\n\n\t\t\tif(log)\n\t\t\t\tlog.error = \"Connection already closed, can't send response for: \"+data.endpoint\n\t\t\tif(this.options.onError)\n            \tthis.options.onError(\"Connection already closed, can't send response: \"+data.endpoint,data)\n            \n\t\t\tif(this.monitor)\n\t\t\t\tthis.monitor.registrateError(data.endpoint);\n\n        }else{\n\t\t\ttry{\n\n\t\t\t\tif(data.file){\n\n\t\t\t\t\tres.sendFile(data.file,err=>{\n\t\t\t\t\t\tif(err){\n\t\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\t\tlog.error = \"Can't send file: \"+data.file\n\t\t\t\t\t\t\tif(this.options.onError)\n\t\t\t\t\t\t\t\tthis.options.onError(\"Can't send file: \"+data.file,err)\n\t\t\t\t\t\t\tif(this.monitor && data.endpoint)\n\t\t\t\t\t\t\t\tthis.monitor.registrateAPIError(data.endpoint);\n\n\t\t\t\t\t\t\tthis.sendResponse(ref,res,{\n\t\t\t\t\t\t\t\terror:DefaultErrors.CANT_SEND_FILE,\n\t\t\t\t\t\t\t\tdata:null,\n\t\t\t\t\t\t\t\thttpStatus:500\n\t\t\t\t\t\t\t},requestTime,data.endpoint);\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t})\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(data.redirect){\n\t\t\t\t\tres.redirect(data.redirect);\n\t\t\t\t\tif(log)\n\t\t\t\t\t\tlog.response = {redirect:data.redirect}\n\t\t\t\t}else{\n\t\t\t\t\t// setup headers\n\t\t\t\t\tif(data.headers){\n\t\t\t\t\t\tfor(let i in data.headers)\n\t\t\t\t\t\t\tres.setHeader(i,data.headers[i]);\n\t\t\t\t\t}\n\n\t\t\t\t\tif(data.error && data.error.httpStatus && data.error.httpStatus>99)\n\t\t\t\t\t\tres.statusCode = data.error.httpStatus\n\t\t\t\t\telse\n\t\t\t\t\t\tres.statusCode=data.httpStatus ?? 200\n\t\t\t\t\t\n\t\t\t\t\tif(data.rawResponse){\n\t\t\t\t\t\tres.send(data.data)\n\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\tlog.response = this.checkDataLength(data)\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\tres.send(data);\n\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\tlog.response = this.checkDataLength(data)\n\n\t\t\t\t\t\tif(data.error && this.monitor)\n\t\t\t\t\t\t\tthis.monitor.registrateAPIError(data.endpoint)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}catch(e){\n\t\t\t\tif(this.options.onError)\n\t\t\t\t\tthis.options.onError(\"Can't send response\",e);\n\t\t\t\tif(log)\n\t\t\t\t\tlog.error=\"Can't send response\"\n\t\t\t\tif(this.monitor)\n\t\t\t\t\tthis.monitor.registrateError(data.endpoint);\n\t\t\t}\n\t\t}\n\n\t\t// show log\n\t\tif(this.options.onNetworkLog && log)\n\t\t\tthis.options.onNetworkLog(log)\n    }\n\n\n\tcheckDataLength(data:any,result?:any,lvl?:number):any{\n\t\t\n\t\tif(!lvl)\n\t\t\tlvl=0;\n\n\t\tif(typeof data !== \"object\"){\n\t\t\tif(typeof data===\"string\" && data.length>1024)\n\t\t\t\treturn data.substring(0,1000)+\"... (total:\" + data.length + \")\"\n\t\t\treturn data;\n\t\t}\n\n\t\tif(typeof data === \"object\"){\n\t\t\tif(!result)\n\t\t\t\tresult={};\n\t\t\tlet arrcnt = 100;\n\t\t\tfor(let i in data){\n\t\t\t\tresult[i]=this.checkDataLength(data[i],result[i],lvl+1);\n\t\t\t\tarrcnt--;\n\t\t\t\tif(arrcnt<=0){\n\t\t\t\t\tresult[\"...\"]=\"... total: \"+Array.isArray(data)?data.length:Object.keys(data).length;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn result ?? null;\n\t}\n\n}\n"]}
486
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"APIService.js","sourceRoot":"","sources":["../../src/apiServer/APIService.ts"],"names":[],"mappings":"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","sourcesContent":["import express, { Application, Response } from 'express'\nimport { BaseService, IBaseService } from './BaseService'\nimport cors from 'cors'\nimport { IncomingMessage } from 'http'\nimport { BaseEndpoint, IBaseEndpoint } from './BaseEndpoint'\nimport DefaultErrors, { ErrorUtils } from './structures/DefaultErrors'\nimport { HTTPRequestVO, IError, TransferPacketVO } from './structures/Interfaces'\nimport {Req} from \"badmfck-signal\"\nimport { logCrit, logError, logInfo } from './LogService'\nimport { Monitor } from './monitor/Monitor'\nimport path from \"path\"\nimport crypto from \"crypto\";\nimport fs from \"fs\"\nimport fileUpload from 'express-fileupload'\nimport os from \"os\"\nimport { Liveness } from './routes/Liveness'\nimport { Readiness } from './routes/Readiness'\nimport http from 'http'\nimport { HttpStatusCode } from 'axios'\nimport { isMysqlError } from './MysqlService'\nimport { MysqlError } from 'mysql'\nimport { StatService } from './StatService'\n\nexport interface APIServiceNetworkLogItem{\t\n\tid:number,\n\tcreated:number,\n\ttime:number,\n\treferer?:string,\n\trequest:{[key:string]:any},\n\tresponse:{[key:string]:any}\n\terror?:string|null\n}\n\nexport interface APIServiceOptions{\n\tport:number,\n\tbaseEndPoint:string // \"/api/\"\n\tcorsHostWhiteList:string[],\n\tendpoints:IBaseEndpoint[],\n\tjsonLimit:string // \"10mb\"\n\tonNetworkLog?:((log:APIServiceNetworkLogItem)=>void)|null\n\tonError?:((...rest:any[])=>void)|null\n\tisProductionEnvironment:boolean,\n\tinterceptor?:IBaseEndpoint,\n\tpostproducer?:(req:HTTPRequestVO|undefined|null,res:Response,data:TransferPacketVO<any>,requestTime:number,endpoint?:string,log?:APIServiceNetworkLogItem|null)=>Promise<TransferPacketVO>\n\tpreproducer?:(req:HTTPRequestVO|undefined|null)=>any\n\t\n\tmonitor?:{login:string,password:string}[]\n\t//deployment?:{login:string,password:string}\n\tappVersion?:string\n\n\tfileTempDir:string;\n\tfileLimit:number // b\n}\n\nexport function getDefaultOptions():APIServiceOptions{\n\treturn {\n\t\tport: 8091,\n\t\tbaseEndPoint: '/api/',\n\t\tcorsHostWhiteList: [\n\t\t\t'http://localhost:3000',\n\t\t],\n\t\tendpoints: [],\n\t\tjsonLimit:\"10mb\",\n\t\tonNetworkLog: function (log: APIServiceNetworkLogItem): void {\n\t\t\tlogInfo(\"${APIService.js}\",log)\n\t\t},\n\t\tonError:function(err:any){\n\t\t\tlogError(\"${APIService.js}\",err);\n\t\t},\n\t\tisProductionEnvironment:false,\n\t\tfileLimit:50*1024*1024,\n\t\tfileTempDir:path.resolve(os.tmpdir(),\"fileTempDir\")\n\t}\n}\n\nexport const REQ_CREATE_NET_LOG:Req<void,APIServiceNetworkLogItem> = new Req(undefined,\"REQ_CREATE_NET_LOG\");\nexport const REQ_HTTP_LOG:Req<void,APIServiceNetworkLogItem[]> = new Req(undefined,\"REQ_HTTP_LOG\");\nexport const REQ_HTTP_REQUESTS_COUNT:Req<void,number> = new Req(undefined,\"REQ_HTTP_REQUESTS_COUNT\");\nexport const REQ_HTTP_SERVER:Req<void,{express:Application,http:http.Server}> = new Req(undefined,\"REQ_HTTP_SERVER\");\nexport const REQ_INTERNAL_CALL:Req<HTTPRequestVO,IError|any> = new Req(undefined,\"REQ_INTERNAL_CALL\");\nexport const REQ_MONITOR_USERS:Req<{authorization:string},any> = new Req(undefined,\"REQ_MONITOR_USERS\");\n\nconst activeServices:String[]=[]\nconst entryPoints:String[]=[]\n\nexport async function Initializer(services:IBaseService[]){\n\t// add stat service\n\tservices.push(new StatService());\n\t\n    for (let i of services) { await i.init();activeServices.push(i.getName()) }\n    for (let i of services) { i.applicationReady() }\n}\n\nexport class APIService extends BaseService {\n\n\t// NET LOG\n\tprivate static nextLogID=0;\n\tprivate version = \"2.6.3\"\n\tprivate options:APIServiceOptions;\n\tprivate monitor?:Monitor\n\tprivate monitorIndexFile?:Buffer\n\tprivate started:Date = new Date();\n\tprivate requestsCount=0;\n\tprivate server=http\n\n\tnetLog:APIServiceNetworkLogItem[]=[];\n\n\tconstructor(options?:APIServiceOptions|null) {\n\t\tsuper('HTTP Service')\n\t\tthis.options=options ?? getDefaultOptions();\n\t\tif(!this.options.corsHostWhiteList)\n\t\t\tthis.options.corsHostWhiteList=[];\n\t\tconst self = \"http://localhost:\"+this.options.port;\n\t\tif(!this.options.corsHostWhiteList.find(val=>val===self))\n\t\t\tthis.options.corsHostWhiteList.push()\n\n\t\tif(this.options.monitor && this.options.monitor.length>0){\n\t\t\tthis.monitor=new Monitor();\n\t\t\tthis.options.endpoints.push(this.monitor)\n\t\t\tconsole.warn(\"Service Monitor initialized\")\n\t\t\tconsole.warn(\"monitor links:\")\n\t\t\tfor(let i of this.options.monitor){\n\t\t\t\tconst hash = crypto.createHash(\"sha256\").update(i.login+i.password+this.version).digest().toString(\"hex\")\n\t\t\t\tconsole.warn(\"Monitor link for: \"+i.login+\" -> /sm-\"+hash)\t\t\t\t\t\t\n\t\t\t}\n\n\t\t\tREQ_MONITOR_USERS.listener = async (req)=>{\n\t\t\t\tconst result = []\n\t\t\t\tif(this.options.monitor){\n\t\t\t\t\tfor(let i of this.options.monitor){\n\t\t\t\t\t\tconst hash = crypto.createHash(\"sha256\").update(i.login+i.password).digest().toString(\"hex\");\n\t\t\t\t\t\tresult.push(hash);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t}\n\t\t}\n\n\t\t// create liveness, readiness\n\t\tthis.options.endpoints.push(new Liveness(this.started),new Readiness(this.started))\n\t\tREQ_HTTP_REQUESTS_COUNT.listener = async () => this.requestsCount;\n\t}\n\n\n\toverride async init(): Promise<void> {\n\n\t\tREQ_HTTP_LOG.listener=async ignore=>this.netLog;\n\t\tREQ_CREATE_NET_LOG.listener = async ignore=>{\n\t\t\tconst log:APIServiceNetworkLogItem = {\n\t\t\t\tcreated: +new Date(),\n\t\t\t\ttime: 0,\n\t\t\t\trequest: {},\n\t\t\t\tresponse: {},\n\t\t\t\terror:null,\n\t\t\t\tid: APIService.nextLogID++\n\t\t\t}\n\t\t\tthis.netLog.push(log)\n\t\t\tif(this.netLog.length>1000)\n\t\t\t\tthis.netLog.shift()\n\t\t\treturn log;\n\t\t}\n\n\t\t// internal call\n\t\tREQ_INTERNAL_CALL.listener = async (req)=>{\n\t\t\tfor(let i of this.options.endpoints){\n\t\t\t\tif(!i || !i.endpoints)\n\t\t\t\t\tcontinue;\n\t\t\t\tfor(let j of i.endpoints){\n\t\t\t\t\tlet ep = BaseEndpoint.getEntryPoint()+j.endpoint;\n\t\t\t\t\tep = ep.replaceAll(\"//\",\"/\")\n\t\t\t\t\tif(ep === req.endpoint){\n\t\t\t\t\t\treq.internalCall=true;\n\t\t\t\t\t\tconst response = await i.execute(req)\n\t\t\t\t\t\tif(response.error)\n\t\t\t\t\t\t\treturn response.error;\n\t\t\t\t\t\treturn response.data;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn {error:DefaultErrors.UNKNOWN_REQUEST,data:null,httpStatus:404}\n\t\t}\n\n\t\t// initialize express\n\t\tconst app = express()\n\t\tconst server = http.createServer(app);\n\n\t\tREQ_HTTP_SERVER.listener = async ignore=>{return {express:app,http:server}};\n\n\t\tif(this.options.isProductionEnvironment)\n\t\t\tapp.set(\"env\",'production');\n\n\t\tapp.use(express.json({ limit: '10mb' })) // for parsing application/json\n\t\tapp.use(express.urlencoded({ limit: '10mb', extended: true })) // for parsing application/x-www-form-urlencoded\n\n\t\tapp.use(fileUpload({\n\t\t\tlimitHandler: (req, res, next)=>{\n\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{\n\t\t\t\t\terror:DefaultErrors.FILE_TOO_LARGE,\n\t\t\t\t\tdata:null,\n\t\t\t\t\thttpStatus:413,\n\t\t\t\t},+new Date(),req.path);\n\t\t\t},\n\t\t\tlimits: { fileSize: this.options.fileLimit },\n\t\t\tuseTempFiles: true,\n\t\t\turiDecodeFileNames: true,\n\t\t\ttempFileDir: this.options.fileTempDir,\n\t\t\t//safeFileNames: true,\n\t\t\tabortOnLimit:true\n\t\t}))\n\n\t\tapp.use(async (err:any,req:any,resp:any,next:any)=>{\n\t\t\t\n\t\t\tif(!err){\n\t\t\t\tnext();\n\t\t\t\treturn\n\t\t\t}\n\t\t\t\t//request start time\n\t\t\tconst tme = +new Date();\n\t\t\tconst log = await REQ_CREATE_NET_LOG.request();\n\t\t\tlog.request={\n\t\t\t\tmethod:req.method,\n\t\t\t\tdata:\"\",\n\t\t\t\tparams:req.params\n\t\t\t}\n\n\t\t\tlet responseError=DefaultErrors.UNKNOWN_REQUEST;\n\t\t\tif (typeof err === \"object\" && err.status === 400 && 'body' in err && err.type === 'entity.parse.failed') {\n\t\t\t\tresponseError = DefaultErrors.JSON_MALFORMED\n\t\t\t}\n      \n\n\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",resp,{\n\t\t\t\terror:responseError,\n\t\t\t\tdata:null,\n\t\t\t\thttpStatus:400\n\t\t\t},tme,\"\",log)\n\n\t\t})\n\n\t\tconst corsOptions = {\n\t\t\torigin: (origin: any, callback: any) => {\n\t\t\t\tconst originIsWhitelisted = this.options.corsHostWhiteList.includes(origin)\n\t\t\t\tcallback(null, originIsWhitelisted)\n\t\t\t},\n\t\t\tcredentials: true\n\t\t}\n\t\tapp.use(cors(corsOptions))\n\n\t\t// registrate endpoints\n\t\tBaseEndpoint.setEntryPoint(this.options.baseEndPoint)\n\t\t\n\t\tfor(let i of this.options.endpoints){\n\t\t\tawait i.init();\n\t\t\tif(!i.endpoints)\n\t\t\t\tcontinue;\n\t\t\tfor(let j of i.endpoints){\n\t\t\t\tlet ep = BaseEndpoint.getEntryPoint()+j.endpoint;\n\t\t\t\tep = ep.replaceAll(\"//\",\"/\")\n\t\t\t\t\n\n\t\t\t\t// incoming request\n\t\t\t\tapp.all(ep,async (req,res)=>{\n\t\t\t\t\tthis.requestsCount++;\n\t\t\t\t\tconst tme = +new Date();\n\t\t\t\t\tlet log:APIServiceNetworkLogItem|null = null;\n\t\t\t\t\tif(!i.ignoreHttpLogging){\n\t\t\t\t\t\tlog = await REQ_CREATE_NET_LOG.request();\n\t\t\t\t\t\tlog.request={\n\t\t\t\t\t\t\turl:req.url,\n\t\t\t\t\t\t\tmethod:req.method,\n\t\t\t\t\t\t\tdata:this.checkDataLength(req.body),\n\t\t\t\t\t\t\tparams:this.checkDataLength(req.params)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tconst execute = async ()=>{\n\n\t\t\t\t\t\tconst body = req.body;\n\t\t\t\t\t\tif(req.query && typeof req.query === \"object\"){\n\t\t\t\t\t\t\tfor(let i in req.query){\n\t\t\t\t\t\t\t\tbody[i]=req.query[i];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tconst httpRequest:HTTPRequestVO = {\n\t\t\t\t\t\t\traw:req as IncomingMessage,\n\t\t\t\t\t\t\tmethod:req.method,\n\t\t\t\t\t\t\tdata:req.body,\n\t\t\t\t\t\t\tparams:req.params,\n\t\t\t\t\t\t\theaders:req.headers as any,\n\t\t\t\t\t\t\tendpoint:ep,\n\t\t\t\t\t\t\tfiles:req.files ?? null,\n\t\t\t\t\t\t\treferer:req.get(\"Referer\"),\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif(this.options.preproducer){\n\t\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\tconst preproducerResult = await this.options.preproducer(httpRequest);\n\t\t\t\t\t\t\tif(preproducerResult)\n\t\t\t\t\t\t\t\thttpRequest.preproducerResult = preproducerResult;\n\t\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\t\tlet details=`${e}`\n\t\t\t\t\t\t\t\tlet stack:IError[]|undefined=undefined;\n\t\t\t\t\t\t\t\tif(ErrorUtils.isError(e)){\n\t\t\t\t\t\t\t\t\tdetails=(e as any).message\n\t\t\t\t\t\t\t\t\tstack = [e as any];\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif(isMysqlError(e))\n\t\t\t\t\t\t\t\t\tdetails = (e as MysqlError).message;\n\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{error:{code:10002,message:\"Internal server error\",stack:stack,details:details},data:null,httpStatus:500},tme,ep,log,httpRequest);\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet result\n\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\t// Execute interceptor if exists\n\t\t\t\t\t\t\tif(!j.ignoreInterceptor){\n\t\t\t\t\t\t\t\tlet interceptorResult;\n\t\t\t\t\t\t\t\tif(this.options.interceptor){\n\t\t\t\t\t\t\t\t\tinterceptorResult=await this.options.interceptor.execute(httpRequest);\n\t\t\t\t\t\t\t\t\tif(interceptorResult.error && !j.allowInterceptorError){\n\t\t\t\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,interceptorResult,tme,ep,log,httpRequest);\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\thttpRequest.interceptorResult = interceptorResult\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// Precheck\n\t\t\t\t\t\t\tif(i === this.monitor)\n\t\t\t\t\t\t\t\thttpRequest.precheck={data:this.options.monitor}\n\n\t\t\t\t\t\t\tconst precheck=await i.precheck(httpRequest)\n\t\t\t\t\t\t\tif(precheck && precheck.error){\n\t\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,precheck,tme,ep,log,httpRequest);\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\thttpRequest.precheck=precheck;\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t// If interceptor has no errors, execute main handler\n\t\t\t\t\t\t\tresult = await i.execute(httpRequest)\n\t\t\t\t\t\t\t \n\t\t\t\t\t\t}catch(e){\n\n\t\t\t\t\t\t\tconsole.error(e);\n\t\t\t\t\t\t\tif(this.options.onError)\n\t\t\t\t\t\t\t\tthis.options.onError(e)\n\t\t\t\t\t\t\tif(this.monitor)\n\t\t\t\t\t\t\t\tthis.monitor.registrateFatalError(ep);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t// check if error is IError\n\t\t\t\t\t\t\tlet data:TransferPacketVO = {\n\t\t\t\t\t\t\t\terror:{\n\t\t\t\t\t\t\t\t\tcode:10002,\n\t\t\t\t\t\t\t\t\tmessage:\"Internal server error\",\n\t\t\t\t\t\t\t\t\thttpStatus:500,\n\t\t\t\t\t\t\t\t\tdetails:`${e}`\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif(ErrorUtils.isError(e))\n\t\t\t\t\t\t\t\tdata = {error:e as IError}\n\n\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,data,tme,ep,log,httpRequest);\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,result,tme,ep,log,httpRequest);\n\t\t\t\t\t}\n\n\t\t\t\t\texecute()\n\t\t\t\t});// handle incoming request\n\n\t\t\t}\n\t\t}\n\n\t\n\n\t\t// final handler\n\t\tapp.use((req, res, next) => {\n\t\t\t\n\t\t\tconst tme = +new Date()\n\n\t\t\tif(this.monitor && this.options && this.options.monitor){\n\t\t\t\t//check if requesting monitor\n\t\t\t\tif(req.method===\"GET\"){\n\t\t\t\t\t\n\t\t\t\t\tlet monitorRequest=false;\n\t\t\t\t\tfor(let i of this.options.monitor){\n\t\t\t\t\t\tconst hash = crypto.createHash(\"sha256\").update(i.login+i.password).digest().toString(\"hex\")\n\t\t\t\t\t\tif(req.originalUrl.endsWith(\"/sm-\"+hash)){\n\t\t\t\t\t\t\tmonitorRequest=true;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif(monitorRequest){\n\t\t\t\t\t\t// send index Thu, 16 Nov 2023 23:33:35 GMT\n\t\t\t\t\t\tconst date = new Date();\n\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\tif(!this.monitorIndexFile)\n\t\t\t\t\t\t\tthis.monitorIndexFile = fs.readFileSync(path.resolve(__dirname,\"monitor\",\"index.html\"));\n\t\t\t\t\t\t\tres.setHeader(\"Content-Type\",\"text/html\")\n\t\t\t\t\t\t\tres.setHeader(\"Content-Length\",this.monitorIndexFile.byteLength)\n\t\t\t\t\t\t\tres.status(200).send(this.monitorIndexFile);\n\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{\n\t\t\t\t\t\t\t\terror:{\n\t\t\t\t\t\t\t\t\tcode:10002,\n\t\t\t\t\t\t\t\t\tmessage:\"Internal server error\",\n\t\t\t\t\t\t\t\t\tdetails:`${e}`\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tdata:null,\n\t\t\t\t\t\t\t\thttpStatus:500\n\t\t\t\t\t\t\t},tme,req.path);\t\t\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t\n\t\t\tthis.sendResponse(req.get(\"Referer\")??\"\",res,{\n\t\t\t\terror:DefaultErrors.UNKNOWN_REQUEST,\n\t\t\t\tdata:null,\n\t\t\t\thttpStatus:404\n\t\t\t},tme,req.path);\n\t\t})\n\n\t\tserver.listen(this.options.port, () => {\n\t\t\tlogCrit('${APIService.js}','API Service started at: '+this.options.port+\", with base endpoint:\"+this.options.baseEndPoint+\", ver.: \"+this.version)\n\t\t})\n\n\t\t/*app.listen(this.options.port, () => {\n\t\t\tlogCrit('${APIService.js}','API Service started at: '+this.options.port+\", with base endpoint:\"+this.options.baseEndPoint+\", ver.: \"+this.version)\n\t\t})*/\n\t}\n\n\tasync sendResponse(ref:string,res:Response,data:TransferPacketVO<any>,requestTime:number,endpoint?:string,log?:APIServiceNetworkLogItem|null,req?:HTTPRequestVO){\n\n\t\tif(this.options.postproducer){\n\t\t\ttry{\n\t\t\t\tdata = await this.options.postproducer(req,res,data,requestTime,endpoint,log);\n\t\t\t}catch(e){\n\t\t\t\tlogError(\"Postproducer error\",e)\n\t\t\t}\n\t\t}\n\n\t\tif(ErrorUtils.isError(data))\n\t\t\tdata = {error:data as IError,data:null}\n\t\t\n        data.responseTime = (+new Date()) - requestTime;\n        data.core = this.version\n        data.endpoint = endpoint ?? \"no_endpoint\"\n\t\t\n\t\tif(this.options.appVersion)\n\t\t\tdata.version=this.options.appVersion\n\n\t\t\n\t\tif(log){\n\t\t\tlog.time = data.responseTime\n\t\t\tlog.referer=ref;\n\t\t}\n\n\t\tif(this.monitor)\n\t\t\tthis.monitor.registrateResponse(data.endpoint,data.responseTime)\n\n        if(res.destroyed || res.closed){\n\n\t\t\tif(log)\n\t\t\t\tlog.error = \"Connection already closed, can't send response for: \"+data.endpoint\n\t\t\tif(this.options.onError)\n            \tthis.options.onError(\"Connection already closed, can't send response: \"+data.endpoint,data)\n            \n\t\t\tif(this.monitor)\n\t\t\t\tthis.monitor.registrateError(data.endpoint);\n\n        }else{\n\t\t\ttry{\n\n\t\t\t\tif(data.file){\n\n\t\t\t\t\tres.sendFile(data.file,err=>{\n\t\t\t\t\t\tif(err){\n\t\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\t\tlog.error = \"Can't send file: \"+data.file\n\t\t\t\n\t\t\t\t\t\t\tif(this.monitor && data.endpoint)\n\t\t\t\t\t\t\t\tthis.monitor.registrateAPIError(data.endpoint);\n\n\t\t\t\t\t\t\tthis.sendResponse(ref,res,{\n\t\t\t\t\t\t\t\terror:DefaultErrors.CANT_SEND_FILE,\n\t\t\t\t\t\t\t\tdata:null,\n\t\t\t\t\t\t\t\thttpStatus:500\n\t\t\t\t\t\t\t},requestTime,data.endpoint);\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t})\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(data.redirect){\n\t\t\t\t\tres.redirect(data.redirect);\n\t\t\t\t\tif(log)\n\t\t\t\t\t\tlog.response = {redirect:data.redirect}\n\t\t\t\t}else{\n\t\t\t\t\t// setup headers\n\t\t\t\t\tif(data.headers){\n\t\t\t\t\t\tfor(let i in data.headers)\n\t\t\t\t\t\t\tres.setHeader(i,data.headers[i]);\n\t\t\t\t\t}\n\n\t\t\t\t\tif(data.error && data.error.httpStatus && data.error.httpStatus>99)\n\t\t\t\t\t\tres.statusCode = data.error.httpStatus\n\t\t\t\t\telse\n\t\t\t\t\t\tres.statusCode=data.httpStatus ?? 200\n\t\t\t\t\t\n\t\t\t\t\tif(data.rawResponse){\n\t\t\t\t\t\tres.send(data.data)\n\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\tlog.response = this.checkDataLength(data)\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\tres.send(data);\n\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\tlog.response = this.checkDataLength(data)\n\n\t\t\t\t\t\tif(data.error && this.monitor){\n\t\t\t\t\t\t\tthis.monitor.registrateAPIError(data.endpoint)\n\t\t\t\t\t\t\tif(log)\n\t\t\t\t\t\t\t\tlog.error = data.error.message;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}catch(e){\n\t\t\t\tif(this.options.onError)\n\t\t\t\t\tthis.options.onError(\"Can't send response\",e);\n\t\t\t\tif(log)\n\t\t\t\t\tlog.error=\"Can't send response\"\n\t\t\t\tif(this.monitor)\n\t\t\t\t\tthis.monitor.registrateError(data.endpoint);\n\t\t\t}\n\t\t}\n\n\t\t// show log\n\t\tif(log && log.error && this.options.onError){\n\t\t\tthis.options.onError(log.error)\n\t\t}else{\n\n\t\t\tif(this.options.onNetworkLog && log)\n\t\t\t\tthis.options.onNetworkLog(log)\n\t\t}\n    }\n\n\n\tcheckDataLength(data:any,result?:any,lvl?:number):any{\n\t\t\n\t\tif(!lvl)\n\t\t\tlvl=0;\n\n\t\tif(typeof data !== \"object\"){\n\t\t\tif(typeof data===\"string\" && data.length>1024)\n\t\t\t\treturn data.substring(0,1000)+\"... (total:\" + data.length + \")\"\n\t\t\treturn data;\n\t\t}\n\n\t\tif(typeof data === \"object\"){\n\t\t\tif(!result)\n\t\t\t\tresult={};\n\t\t\tlet arrcnt = 100;\n\t\t\tfor(let i in data){\n\t\t\t\tresult[i]=this.checkDataLength(data[i],result[i],lvl+1);\n\t\t\t\tarrcnt--;\n\t\t\t\tif(arrcnt<=0){\n\t\t\t\t\tresult[\"...\"]=\"... total: \"+Array.isArray(data)?data.length:Object.keys(data).length;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn result ?? null;\n\t}\n\n}\n"]}
@@ -39,6 +39,7 @@ export interface MysqlError {
39
39
  fatal?: boolean;
40
40
  throwable: boolean;
41
41
  }
42
+ export declare const isMysqlError: (e: any) => e is MysqlError;
42
43
  export interface MysqlResult {
43
44
  error?: MysqlError | null;
44
45
  rollbackError?: MysqlError | null;
@@ -26,7 +26,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
26
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.MysqlService = exports.executeQuery = exports.REQ_MYSQL_TROLLBACK = exports.REQ_MYSQL_TCOMMIT = exports.REQ_MYSQL_TQUERY = exports.REQ_MYSQL_TBEGIN = exports.REQ_MYSQL_QUERY = exports.S_MYSQL_STARTED = void 0;
29
+ exports.MysqlService = exports.isMysqlError = exports.executeQuery = exports.REQ_MYSQL_TROLLBACK = exports.REQ_MYSQL_TCOMMIT = exports.REQ_MYSQL_TQUERY = exports.REQ_MYSQL_TBEGIN = exports.REQ_MYSQL_QUERY = exports.S_MYSQL_STARTED = void 0;
30
30
  const BaseService_1 = require("./BaseService");
31
31
  const badmfck_signal_1 = __importStar(require("badmfck-signal"));
32
32
  const crypto_1 = require("crypto");
@@ -42,6 +42,10 @@ exports.REQ_MYSQL_TCOMMIT = new badmfck_signal_1.Req(undefined, "REQ_MYSQL_TCOMM
42
42
  exports.REQ_MYSQL_TROLLBACK = new badmfck_signal_1.Req(undefined, "REQ_MYSQL_TROLLBACK");
43
43
  const executeQuery = async (query) => { return await exports.REQ_MYSQL_QUERY.request(query); };
44
44
  exports.executeQuery = executeQuery;
45
+ const isMysqlError = (e) => {
46
+ return e.code !== undefined && e.errno !== undefined && e.sql !== undefined && e.name !== undefined && e.message !== undefined;
47
+ };
48
+ exports.isMysqlError = isMysqlError;
45
49
  class MysqlService extends BaseService_1.BaseService {
46
50
  reconnectionTimeout = 1000 * 3;
47
51
  reconnecting = false;
@@ -766,4 +770,4 @@ const encrypt = (txt) => {
766
770
  }
767
771
  };
768
772
  exports.default = MysqlService;
769
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MysqlService.js","sourceRoot":"","sources":["../../src/apiServer/MysqlService.ts"],"names":[],"mappings":"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","sourcesContent":["//import mysql, { FieldInfo, MysqlError, Pool, PoolConnection } from \"mysql\"\n\nimport { BaseService } from \"./BaseService\";\nimport Signal, { Req } from \"badmfck-signal\";\nimport { createCipheriv, createDecipheriv, createHash } from \"crypto\"\nimport { logCrit, logError, logInfo } from \"./LogService\";\nimport * as mysql from \"mysql2/promise\"\nimport fs from \"fs\"\nimport path from \"path\"\n\nexport const S_MYSQL_STARTED=new Signal<void>()\nexport const REQ_MYSQL_QUERY = new Req<MySqlQuery|MySqlQuery[],MysqlResult[]>(undefined,\"REQ_MYSQL_QUERY\");\n//export const REQ_MYSQL_TRANSACTION = new Req<MySqlQuery[],MysqlResult>(undefined,\"REQ_MYSQL_TRANSACTION\");\n\nexport const REQ_MYSQL_TBEGIN = new Req<void,MysqlError|number>(undefined,\"REQ_MYSQL_TRANSACTION_BEGING\"); // return transaction id or mysql error\nexport const REQ_MYSQL_TQUERY=new Req<{query:MySqlQuery,tid:number},MysqlResult>(undefined,\"REQ_MYSQL_TRANSACTION_ADD_OPERATION\"); // tid means transaction id\nexport const REQ_MYSQL_TCOMMIT=new Req<number,MysqlError|null>(undefined,\"REQ_MYSQL_TCOMMIT\"); // tid\nexport const REQ_MYSQL_TROLLBACK=new Req<number,MysqlError|null>(undefined,\"REQ_MYSQL_TROLLBACK\"); // tid\n\nexport const executeQuery = async (query:MySqlQuery|MySqlQuery[]):Promise<MysqlResult[]>=>{return await REQ_MYSQL_QUERY.request(query)}\n\nexport interface MysqlServiceOptions{\n    connectionLimit:number,\n    host:string,\n    user:string,\n    password:string,\n    port:number,\n    database:string,  \n    queueLimit?:number,\n    transactionFailReport?:(trx:ITransaction,message:string)=>void,\n    transactionFailReportDir?:string,\n    debug?:boolean,\n    naxTransactionWaitTime?:number,\n\tmigrations?:{\n\t\tdir:string,\n\t\tcallback:()=>void\n\t}|null\n}\n\nexport interface MysqlError{\n    code: string,\n    errno: number,\n    sql: string,\n    name:string,\n    message:string\n    fatal?:boolean,\n    throwable:boolean\n}\n\nexport interface MysqlResult{\n    error?:MysqlError|null,\n    rollbackError?:MysqlError|null,\n    isDuplicateError?:boolean\n    data:any\n    count:number\n}\n\nexport interface MySqlQuery{\n    query:string\n    fields:MysqlQueryField[]|MysqlQueryFieldObject,\n    rollbackQuery?:string|null\n    transactionID?:number\n    throwable?:boolean\n    calculateCount?:boolean\n}\n\nexport interface MysqlQueryField{\n    name:string,\n    value:string|number|boolean|null|undefined,\n    system?:boolean,\n    ignoreInInsert?:boolean,\n    ignoreInUpdate?:boolean\n    useInReplace?:boolean,\n    _parsedValue?:string|number|boolean|null\n}\n\nexport interface ITransaction{\n    id:number\n    timestamp:number,\n    conn:mysql.PoolConnection,\n    queries:{sql:string,status:string}[]\n}\n\nexport interface MysqlQueryFieldObject extends Record<string,string|number|boolean|null|undefined|{name?:string|null,value:string|number|boolean|null|undefined,system?:boolean,ignoreInInsert?:boolean,ignoreInUpdate?:boolean,useInReplace?:boolean}>{\n\n}\n    \n\n/**\n * Mysql Services, execute queries\n * MySqlQuery.query:\n * @fields - replaced by field's names\n * @values - replaced by parsed values\n * @onupdate - repalced by pair field name = value\n * @onduplicate - replaced by pair field name = value\n */\n\nexport class MysqlService extends BaseService{\n\n    reconnectionTimeout=1000*3;\n    reconnecting=false;\n    pool:mysql.Pool|null=null;\n    options:MysqlServiceOptions;\n    serviceStarted=false;\n    timeoutID:any\n\n    debug=false;\n\n    queries=[]; // TODO: STORE QUERIES SENTS BEFORE THE SERVICE IS STARTED!\n    static nextTransactionID=1;\n    transactions:ITransaction[]=[]\n\n    maxTransactionWaitTime = 1000*60*1; // 1 min and detelete transaction\n\n    failReportFileStream:fs.WriteStream|null=null;\n    failReportFileStreamName:string|null=null;\n    failReportLastAccessTime:number=0;\n\n    constructor(options:MysqlServiceOptions){\n        super(\"mysql\");\n        this.options = options;\n        \n\n        // decrypt when needed\n        if(this.options.host.startsWith(\"_\"))\n            this.options.host = decrypt(this.options.host.substring(1)) ?? this.options.host\n        if(this.options.user.startsWith(\"_\"))\n            this.options.user = decrypt(this.options.user.substring(1)) ?? this.options.user\n        if(this.options.database.startsWith(\"_\"))\n            this.options.database = decrypt(this.options.database.substring(1)) ?? this.options.database\n        if(this.options.password.startsWith(\"_\"))\n            this.options.password = decrypt(this.options.password.substring(1)) ?? this.options.password\n\n        if(this.options.debug)\n            this.debug = true\n        if(this.options.naxTransactionWaitTime)\n            this.maxTransactionWaitTime = this.options.naxTransactionWaitTime;\n\n        setInterval(()=>{\n            // check transactions\n            const now = Date.now();\n            const count = this.transactions.length;\n            const removedIDs:number[]=[];\n            for(let i of this.transactions){\n                if(now-i.timestamp>this.maxTransactionWaitTime){\n                    logError(\"Release transaction connection due to timeout\")\n                    this.rollbackTransaction(i,true);\n                    removedIDs.push(i.id)\n                }\n            }\n\n            this.transactions = this.transactions.filter(i=>!removedIDs.includes(i.id))\n            \n            if(this.debug)\n                console.log(\"Removed: \",count-this.transactions.length)\n\n            \n\n        },1000*30)\n\n        setInterval(()=>{\n            if(!this.failReportFileStream)\n                return;\n                \n            // after 15 min of inactivity, close file\n            if(Date.now()-this.failReportLastAccessTime>1000*60*15){\n                this.failReportFileStream.end();\n                this.failReportFileStream=null;\n            }\n\n        },1000*60*5)\n\n        if(options.transactionFailReportDir){\n            try{\n               if (!fs.existsSync(options.transactionFailReportDir)){\n                    fs.mkdirSync(options.transactionFailReportDir);\n                }\n            }catch(e){\n                options.transactionFailReportDir=undefined;\n                logCrit(\"${MysqlService.js}\",\"Can't create transaction fail report dir\")\n            }\n        }\n    }\n\n    static async executeQuery (query:MySqlQuery|MySqlQuery[]):Promise<MysqlResult[]>{ return await REQ_MYSQL_QUERY.request(query) }\n\n    async init(){\n        super.init();\n\n        // setup process exit handlers interrupt (ctrl+c)\n        process.on('SIGINT', async () => {\n            await this.finishApp();\n            process.exit(0);\n        });\n          \n        // terminate (kill)\n        process.on('SIGTERM',async () => {\n            await this.finishApp();\n            process.exit(0);\n        });\n\n        this.serviceStarted=false;\n        let poolCreated:boolean = false;\n\n        while(!poolCreated){\n            logInfo(\"${MysqlService.js}\",\"Connecting to MYSQL!\")\n            poolCreated = await this.recreatePool();\n            if(!poolCreated){\n                logCrit(\"${MysqlService.js}\",\"Can't connect to MYSQL! Retrying in 3 seconds...\")\n                await new Promise((resolve)=>setTimeout(resolve,3000))\n            }\n        }\n\n        REQ_MYSQL_QUERY.listener=async data =>{\n            if(!Array.isArray(data))\n                data=[data];\n            const promises=[]\n            for(let i of data){\n                const query = MysqlService.prepareQuery(i.query,i.fields);\n                promises.push(this.execute(query,i.rollbackQuery ?? null,i.transactionID ?? 0,i.throwable ?? false,i.calculateCount ?? false));\n            }\n            \n            if(this.debug)\n                console.log(\"Execute queries: \",data.length)\n            \n            const result =  await Promise.all(promises);\n            for(let i of result){\n                if(i.error && (i.error.fatal || i.error.throwable))\n                    throw i.error;\n            }\n            return result;\n        }\n\n        REQ_MYSQL_TBEGIN.listener=async ()=>{  \n            const conn = await this.pool?.getConnection();\n            if(!conn)\n                return {code:\"NO_POOL\",errno:100000,fatal:true,sql:\"\",name:\"NO_POOL\",message:\"Mysql pool not created\",throwable:false}\n\n            // find conn in transactions\n            for(let i of this.transactions){\n                if(i.conn===conn){\n                    logInfo(\"Your connection is in transaction\")\n                    return {code:\"CONN_IN_TRX\",errno:100005,fatal:true,throwable:false,sql:\"\",name:\"CONN_IN_TRX\",message:\"Connection is in transaction\"}\n                }\n            }\n\n            const tid = MysqlService.nextTransactionID++;\n            if(this.debug)\n                console.log(\"Begin transaction with id \",tid)\n\n            try{\n                \n                // await conn.beginTransaction();\n                await conn.query(\"START TRANSACTION\");\n                //const res = await conn.query(\"SET autocommit=0\");\n                if(this.debug)\n                    console.log(\"Transaction started\")\n\n            }catch(e){\n               this.rollbackTransaction({id:tid,conn:conn,timestamp:Date.now(),queries:[{sql:\"START TRANSACTION\",status:\"error\"}]})\n               return this.createMysqlQueryError(e);\n            }\n\n            this.transactions.push({\n                id:tid,\n                timestamp:Date.now(),\n                conn:conn,\n                queries:[]\n            })\n\n            if(this.debug)\n                console.log(\"Transactions pool: \",this.transactions)\n\n            return tid;\n        }\n        \n        REQ_MYSQL_TQUERY.listener=async data=>{\n            const trx = this.transactions.find(i=>i.id===data.tid);\n            if(!trx)\n                return {err: {\n                    code:\"NO_TRX\",\n                    errno:100004,\n                    fatal:true,\n                    sql:\"\",\n                    name:\"NO_TRX\",\n                    message:\"Transaction not found\",\n                },data:null,rollbackError:null,count:0}\n\n            const query = MysqlService.prepareQuery(data.query.query,data.query.fields);\n            let err=null;\n            let sqlData = null;\n\n            if(this.debug)\n                console.log(\"Execute query on transaction: \",trx.id)\n\n            try{\n                sqlData = await trx.conn.query(query);\n            }catch(e){ err = this.createMysqlQueryError(e);}\n\n            let count = 0;\n            if(err)\n                this.rollbackTransaction(trx);\n            else{\n                if(data.query.calculateCount && query.indexOf(\"SELECT\")===0){\n                    let countQuery = this.prepareCountQuery(query);\n                    try{\n                        const countQueryResult = await trx.conn.query(countQuery);\n                        if(countQueryResult && countQueryResult.length>0){\n                            count = (countQueryResult[0] as any).count; // todo : check, probably not working (wrong field or smth)\n                        }\n                    }catch(e){\n                        logError(\"${MysqlService.js}->query error\",e);\n                    }\n                }\n            }\n\n            if(this.debug)\n                console.log(\"Query execution status:\",err?err.message:\"completed\")\n\n            trx.queries.push({sql:query,status:err?err.message:\"completed\"})\n\n            return {\n                data:sqlData?sqlData[0]:null,\n                error:err,\n                count:count\n            };\n        }\n\n        REQ_MYSQL_TROLLBACK.listener=async (tid:number)=>{\n            const trx = this.transactions.find(i=>i.id===tid);\n            if(!trx){\n                return {\n                    code:\"NO_TRX\",\n                    errno:100004,\n                    fatal:true,\n                    throwable:false,\n                    sql:\"\",\n                    name:\"NO_TRX\",\n                    message:\"Transaction not found\"\n                }\n            }\n\n            await this.rollbackTransaction(trx);\n            return null;\n        }\n\n        REQ_MYSQL_TCOMMIT.listener=async (tid:number)=>{\n            const trx = this.transactions.find(i=>i.id===tid);\n            if(!trx){\n                return {\n                    code:\"NO_TRX\",\n                    errno:100004,\n                    fatal:true,\n                    sql:\"\",\n                    name:\"NO_TRX\",\n                    message:\"Transaction not found\",\n                    throwable:false\n                }\n            }\n\n\n            if(this.debug)\n                console.log(\"Commit transaction:\",trx.id)\n            \n            // remove from transactions\n            this.transactions = this.transactions.filter(i=>i.id!==tid);\n\n            if(this.debug)\n                console.log(\"Transaction pool:\",this.transactions )\n            \n            const err = await this.commit(trx);\n\n            return err;\n        }\n    }\n\n    async commit(trx:ITransaction):Promise<MysqlError|null>{\n       \n        try{\n            await trx.conn.commit();\n            //await trx.conn.query(\"COMMIT\");\n            trx.conn.removeAllListeners();\n            trx.conn.release();\n        }catch(e){\n            await this.rollbackTransaction(trx);\n            return this.createMysqlQueryError(e);\n        }\n        return null;\n\n    }\n\n    async rollbackTransaction(trx:ITransaction,donNotRemove?:boolean):Promise<MysqlError|null>{\n        let err=null;\n        try{\n            console.log(\"Rollback started\",trx.conn.threadId)\n            await trx.conn.rollback();\n            await trx.conn.commit();\n            //await trx.conn.query(\"ROLLBACK\");\n            trx.conn.removeAllListeners();\n            trx.conn.release();\n            if(!donNotRemove)\n                this.transactions = this.transactions.filter(i=>i.id!==trx.id);\n            if(this.debug)\n                console.log(\"Rollback complete\",trx.conn.threadId)\n        }catch(e){\n            logCrit(\"${MysqlService.js}\",\"Can't rollback transaction\",trx.queries)\n            err = this.createMysqlQueryError(e);\n        }\n        this.storeTransactionAsProblem(trx,\"rollback\")\n        return err;\n    }\n\n    async finishApp(){\n        console.log(\"Finishing mysql service\")\n        for(let i of this.transactions)\n            this.rollbackTransaction(i);\n\n        if(this.pool){\n            try{await this.pool.end();}catch(e){\n                logCrit(\"${MysqlService.js}\",\"Can't close MYSQL pool!\")\n            }\n        }\n\n        if(this.failReportFileStream)\n            this.failReportFileStream.end();\n        this.failReportFileStream=null;\n    }\n\n    prepareCountQuery(query:string):string{\n        let countQuery = query;\n        countQuery = countQuery.substring(0,countQuery.indexOf(\"LIMIT\"));\n        countQuery = countQuery.substring(countQuery.indexOf(\"FROM\"));\n        countQuery = \"SELECT COUNT(1) as `count` \"+countQuery\n        return countQuery;\n    }\n\n    async storeTransactionAsProblem(trx:ITransaction,message:string){\n\n        if(!this.options.transactionFailReport && !this.options.transactionFailReportDir){\n            logCrit(\"${MysqlService.js}\",\"Can't report failed transaction, no report function: transactionFailReport in options, and transactionFailReportDir isnt set\")\n            return;\n        }\n\n\n        if(this.options.transactionFailReportDir){\n            const yyymmdd = new Date().toISOString().substring(0,10).replaceAll(\"-\",\"\");\n\n            //store transaction\n            const date = new Date();\n            const file = path.resolve(this.options.transactionFailReportDir,yyymmdd+\".json\");\n            if(this.failReportFileStream){\n                if(this.failReportFileStreamName!==file){\n                    this.failReportFileStream.end();\n                    this.failReportFileStream=null;\n                }\n            }\n\n\n            if(this.failReportFileStreamName){\n                this.failReportFileStream = fs.createWriteStream(file,{flags:'a'});\n                this.failReportFileStreamName=file;\n            }\n            \n            if(this.debug)\n                console.log(\"Store transaction fail report: \",file,trx.queries,message)\n\n            if(!this.failReportFileStream)\n                this.failReportFileStream = fs.createWriteStream(file,{flags:'a'});\n\n            this.failReportFileStream.write(JSON.stringify({queries:trx.queries,time:trx.timestamp,date,message})+\"\\n}EOB{\\n\",err=>{\n                if(err)\n                    logCrit(\"${MysqlService.js}\",\"Can't write to transaction fail report file\")\n                else\n                    logInfo(\"${MysqlService.js}\",\"Transaction fail report stored\")\n            });\n\n            this.failReportLastAccessTime = Date.now();\n\n        }\n\n        \n        if(this.options.transactionFailReport)\n            this.options.transactionFailReport(trx,message);\n    }\n\n\n    async recreatePool():Promise<boolean>{\n\n        logInfo(\"${MysqlService.js}\",\"Connecting to mysql: \\n HOST: \"+this.options.host+'\\n PORT:'+this.options.port)\n\n        if(this.pool){\n            this.pool.removeAllListeners();\n            try{await this.pool.end();}catch(e){\n                logCrit(\"${MysqlService.js}\",\"Can't close MYSQL pool!\")\n            }\n            this.pool = null;\n        }\n\n        \n        // Keep alive packets should be sent\n        /*enableKeepAlive: true,\n        // We should start sending them early\n        keepAliveInitialDelay: 3 * 1000, // 3 seconds\n        // We don't want idle connections, but it's not mandatory for the fix to work, it seems\n        maxIdle: 0,\n        // Idle timeout much larger than keep alive delay and much smaller than MySQL's timeout setting\n        idleTimeout: 5 * 60 * 1000 // 5 minutes\n        */\n\n        try{\n            this.pool =mysql.createPool({\n                host: this.options.host\n                ,user: this.options.user\n                ,password: this.options.password\n                ,database: this.options.database\n                ,port: this.options.port\n                ,connectionLimit: this.options.connectionLimit\n                ,queueLimit: 10\n                ,multipleStatements: true\n\n                ,enableKeepAlive:true\n                ,keepAliveInitialDelay:3*1000\n                //,maxIdle:0\n                ,idleTimeout:1000*60*5\n            });\n        }catch(e){\n            logCrit(\"${MysqlService.js}\",\"Can't connect to MYSQL!\")\n            return false;\n        }\n\n        this.pool?.on('connection', (connection) => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION CREATED\")\n        });\n        this.pool?.on('acquire', (connection) => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION ACQUIRED\")\n        })\n        this.pool?.on('release', (connection) => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION RELEASED\")\n        })\n        this.pool?.on('enqueue', () => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION ENQUEUED\")\n        })\n        \n        // Check connection\n        if(this.debug)\n            console.log(\"Check mysql connection\")\n\n        return new Promise(async (resolve,reject)=>{\n            try{\n                const conn = await this.pool?.getConnection()\n                if(conn){\n                    const [res,f] = await conn.query(\"SELECT 1\");\n                    conn?.release();\n                    logInfo(\"${MysqlService.js}\",\"Connected to MYSQL!\")\n                    resolve(true)\n                    \n                }else\n                    resolve(false)\n            }catch(e){\n                logCrit(\"${MysqlService.js}\",\"Can't connect to MYSQL!\")\n                resolve(false)\n            }\n        });\n\n    }\n\n    async onApplicationReady() {}\n\n\n    static fieldsToObject(fields:MysqlQueryField[]|MysqlQueryFieldObject,ignoreSystemParameters?:boolean):MysqlQueryFieldObject{\n        if(!Array.isArray(fields))\n            return fields;\n        const obj:MysqlQueryFieldObject={};\n        for(let i of fields){\n            if(!i.name)\n                continue;\n            if(typeof i.value!== \"object\")\n                obj[i.name]=i.value;\n            else{\n                if(!ignoreSystemParameters){\n                    obj[i.name]={\n                        value:i.value,\n                        system:i.system,\n                        ignoreInInsert:i.ignoreInInsert,\n                        ignoreInUpdate:i.ignoreInUpdate,\n                        useInReplace:i.useInReplace,\n                        name:i.name\n                    }\n                }else\n                    obj[i.name]=i.value\n            }\n\n        }\n        return obj;\n    }\n\n    static objectToFields(obj:MysqlQueryFieldObject|MysqlQueryField[]):MysqlQueryField[]{\n        if(Array.isArray(obj))\n            return obj;\n        const fields:MysqlQueryField[]=[];\n        for(let i in obj){\n            if(obj[i] && typeof obj[i] === \"object\"){\n                let mo = obj[i] as Record<string,string|number|boolean|null|undefined>;\n                if(!mo){\n                    mo={\n                        name:i,\n                        value:null,\n                        system:false,\n                        ignoreInInsert:false,\n                        ignoreInUpdate:false,\n                        useInReplace:false\n                    }\n                }\n                fields.push({\n                    name:mo.name as string ?? i,\n                    value:mo.value,\n                    system:mo.system as boolean,\n                    ignoreInInsert:mo.ignoreInInsert as boolean,\n                    ignoreInUpdate:mo.ignoreInUpdate as boolean,\n                    useInReplace:mo.useInReplace as boolean\n                })\n            }else{\n                fields.push({\n                    name:i,\n                    value:obj[i] as string|number|boolean|null|undefined\n                })\n            }\n        }\n        return fields;\n    }\n\n    static prepareQuery(query:string,fields:MysqlQueryField[]|MysqlQueryFieldObject):string{\n        \n        if(!Array.isArray(fields))\n            fields = MysqlService.objectToFields(fields);\n\n        for(let i of fields){\n            const val =this.prepareQueryFieldValue(i.value,i.system);\n            i._parsedValue=val;\n            query=query.replaceAll(\"@\"+i.name,val+\"\")\n        }\n\n        const tmp = query.toLowerCase();\n        if(tmp.indexOf(\"select\")===0 && tmp.indexOf(\"limit\")===-1)\n            query+=\" LIMIT 100\"\n        \n        query = query.replaceAll(\"@NOLIMIT\",\"\")\n\n\n        if(query.indexOf(\"@fields\")!==-1){\n            let insertFieldNames=[]\n            let insertFieldValues=[]\n            for(let i of fields){\n                if(i.ignoreInInsert)\n                    continue;\n\n                insertFieldNames.push('`'+i.name.replaceAll(\"`\",'').replaceAll('\\\"',\"\").replaceAll('\\'',\"\")+'`')\n                insertFieldValues.push(i._parsedValue)\n            }\n\n            query=query\n                .replaceAll('@fields',insertFieldNames.join(\",\"))\n                .replaceAll('@values',insertFieldValues.join(\",\"))\n        }\n\n        if(query.indexOf(\"@insert\")!==-1){\n            let oninsertNames=[]\n            let oninsertValues=[]\n            for(let i of fields){\n                if(i.ignoreInInsert)\n                    continue;\n                oninsertNames.push(i.name)\n                oninsertValues.push(i._parsedValue)\n            }\n            query = query.replaceAll(\"@insert\",`(${oninsertNames.join(\",\")}) VALUES (${oninsertValues.join(\",\")})`)\n        }\n\n        if(query.indexOf(\"@onupdate\")!==-1){\n            let onUpdate=[]\n            for(let i of fields){\n                if(i.ignoreInUpdate)\n                    continue;\n                onUpdate.push('`'+i.name.replaceAll(\"`\",'').replaceAll('\\\"',\"\").replaceAll('\\'',\"\")+'` = '+i._parsedValue)\n            }\n            query = query.replaceAll(\"@onupdate\",onUpdate.join(\" , \"))\n       \n        }\n\n        if(query.indexOf('@onduplicate')!==-1){\n            let onDuplicate=[];\n            for(let i of fields){\n                if(!i.useInReplace)\n                    continue;\n                onDuplicate.push('`'+i.name.replaceAll(\"`\",'').replaceAll('\\\"',\"\").replaceAll('\\'',\"\")+'` = '+i._parsedValue)\n            }\n            query = query.replaceAll(\"@onduplicate\",onDuplicate.join(\" , \"))\n        }\n        \n        \n        return  query;\n    }\n\n    static prepareQueryFieldValue(value:string|number|boolean|null|undefined,system?:boolean):string|number|boolean|null|undefined{\n        if(!system && typeof value === \"string\"){\n            value = value?value.replaceAll('\"','\\\\\"'):null\n            if(value!==null)\n                value = '\"'+value+'\"'\n            else\n                value = \"NULL\"\n        }\n        if(value === null || value === undefined)\n            return \"NULL\"\n        return value;\n    }\n\n\n    async execute(query:string,rollbackQuery:string|null,transactionID:number,throwable:boolean,calculateCount:boolean):Promise<MysqlResult>{\n        return new Promise(async (resolve:(data:MysqlResult)=>void,reject)=>{\n            // Check pool\n            if(!this.pool){\n                logError(\"${MysqlService.js}\",\"No pool\")\n                resolve({\n                    error:{\n                        code: \"NO_POOL\",\n                        errno: 100000,\n                        fatal: true,\n                        sql: query,\n                        name:\"NO_POOL\",\n                        message:\"Mysql pool not created\",\n                        throwable:throwable?true:false\n                    },\n                    data:null,\n                    count:0\n                })\n                return;\n            }\n\n            \n            try{\n                let conn:mysql.PoolConnection|null=null\n                if(transactionID && transactionID>0){\n                    conn = this.transactions.find(i=>i.id===transactionID)?.conn ?? null;\n                    if(this.debug)\n                        console.log(\"Execute query on transaction: \",conn?.threadId)\n                }else{\n                    conn = await this.pool.getConnection();\n                }\n\n                if(this.debug)\n                    console.log(\"Execute query\",conn?.threadId)\n\n                // if connection not created\n                if(!conn){\n                    logCrit(\"${MysqlService.js}\",`No connection created!`)\n                    resolve({\n                        error:{\n                            code: \"NO_CONN\",\n                            errno: 100001,\n                            fatal: true,\n                            sql: query,\n                            name:\"NO_CONN\",\n                            message:\"Mysql pool cant get connection\",\n                            throwable:throwable?true:false\n                        },\n                        data:null,\n                        count:0\n                    })\n                    return;\n                }\n\n\n                // Do send query\n                for(let i of this.transactions){\n                    if(i.conn===conn){\n                        logInfo(\"Your connection is in transaction\")\n                        break;\n                    }\n                }\n                this.sendQuery(conn,query,resolve,rollbackQuery,throwable?true:false,calculateCount);\n\n            }catch(e){\n                logError(\"${MysqlService.js}\",e);\n                \n                // recreate pool, connection error\n                if(`${e}`.indexOf('ECONNREFUSED')!==-1)\n                    this.recreatePool();\n                \n                resolve({\n                    error:{\n                        code: \"NO_CONN\",\n                        errno: 100001,\n                        fatal: true,\n                        throwable:throwable?true:false,\n                        sql: query,\n                        name:\"NO_CONN\",\n                        message:(e && typeof e === \"object\" && \"message\" in e as any)?(e as any).message:\"Mysql cant get connection\"\n                    },\n                    data:null,\n                    count:0\n                })\n                return;\n            }\n        });\n    }\n\n    async sendQuery(conn:mysql.PoolConnection,query:string,resolve:(data:MysqlResult)=>void,rollback:string|null,throwable:boolean,calculateCount:boolean){\n        \n        let errCatched=false;\n\n        conn.on(\"error\",async err=>{\n            errCatched=true;\n\n            let rollbackError = null;\n            if(rollback)\n                rollbackError=(await this.queryAsync(conn,rollback)).err\n       \n            logError(\"${MysqlService.js}->conn.on('error')\",err)\n\n            // close conn on success\n            try{\n\n                conn.removeAllListeners();\n                conn.destroy()\n                \n            }catch(e){}\n     \n            resolve({\n                error:{\n                    code: \"CONN_ERR\",\n                    errno: 100003,\n                    fatal: true,\n                    sql: query,\n                    name:\"CONN_ERR\",\n                    message:\"Error: \"+err,\n                    throwable:throwable\n                },\n                data:null,\n                rollbackError:rollbackError,\n                count:0\n            })\n        })\n\n\n\n        logInfo(\"${MysqlService.js}\",query)\n\n        // send query\n        const queryResult = await this.queryAsync(conn,query);\n\n        // handle error\n        if(queryResult.err){\n            \n            // rollback\n            let rollbackError=null;\n            if(rollback)\n                rollbackError=(await this.queryAsync(conn,rollback)).err\n\n            // close connection\n            try{\n                conn.release();\n                conn.removeAllListeners();\n            }catch(e){}\n\n\n\n            // determine duplicate error\n            let dup=false;\n            if(queryResult.err && queryResult.err.code && queryResult.err.code.toLowerCase().indexOf(\"er_dup_entry\")!==-1)\n                dup=true;\n            \n            logError(\"${MysqlService.js}->query error\",queryResult.err);\n\n            resolve({\n                error:{...queryResult.err,throwable:throwable},\n                data:null,\n                rollbackError:rollbackError,\n                isDuplicateError:dup,\n                count:0\n            })\n        }\n\n        let count = 0;\n        if(calculateCount && query.indexOf(\"SELECT\")===0){\n            let countQuery = this.prepareCountQuery(query);\n            const countQueryResult = await this.queryAsync(conn,countQuery);\n            if(countQueryResult.err)\n                logError(\"${MysqlService.js}->query error\",countQueryResult.err);\n            else{\n                if(countQueryResult.results && countQueryResult.results.length>0){\n                    count = countQueryResult.results[0].count;\n                }\n            }\n        }\n\n\n        // close conn on success\n        try{\n            conn.release();\n            conn.removeAllListeners();\n        }catch(e){}\n\n        // handle success\n        const err = queryResult.err?{...queryResult.err,throwable:throwable}:null;\n        resolve({\n            error:err,\n            data:queryResult.results,\n            count:count\n        })\n    }\n\n\n    // Async query wrapper to conn.query\n    async queryAsync(conn:mysql.PoolConnection,query:string):Promise<{err:MysqlError|null,results?:any}>{\n\n        let result=null;\n        try{\n            result = await conn.query(query);\n        }catch(e){\n            return {err:this.createMysqlQueryError(e)};\n        }\n\n        return {\n            err:null,\n            results:result[0],\n        }\n    }\n\n    createMysqlQueryError(err:any,throwable?:boolean):MysqlError{\n        if(err &&  typeof err===\"object\" && \"code\" in err && \"errno\" in err && \"sql\" in err && \"name\" in err && \"message\" in err){\n            return {\n                    code: err.code,\n                    errno: err.errno,\n                    sql: err.sql,\n                    name:err.name,\n                    message:err.message,\n                    throwable:throwable?true:false\n                \n            }\n        }else{\n            return {\n                code: \"QUERY_ERR\",\n                errno: 100002,\n                fatal: true,\n                sql: \"no query\",\n                name:\"QUERY_ERR\",\n                message:\"Error: \"+(err)?err:\"\",\n                throwable:throwable?true:false\n            }\n        }\n    }\n}\n\n\nconst secret_key=\"AKLWkajw%^&dgwqhw#98453i23bfk23rn2knknglrgjeit\"\nconst secret_iv=\"rthadrfk23rn2kn#*FNKA@gt44df3tslrgj##!it\"\n\n// Generate secret hash with crypto to use for encryption\nconst key = createHash('sha512').update(secret_key).digest('hex').substring(0, 32)\nconst iv = createHash('sha512').update(secret_iv).digest('hex').substring(0, 16)\n\nconst decrypt =(encrypted:string):string|null=>{\n  try{\n      encrypted = Buffer.from(encrypted, 'base64').toString('binary');\n      const decipher = createDecipheriv('aes-256-cbc', key, iv);\n      let decrypted = decipher.update(encrypted, 'binary', 'utf8');\n      decrypted += decipher.final('utf8');\n      return decrypted;\n  }catch(e){\n      return null;\n  }\n}\n\nconst encrypt = (txt:string):string|null=>{\n  try{\n      let encipher = createCipheriv('aes-256-cbc', key, iv),\n      encrypted = encipher.update(txt, 'utf8', 'binary');\n      encrypted += encipher.final('binary');\n      return Buffer.from(encrypted, 'binary').toString('base64');\n  }catch(e){\n      return null;\n  }\n}\n\nexport default MysqlService;"]}
773
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MysqlService.js","sourceRoot":"","sources":["../../src/apiServer/MysqlService.ts"],"names":[],"mappings":"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","sourcesContent":["//import mysql, { FieldInfo, MysqlError, Pool, PoolConnection } from \"mysql\"\n\nimport { BaseService } from \"./BaseService\";\nimport Signal, { Req } from \"badmfck-signal\";\nimport { createCipheriv, createDecipheriv, createHash } from \"crypto\"\nimport { logCrit, logError, logInfo } from \"./LogService\";\nimport * as mysql from \"mysql2/promise\"\nimport fs from \"fs\"\nimport path from \"path\"\n\nexport const S_MYSQL_STARTED=new Signal<void>()\nexport const REQ_MYSQL_QUERY = new Req<MySqlQuery|MySqlQuery[],MysqlResult[]>(undefined,\"REQ_MYSQL_QUERY\");\n//export const REQ_MYSQL_TRANSACTION = new Req<MySqlQuery[],MysqlResult>(undefined,\"REQ_MYSQL_TRANSACTION\");\n\nexport const REQ_MYSQL_TBEGIN = new Req<void,MysqlError|number>(undefined,\"REQ_MYSQL_TRANSACTION_BEGING\"); // return transaction id or mysql error\nexport const REQ_MYSQL_TQUERY=new Req<{query:MySqlQuery,tid:number},MysqlResult>(undefined,\"REQ_MYSQL_TRANSACTION_ADD_OPERATION\"); // tid means transaction id\nexport const REQ_MYSQL_TCOMMIT=new Req<number,MysqlError|null>(undefined,\"REQ_MYSQL_TCOMMIT\"); // tid\nexport const REQ_MYSQL_TROLLBACK=new Req<number,MysqlError|null>(undefined,\"REQ_MYSQL_TROLLBACK\"); // tid\n\nexport const executeQuery = async (query:MySqlQuery|MySqlQuery[]):Promise<MysqlResult[]>=>{return await REQ_MYSQL_QUERY.request(query)}\n\nexport interface MysqlServiceOptions{\n    connectionLimit:number,\n    host:string,\n    user:string,\n    password:string,\n    port:number,\n    database:string,  \n    queueLimit?:number,\n    transactionFailReport?:(trx:ITransaction,message:string)=>void,\n    transactionFailReportDir?:string,\n    debug?:boolean,\n    naxTransactionWaitTime?:number,\n\tmigrations?:{\n\t\tdir:string,\n\t\tcallback:()=>void\n\t}|null\n}\n\nexport interface MysqlError{\n    code: string,\n    errno: number,\n    sql: string,\n    name:string,\n    message:string\n    fatal?:boolean,\n    throwable:boolean\n}\n\nexport const isMysqlError=(e:any):e is MysqlError=>{\n    return e.code!==undefined && e.errno!==undefined && e.sql!==undefined && e.name!==undefined && e.message!==undefined;\n}\n\nexport interface MysqlResult{\n    error?:MysqlError|null,\n    rollbackError?:MysqlError|null,\n    isDuplicateError?:boolean\n    data:any\n    count:number\n}\n\nexport interface MySqlQuery{\n    query:string\n    fields:MysqlQueryField[]|MysqlQueryFieldObject,\n    rollbackQuery?:string|null\n    transactionID?:number\n    throwable?:boolean\n    calculateCount?:boolean\n}\n\nexport interface MysqlQueryField{\n    name:string,\n    value:string|number|boolean|null|undefined,\n    system?:boolean,\n    ignoreInInsert?:boolean,\n    ignoreInUpdate?:boolean\n    useInReplace?:boolean,\n    _parsedValue?:string|number|boolean|null\n}\n\nexport interface ITransaction{\n    id:number\n    timestamp:number,\n    conn:mysql.PoolConnection,\n    queries:{sql:string,status:string}[]\n}\n\nexport interface MysqlQueryFieldObject extends Record<string,string|number|boolean|null|undefined|{name?:string|null,value:string|number|boolean|null|undefined,system?:boolean,ignoreInInsert?:boolean,ignoreInUpdate?:boolean,useInReplace?:boolean}>{\n\n}\n    \n\n/**\n * Mysql Services, execute queries\n * MySqlQuery.query:\n * @fields - replaced by field's names\n * @values - replaced by parsed values\n * @onupdate - repalced by pair field name = value\n * @onduplicate - replaced by pair field name = value\n */\n\nexport class MysqlService extends BaseService{\n\n    reconnectionTimeout=1000*3;\n    reconnecting=false;\n    pool:mysql.Pool|null=null;\n    options:MysqlServiceOptions;\n    serviceStarted=false;\n    timeoutID:any\n\n    debug=false;\n\n    queries=[]; // TODO: STORE QUERIES SENTS BEFORE THE SERVICE IS STARTED!\n    static nextTransactionID=1;\n    transactions:ITransaction[]=[]\n\n    maxTransactionWaitTime = 1000*60*1; // 1 min and detelete transaction\n\n    failReportFileStream:fs.WriteStream|null=null;\n    failReportFileStreamName:string|null=null;\n    failReportLastAccessTime:number=0;\n\n    constructor(options:MysqlServiceOptions){\n        super(\"mysql\");\n        this.options = options;\n        \n\n        // decrypt when needed\n        if(this.options.host.startsWith(\"_\"))\n            this.options.host = decrypt(this.options.host.substring(1)) ?? this.options.host\n        if(this.options.user.startsWith(\"_\"))\n            this.options.user = decrypt(this.options.user.substring(1)) ?? this.options.user\n        if(this.options.database.startsWith(\"_\"))\n            this.options.database = decrypt(this.options.database.substring(1)) ?? this.options.database\n        if(this.options.password.startsWith(\"_\"))\n            this.options.password = decrypt(this.options.password.substring(1)) ?? this.options.password\n\n        if(this.options.debug)\n            this.debug = true\n        if(this.options.naxTransactionWaitTime)\n            this.maxTransactionWaitTime = this.options.naxTransactionWaitTime;\n\n        setInterval(()=>{\n            // check transactions\n            const now = Date.now();\n            const count = this.transactions.length;\n            const removedIDs:number[]=[];\n            for(let i of this.transactions){\n                if(now-i.timestamp>this.maxTransactionWaitTime){\n                    logError(\"Release transaction connection due to timeout\")\n                    this.rollbackTransaction(i,true);\n                    removedIDs.push(i.id)\n                }\n            }\n\n            this.transactions = this.transactions.filter(i=>!removedIDs.includes(i.id))\n            \n            if(this.debug)\n                console.log(\"Removed: \",count-this.transactions.length)\n\n            \n\n        },1000*30)\n\n        setInterval(()=>{\n            if(!this.failReportFileStream)\n                return;\n                \n            // after 15 min of inactivity, close file\n            if(Date.now()-this.failReportLastAccessTime>1000*60*15){\n                this.failReportFileStream.end();\n                this.failReportFileStream=null;\n            }\n\n        },1000*60*5)\n\n        if(options.transactionFailReportDir){\n            try{\n               if (!fs.existsSync(options.transactionFailReportDir)){\n                    fs.mkdirSync(options.transactionFailReportDir);\n                }\n            }catch(e){\n                options.transactionFailReportDir=undefined;\n                logCrit(\"${MysqlService.js}\",\"Can't create transaction fail report dir\")\n            }\n        }\n    }\n\n    static async executeQuery (query:MySqlQuery|MySqlQuery[]):Promise<MysqlResult[]>{ return await REQ_MYSQL_QUERY.request(query) }\n\n    async init(){\n        super.init();\n\n        // setup process exit handlers interrupt (ctrl+c)\n        process.on('SIGINT', async () => {\n            await this.finishApp();\n            process.exit(0);\n        });\n          \n        // terminate (kill)\n        process.on('SIGTERM',async () => {\n            await this.finishApp();\n            process.exit(0);\n        });\n\n        this.serviceStarted=false;\n        let poolCreated:boolean = false;\n\n        while(!poolCreated){\n            logInfo(\"${MysqlService.js}\",\"Connecting to MYSQL!\")\n            poolCreated = await this.recreatePool();\n            if(!poolCreated){\n                logCrit(\"${MysqlService.js}\",\"Can't connect to MYSQL! Retrying in 3 seconds...\")\n                await new Promise((resolve)=>setTimeout(resolve,3000))\n            }\n        }\n\n        REQ_MYSQL_QUERY.listener=async data =>{\n            if(!Array.isArray(data))\n                data=[data];\n            const promises=[]\n            for(let i of data){\n                const query = MysqlService.prepareQuery(i.query,i.fields);\n                promises.push(this.execute(query,i.rollbackQuery ?? null,i.transactionID ?? 0,i.throwable ?? false,i.calculateCount ?? false));\n            }\n            \n            if(this.debug)\n                console.log(\"Execute queries: \",data.length)\n            \n            const result =  await Promise.all(promises);\n            for(let i of result){\n                if(i.error && (i.error.fatal || i.error.throwable))\n                    throw i.error;\n            }\n            return result;\n        }\n\n        REQ_MYSQL_TBEGIN.listener=async ()=>{  \n            const conn = await this.pool?.getConnection();\n            if(!conn)\n                return {code:\"NO_POOL\",errno:100000,fatal:true,sql:\"\",name:\"NO_POOL\",message:\"Mysql pool not created\",throwable:false}\n\n            // find conn in transactions\n            for(let i of this.transactions){\n                if(i.conn===conn){\n                    logInfo(\"Your connection is in transaction\")\n                    return {code:\"CONN_IN_TRX\",errno:100005,fatal:true,throwable:false,sql:\"\",name:\"CONN_IN_TRX\",message:\"Connection is in transaction\"}\n                }\n            }\n\n            const tid = MysqlService.nextTransactionID++;\n            if(this.debug)\n                console.log(\"Begin transaction with id \",tid)\n\n            try{\n                \n                // await conn.beginTransaction();\n                await conn.query(\"START TRANSACTION\");\n                //const res = await conn.query(\"SET autocommit=0\");\n                if(this.debug)\n                    console.log(\"Transaction started\")\n\n            }catch(e){\n               this.rollbackTransaction({id:tid,conn:conn,timestamp:Date.now(),queries:[{sql:\"START TRANSACTION\",status:\"error\"}]})\n               return this.createMysqlQueryError(e);\n            }\n\n            this.transactions.push({\n                id:tid,\n                timestamp:Date.now(),\n                conn:conn,\n                queries:[]\n            })\n\n            if(this.debug)\n                console.log(\"Transactions pool: \",this.transactions)\n\n            return tid;\n        }\n        \n        REQ_MYSQL_TQUERY.listener=async data=>{\n            const trx = this.transactions.find(i=>i.id===data.tid);\n            if(!trx)\n                return {err: {\n                    code:\"NO_TRX\",\n                    errno:100004,\n                    fatal:true,\n                    sql:\"\",\n                    name:\"NO_TRX\",\n                    message:\"Transaction not found\",\n                },data:null,rollbackError:null,count:0}\n\n            const query = MysqlService.prepareQuery(data.query.query,data.query.fields);\n            let err=null;\n            let sqlData = null;\n\n            if(this.debug)\n                console.log(\"Execute query on transaction: \",trx.id)\n\n            try{\n                sqlData = await trx.conn.query(query);\n            }catch(e){ err = this.createMysqlQueryError(e);}\n\n            let count = 0;\n            if(err)\n                this.rollbackTransaction(trx);\n            else{\n                if(data.query.calculateCount && query.indexOf(\"SELECT\")===0){\n                    let countQuery = this.prepareCountQuery(query);\n                    try{\n                        const countQueryResult = await trx.conn.query(countQuery);\n                        if(countQueryResult && countQueryResult.length>0){\n                            count = (countQueryResult[0] as any).count; // todo : check, probably not working (wrong field or smth)\n                        }\n                    }catch(e){\n                        logError(\"${MysqlService.js}->query error\",e);\n                    }\n                }\n            }\n\n            if(this.debug)\n                console.log(\"Query execution status:\",err?err.message:\"completed\")\n\n            trx.queries.push({sql:query,status:err?err.message:\"completed\"})\n\n            return {\n                data:sqlData?sqlData[0]:null,\n                error:err,\n                count:count\n            };\n        }\n\n        REQ_MYSQL_TROLLBACK.listener=async (tid:number)=>{\n            const trx = this.transactions.find(i=>i.id===tid);\n            if(!trx){\n                return {\n                    code:\"NO_TRX\",\n                    errno:100004,\n                    fatal:true,\n                    throwable:false,\n                    sql:\"\",\n                    name:\"NO_TRX\",\n                    message:\"Transaction not found\"\n                }\n            }\n\n            await this.rollbackTransaction(trx);\n            return null;\n        }\n\n        REQ_MYSQL_TCOMMIT.listener=async (tid:number)=>{\n            const trx = this.transactions.find(i=>i.id===tid);\n            if(!trx){\n                return {\n                    code:\"NO_TRX\",\n                    errno:100004,\n                    fatal:true,\n                    sql:\"\",\n                    name:\"NO_TRX\",\n                    message:\"Transaction not found\",\n                    throwable:false\n                }\n            }\n\n\n            if(this.debug)\n                console.log(\"Commit transaction:\",trx.id)\n            \n            // remove from transactions\n            this.transactions = this.transactions.filter(i=>i.id!==tid);\n\n            if(this.debug)\n                console.log(\"Transaction pool:\",this.transactions )\n            \n            const err = await this.commit(trx);\n\n            return err;\n        }\n    }\n\n    async commit(trx:ITransaction):Promise<MysqlError|null>{\n       \n        try{\n            await trx.conn.commit();\n            //await trx.conn.query(\"COMMIT\");\n            trx.conn.removeAllListeners();\n            trx.conn.release();\n        }catch(e){\n            await this.rollbackTransaction(trx);\n            return this.createMysqlQueryError(e);\n        }\n        return null;\n\n    }\n\n    async rollbackTransaction(trx:ITransaction,donNotRemove?:boolean):Promise<MysqlError|null>{\n        let err=null;\n        try{\n            console.log(\"Rollback started\",trx.conn.threadId)\n            await trx.conn.rollback();\n            await trx.conn.commit();\n            //await trx.conn.query(\"ROLLBACK\");\n            trx.conn.removeAllListeners();\n            trx.conn.release();\n            if(!donNotRemove)\n                this.transactions = this.transactions.filter(i=>i.id!==trx.id);\n            if(this.debug)\n                console.log(\"Rollback complete\",trx.conn.threadId)\n        }catch(e){\n            logCrit(\"${MysqlService.js}\",\"Can't rollback transaction\",trx.queries)\n            err = this.createMysqlQueryError(e);\n        }\n        this.storeTransactionAsProblem(trx,\"rollback\")\n        return err;\n    }\n\n    async finishApp(){\n        console.log(\"Finishing mysql service\")\n        for(let i of this.transactions)\n            this.rollbackTransaction(i);\n\n        if(this.pool){\n            try{await this.pool.end();}catch(e){\n                logCrit(\"${MysqlService.js}\",\"Can't close MYSQL pool!\")\n            }\n        }\n\n        if(this.failReportFileStream)\n            this.failReportFileStream.end();\n        this.failReportFileStream=null;\n    }\n\n    prepareCountQuery(query:string):string{\n        let countQuery = query;\n        countQuery = countQuery.substring(0,countQuery.indexOf(\"LIMIT\"));\n        countQuery = countQuery.substring(countQuery.indexOf(\"FROM\"));\n        countQuery = \"SELECT COUNT(1) as `count` \"+countQuery\n        return countQuery;\n    }\n\n    async storeTransactionAsProblem(trx:ITransaction,message:string){\n\n        if(!this.options.transactionFailReport && !this.options.transactionFailReportDir){\n            logCrit(\"${MysqlService.js}\",\"Can't report failed transaction, no report function: transactionFailReport in options, and transactionFailReportDir isnt set\")\n            return;\n        }\n\n\n        if(this.options.transactionFailReportDir){\n            const yyymmdd = new Date().toISOString().substring(0,10).replaceAll(\"-\",\"\");\n\n            //store transaction\n            const date = new Date();\n            const file = path.resolve(this.options.transactionFailReportDir,yyymmdd+\".json\");\n            if(this.failReportFileStream){\n                if(this.failReportFileStreamName!==file){\n                    this.failReportFileStream.end();\n                    this.failReportFileStream=null;\n                }\n            }\n\n\n            if(this.failReportFileStreamName){\n                this.failReportFileStream = fs.createWriteStream(file,{flags:'a'});\n                this.failReportFileStreamName=file;\n            }\n            \n            if(this.debug)\n                console.log(\"Store transaction fail report: \",file,trx.queries,message)\n\n            if(!this.failReportFileStream)\n                this.failReportFileStream = fs.createWriteStream(file,{flags:'a'});\n\n            this.failReportFileStream.write(JSON.stringify({queries:trx.queries,time:trx.timestamp,date,message})+\"\\n}EOB{\\n\",err=>{\n                if(err)\n                    logCrit(\"${MysqlService.js}\",\"Can't write to transaction fail report file\")\n                else\n                    logInfo(\"${MysqlService.js}\",\"Transaction fail report stored\")\n            });\n\n            this.failReportLastAccessTime = Date.now();\n\n        }\n\n        \n        if(this.options.transactionFailReport)\n            this.options.transactionFailReport(trx,message);\n    }\n\n\n    async recreatePool():Promise<boolean>{\n\n        logInfo(\"${MysqlService.js}\",\"Connecting to mysql: \\n HOST: \"+this.options.host+'\\n PORT:'+this.options.port)\n\n        if(this.pool){\n            this.pool.removeAllListeners();\n            try{await this.pool.end();}catch(e){\n                logCrit(\"${MysqlService.js}\",\"Can't close MYSQL pool!\")\n            }\n            this.pool = null;\n        }\n\n        \n        // Keep alive packets should be sent\n        /*enableKeepAlive: true,\n        // We should start sending them early\n        keepAliveInitialDelay: 3 * 1000, // 3 seconds\n        // We don't want idle connections, but it's not mandatory for the fix to work, it seems\n        maxIdle: 0,\n        // Idle timeout much larger than keep alive delay and much smaller than MySQL's timeout setting\n        idleTimeout: 5 * 60 * 1000 // 5 minutes\n        */\n\n        try{\n            this.pool =mysql.createPool({\n                host: this.options.host\n                ,user: this.options.user\n                ,password: this.options.password\n                ,database: this.options.database\n                ,port: this.options.port\n                ,connectionLimit: this.options.connectionLimit\n                ,queueLimit: 10\n                ,multipleStatements: true\n\n                ,enableKeepAlive:true\n                ,keepAliveInitialDelay:3*1000\n                //,maxIdle:0\n                ,idleTimeout:1000*60*5\n            });\n        }catch(e){\n            logCrit(\"${MysqlService.js}\",\"Can't connect to MYSQL!\")\n            return false;\n        }\n\n        this.pool?.on('connection', (connection) => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION CREATED\")\n        });\n        this.pool?.on('acquire', (connection) => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION ACQUIRED\")\n        })\n        this.pool?.on('release', (connection) => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION RELEASED\")\n        })\n        this.pool?.on('enqueue', () => {\n            if(this.debug)\n                logInfo(\"${MysqlService.js}\",\"MYSQL CONNECTION ENQUEUED\")\n        })\n        \n        // Check connection\n        if(this.debug)\n            console.log(\"Check mysql connection\")\n\n        return new Promise(async (resolve,reject)=>{\n            try{\n                const conn = await this.pool?.getConnection()\n                if(conn){\n                    const [res,f] = await conn.query(\"SELECT 1\");\n                    conn?.release();\n                    logInfo(\"${MysqlService.js}\",\"Connected to MYSQL!\")\n                    resolve(true)\n                    \n                }else\n                    resolve(false)\n            }catch(e){\n                logCrit(\"${MysqlService.js}\",\"Can't connect to MYSQL!\")\n                resolve(false)\n            }\n        });\n\n    }\n\n    async onApplicationReady() {}\n\n\n    static fieldsToObject(fields:MysqlQueryField[]|MysqlQueryFieldObject,ignoreSystemParameters?:boolean):MysqlQueryFieldObject{\n        if(!Array.isArray(fields))\n            return fields;\n        const obj:MysqlQueryFieldObject={};\n        for(let i of fields){\n            if(!i.name)\n                continue;\n            if(typeof i.value!== \"object\")\n                obj[i.name]=i.value;\n            else{\n                if(!ignoreSystemParameters){\n                    obj[i.name]={\n                        value:i.value,\n                        system:i.system,\n                        ignoreInInsert:i.ignoreInInsert,\n                        ignoreInUpdate:i.ignoreInUpdate,\n                        useInReplace:i.useInReplace,\n                        name:i.name\n                    }\n                }else\n                    obj[i.name]=i.value\n            }\n\n        }\n        return obj;\n    }\n\n    static objectToFields(obj:MysqlQueryFieldObject|MysqlQueryField[]):MysqlQueryField[]{\n        if(Array.isArray(obj))\n            return obj;\n        const fields:MysqlQueryField[]=[];\n        for(let i in obj){\n            if(obj[i] && typeof obj[i] === \"object\"){\n                let mo = obj[i] as Record<string,string|number|boolean|null|undefined>;\n                if(!mo){\n                    mo={\n                        name:i,\n                        value:null,\n                        system:false,\n                        ignoreInInsert:false,\n                        ignoreInUpdate:false,\n                        useInReplace:false\n                    }\n                }\n                fields.push({\n                    name:mo.name as string ?? i,\n                    value:mo.value,\n                    system:mo.system as boolean,\n                    ignoreInInsert:mo.ignoreInInsert as boolean,\n                    ignoreInUpdate:mo.ignoreInUpdate as boolean,\n                    useInReplace:mo.useInReplace as boolean\n                })\n            }else{\n                fields.push({\n                    name:i,\n                    value:obj[i] as string|number|boolean|null|undefined\n                })\n            }\n        }\n        return fields;\n    }\n\n    static prepareQuery(query:string,fields:MysqlQueryField[]|MysqlQueryFieldObject):string{\n        \n        if(!Array.isArray(fields))\n            fields = MysqlService.objectToFields(fields);\n\n        for(let i of fields){\n            const val =this.prepareQueryFieldValue(i.value,i.system);\n            i._parsedValue=val;\n            query=query.replaceAll(\"@\"+i.name,val+\"\")\n        }\n\n        const tmp = query.toLowerCase();\n        if(tmp.indexOf(\"select\")===0 && tmp.indexOf(\"limit\")===-1)\n            query+=\" LIMIT 100\"\n        \n        query = query.replaceAll(\"@NOLIMIT\",\"\")\n\n\n        if(query.indexOf(\"@fields\")!==-1){\n            let insertFieldNames=[]\n            let insertFieldValues=[]\n            for(let i of fields){\n                if(i.ignoreInInsert)\n                    continue;\n\n                insertFieldNames.push('`'+i.name.replaceAll(\"`\",'').replaceAll('\\\"',\"\").replaceAll('\\'',\"\")+'`')\n                insertFieldValues.push(i._parsedValue)\n            }\n\n            query=query\n                .replaceAll('@fields',insertFieldNames.join(\",\"))\n                .replaceAll('@values',insertFieldValues.join(\",\"))\n        }\n\n        if(query.indexOf(\"@insert\")!==-1){\n            let oninsertNames=[]\n            let oninsertValues=[]\n            for(let i of fields){\n                if(i.ignoreInInsert)\n                    continue;\n                oninsertNames.push(i.name)\n                oninsertValues.push(i._parsedValue)\n            }\n            query = query.replaceAll(\"@insert\",`(${oninsertNames.join(\",\")}) VALUES (${oninsertValues.join(\",\")})`)\n        }\n\n        if(query.indexOf(\"@onupdate\")!==-1){\n            let onUpdate=[]\n            for(let i of fields){\n                if(i.ignoreInUpdate)\n                    continue;\n                onUpdate.push('`'+i.name.replaceAll(\"`\",'').replaceAll('\\\"',\"\").replaceAll('\\'',\"\")+'` = '+i._parsedValue)\n            }\n            query = query.replaceAll(\"@onupdate\",onUpdate.join(\" , \"))\n       \n        }\n\n        if(query.indexOf('@onduplicate')!==-1){\n            let onDuplicate=[];\n            for(let i of fields){\n                if(!i.useInReplace)\n                    continue;\n                onDuplicate.push('`'+i.name.replaceAll(\"`\",'').replaceAll('\\\"',\"\").replaceAll('\\'',\"\")+'` = '+i._parsedValue)\n            }\n            query = query.replaceAll(\"@onduplicate\",onDuplicate.join(\" , \"))\n        }\n        \n        \n        return  query;\n    }\n\n    static prepareQueryFieldValue(value:string|number|boolean|null|undefined,system?:boolean):string|number|boolean|null|undefined{\n        if(!system && typeof value === \"string\"){\n            value = value?value.replaceAll('\"','\\\\\"'):null\n            if(value!==null)\n                value = '\"'+value+'\"'\n            else\n                value = \"NULL\"\n        }\n        if(value === null || value === undefined)\n            return \"NULL\"\n        return value;\n    }\n\n\n    async execute(query:string,rollbackQuery:string|null,transactionID:number,throwable:boolean,calculateCount:boolean):Promise<MysqlResult>{\n        return new Promise(async (resolve:(data:MysqlResult)=>void,reject)=>{\n            // Check pool\n            if(!this.pool){\n                logError(\"${MysqlService.js}\",\"No pool\")\n                resolve({\n                    error:{\n                        code: \"NO_POOL\",\n                        errno: 100000,\n                        fatal: true,\n                        sql: query,\n                        name:\"NO_POOL\",\n                        message:\"Mysql pool not created\",\n                        throwable:throwable?true:false\n                    },\n                    data:null,\n                    count:0\n                })\n                return;\n            }\n\n            \n            try{\n                let conn:mysql.PoolConnection|null=null\n                if(transactionID && transactionID>0){\n                    conn = this.transactions.find(i=>i.id===transactionID)?.conn ?? null;\n                    if(this.debug)\n                        console.log(\"Execute query on transaction: \",conn?.threadId)\n                }else{\n                    conn = await this.pool.getConnection();\n                }\n\n                if(this.debug)\n                    console.log(\"Execute query\",conn?.threadId)\n\n                // if connection not created\n                if(!conn){\n                    logCrit(\"${MysqlService.js}\",`No connection created!`)\n                    resolve({\n                        error:{\n                            code: \"NO_CONN\",\n                            errno: 100001,\n                            fatal: true,\n                            sql: query,\n                            name:\"NO_CONN\",\n                            message:\"Mysql pool cant get connection\",\n                            throwable:throwable?true:false\n                        },\n                        data:null,\n                        count:0\n                    })\n                    return;\n                }\n\n\n                // Do send query\n                for(let i of this.transactions){\n                    if(i.conn===conn){\n                        logInfo(\"Your connection is in transaction\")\n                        break;\n                    }\n                }\n                this.sendQuery(conn,query,resolve,rollbackQuery,throwable?true:false,calculateCount);\n\n            }catch(e){\n                logError(\"${MysqlService.js}\",e);\n                \n                // recreate pool, connection error\n                if(`${e}`.indexOf('ECONNREFUSED')!==-1)\n                    this.recreatePool();\n                \n                resolve({\n                    error:{\n                        code: \"NO_CONN\",\n                        errno: 100001,\n                        fatal: true,\n                        throwable:throwable?true:false,\n                        sql: query,\n                        name:\"NO_CONN\",\n                        message:(e && typeof e === \"object\" && \"message\" in e as any)?(e as any).message:\"Mysql cant get connection\"\n                    },\n                    data:null,\n                    count:0\n                })\n                return;\n            }\n        });\n    }\n\n    async sendQuery(conn:mysql.PoolConnection,query:string,resolve:(data:MysqlResult)=>void,rollback:string|null,throwable:boolean,calculateCount:boolean){\n        \n        let errCatched=false;\n\n        conn.on(\"error\",async err=>{\n            errCatched=true;\n\n            let rollbackError = null;\n            if(rollback)\n                rollbackError=(await this.queryAsync(conn,rollback)).err\n       \n            logError(\"${MysqlService.js}->conn.on('error')\",err)\n\n            // close conn on success\n            try{\n\n                conn.removeAllListeners();\n                conn.destroy()\n                \n            }catch(e){}\n     \n            resolve({\n                error:{\n                    code: \"CONN_ERR\",\n                    errno: 100003,\n                    fatal: true,\n                    sql: query,\n                    name:\"CONN_ERR\",\n                    message:\"Error: \"+err,\n                    throwable:throwable\n                },\n                data:null,\n                rollbackError:rollbackError,\n                count:0\n            })\n        })\n\n\n\n        logInfo(\"${MysqlService.js}\",query)\n\n        // send query\n        const queryResult = await this.queryAsync(conn,query);\n\n        // handle error\n        if(queryResult.err){\n            \n            // rollback\n            let rollbackError=null;\n            if(rollback)\n                rollbackError=(await this.queryAsync(conn,rollback)).err\n\n            // close connection\n            try{\n                conn.release();\n                conn.removeAllListeners();\n            }catch(e){}\n\n\n\n            // determine duplicate error\n            let dup=false;\n            if(queryResult.err && queryResult.err.code && queryResult.err.code.toLowerCase().indexOf(\"er_dup_entry\")!==-1)\n                dup=true;\n            \n            logError(\"${MysqlService.js}->query error\",queryResult.err);\n\n            resolve({\n                error:{...queryResult.err,throwable:throwable},\n                data:null,\n                rollbackError:rollbackError,\n                isDuplicateError:dup,\n                count:0\n            })\n        }\n\n        let count = 0;\n        if(calculateCount && query.indexOf(\"SELECT\")===0){\n            let countQuery = this.prepareCountQuery(query);\n            const countQueryResult = await this.queryAsync(conn,countQuery);\n            if(countQueryResult.err)\n                logError(\"${MysqlService.js}->query error\",countQueryResult.err);\n            else{\n                if(countQueryResult.results && countQueryResult.results.length>0){\n                    count = countQueryResult.results[0].count;\n                }\n            }\n        }\n\n\n        // close conn on success\n        try{\n            conn.release();\n            conn.removeAllListeners();\n        }catch(e){}\n\n        // handle success\n        const err = queryResult.err?{...queryResult.err,throwable:throwable}:null;\n        resolve({\n            error:err,\n            data:queryResult.results,\n            count:count\n        })\n    }\n\n\n    // Async query wrapper to conn.query\n    async queryAsync(conn:mysql.PoolConnection,query:string):Promise<{err:MysqlError|null,results?:any}>{\n\n        let result=null;\n        try{\n            result = await conn.query(query);\n        }catch(e){\n            return {err:this.createMysqlQueryError(e)};\n        }\n\n        return {\n            err:null,\n            results:result[0],\n        }\n    }\n\n    createMysqlQueryError(err:any,throwable?:boolean):MysqlError{\n        if(err &&  typeof err===\"object\" && \"code\" in err && \"errno\" in err && \"sql\" in err && \"name\" in err && \"message\" in err){\n            return {\n                    code: err.code,\n                    errno: err.errno,\n                    sql: err.sql,\n                    name:err.name,\n                    message:err.message,\n                    throwable:throwable?true:false\n                \n            }\n        }else{\n            return {\n                code: \"QUERY_ERR\",\n                errno: 100002,\n                fatal: true,\n                sql: \"no query\",\n                name:\"QUERY_ERR\",\n                message:\"Error: \"+(err)?err:\"\",\n                throwable:throwable?true:false\n            }\n        }\n    }\n}\n\n\nconst secret_key=\"AKLWkajw%^&dgwqhw#98453i23bfk23rn2knknglrgjeit\"\nconst secret_iv=\"rthadrfk23rn2kn#*FNKA@gt44df3tslrgj##!it\"\n\n// Generate secret hash with crypto to use for encryption\nconst key = createHash('sha512').update(secret_key).digest('hex').substring(0, 32)\nconst iv = createHash('sha512').update(secret_iv).digest('hex').substring(0, 16)\n\nconst decrypt =(encrypted:string):string|null=>{\n  try{\n      encrypted = Buffer.from(encrypted, 'base64').toString('binary');\n      const decipher = createDecipheriv('aes-256-cbc', key, iv);\n      let decrypted = decipher.update(encrypted, 'binary', 'utf8');\n      decrypted += decipher.final('utf8');\n      return decrypted;\n  }catch(e){\n      return null;\n  }\n}\n\nconst encrypt = (txt:string):string|null=>{\n  try{\n      let encipher = createCipheriv('aes-256-cbc', key, iv),\n      encrypted = encipher.update(txt, 'utf8', 'binary');\n      encrypted += encipher.final('binary');\n      return Buffer.from(encrypted, 'binary').toString('base64');\n  }catch(e){\n      return null;\n  }\n}\n\nexport default MysqlService;"]}
@@ -0,0 +1,4 @@
1
+ import { BaseService } from "./BaseService";
2
+ export declare class StatService extends BaseService {
3
+ constructor();
4
+ }
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StatService = void 0;
4
+ const BaseService_1 = require("./BaseService");
5
+ class StatService extends BaseService_1.BaseService {
6
+ constructor() {
7
+ super("StatService");
8
+ }
9
+ }
10
+ exports.StatService = StatService;
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhdFNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpU2VydmVyL1N0YXRTZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLCtDQUE0QztBQUU1QyxNQUFhLFdBQVksU0FBUSx5QkFBVztJQUN4QztRQUNJLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUN6QixDQUFDO0NBQ0o7QUFKRCxrQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VTZXJ2aWNlIH0gZnJvbSBcIi4vQmFzZVNlcnZpY2VcIjtcblxuZXhwb3J0IGNsYXNzIFN0YXRTZXJ2aWNlIGV4dGVuZHMgQmFzZVNlcnZpY2V7XG4gICAgY29uc3RydWN0b3IoKXtcbiAgICAgICAgc3VwZXIoXCJTdGF0U2VydmljZVwiKTtcbiAgICB9XG59Il19
@@ -0,0 +1,9 @@
1
+ import { BaseEndpoint } from "../BaseEndpoint";
2
+ import { HTTPRequestVO, TransferPacketVO } from "../structures/Interfaces";
3
+ export declare class Monitor extends BaseEndpoint {
4
+ constructor();
5
+ getLogs(req: HTTPRequestVO): Promise<TransferPacketVO<any>>;
6
+ getNetLogs(req: HTTPRequestVO): Promise<TransferPacketVO<any>>;
7
+ getStat(req: HTTPRequestVO): Promise<TransferPacketVO<any>>;
8
+ checkAuthorization(req: HTTPRequestVO): Promise<boolean>;
9
+ }
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.Monitor = void 0;
27
+ const APIService_1 = require("../APIService");
28
+ const BaseEndpoint_1 = require("../BaseEndpoint");
29
+ const LogService_1 = require("../LogService");
30
+ const DefaultErrors_1 = __importStar(require("../structures/DefaultErrors"));
31
+ class Monitor extends BaseEndpoint_1.BaseEndpoint {
32
+ constructor() {
33
+ super("-sys-monitor");
34
+ this.registerEndpoints([
35
+ { ignoreInterceptor: true, endpoint: "log", handler: this.getLogs },
36
+ { ignoreInterceptor: true, endpoint: "net", handler: this.getNetLogs },
37
+ ]);
38
+ }
39
+ async getLogs(req) {
40
+ await this.checkAuthorization(req);
41
+ const logs = await LogService_1.REQ_LOG.request({ lastID: req.data.lasttID ? req.data.lastID : 0 });
42
+ if (DefaultErrors_1.ErrorUtils.isError(logs))
43
+ return { error: logs };
44
+ return { data: logs };
45
+ }
46
+ async getNetLogs(req) {
47
+ await this.checkAuthorization(req);
48
+ const logs = await APIService_1.REQ_HTTP_LOG.request();
49
+ if (DefaultErrors_1.ErrorUtils.isError(logs))
50
+ return { error: logs };
51
+ return { data: logs };
52
+ }
53
+ async getStat(req) {
54
+ await this.checkAuthorization(req);
55
+ const httpCount = await APIService_1.REQ_HTTP_REQUESTS_COUNT.request;
56
+ return { data: {
57
+ http: httpCount
58
+ } };
59
+ }
60
+ async checkAuthorization(req) {
61
+ if (!req.headers['authorization'])
62
+ throw { ...DefaultErrors_1.default.UNAUTHORIZED, details: "no authorization header found" };
63
+ let authorization = req.headers['authorization'];
64
+ if (!authorization)
65
+ throw { ...DefaultErrors_1.default.UNAUTHORIZED, details: "empty authorization header" };
66
+ authorization = authorization.split(" ").pop();
67
+ if (!authorization)
68
+ throw { ...DefaultErrors_1.default.UNAUTHORIZED, details: "wrong authorization header" };
69
+ const monitorUsers = await APIService_1.REQ_MONITOR_USERS.request({ authorization });
70
+ for (let i of monitorUsers)
71
+ if (i === authorization)
72
+ return true;
73
+ throw { ...DefaultErrors_1.default.UNAUTHORIZED, details: "wrong user" };
74
+ }
75
+ }
76
+ exports.Monitor = Monitor;
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTW9uaXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGlTZXJ2ZXIvcm91dGVzL01vbml0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw4Q0FBeUY7QUFDekYsa0RBQStDO0FBQy9DLDhDQUF3QztBQUN4Qyw2RUFBd0U7QUFHeEUsTUFBYSxPQUFRLFNBQVEsMkJBQVk7SUFDckM7UUFDSSxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1lBQ25CLEVBQUMsaUJBQWlCLEVBQUMsSUFBSSxFQUFDLFFBQVEsRUFBQyxLQUFLLEVBQUMsT0FBTyxFQUFDLElBQUksQ0FBQyxPQUFPLEVBQUM7WUFDNUQsRUFBQyxpQkFBaUIsRUFBQyxJQUFJLEVBQUMsUUFBUSxFQUFDLEtBQUssRUFBQyxPQUFPLEVBQUMsSUFBSSxDQUFDLFVBQVUsRUFBQztTQUNsRSxDQUFDLENBQUE7SUFDTixDQUFDO0lBRUQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFrQjtRQUM1QixNQUFNLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQTtRQUNsQyxNQUFNLElBQUksR0FBRyxNQUFNLG9CQUFPLENBQUMsT0FBTyxDQUFDLEVBQUMsTUFBTSxFQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFBLENBQUMsQ0FBQSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQSxDQUFDLENBQUEsQ0FBQyxFQUFDLENBQUMsQ0FBQztRQUNoRixJQUFHLDBCQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztZQUN2QixPQUFPLEVBQUMsS0FBSyxFQUFDLElBQXFCLEVBQUMsQ0FBQTtRQUN4QyxPQUFPLEVBQUMsSUFBSSxFQUFDLElBQUksRUFBQyxDQUFBO0lBQ3RCLENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLEdBQWtCO1FBQy9CLE1BQU0sSUFBSSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBQ2xDLE1BQU0sSUFBSSxHQUFHLE1BQU0seUJBQVksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUMxQyxJQUFHLDBCQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztZQUN2QixPQUFPLEVBQUMsS0FBSyxFQUFDLElBQXFCLEVBQUMsQ0FBQTtRQUN4QyxPQUFPLEVBQUMsSUFBSSxFQUFDLElBQUksRUFBQyxDQUFBO0lBQ3RCLENBQUM7SUFFRCxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQWtCO1FBQzVCLE1BQU0sSUFBSSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBQ2xDLE1BQU0sU0FBUyxHQUFHLE1BQU0sb0NBQXVCLENBQUMsT0FBTyxDQUFBO1FBRXZELE9BQU8sRUFBQyxJQUFJLEVBQUM7Z0JBQ1QsSUFBSSxFQUFFLFNBQVM7YUFDbEIsRUFBQyxDQUFBO0lBQ04sQ0FBQztJQUVELEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxHQUFrQjtRQUN2QyxJQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUM7WUFDNUIsTUFBTSxFQUFDLEdBQUcsdUJBQWEsQ0FBQyxZQUFZLEVBQUMsT0FBTyxFQUFDLCtCQUErQixFQUFDLENBQUM7UUFDbEYsSUFBSSxhQUFhLEdBQXFCLEdBQUcsQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUE7UUFDbEUsSUFBRyxDQUFDLGFBQWE7WUFDYixNQUFNLEVBQUMsR0FBRyx1QkFBYSxDQUFDLFlBQVksRUFBQyxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsQ0FBQztRQUMvRSxhQUFhLEdBQUcsYUFBYSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUMvQyxJQUFHLENBQUMsYUFBYTtZQUNiLE1BQU0sRUFBQyxHQUFHLHVCQUFhLENBQUMsWUFBWSxFQUFDLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxDQUFDO1FBRS9FLE1BQU0sWUFBWSxHQUFHLE1BQU0sOEJBQWlCLENBQUMsT0FBTyxDQUFDLEVBQUMsYUFBYSxFQUFDLENBQUMsQ0FBQztRQUN0RSxLQUFJLElBQUksQ0FBQyxJQUFJLFlBQVk7WUFDckIsSUFBRyxDQUFDLEtBQUssYUFBYTtnQkFDbEIsT0FBTyxJQUFJLENBQUM7UUFFcEIsTUFBTSxFQUFDLEdBQUcsdUJBQWEsQ0FBQyxZQUFZLEVBQUMsT0FBTyxFQUFDLFlBQVksRUFBQyxDQUFDO0lBQy9ELENBQUM7Q0FFSjtBQXBERCwwQkFvREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSRVFfSFRUUF9MT0csIFJFUV9IVFRQX1JFUVVFU1RTX0NPVU5ULCBSRVFfTU9OSVRPUl9VU0VSUyB9IGZyb20gXCIuLi9BUElTZXJ2aWNlXCI7XG5pbXBvcnQgeyBCYXNlRW5kcG9pbnQgfSBmcm9tIFwiLi4vQmFzZUVuZHBvaW50XCI7XG5pbXBvcnQgeyBSRVFfTE9HIH0gZnJvbSBcIi4uL0xvZ1NlcnZpY2VcIjtcbmltcG9ydCBEZWZhdWx0RXJyb3JzLCB7IEVycm9yVXRpbHMgfSBmcm9tIFwiLi4vc3RydWN0dXJlcy9EZWZhdWx0RXJyb3JzXCI7XG5pbXBvcnQgeyBIVFRQUmVxdWVzdFZPLCBJRXJyb3IsIFRyYW5zZmVyUGFja2V0Vk8gfSBmcm9tIFwiLi4vc3RydWN0dXJlcy9JbnRlcmZhY2VzXCI7XG5cbmV4cG9ydCBjbGFzcyBNb25pdG9yIGV4dGVuZHMgQmFzZUVuZHBvaW50e1xuICAgIGNvbnN0cnVjdG9yKCl7XG4gICAgICAgIHN1cGVyKFwiLXN5cy1tb25pdG9yXCIpO1xuICAgICAgICB0aGlzLnJlZ2lzdGVyRW5kcG9pbnRzKFtcbiAgICAgICAgICAgIHtpZ25vcmVJbnRlcmNlcHRvcjp0cnVlLGVuZHBvaW50OlwibG9nXCIsaGFuZGxlcjp0aGlzLmdldExvZ3N9LFxuICAgICAgICAgICAge2lnbm9yZUludGVyY2VwdG9yOnRydWUsZW5kcG9pbnQ6XCJuZXRcIixoYW5kbGVyOnRoaXMuZ2V0TmV0TG9nc30sXG4gICAgICAgIF0pXG4gICAgfVxuXG4gICAgYXN5bmMgZ2V0TG9ncyhyZXE6IEhUVFBSZXF1ZXN0Vk8pOiBQcm9taXNlPFRyYW5zZmVyUGFja2V0Vk88YW55Pj4ge1xuICAgICAgICBhd2FpdCB0aGlzLmNoZWNrQXV0aG9yaXphdGlvbihyZXEpXG4gICAgICAgIGNvbnN0IGxvZ3MgPSBhd2FpdCBSRVFfTE9HLnJlcXVlc3Qoe2xhc3RJRDpyZXEuZGF0YS5sYXN0dElEP3JlcS5kYXRhLmxhc3RJRDowfSk7XG4gICAgICAgIGlmKEVycm9yVXRpbHMuaXNFcnJvcihsb2dzKSlcbiAgICAgICAgICAgIHJldHVybiB7ZXJyb3I6bG9ncyBhcyBhbnkgYXMgSUVycm9yfVxuICAgICAgICByZXR1cm4ge2RhdGE6bG9nc31cbiAgICB9XG5cbiAgICBhc3luYyBnZXROZXRMb2dzKHJlcTogSFRUUFJlcXVlc3RWTyk6IFByb21pc2U8VHJhbnNmZXJQYWNrZXRWTzxhbnk+PiB7XG4gICAgICAgIGF3YWl0IHRoaXMuY2hlY2tBdXRob3JpemF0aW9uKHJlcSlcbiAgICAgICAgY29uc3QgbG9ncyA9IGF3YWl0IFJFUV9IVFRQX0xPRy5yZXF1ZXN0KCk7XG4gICAgICAgIGlmKEVycm9yVXRpbHMuaXNFcnJvcihsb2dzKSlcbiAgICAgICAgICAgIHJldHVybiB7ZXJyb3I6bG9ncyBhcyBhbnkgYXMgSUVycm9yfVxuICAgICAgICByZXR1cm4ge2RhdGE6bG9nc31cbiAgICB9XG5cbiAgICBhc3luYyBnZXRTdGF0KHJlcTogSFRUUFJlcXVlc3RWTyk6IFByb21pc2U8VHJhbnNmZXJQYWNrZXRWTzxhbnk+PiB7XG4gICAgICAgIGF3YWl0IHRoaXMuY2hlY2tBdXRob3JpemF0aW9uKHJlcSlcbiAgICAgICAgY29uc3QgaHR0cENvdW50ID0gYXdhaXQgUkVRX0hUVFBfUkVRVUVTVFNfQ09VTlQucmVxdWVzdFxuICAgICAgICAvLyB0b2RvIC0gc3RhdCBieSBhbGwgZW50cnlwb2ludHNcbiAgICAgICAgcmV0dXJuIHtkYXRhOntcbiAgICAgICAgICAgIGh0dHA6IGh0dHBDb3VudFxuICAgICAgICB9fVxuICAgIH1cblxuICAgIGFzeW5jIGNoZWNrQXV0aG9yaXphdGlvbihyZXE6IEhUVFBSZXF1ZXN0Vk8pOiBQcm9taXNlPGJvb2xlYW4+e1xuICAgICAgICBpZighcmVxLmhlYWRlcnNbJ2F1dGhvcml6YXRpb24nXSlcbiAgICAgICAgICAgIHRocm93IHsuLi5EZWZhdWx0RXJyb3JzLlVOQVVUSE9SSVpFRCxkZXRhaWxzOlwibm8gYXV0aG9yaXphdGlvbiBoZWFkZXIgZm91bmRcIn07XG4gICAgICAgIGxldCBhdXRob3JpemF0aW9uOnN0cmluZ3x1bmRlZmluZWQgID0gcmVxLmhlYWRlcnNbJ2F1dGhvcml6YXRpb24nXVxuICAgICAgICBpZighYXV0aG9yaXphdGlvbilcbiAgICAgICAgICAgIHRocm93IHsuLi5EZWZhdWx0RXJyb3JzLlVOQVVUSE9SSVpFRCxkZXRhaWxzOlwiZW1wdHkgYXV0aG9yaXphdGlvbiBoZWFkZXJcIn07XG4gICAgICAgIGF1dGhvcml6YXRpb24gPSBhdXRob3JpemF0aW9uLnNwbGl0KFwiIFwiKS5wb3AoKTtcbiAgICAgICAgaWYoIWF1dGhvcml6YXRpb24pXG4gICAgICAgICAgICB0aHJvdyB7Li4uRGVmYXVsdEVycm9ycy5VTkFVVEhPUklaRUQsZGV0YWlsczpcIndyb25nIGF1dGhvcml6YXRpb24gaGVhZGVyXCJ9O1xuXG4gICAgICAgIGNvbnN0IG1vbml0b3JVc2VycyA9IGF3YWl0IFJFUV9NT05JVE9SX1VTRVJTLnJlcXVlc3Qoe2F1dGhvcml6YXRpb259KTtcbiAgICAgICAgZm9yKGxldCBpIG9mIG1vbml0b3JVc2VycylcbiAgICAgICAgICAgIGlmKGkgPT09IGF1dGhvcml6YXRpb24pXG4gICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7XG5cbiAgICAgICAgdGhyb3cgey4uLkRlZmF1bHRFcnJvcnMuVU5BVVRIT1JJWkVELGRldGFpbHM6XCJ3cm9uZyB1c2VyXCJ9O1xuICAgIH1cblxufSJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "badmfck-api-server",
3
- "version": "2.6.1",
3
+ "version": "2.6.3",
4
4
  "description": "Simple API http server based on express",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",