velocious 1.0.309 → 1.0.311

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -32,6 +32,8 @@ export default class VelociousHttpServerClientRequest {
32
32
  /** @returns {Record<string, string | string[] | undefined | Record<string, unknown> | unknown[]>} - The request params. */
33
33
  params(): Record<string, string | string[] | undefined | Record<string, unknown> | unknown[]>;
34
34
  port(): number | void;
35
+ /** @returns {Record<string, string | string[]>} - Parsed query parameters from the URL. */
36
+ queryParams(): Record<string, string | string[]>;
35
37
  protocol(): string | null;
36
38
  remoteAddress(): string | undefined;
37
39
  getRequestBuffer(): import("./request-buffer/index.js").default;
@@ -1 +1 @@
1
- {"version":3,"file":"request.d.ts","sourceRoot":"","sources":["../../../../src/http-server/client/request.js"],"names":[],"mappings":"AAMA;IACE;;;;OAIG;IACH,oDAHG;QAA2C,MAAM,EAAzC,OAAO,YAAY,EAAE,OAAO;QACmB,aAAa,EAA5D,OAAO,wBAAwB,EAAE,OAAO;KAClD,EAOA;IAHC,qCAAoB;IACpB,wDAAkC;IAClC,6BAAuD;IAGzD,kBAAkE;IAElE;;;OAGG;IACH,WAHW,MAAM,GACJ,MAAM,GAAG,SAAS,CAEoB;IAEnD;;;OAGG;IACH,mBAHW,MAAM,GACJ,MAAM,GAAG,IAAI,CAE6D;IACvF,kCAA6D;IAC7D,qBAA0D;IAC1D,sBAA4D;IAC5D,sBAA8C;IAE9C,uBAcC;IAED,wBAAyC;IACzC,eAA8C;IAC9C,2HAA2H;IAC3H,UADc,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,EAAE,CAAC,CACxC;IACzD,sBAA8C;IAC9C,0BAAsD;IACtD,oCAAqD;IAErD,gEAAwE;IACxE,kCAAgD;CACjD;0BA7DyB,qBAAqB"}
1
+ {"version":3,"file":"request.d.ts","sourceRoot":"","sources":["../../../../src/http-server/client/request.js"],"names":[],"mappings":"AAOA;IACE;;;;OAIG;IACH,oDAHG;QAA2C,MAAM,EAAzC,OAAO,YAAY,EAAE,OAAO;QACmB,aAAa,EAA5D,OAAO,wBAAwB,EAAE,OAAO;KAClD,EAOA;IAHC,qCAAoB;IACpB,wDAAkC;IAClC,6BAAuD;IAGzD,kBAAkE;IAElE;;;OAGG;IACH,WAHW,MAAM,GACJ,MAAM,GAAG,SAAS,CAEoB;IAEnD;;;OAGG;IACH,mBAHW,MAAM,GACJ,MAAM,GAAG,IAAI,CAE6D;IACvF,kCAA6D;IAC7D,qBAA0D;IAC1D,sBAA4D;IAC5D,sBAA8C;IAE9C,uBAcC;IAED,wBAAyC;IACzC,eAA8C;IAC9C,2HAA2H;IAC3H,UADc,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,EAAE,CAAC,CACxC;IACzD,sBAA8C;IAE9C,2FAA2F;IAC3F,eADc,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAiB9C;IACD,0BAAsD;IACtD,oCAAqD;IAErD,gEAAwE;IACxE,kCAAgD;CACjD;0BAhFyB,qBAAqB"}
@@ -1,5 +1,6 @@
1
1
  // @ts-check
2
2
  import { digg } from "diggerize";
3
+ import querystring from "querystring";
3
4
  import RequestParser from "./request-parser.js";
4
5
  import restArgsError from "../../utils/rest-args-error.js";
5
6
  export default class VelociousHttpServerClientRequest {
@@ -49,9 +50,24 @@ export default class VelociousHttpServerClientRequest {
49
50
  /** @returns {Record<string, string | string[] | undefined | Record<string, unknown> | unknown[]>} - The request params. */
50
51
  params() { return digg(this, "requestParser", "params"); }
51
52
  port() { return this.requestParser.getPort(); }
53
+ /** @returns {Record<string, string | string[]>} - Parsed query parameters from the URL. */
54
+ queryParams() {
55
+ const query = this.path().split("?")[1];
56
+ if (!query)
57
+ return Object.create(null);
58
+ const parsed = querystring.parse(query);
59
+ /** @type {Record<string, string | string[]>} */
60
+ const params = Object.create(null);
61
+ for (const [key, value] of Object.entries(parsed)) {
62
+ if (typeof value !== "undefined") {
63
+ params[key] = value;
64
+ }
65
+ }
66
+ return params;
67
+ }
52
68
  protocol() { return this.requestParser.getProtocol(); }
53
69
  remoteAddress() { return this.client?.remoteAddress; }
54
70
  getRequestBuffer() { return this.getRequestParser().getRequestBuffer(); }
55
71
  getRequestParser() { return this.requestParser; }
56
72
  }
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9odHRwLXNlcnZlci9jbGllbnQvcmVxdWVzdC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZO0FBRVosT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLFdBQVcsQ0FBQTtBQUM5QixPQUFPLGFBQWEsTUFBTSxxQkFBcUIsQ0FBQTtBQUMvQyxPQUFPLGFBQWEsTUFBTSxnQ0FBZ0MsQ0FBQTtBQUUxRCxNQUFNLENBQUMsT0FBTyxPQUFPLGdDQUFnQztJQUNuRDs7OztPQUlHO0lBQ0gsWUFBWSxFQUFDLE1BQU0sRUFBRSxhQUFhLEVBQUUsR0FBRyxRQUFRLEVBQUM7UUFDOUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBRXZCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1FBQ3BCLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFBO1FBQ2xDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxhQUFhLENBQUMsRUFBQyxhQUFhLEVBQUMsQ0FBQyxDQUFBO0lBQ3pELENBQUM7SUFFRCxPQUFPLEtBQUssT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsTUFBTSxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFFbEU7OztPQUdHO0lBQ0gsSUFBSSxDQUFDLElBQUksSUFBSSxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUVuRDs7O09BR0c7SUFDSCxNQUFNLENBQUMsVUFBVSxJQUFJLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxDQUFBLENBQUMsQ0FBQztJQUN2RixPQUFPLEtBQUssT0FBTyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxjQUFjLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFDN0QsVUFBVSxLQUFLLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFDMUQsV0FBVyxLQUFLLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxjQUFjLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFDNUQsSUFBSSxLQUFLLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFFOUMsWUFBWTtRQUNWLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQTtRQUN4QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUE7UUFDaEMsSUFBSSxZQUFZLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQTtRQUVuQyxJQUFJLElBQUksSUFBSSxFQUFFLElBQUksUUFBUSxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ3JDLGFBQWE7UUFDZixDQUFDO2FBQU0sSUFBSSxJQUFJLElBQUksR0FBRyxJQUFJLFFBQVEsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUM5QyxhQUFhO1FBQ2YsQ0FBQzthQUFNLElBQUksSUFBSSxFQUFFLENBQUM7WUFDaEIsWUFBWSxJQUFJLElBQUksSUFBSSxFQUFFLENBQUE7UUFDNUIsQ0FBQztRQUVELE9BQU8sWUFBWSxDQUFBO0lBQ3JCLENBQUM7SUFFRCxNQUFNLEtBQUssT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUN6QyxJQUFJLEtBQUssT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFBLENBQUMsQ0FBQztJQUM5QywySEFBMkg7SUFDM0gsTUFBTSxLQUFLLE9BQU8sSUFBSSxDQUFDLElBQUksRUFBRSxlQUFlLEVBQUUsUUFBUSxDQUFDLENBQUEsQ0FBQyxDQUFDO0lBQ3pELElBQUksS0FBSyxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBQzlDLFFBQVEsS0FBSyxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBQ3RELGFBQWEsS0FBSyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFBLENBQUMsQ0FBQztJQUVyRCxnQkFBZ0IsS0FBSyxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLGdCQUFnQixFQUFFLENBQUEsQ0FBQyxDQUFDO0lBQ3hFLGdCQUFnQixLQUFLLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQSxDQUFDLENBQUM7Q0FDakQiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuaW1wb3J0IHtkaWdnfSBmcm9tIFwiZGlnZ2VyaXplXCJcbmltcG9ydCBSZXF1ZXN0UGFyc2VyIGZyb20gXCIuL3JlcXVlc3QtcGFyc2VyLmpzXCJcbmltcG9ydCByZXN0QXJnc0Vycm9yIGZyb20gXCIuLi8uLi91dGlscy9yZXN0LWFyZ3MtZXJyb3IuanNcIlxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWZWxvY2lvdXNIdHRwU2VydmVyQ2xpZW50UmVxdWVzdCB7XG4gIC8qKlxuICAgKiBAcGFyYW0ge29iamVjdH0gYXJncyAtIE9wdGlvbnMgb2JqZWN0LlxuICAgKiBAcGFyYW0ge2ltcG9ydChcIi4vaW5kZXguanNcIikuZGVmYXVsdH0gYXJncy5jbGllbnQgLSBDbGllbnQgaW5zdGFuY2UuXG4gICAqIEBwYXJhbSB7aW1wb3J0KFwiLi4vLi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0fSBhcmdzLmNvbmZpZ3VyYXRpb24gLSBDb25maWd1cmF0aW9uIGluc3RhbmNlLlxuICAgKi9cbiAgY29uc3RydWN0b3Ioe2NsaWVudCwgY29uZmlndXJhdGlvbiwgLi4ucmVzdEFyZ3N9KSB7XG4gICAgcmVzdEFyZ3NFcnJvcihyZXN0QXJncylcblxuICAgIHRoaXMuY2xpZW50ID0gY2xpZW50XG4gICAgdGhpcy5jb25maWd1cmF0aW9uID0gY29uZmlndXJhdGlvblxuICAgIHRoaXMucmVxdWVzdFBhcnNlciA9IG5ldyBSZXF1ZXN0UGFyc2VyKHtjb25maWd1cmF0aW9ufSlcbiAgfVxuXG4gIGJhc2VVUkwoKSB7IHJldHVybiBgJHt0aGlzLnByb3RvY29sKCl9Oi8vJHt0aGlzLmhvc3RXaXRoUG9ydCgpfWAgfVxuXG4gIC8qKlxuICAgKiBAcGFyYW0ge0J1ZmZlcn0gZGF0YSAtIERhdGEgcGF5bG9hZC5cbiAgICogQHJldHVybnMge0J1ZmZlciB8IHVuZGVmaW5lZH0gLSBSZW1haW5pbmcgZGF0YSwgaWYgYW55LlxuICAgKi9cbiAgZmVlZChkYXRhKSB7IHJldHVybiB0aGlzLnJlcXVlc3RQYXJzZXIuZmVlZChkYXRhKSB9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBoZWFkZXJOYW1lIC0gSGVhZGVyIG5hbWUuXG4gICAqIEByZXR1cm5zIHtzdHJpbmcgfCBudWxsfSAtIFRoZSBoZWFkZXIuXG4gICAqL1xuICBoZWFkZXIoaGVhZGVyTmFtZSkgeyByZXR1cm4gdGhpcy5nZXRSZXF1ZXN0QnVmZmVyKCkuZ2V0SGVhZGVyKGhlYWRlck5hbWUpPy5nZXRWYWx1ZSgpIH1cbiAgaGVhZGVycygpIHsgcmV0dXJuIHRoaXMuZ2V0UmVxdWVzdEJ1ZmZlcigpLmdldEhlYWRlcnNIYXNoKCkgfVxuICBodHRwTWV0aG9kKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldEh0dHBNZXRob2QoKSB9XG4gIGh0dHBWZXJzaW9uKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldEh0dHBWZXJzaW9uKCkgfVxuICBob3N0KCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldEhvc3QoKSB9XG5cbiAgaG9zdFdpdGhQb3J0KCkge1xuICAgIGNvbnN0IHBvcnQgPSB0aGlzLnBvcnQoKVxuICAgIGNvbnN0IHByb3RvY29sID0gdGhpcy5wcm90b2NvbCgpXG4gICAgbGV0IGhvc3RXaXRoUG9ydCA9IGAke3RoaXMuaG9zdCgpfWBcblxuICAgIGlmIChwb3J0ID09IDgwICYmIHByb3RvY29sID09IFwiaHR0cFwiKSB7XG4gICAgICAvLyBEbyBub3RoaW5nXG4gICAgfSBlbHNlIGlmIChwb3J0ID09IDQ0MyAmJiBwcm90b2NvbCA9PSBcImh0dHBzXCIpIHtcbiAgICAgIC8vIERvIG5vdGhpbmdcbiAgICB9IGVsc2UgaWYgKHBvcnQpIHtcbiAgICAgIGhvc3RXaXRoUG9ydCArPSBgOiR7cG9ydH1gXG4gICAgfVxuXG4gICAgcmV0dXJuIGhvc3RXaXRoUG9ydFxuICB9XG5cbiAgb3JpZ2luKCkgeyByZXR1cm4gdGhpcy5oZWFkZXIoXCJvcmlnaW5cIikgfVxuICBwYXRoKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldFBhdGgoKSB9XG4gIC8qKiBAcmV0dXJucyB7UmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10gfCB1bmRlZmluZWQgfCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB8IHVua25vd25bXT59IC0gVGhlIHJlcXVlc3QgcGFyYW1zLiAqL1xuICBwYXJhbXMoKSB7IHJldHVybiBkaWdnKHRoaXMsIFwicmVxdWVzdFBhcnNlclwiLCBcInBhcmFtc1wiKSB9XG4gIHBvcnQoKSB7IHJldHVybiB0aGlzLnJlcXVlc3RQYXJzZXIuZ2V0UG9ydCgpIH1cbiAgcHJvdG9jb2woKSB7IHJldHVybiB0aGlzLnJlcXVlc3RQYXJzZXIuZ2V0UHJvdG9jb2woKSB9XG4gIHJlbW90ZUFkZHJlc3MoKSB7IHJldHVybiB0aGlzLmNsaWVudD8ucmVtb3RlQWRkcmVzcyB9XG5cbiAgZ2V0UmVxdWVzdEJ1ZmZlcigpIHsgcmV0dXJuIHRoaXMuZ2V0UmVxdWVzdFBhcnNlcigpLmdldFJlcXVlc3RCdWZmZXIoKSB9XG4gIGdldFJlcXVlc3RQYXJzZXIoKSB7IHJldHVybiB0aGlzLnJlcXVlc3RQYXJzZXIgfVxufVxuIl19
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9odHRwLXNlcnZlci9jbGllbnQvcmVxdWVzdC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZO0FBRVosT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLFdBQVcsQ0FBQTtBQUM5QixPQUFPLFdBQVcsTUFBTSxhQUFhLENBQUE7QUFDckMsT0FBTyxhQUFhLE1BQU0scUJBQXFCLENBQUE7QUFDL0MsT0FBTyxhQUFhLE1BQU0sZ0NBQWdDLENBQUE7QUFFMUQsTUFBTSxDQUFDLE9BQU8sT0FBTyxnQ0FBZ0M7SUFDbkQ7Ozs7T0FJRztJQUNILFlBQVksRUFBQyxNQUFNLEVBQUUsYUFBYSxFQUFFLEdBQUcsUUFBUSxFQUFDO1FBQzlDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQTtRQUV2QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQTtRQUNwQixJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQTtRQUNsQyxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksYUFBYSxDQUFDLEVBQUMsYUFBYSxFQUFDLENBQUMsQ0FBQTtJQUN6RCxDQUFDO0lBRUQsT0FBTyxLQUFLLE9BQU8sR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sSUFBSSxDQUFDLFlBQVksRUFBRSxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBRWxFOzs7T0FHRztJQUNILElBQUksQ0FBQyxJQUFJLElBQUksT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQSxDQUFDLENBQUM7SUFFbkQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLFVBQVUsSUFBSSxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFDdkYsT0FBTyxLQUFLLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUMsY0FBYyxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBQzdELFVBQVUsS0FBSyxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBQzFELFdBQVcsS0FBSyxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsY0FBYyxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBQzVELElBQUksS0FBSyxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLENBQUEsQ0FBQyxDQUFDO0lBRTlDLFlBQVk7UUFDVixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUE7UUFDeEIsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFBO1FBQ2hDLElBQUksWUFBWSxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUE7UUFFbkMsSUFBSSxJQUFJLElBQUksRUFBRSxJQUFJLFFBQVEsSUFBSSxNQUFNLEVBQUUsQ0FBQztZQUNyQyxhQUFhO1FBQ2YsQ0FBQzthQUFNLElBQUksSUFBSSxJQUFJLEdBQUcsSUFBSSxRQUFRLElBQUksT0FBTyxFQUFFLENBQUM7WUFDOUMsYUFBYTtRQUNmLENBQUM7YUFBTSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ2hCLFlBQVksSUFBSSxJQUFJLElBQUksRUFBRSxDQUFBO1FBQzVCLENBQUM7UUFFRCxPQUFPLFlBQVksQ0FBQTtJQUNyQixDQUFDO0lBRUQsTUFBTSxLQUFLLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQSxDQUFDLENBQUM7SUFDekMsSUFBSSxLQUFLLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQSxDQUFDLENBQUM7SUFDOUMsMkhBQTJIO0lBQzNILE1BQU0sS0FBSyxPQUFPLElBQUksQ0FBQyxJQUFJLEVBQUUsZUFBZSxFQUFFLFFBQVEsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUN6RCxJQUFJLEtBQUssT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFBLENBQUMsQ0FBQztJQUU5QywyRkFBMkY7SUFDM0YsV0FBVztRQUNULE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFFdkMsSUFBSSxDQUFDLEtBQUs7WUFBRSxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUE7UUFFdEMsTUFBTSxNQUFNLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUN2QyxnREFBZ0Q7UUFDaEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUVsQyxLQUFLLE1BQU0sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ2xELElBQUksT0FBTyxLQUFLLEtBQUssV0FBVyxFQUFFLENBQUM7Z0JBQ2pDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUE7WUFDckIsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLE1BQU0sQ0FBQTtJQUNmLENBQUM7SUFDRCxRQUFRLEtBQUssT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsRUFBRSxDQUFBLENBQUMsQ0FBQztJQUN0RCxhQUFhLEtBQUssT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBQSxDQUFDLENBQUM7SUFFckQsZ0JBQWdCLEtBQUssT0FBTyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFBLENBQUMsQ0FBQztJQUN4RSxnQkFBZ0IsS0FBSyxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUEsQ0FBQyxDQUFDO0NBQ2pEIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCB7ZGlnZ30gZnJvbSBcImRpZ2dlcml6ZVwiXG5pbXBvcnQgcXVlcnlzdHJpbmcgZnJvbSBcInF1ZXJ5c3RyaW5nXCJcbmltcG9ydCBSZXF1ZXN0UGFyc2VyIGZyb20gXCIuL3JlcXVlc3QtcGFyc2VyLmpzXCJcbmltcG9ydCByZXN0QXJnc0Vycm9yIGZyb20gXCIuLi8uLi91dGlscy9yZXN0LWFyZ3MtZXJyb3IuanNcIlxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWZWxvY2lvdXNIdHRwU2VydmVyQ2xpZW50UmVxdWVzdCB7XG4gIC8qKlxuICAgKiBAcGFyYW0ge29iamVjdH0gYXJncyAtIE9wdGlvbnMgb2JqZWN0LlxuICAgKiBAcGFyYW0ge2ltcG9ydChcIi4vaW5kZXguanNcIikuZGVmYXVsdH0gYXJncy5jbGllbnQgLSBDbGllbnQgaW5zdGFuY2UuXG4gICAqIEBwYXJhbSB7aW1wb3J0KFwiLi4vLi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0fSBhcmdzLmNvbmZpZ3VyYXRpb24gLSBDb25maWd1cmF0aW9uIGluc3RhbmNlLlxuICAgKi9cbiAgY29uc3RydWN0b3Ioe2NsaWVudCwgY29uZmlndXJhdGlvbiwgLi4ucmVzdEFyZ3N9KSB7XG4gICAgcmVzdEFyZ3NFcnJvcihyZXN0QXJncylcblxuICAgIHRoaXMuY2xpZW50ID0gY2xpZW50XG4gICAgdGhpcy5jb25maWd1cmF0aW9uID0gY29uZmlndXJhdGlvblxuICAgIHRoaXMucmVxdWVzdFBhcnNlciA9IG5ldyBSZXF1ZXN0UGFyc2VyKHtjb25maWd1cmF0aW9ufSlcbiAgfVxuXG4gIGJhc2VVUkwoKSB7IHJldHVybiBgJHt0aGlzLnByb3RvY29sKCl9Oi8vJHt0aGlzLmhvc3RXaXRoUG9ydCgpfWAgfVxuXG4gIC8qKlxuICAgKiBAcGFyYW0ge0J1ZmZlcn0gZGF0YSAtIERhdGEgcGF5bG9hZC5cbiAgICogQHJldHVybnMge0J1ZmZlciB8IHVuZGVmaW5lZH0gLSBSZW1haW5pbmcgZGF0YSwgaWYgYW55LlxuICAgKi9cbiAgZmVlZChkYXRhKSB7IHJldHVybiB0aGlzLnJlcXVlc3RQYXJzZXIuZmVlZChkYXRhKSB9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBoZWFkZXJOYW1lIC0gSGVhZGVyIG5hbWUuXG4gICAqIEByZXR1cm5zIHtzdHJpbmcgfCBudWxsfSAtIFRoZSBoZWFkZXIuXG4gICAqL1xuICBoZWFkZXIoaGVhZGVyTmFtZSkgeyByZXR1cm4gdGhpcy5nZXRSZXF1ZXN0QnVmZmVyKCkuZ2V0SGVhZGVyKGhlYWRlck5hbWUpPy5nZXRWYWx1ZSgpIH1cbiAgaGVhZGVycygpIHsgcmV0dXJuIHRoaXMuZ2V0UmVxdWVzdEJ1ZmZlcigpLmdldEhlYWRlcnNIYXNoKCkgfVxuICBodHRwTWV0aG9kKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldEh0dHBNZXRob2QoKSB9XG4gIGh0dHBWZXJzaW9uKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldEh0dHBWZXJzaW9uKCkgfVxuICBob3N0KCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldEhvc3QoKSB9XG5cbiAgaG9zdFdpdGhQb3J0KCkge1xuICAgIGNvbnN0IHBvcnQgPSB0aGlzLnBvcnQoKVxuICAgIGNvbnN0IHByb3RvY29sID0gdGhpcy5wcm90b2NvbCgpXG4gICAgbGV0IGhvc3RXaXRoUG9ydCA9IGAke3RoaXMuaG9zdCgpfWBcblxuICAgIGlmIChwb3J0ID09IDgwICYmIHByb3RvY29sID09IFwiaHR0cFwiKSB7XG4gICAgICAvLyBEbyBub3RoaW5nXG4gICAgfSBlbHNlIGlmIChwb3J0ID09IDQ0MyAmJiBwcm90b2NvbCA9PSBcImh0dHBzXCIpIHtcbiAgICAgIC8vIERvIG5vdGhpbmdcbiAgICB9IGVsc2UgaWYgKHBvcnQpIHtcbiAgICAgIGhvc3RXaXRoUG9ydCArPSBgOiR7cG9ydH1gXG4gICAgfVxuXG4gICAgcmV0dXJuIGhvc3RXaXRoUG9ydFxuICB9XG5cbiAgb3JpZ2luKCkgeyByZXR1cm4gdGhpcy5oZWFkZXIoXCJvcmlnaW5cIikgfVxuICBwYXRoKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldFBhdGgoKSB9XG4gIC8qKiBAcmV0dXJucyB7UmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10gfCB1bmRlZmluZWQgfCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB8IHVua25vd25bXT59IC0gVGhlIHJlcXVlc3QgcGFyYW1zLiAqL1xuICBwYXJhbXMoKSB7IHJldHVybiBkaWdnKHRoaXMsIFwicmVxdWVzdFBhcnNlclwiLCBcInBhcmFtc1wiKSB9XG4gIHBvcnQoKSB7IHJldHVybiB0aGlzLnJlcXVlc3RQYXJzZXIuZ2V0UG9ydCgpIH1cblxuICAvKiogQHJldHVybnMge1JlY29yZDxzdHJpbmcsIHN0cmluZyB8IHN0cmluZ1tdPn0gLSBQYXJzZWQgcXVlcnkgcGFyYW1ldGVycyBmcm9tIHRoZSBVUkwuICovXG4gIHF1ZXJ5UGFyYW1zKCkge1xuICAgIGNvbnN0IHF1ZXJ5ID0gdGhpcy5wYXRoKCkuc3BsaXQoXCI/XCIpWzFdXG5cbiAgICBpZiAoIXF1ZXJ5KSByZXR1cm4gT2JqZWN0LmNyZWF0ZShudWxsKVxuXG4gICAgY29uc3QgcGFyc2VkID0gcXVlcnlzdHJpbmcucGFyc2UocXVlcnkpXG4gICAgLyoqIEB0eXBlIHtSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCBzdHJpbmdbXT59ICovXG4gICAgY29uc3QgcGFyYW1zID0gT2JqZWN0LmNyZWF0ZShudWxsKVxuXG4gICAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMocGFyc2VkKSkge1xuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gXCJ1bmRlZmluZWRcIikge1xuICAgICAgICBwYXJhbXNba2V5XSA9IHZhbHVlXG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHBhcmFtc1xuICB9XG4gIHByb3RvY29sKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyLmdldFByb3RvY29sKCkgfVxuICByZW1vdGVBZGRyZXNzKCkgeyByZXR1cm4gdGhpcy5jbGllbnQ/LnJlbW90ZUFkZHJlc3MgfVxuXG4gIGdldFJlcXVlc3RCdWZmZXIoKSB7IHJldHVybiB0aGlzLmdldFJlcXVlc3RQYXJzZXIoKS5nZXRSZXF1ZXN0QnVmZmVyKCkgfVxuICBnZXRSZXF1ZXN0UGFyc2VyKCkgeyByZXR1cm4gdGhpcy5yZXF1ZXN0UGFyc2VyIH1cbn1cbiJdfQ==
@@ -40,7 +40,9 @@ export default class VelociousHttpServerClientWebsocketRequest {
40
40
  params(): Record<string, any>;
41
41
  port(): number | undefined;
42
42
  protocol(): string | undefined;
43
+ /** @returns {Record<string, string | string[]>} - Parsed query parameters from the URL. */
44
+ queryParams(): Record<string, string | string[]>;
43
45
  remoteAddress(): string | undefined;
44
- _parseQueryParams(): Record<string, string | string[]>;
46
+ _parseQueryParams(): any;
45
47
  }
46
48
  //# sourceMappingURL=websocket-request.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"websocket-request.d.ts","sourceRoot":"","sources":["../../../../src/http-server/client/websocket-request.js"],"names":[],"mappings":"AAIA;IACE;;;;;;;;OAQG;IACH,oEAPG;QAAmB,IAAI,GAAf,GAAG;QAC2B,OAAO;QACxB,MAAM,EAAnB,MAAM;QACO,IAAI,EAAjB,MAAM;QACqB,MAAM;QACnB,aAAa;KACrC,EA6BA;IAxBC,UAAgB;IAChB,qCAAqC;IACrC,YADW,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CACb;IACpB,eAAkC;IAClC,kCAAkC;IAClC,cADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACR;IACtB,cAAiB;IACjB,uCAAuC;IAmBzC,8BAKC;IAED;;;OAGG;IACH,aAHW,MAAM,GACJ,MAAM,GAAG,IAAI,CAEyC;IAEnE,kCAAoC;IAEpC,qBAAmC;IAEnC,sBAAoC;IAEpC,2BAAkD;IAElD,mCAQC;IAED,wBAAyC;IAEzC,eAA4B;IAE5B,8BAAqC;IAErC,2BAKC;IAED,+BAKC;IAED,oCAAkD;IAElD,uDAkBC;CACF"}
1
+ {"version":3,"file":"websocket-request.d.ts","sourceRoot":"","sources":["../../../../src/http-server/client/websocket-request.js"],"names":[],"mappings":"AAIA;IACE;;;;;;;;OAQG;IACH,oEAPG;QAAmB,IAAI,GAAf,GAAG;QAC2B,OAAO;QACxB,MAAM,EAAnB,MAAM;QACO,IAAI,EAAjB,MAAM;QACqB,MAAM;QACnB,aAAa;KACrC,EA6BA;IAxBC,UAAgB;IAChB,qCAAqC;IACrC,YADW,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CACb;IACpB,eAAkC;IAClC,kCAAkC;IAClC,cADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACR;IACtB,cAAiB;IACjB,uCAAuC;IAmBzC,8BAKC;IAED;;;OAGG;IACH,aAHW,MAAM,GACJ,MAAM,GAAG,IAAI,CAEyC;IAEnE,kCAAoC;IAEpC,qBAAmC;IAEnC,sBAAoC;IAEpC,2BAAkD;IAElD,mCAQC;IAED,wBAAyC;IAEzC,eAA4B;IAE5B,8BAAqC;IAErC,2BAKC;IAED,+BAKC;IAED,2FAA2F;IAC3F,eADc,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CACE;IAEjD,oCAAkD;IAElD,yBAkBC;CACF"}
@@ -76,14 +76,16 @@ export default class VelociousHttpServerClientWebsocketRequest {
76
76
  const match = origin?.match(/^(.+):\/\//);
77
77
  return match?.[1];
78
78
  }
79
+ /** @returns {Record<string, string | string[]>} - Parsed query parameters from the URL. */
80
+ queryParams() { return this._parseQueryParams(); }
79
81
  remoteAddress() { return this.remoteAddressValue; }
80
82
  _parseQueryParams() {
81
83
  const query = this._path.split("?")[1];
82
84
  if (!query)
83
- return {};
85
+ return Object.create(null);
84
86
  const parsedQuery = querystring.parse(query);
85
87
  /** @type {Record<string, string | string[]>} */
86
- const params = {};
88
+ const params = Object.create(null);
87
89
  for (const key of Object.keys(parsedQuery)) {
88
90
  const value = parsedQuery[key];
89
91
  if (typeof value !== "undefined") {
@@ -93,4 +95,4 @@ export default class VelociousHttpServerClientWebsocketRequest {
93
95
  return params;
94
96
  }
95
97
  }
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"websocket-request.js","sourceRoot":"","sources":["../../../../src/http-server/client/websocket-request.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport querystring from \"querystring\"\n\nexport default class VelociousHttpServerClientWebsocketRequest {\n  /**\n   * @param {object} args - Options object.\n   * @param {any} [args.body] - Request body.\n   * @param {Record<string, string>} [args.headers] - Header list.\n   * @param {string} args.method - HTTP method.\n   * @param {string} args.path - Path.\n   * @param {Record<string, any>} [args.params] - Parameters object.\n   * @param {string} [args.remoteAddress] - Remote address.\n   */\n  constructor({body, headers, method, params, path, remoteAddress}) {\n    if (!method) throw new Error(\"method is required\")\n    if (!path) throw new Error(\"path is required\")\n\n    this.body = body\n    /** @type {Record<string, string>} */\n    this.headersMap = {}\n    this.method = method.toUpperCase()\n    /** @type {Record<string, any>} */\n    this.paramsObject = {}\n    this._path = path\n    this.remoteAddressValue = remoteAddress\n\n    if (headers) {\n      for (const [key, value] of Object.entries(headers)) {\n        this.headersMap[key.toLowerCase()] = value\n      }\n    }\n\n    if (params) this.paramsObject = {...params}\n    if (this.body && typeof this.body === \"object\") this.paramsObject = {...this.paramsObject, ...this.body}\n    if (this.body && typeof this.body === \"object\" && !this.headersMap[\"content-type\"]) {\n      this.headersMap[\"content-type\"] = \"application/json\"\n    }\n\n    const queryParams = this._parseQueryParams()\n\n    this.paramsObject = {...queryParams, ...this.paramsObject}\n  }\n\n  baseURL() {\n    const protocol = this.protocol()\n    const host = this.hostWithPort()\n\n    if (protocol && host) return `${protocol}://${host}`\n  }\n\n  /**\n   * @param {string} name - Header name.\n   * @returns {string | null} - Header value.\n   */\n  header(name) { return this.headersMap[name.toLowerCase()] || null }\n\n  headers() { return this.headersMap }\n\n  httpMethod() { return this.method }\n\n  httpVersion() { return \"websocket\" }\n\n  host() { return this.header(\"host\") || undefined }\n\n  hostWithPort() {\n    const host = this.host()\n    const port = this.port()\n\n    if (!host) return\n    if (!port) return host\n\n    return `${host}:${port}`\n  }\n\n  origin() { return this.header(\"origin\") }\n\n  path() { return this._path }\n\n  params() { return this.paramsObject }\n\n  port() {\n    const hostHeader = this.header(\"host\")\n    const match = hostHeader?.match(/:(\\d+)$/)\n\n    if (match) return parseInt(match[1])\n  }\n\n  protocol() {\n    const origin = this.origin()\n    const match = origin?.match(/^(.+):\\/\\//)\n\n    return match?.[1]\n  }\n\n  remoteAddress() { return this.remoteAddressValue }\n\n  _parseQueryParams() {\n    const query = this._path.split(\"?\")[1]\n\n    if (!query) return {}\n\n    const parsedQuery = querystring.parse(query)\n    /** @type {Record<string, string | string[]>} */\n    const params = {}\n\n    for (const key of Object.keys(parsedQuery)) {\n      const value = parsedQuery[key]\n\n      if (typeof value !== \"undefined\") {\n        params[key] = value\n      }\n    }\n\n    return params\n  }\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"websocket-request.js","sourceRoot":"","sources":["../../../../src/http-server/client/websocket-request.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport querystring from \"querystring\"\n\nexport default class VelociousHttpServerClientWebsocketRequest {\n  /**\n   * @param {object} args - Options object.\n   * @param {any} [args.body] - Request body.\n   * @param {Record<string, string>} [args.headers] - Header list.\n   * @param {string} args.method - HTTP method.\n   * @param {string} args.path - Path.\n   * @param {Record<string, any>} [args.params] - Parameters object.\n   * @param {string} [args.remoteAddress] - Remote address.\n   */\n  constructor({body, headers, method, params, path, remoteAddress}) {\n    if (!method) throw new Error(\"method is required\")\n    if (!path) throw new Error(\"path is required\")\n\n    this.body = body\n    /** @type {Record<string, string>} */\n    this.headersMap = {}\n    this.method = method.toUpperCase()\n    /** @type {Record<string, any>} */\n    this.paramsObject = {}\n    this._path = path\n    this.remoteAddressValue = remoteAddress\n\n    if (headers) {\n      for (const [key, value] of Object.entries(headers)) {\n        this.headersMap[key.toLowerCase()] = value\n      }\n    }\n\n    if (params) this.paramsObject = {...params}\n    if (this.body && typeof this.body === \"object\") this.paramsObject = {...this.paramsObject, ...this.body}\n    if (this.body && typeof this.body === \"object\" && !this.headersMap[\"content-type\"]) {\n      this.headersMap[\"content-type\"] = \"application/json\"\n    }\n\n    const queryParams = this._parseQueryParams()\n\n    this.paramsObject = {...queryParams, ...this.paramsObject}\n  }\n\n  baseURL() {\n    const protocol = this.protocol()\n    const host = this.hostWithPort()\n\n    if (protocol && host) return `${protocol}://${host}`\n  }\n\n  /**\n   * @param {string} name - Header name.\n   * @returns {string | null} - Header value.\n   */\n  header(name) { return this.headersMap[name.toLowerCase()] || null }\n\n  headers() { return this.headersMap }\n\n  httpMethod() { return this.method }\n\n  httpVersion() { return \"websocket\" }\n\n  host() { return this.header(\"host\") || undefined }\n\n  hostWithPort() {\n    const host = this.host()\n    const port = this.port()\n\n    if (!host) return\n    if (!port) return host\n\n    return `${host}:${port}`\n  }\n\n  origin() { return this.header(\"origin\") }\n\n  path() { return this._path }\n\n  params() { return this.paramsObject }\n\n  port() {\n    const hostHeader = this.header(\"host\")\n    const match = hostHeader?.match(/:(\\d+)$/)\n\n    if (match) return parseInt(match[1])\n  }\n\n  protocol() {\n    const origin = this.origin()\n    const match = origin?.match(/^(.+):\\/\\//)\n\n    return match?.[1]\n  }\n\n  /** @returns {Record<string, string | string[]>} - Parsed query parameters from the URL. */\n  queryParams() { return this._parseQueryParams() }\n\n  remoteAddress() { return this.remoteAddressValue }\n\n  _parseQueryParams() {\n    const query = this._path.split(\"?\")[1]\n\n    if (!query) return Object.create(null)\n\n    const parsedQuery = querystring.parse(query)\n    /** @type {Record<string, string | string[]>} */\n    const params = Object.create(null)\n\n    for (const key of Object.keys(parsedQuery)) {\n      const value = parsedQuery[key]\n\n      if (typeof value !== \"undefined\") {\n        params[key] = value\n      }\n    }\n\n    return params\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"AAsPA;IACE;;;;;;OAMG;IACH,oBANW,MAAM,GAAG,MAAM,gEAEvB;QAAoD,aAAa;QAC1C,KAAK;QAC2C,oBAAoB;KAC7F,EAkBA;IAdC,gBAAmB;IACnB,0CAAmC;IACnC,2FAAiD;IAG/C,iBAAsB;IAEtB,4BAAqB;IASzB;;OAEG;IACH,oBAFa,OAAO,oBAAoB,EAAE,OAAO,CAShD;IAED;;OAEG;IACH,sBAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAQ5D;IAED;;;OAGG;IACH,mBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,kBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,2BAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,iBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,mBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,mBAHW,OAAO,GACL,IAAI,CAIhB;IAGS,cAAU,UAAU,CAAC,OAAO,kBAAkB,CAAC,GAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAM3E;;;;;OAKG;IACH,4BAJG;QAAuB,KAAK,EAApB,QAAQ;QACoC,QAAQ,EAApD,UAAU,CAAC,OAAO,kBAAkB,CAAC;KAC7C,GAAU,OAAO,CAAC,IAAI,CAAC,CAczB;CACF;uBA1Wa,iBAAiB,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO;0BAN3C,oBAAoB;AAkB9C;;;GAGG;AACH,iDAHW,CAAG,GAAG,IAAC,MAAa,KAAK,CAAC,GAAG,CAAC,CAAA,GAAA,GAC5B,KAAK,CAAC,GAAG,CAAC,CAStB"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"AAsPA;IACE;;;;;;OAMG;IACH,oBANW,MAAM,GAAG,MAAM,gEAEvB;QAAoD,aAAa;QAC1C,KAAK;QAC2C,oBAAoB;KAC7F,EAcA;IAVC,gBAAmB;IACnB,0CAAmC;IACnC,2FAAiD;IAG/C,iBAAuC;IAEvC,4BAAqB;IAKzB;;OAEG;IACH,oBAFa,OAAO,oBAAoB,EAAE,OAAO,CAShD;IAED;;OAEG;IACH,sBAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAQ5D;IAED;;;OAGG;IACH,mBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,kBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,2BAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,iBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,mBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,mBAHW,OAAO,GACL,IAAI,CAIhB;IAGS,cAAU,UAAU,CAAC,OAAO,kBAAkB,CAAC,GAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAM3E;;;;;OAKG;IACH,4BAJG;QAAuB,KAAK,EAApB,QAAQ;QACoC,QAAQ,EAApD,UAAU,CAAC,OAAO,kBAAkB,CAAC;KAC7C,GAAU,OAAO,CAAC,IAAI,CAAC,CAczB;CACF;uBAtWa,iBAAiB,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO;0BAN3C,oBAAoB;AAkB9C;;;GAGG;AACH,iDAHW,CAAG,GAAG,IAAC,MAAa,KAAK,CAAC,GAAG,CAAC,CAAA,GAAA,GAC5B,KAAK,CAAC,GAAG,CAAC,CAStB"}
@@ -225,14 +225,11 @@ export default class Logger {
225
225
  this._configuration = configuration;
226
226
  this._loggingConfiguration = loggingConfiguration;
227
227
  if (typeof object == "string") {
228
- this._subject = object;
228
+ this._subject = object || "EmptyString";
229
229
  }
230
230
  else {
231
231
  this._object = object;
232
- this._subject = object.constructor.name;
233
- }
234
- if (!this._subject) {
235
- throw new Error(`No subject given`);
232
+ this._subject = object.constructor.name || "UnknownClass";
236
233
  }
237
234
  }
238
235
  /**
@@ -323,4 +320,4 @@ export default class Logger {
323
320
  });
324
321
  }
325
322
  }
326
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Configuration from \"./configuration.js\"\nimport LoggerConsoleOutput from \"./logger/outputs/console-output.js\"\nimport LoggerFileOutput from \"./logger/outputs/file-output.js\"\nimport {formatValue} from \"./utils/format-value.js\"\nimport restArgsError from \"./utils/rest-args-error.js\"\n\n/** @typedef {\"debug-low-level\" | \"debug\" | \"info\" | \"warn\" | \"error\"} LogLevel */\n\nconst DEFAULT_LOGGING_CONFIGURATION = {\n  console: true,\n  file: false,\n  /** @type {LogLevel[]} */\n  levels: [\"info\", \"warn\", \"error\"]\n}\n\n/** @type {LogLevel[]} */\nconst LEVEL_ORDER = [\"debug-low-level\", \"debug\", \"info\", \"warn\", \"error\"]\n\n/**\n * @param {...any|function() : Array<any>} messages - Messages.\n * @returns {Array<any>} - Either the function result or the messages\n */\nfunction functionOrMessages(...messages) {\n  if (messages.length === 1 && typeof messages[0] == \"function\") {\n    const result = messages[0]()\n    messages = Array.isArray(result) ? result : [result]\n  }\n\n  return messages\n}\n\n/**\n * Converts multiple message parts into a single string.\n * @param {...any} messages - Parts to combine into a message\n * @returns {string} - The messages to message.\n */\nfunction messagesToMessage(...messages) {\n  let message = \"\"\n\n  for (const messagePartIndex in messages) {\n    const messagePart = messages[messagePartIndex]\n\n    if (Number(messagePartIndex) > 0) {\n      message += \" \"\n    }\n\n    if (messagePart instanceof Error) {\n      message += `${messagePart.message}\\n${messagePart.stack}`\n    } else if (typeof messagePart == \"object\") {\n      message += formatValue(messagePart)\n    } else {\n      message += messagePart\n    }\n  }\n\n  return message\n}\n\n/**\n * @param {import(\"./configuration.js\").default | undefined} configuration - Configuration instance.\n * @returns {Required<Pick<import(\"./configuration-types.js\").LoggingConfiguration, \"console\" | \"file\" | \"levels\">> & Partial<Pick<import(\"./configuration-types.js\").LoggingConfiguration, \"filePath\" | \"outputs\">>} - The logging configuration.\n */\nfunction resolveLoggingConfiguration(configuration) {\n  const debugEnabled = configuration?.debug === true\n  if (configuration && typeof configuration.getLoggingConfiguration === \"function\") {\n    const resolved = configuration.getLoggingConfiguration()\n\n    if (debugEnabled) {\n      return {\n        ...resolved,\n        console: true,\n        levels: LEVEL_ORDER\n      }\n    }\n\n    return resolved\n  }\n\n  if (debugEnabled) {\n    return {\n      ...DEFAULT_LOGGING_CONFIGURATION,\n      console: true,\n      levels: LEVEL_ORDER\n    }\n  }\n\n  return DEFAULT_LOGGING_CONFIGURATION\n}\n\n/**\n * @param {object} args - Options object.\n * @param {LogLevel} args.level - Level.\n * @param {LogLevel[]} args.allowedLevels - Allowed levels.\n * @param {boolean} [args.debugFlag] - Whether debug flag.\n * @returns {boolean} - Whether level allowed.\n */\nfunction isLevelAllowed({level, allowedLevels, debugFlag}) {\n  if (allowedLevels.includes(level)) return true\n\n  if (debugFlag && LEVEL_ORDER.indexOf(level) >= LEVEL_ORDER.indexOf(\"debug\")) return true\n\n  return false\n}\n\n/**\n * @param {object} args - Options object.\n * @param {import(\"./configuration-types.js\").LoggingConfiguration} args.loggingConfiguration - Logging configuration.\n * @param {import(\"./configuration.js\").default | undefined} args.configuration - Configuration instance.\n * @returns {import(\"./configuration-types.js\").LoggingOutputConfig[]} - Logging outputs.\n */\nfunction resolveLoggingOutputs({loggingConfiguration, configuration}) {\n  if (Array.isArray(loggingConfiguration.outputs)) return loggingConfiguration.outputs\n\n  if (Array.isArray(loggingConfiguration.loggers)) {\n    /** @type {import(\"./configuration-types.js\").LoggingOutputConfig[]} */\n    const loggerOutputs = []\n\n    for (const logger of loggingConfiguration.loggers) {\n      if (!logger) continue\n\n      const loggerConfig = /** @type {any} */ (logger)\n\n      if (typeof loggerConfig.toOutputConfig === \"function\") {\n        loggerOutputs.push(loggerConfig.toOutputConfig({configuration}))\n        continue\n      }\n\n      if (loggerConfig.output && typeof loggerConfig.output.write === \"function\") {\n        loggerOutputs.push({\n          output: loggerConfig.output,\n          levels: loggerConfig.levels\n        })\n        continue\n      }\n\n      if (typeof loggerConfig.write === \"function\") {\n        loggerOutputs.push({\n          output: loggerConfig,\n          levels: loggerConfig.levels\n        })\n        continue\n      }\n\n      const loggerName = loggerConfig?.constructor?.name || \"UnknownLogger\"\n      throw new Error(`Logger must implement toOutputConfig or write: ${loggerName}`)\n    }\n\n    return loggerOutputs\n  }\n\n  /** @type {import(\"./configuration-types.js\").LoggingOutputConfig[]} */\n  const outputs = []\n  if (loggingConfiguration.console !== false) {\n    outputs.push({\n      output: new LoggerConsoleOutput(),\n      levels: loggingConfiguration.levels\n    })\n  }\n\n  if (loggingConfiguration.file !== false && loggingConfiguration.filePath) {\n    outputs.push({\n      output: new LoggerFileOutput({\n        configuration,\n        getConfiguration: () => configuration,\n        filePath: loggingConfiguration.filePath\n      }),\n      levels: loggingConfiguration.levels\n    })\n  }\n\n  return outputs\n}\n\n/**\n * @param {object} args - Options object.\n * @param {LogLevel} args.level - Level.\n * @param {import(\"./configuration-types.js\").LoggingOutputConfig} args.outputConfig - Output configuration.\n * @param {import(\"./configuration-types.js\").LoggingConfiguration} args.loggingConfiguration - Logging configuration.\n * @param {boolean} [args.debugFlag] - Whether debug flag.\n * @returns {boolean} - Whether output should log.\n */\nfunction isOutputLevelAllowed({level, outputConfig, loggingConfiguration, debugFlag}) {\n  if (Array.isArray(outputConfig.levels)) {\n    return isLevelAllowed({level, allowedLevels: outputConfig.levels, debugFlag: false})\n  }\n\n  if (Array.isArray(outputConfig.output?.levels)) {\n    return isLevelAllowed({level, allowedLevels: outputConfig.output.levels, debugFlag: false})\n  }\n\n  const allowedLevels = loggingConfiguration.levels || DEFAULT_LOGGING_CONFIGURATION.levels\n\n  return isLevelAllowed({level, allowedLevels, debugFlag})\n}\n\n/**\n * @param {object} args - Options object.\n * @param {string} args.subject - Log subject.\n * @param {LogLevel} args.level - Level.\n * @param {Parameters<typeof functionOrMessages>} args.messages - Messages.\n * @param {import(\"./configuration.js\").default | undefined} args.configuration - Configuration instance.\n * @param {import(\"./configuration-types.js\").LoggingConfiguration | undefined} args.loggingConfiguration - Logging configuration.\n * @param {boolean} [args.debugFlag] - Whether debug flag.\n * @returns {Promise<void>} - Resolves when complete.\n */\nasync function writeLog({subject, level, messages, configuration, loggingConfiguration, debugFlag}) {\n  const resolvedLoggingConfiguration = loggingConfiguration || resolveLoggingConfiguration(configuration)\n  const outputs = resolveLoggingOutputs({loggingConfiguration: resolvedLoggingConfiguration, configuration})\n\n  if (outputs.length === 0) return\n\n  const writes = []\n  /** @type {Array<any> | undefined} */\n  let resolvedMessages\n  /** @type {string | undefined} */\n  let message\n  /** @type {import(\"./configuration-types.js\").LoggingOutputPayload | null} */\n  let payload = null\n\n  for (const outputConfig of outputs) {\n    if (!outputConfig || !outputConfig.output || typeof outputConfig.output.write !== \"function\") continue\n    if (!isOutputLevelAllowed({level, outputConfig, loggingConfiguration: resolvedLoggingConfiguration, debugFlag})) continue\n\n    if (!payload) {\n      resolvedMessages = functionOrMessages(...messages)\n      message = messagesToMessage(subject, ...resolvedMessages)\n      payload = {\n        level,\n        message,\n        subject,\n        timestamp: new Date()\n      }\n    }\n\n    writes.push(outputConfig.output.write(payload))\n  }\n\n  if (writes.length === 1) {\n    await writes[0]\n  } else if (writes.length > 1) {\n    await Promise.all(writes)\n  }\n}\n\nexport default class Logger {\n  /**\n   * @param {string | object} object - Object.\n   * @param {object} args - Options object.\n   * @param {import(\"./configuration.js\").default} [args.configuration] - Configuration instance.\n   * @param {boolean} [args.debug] - Whether debug.\n   * @param {import(\"./configuration-types.js\").LoggingConfiguration} [args.loggingConfiguration] - Logging configuration.\n   */\n  constructor(object, {configuration, debug = false, loggingConfiguration, ...restArgs} = {}) {\n    restArgsError(restArgs)\n\n    this._debug = debug\n    this._configuration = configuration\n    this._loggingConfiguration = loggingConfiguration\n\n    if (typeof object == \"string\") {\n      this._subject = object\n    } else {\n      this._object = object\n      this._subject = object.constructor.name\n    }\n\n    if (!this._subject) {\n      throw new Error(`No subject given`)\n    }\n  }\n\n  /**\n   * @returns {import(\"./configuration.js\").default} - The configuration.\n   */\n  getConfiguration() {\n    if (!this._configuration) {\n      const objectWithConfig = /** @type {{configuration?: import(\"./configuration.js\").default}} */ (this._object)\n      this._configuration = objectWithConfig?.configuration || Configuration.current()\n    }\n\n    return this._configuration\n  }\n\n  /**\n   * @returns {import(\"./configuration.js\").default | undefined} - The safe configuration.\n   */\n  _safeConfiguration() {\n    try {\n      return this.getConfiguration()\n    } catch {\n      return undefined\n    }\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async debug(...messages) {\n    await this._write({level: \"debug\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async info(...messages) {\n    await this._write({level: \"info\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async debugLowLevel(...messages) {\n    await this._write({level: \"debug-low-level\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async log(...messages) {\n    await this._write({level: \"info\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async error(...messages) {\n    await this._write({level: \"error\", messages})\n  }\n\n  /**\n   * @param {boolean} newValue - New value.\n   * @returns {void} - No return value.\n   */\n  setDebug(newValue) {\n    this._debug = newValue\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async warn(...messages) {\n    await this._write({level: \"warn\", messages})\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {LogLevel} args.level - Level.\n   * @param {Parameters<typeof functionOrMessages>} args.messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _write({level, messages}) {\n    const configuration = this._safeConfiguration()\n    const loggingConfiguration = this._loggingConfiguration || resolveLoggingConfiguration(configuration)\n\n    await writeLog({\n      subject: this._subject,\n      level,\n      messages,\n      configuration,\n      loggingConfiguration,\n      debugFlag: this._debug\n    })\n  }\n}\n"]}
323
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Configuration from \"./configuration.js\"\nimport LoggerConsoleOutput from \"./logger/outputs/console-output.js\"\nimport LoggerFileOutput from \"./logger/outputs/file-output.js\"\nimport {formatValue} from \"./utils/format-value.js\"\nimport restArgsError from \"./utils/rest-args-error.js\"\n\n/** @typedef {\"debug-low-level\" | \"debug\" | \"info\" | \"warn\" | \"error\"} LogLevel */\n\nconst DEFAULT_LOGGING_CONFIGURATION = {\n  console: true,\n  file: false,\n  /** @type {LogLevel[]} */\n  levels: [\"info\", \"warn\", \"error\"]\n}\n\n/** @type {LogLevel[]} */\nconst LEVEL_ORDER = [\"debug-low-level\", \"debug\", \"info\", \"warn\", \"error\"]\n\n/**\n * @param {...any|function() : Array<any>} messages - Messages.\n * @returns {Array<any>} - Either the function result or the messages\n */\nfunction functionOrMessages(...messages) {\n  if (messages.length === 1 && typeof messages[0] == \"function\") {\n    const result = messages[0]()\n    messages = Array.isArray(result) ? result : [result]\n  }\n\n  return messages\n}\n\n/**\n * Converts multiple message parts into a single string.\n * @param {...any} messages - Parts to combine into a message\n * @returns {string} - The messages to message.\n */\nfunction messagesToMessage(...messages) {\n  let message = \"\"\n\n  for (const messagePartIndex in messages) {\n    const messagePart = messages[messagePartIndex]\n\n    if (Number(messagePartIndex) > 0) {\n      message += \" \"\n    }\n\n    if (messagePart instanceof Error) {\n      message += `${messagePart.message}\\n${messagePart.stack}`\n    } else if (typeof messagePart == \"object\") {\n      message += formatValue(messagePart)\n    } else {\n      message += messagePart\n    }\n  }\n\n  return message\n}\n\n/**\n * @param {import(\"./configuration.js\").default | undefined} configuration - Configuration instance.\n * @returns {Required<Pick<import(\"./configuration-types.js\").LoggingConfiguration, \"console\" | \"file\" | \"levels\">> & Partial<Pick<import(\"./configuration-types.js\").LoggingConfiguration, \"filePath\" | \"outputs\">>} - The logging configuration.\n */\nfunction resolveLoggingConfiguration(configuration) {\n  const debugEnabled = configuration?.debug === true\n  if (configuration && typeof configuration.getLoggingConfiguration === \"function\") {\n    const resolved = configuration.getLoggingConfiguration()\n\n    if (debugEnabled) {\n      return {\n        ...resolved,\n        console: true,\n        levels: LEVEL_ORDER\n      }\n    }\n\n    return resolved\n  }\n\n  if (debugEnabled) {\n    return {\n      ...DEFAULT_LOGGING_CONFIGURATION,\n      console: true,\n      levels: LEVEL_ORDER\n    }\n  }\n\n  return DEFAULT_LOGGING_CONFIGURATION\n}\n\n/**\n * @param {object} args - Options object.\n * @param {LogLevel} args.level - Level.\n * @param {LogLevel[]} args.allowedLevels - Allowed levels.\n * @param {boolean} [args.debugFlag] - Whether debug flag.\n * @returns {boolean} - Whether level allowed.\n */\nfunction isLevelAllowed({level, allowedLevels, debugFlag}) {\n  if (allowedLevels.includes(level)) return true\n\n  if (debugFlag && LEVEL_ORDER.indexOf(level) >= LEVEL_ORDER.indexOf(\"debug\")) return true\n\n  return false\n}\n\n/**\n * @param {object} args - Options object.\n * @param {import(\"./configuration-types.js\").LoggingConfiguration} args.loggingConfiguration - Logging configuration.\n * @param {import(\"./configuration.js\").default | undefined} args.configuration - Configuration instance.\n * @returns {import(\"./configuration-types.js\").LoggingOutputConfig[]} - Logging outputs.\n */\nfunction resolveLoggingOutputs({loggingConfiguration, configuration}) {\n  if (Array.isArray(loggingConfiguration.outputs)) return loggingConfiguration.outputs\n\n  if (Array.isArray(loggingConfiguration.loggers)) {\n    /** @type {import(\"./configuration-types.js\").LoggingOutputConfig[]} */\n    const loggerOutputs = []\n\n    for (const logger of loggingConfiguration.loggers) {\n      if (!logger) continue\n\n      const loggerConfig = /** @type {any} */ (logger)\n\n      if (typeof loggerConfig.toOutputConfig === \"function\") {\n        loggerOutputs.push(loggerConfig.toOutputConfig({configuration}))\n        continue\n      }\n\n      if (loggerConfig.output && typeof loggerConfig.output.write === \"function\") {\n        loggerOutputs.push({\n          output: loggerConfig.output,\n          levels: loggerConfig.levels\n        })\n        continue\n      }\n\n      if (typeof loggerConfig.write === \"function\") {\n        loggerOutputs.push({\n          output: loggerConfig,\n          levels: loggerConfig.levels\n        })\n        continue\n      }\n\n      const loggerName = loggerConfig?.constructor?.name || \"UnknownLogger\"\n      throw new Error(`Logger must implement toOutputConfig or write: ${loggerName}`)\n    }\n\n    return loggerOutputs\n  }\n\n  /** @type {import(\"./configuration-types.js\").LoggingOutputConfig[]} */\n  const outputs = []\n  if (loggingConfiguration.console !== false) {\n    outputs.push({\n      output: new LoggerConsoleOutput(),\n      levels: loggingConfiguration.levels\n    })\n  }\n\n  if (loggingConfiguration.file !== false && loggingConfiguration.filePath) {\n    outputs.push({\n      output: new LoggerFileOutput({\n        configuration,\n        getConfiguration: () => configuration,\n        filePath: loggingConfiguration.filePath\n      }),\n      levels: loggingConfiguration.levels\n    })\n  }\n\n  return outputs\n}\n\n/**\n * @param {object} args - Options object.\n * @param {LogLevel} args.level - Level.\n * @param {import(\"./configuration-types.js\").LoggingOutputConfig} args.outputConfig - Output configuration.\n * @param {import(\"./configuration-types.js\").LoggingConfiguration} args.loggingConfiguration - Logging configuration.\n * @param {boolean} [args.debugFlag] - Whether debug flag.\n * @returns {boolean} - Whether output should log.\n */\nfunction isOutputLevelAllowed({level, outputConfig, loggingConfiguration, debugFlag}) {\n  if (Array.isArray(outputConfig.levels)) {\n    return isLevelAllowed({level, allowedLevels: outputConfig.levels, debugFlag: false})\n  }\n\n  if (Array.isArray(outputConfig.output?.levels)) {\n    return isLevelAllowed({level, allowedLevels: outputConfig.output.levels, debugFlag: false})\n  }\n\n  const allowedLevels = loggingConfiguration.levels || DEFAULT_LOGGING_CONFIGURATION.levels\n\n  return isLevelAllowed({level, allowedLevels, debugFlag})\n}\n\n/**\n * @param {object} args - Options object.\n * @param {string} args.subject - Log subject.\n * @param {LogLevel} args.level - Level.\n * @param {Parameters<typeof functionOrMessages>} args.messages - Messages.\n * @param {import(\"./configuration.js\").default | undefined} args.configuration - Configuration instance.\n * @param {import(\"./configuration-types.js\").LoggingConfiguration | undefined} args.loggingConfiguration - Logging configuration.\n * @param {boolean} [args.debugFlag] - Whether debug flag.\n * @returns {Promise<void>} - Resolves when complete.\n */\nasync function writeLog({subject, level, messages, configuration, loggingConfiguration, debugFlag}) {\n  const resolvedLoggingConfiguration = loggingConfiguration || resolveLoggingConfiguration(configuration)\n  const outputs = resolveLoggingOutputs({loggingConfiguration: resolvedLoggingConfiguration, configuration})\n\n  if (outputs.length === 0) return\n\n  const writes = []\n  /** @type {Array<any> | undefined} */\n  let resolvedMessages\n  /** @type {string | undefined} */\n  let message\n  /** @type {import(\"./configuration-types.js\").LoggingOutputPayload | null} */\n  let payload = null\n\n  for (const outputConfig of outputs) {\n    if (!outputConfig || !outputConfig.output || typeof outputConfig.output.write !== \"function\") continue\n    if (!isOutputLevelAllowed({level, outputConfig, loggingConfiguration: resolvedLoggingConfiguration, debugFlag})) continue\n\n    if (!payload) {\n      resolvedMessages = functionOrMessages(...messages)\n      message = messagesToMessage(subject, ...resolvedMessages)\n      payload = {\n        level,\n        message,\n        subject,\n        timestamp: new Date()\n      }\n    }\n\n    writes.push(outputConfig.output.write(payload))\n  }\n\n  if (writes.length === 1) {\n    await writes[0]\n  } else if (writes.length > 1) {\n    await Promise.all(writes)\n  }\n}\n\nexport default class Logger {\n  /**\n   * @param {string | object} object - Object.\n   * @param {object} args - Options object.\n   * @param {import(\"./configuration.js\").default} [args.configuration] - Configuration instance.\n   * @param {boolean} [args.debug] - Whether debug.\n   * @param {import(\"./configuration-types.js\").LoggingConfiguration} [args.loggingConfiguration] - Logging configuration.\n   */\n  constructor(object, {configuration, debug = false, loggingConfiguration, ...restArgs} = {}) {\n    restArgsError(restArgs)\n\n    this._debug = debug\n    this._configuration = configuration\n    this._loggingConfiguration = loggingConfiguration\n\n    if (typeof object == \"string\") {\n      this._subject = object || \"EmptyString\"\n    } else {\n      this._object = object\n      this._subject = object.constructor.name || \"UnknownClass\"\n    }\n  }\n\n  /**\n   * @returns {import(\"./configuration.js\").default} - The configuration.\n   */\n  getConfiguration() {\n    if (!this._configuration) {\n      const objectWithConfig = /** @type {{configuration?: import(\"./configuration.js\").default}} */ (this._object)\n      this._configuration = objectWithConfig?.configuration || Configuration.current()\n    }\n\n    return this._configuration\n  }\n\n  /**\n   * @returns {import(\"./configuration.js\").default | undefined} - The safe configuration.\n   */\n  _safeConfiguration() {\n    try {\n      return this.getConfiguration()\n    } catch {\n      return undefined\n    }\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async debug(...messages) {\n    await this._write({level: \"debug\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async info(...messages) {\n    await this._write({level: \"info\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async debugLowLevel(...messages) {\n    await this._write({level: \"debug-low-level\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async log(...messages) {\n    await this._write({level: \"info\", messages})\n  }\n\n  /**\n   * @param {any[]} messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async error(...messages) {\n    await this._write({level: \"error\", messages})\n  }\n\n  /**\n   * @param {boolean} newValue - New value.\n   * @returns {void} - No return value.\n   */\n  setDebug(newValue) {\n    this._debug = newValue\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async warn(...messages) {\n    await this._write({level: \"warn\", messages})\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {LogLevel} args.level - Level.\n   * @param {Parameters<typeof functionOrMessages>} args.messages - Messages.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _write({level, messages}) {\n    const configuration = this._safeConfiguration()\n    const loggingConfiguration = this._loggingConfiguration || resolveLoggingConfiguration(configuration)\n\n    await writeLog({\n      subject: this._subject,\n      level,\n      messages,\n      configuration,\n      loggingConfiguration,\n      debugFlag: this._debug\n    })\n  }\n}\n"]}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "velocious": "build/bin/velocious.js"
4
4
  },
5
5
  "name": "velocious",
6
- "version": "1.0.309",
6
+ "version": "1.0.311",
7
7
  "main": "build/index.js",
8
8
  "types": "build/index.d.ts",
9
9
  "files": [
@@ -74,7 +74,7 @@
74
74
  "@types/strftime": "^0.9.8",
75
75
  "chokidar-cli": "^3.0.0",
76
76
  "cpy-cli": "^7.0.0",
77
- "esbuild": "^0.27.2",
77
+ "esbuild": "^0.28.0",
78
78
  "eslint": "^10.0.1",
79
79
  "eslint-plugin-jsdoc": "^62.7.0",
80
80
  "globals": "^17.0.0",