@decaf-ts/logging 0.3.27 → 0.3.28

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.
Files changed (71) hide show
  1. package/README.md +1 -1
  2. package/dist/logging.cjs +2 -2086
  3. package/dist/logging.cjs.map +1 -0
  4. package/dist/logging.js +2 -0
  5. package/dist/logging.js.map +1 -0
  6. package/lib/LoggedClass.cjs +1 -1
  7. package/lib/LoggedClass.js.map +1 -0
  8. package/lib/constants.cjs +1 -1
  9. package/lib/constants.js.map +1 -0
  10. package/lib/decorators.cjs +1 -1
  11. package/lib/decorators.js.map +1 -0
  12. package/lib/environment.cjs +1 -1
  13. package/lib/environment.js.map +1 -0
  14. package/lib/esm/LoggedClass.js +1 -1
  15. package/lib/esm/LoggedClass.js.map +1 -0
  16. package/lib/esm/constants.js +1 -1
  17. package/lib/esm/constants.js.map +1 -0
  18. package/lib/esm/decorators.js +1 -1
  19. package/lib/esm/decorators.js.map +1 -0
  20. package/lib/esm/environment.js +1 -1
  21. package/lib/esm/environment.js.map +1 -0
  22. package/lib/esm/filters/LogFilter.js +1 -1
  23. package/lib/esm/filters/LogFilter.js.map +1 -0
  24. package/lib/esm/filters/PatternFilter.js +1 -1
  25. package/lib/esm/filters/PatternFilter.js.map +1 -0
  26. package/lib/esm/filters/index.js +1 -1
  27. package/lib/esm/filters/index.js.map +1 -0
  28. package/lib/esm/index.js +3 -3
  29. package/lib/esm/index.js.map +1 -0
  30. package/lib/esm/logging.js +1 -1
  31. package/lib/esm/logging.js.map +1 -0
  32. package/lib/esm/text.js +1 -1
  33. package/lib/esm/text.js.map +1 -0
  34. package/lib/esm/time.js +1 -1
  35. package/lib/esm/time.js.map +1 -0
  36. package/lib/esm/types.js +1 -1
  37. package/lib/esm/types.js.map +1 -0
  38. package/lib/esm/utils.js +1 -1
  39. package/lib/esm/utils.js.map +1 -0
  40. package/lib/esm/web.js +1 -1
  41. package/lib/esm/web.js.map +1 -0
  42. package/lib/esm/winston/index.js +1 -1
  43. package/lib/esm/winston/index.js.map +1 -0
  44. package/lib/esm/winston/winston.js +1 -1
  45. package/lib/esm/winston/winston.js.map +1 -0
  46. package/lib/filters/LogFilter.cjs +1 -1
  47. package/lib/filters/LogFilter.js.map +1 -0
  48. package/lib/filters/PatternFilter.cjs +1 -1
  49. package/lib/filters/PatternFilter.js.map +1 -0
  50. package/lib/filters/index.cjs +1 -1
  51. package/lib/filters/index.js.map +1 -0
  52. package/lib/index.cjs +3 -3
  53. package/lib/index.js.map +1 -0
  54. package/lib/logging.cjs +1 -1
  55. package/lib/logging.js.map +1 -0
  56. package/lib/text.cjs +1 -1
  57. package/lib/text.js.map +1 -0
  58. package/lib/time.cjs +1 -1
  59. package/lib/time.js.map +1 -0
  60. package/lib/types.cjs +1 -1
  61. package/lib/types.js.map +1 -0
  62. package/lib/utils.cjs +1 -1
  63. package/lib/utils.js.map +1 -0
  64. package/lib/web.cjs +1 -1
  65. package/lib/web.js.map +1 -0
  66. package/lib/winston/index.cjs +1 -1
  67. package/lib/winston/index.js.map +1 -0
  68. package/lib/winston/winston.cjs +1 -1
  69. package/lib/winston/winston.js.map +1 -0
  70. package/package.json +1 -1
  71. package/dist/logging.esm.cjs +0 -2044
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.cjs","sources":["../src/constants.ts","../src/text.ts","../src/web.ts","../src/environment.ts","../src/logging.ts","../src/LoggedClass.ts","../src/filters/LogFilter.ts","../src/time.ts","../src/decorators.ts","../src/filters/PatternFilter.ts","../src/index.ts","../src/utils.ts"],"sourcesContent":[null,null,null,null,null,null,null,null,null,null,null,null],"names":["BrowserEnvKey","ENV_PATH_DELIMITER","DefaultPlaceholderWrappers","LogLevel","exports","NumericLogLevels","benchmark","error","warn","info","verbose","debug","trace","silly","LoggingMode","DefaultTheme","app","separator","class","fg","id","stack","timestamp","message","method","logLevel","style","DefaultLoggingConfig","env","level","contextSeparator","timestampFormat","context","format","RAW","pattern","theme","patchString","input","values","flags","Object","entries","forEach","key","val","regexp","RegExp","escapeRegExp","replace","toENVFormat","text","toSnakeCase","toUpperCase","toLowerCase","string","sf","args","length","every","arg","Error","obj","reduce","acc","match","number","toString","stringFormat","isBrowser","getPrototypeOf","globalThis","prototype","EmptyValue","Symbol","ModelSymbol","Environment","ObjectAccumulator","this","factory","constructor","super","defineProperty","value","writable","enumerable","configurable","fromEnv","k","process","parseEnvValue","result","parseFloat","isNaN","expand","v","mergeModel","get","buildEnvProxy","set","orThrow","modelRoot","buildKey","path","map","segment","join","readRuntime","readRuntimeEnv","parseRuntime","raw","undefined","missing","empty","missingEnvError","createNestedProxy","model","Proxy","_target","prop","nextPath","envKey","runtimeRaw","runtimeValue","hasOwnProperty","call","modelValue","Array","isArray","ownKeys","Reflect","getOwnPropertyDescriptor","target","receiver","actual","instance","_instance","base","proxied","accumulate","keys","desc","current","p","seg","toPrimitive","hasProp","nextModel","envValue","_t","toEnv","existing","childKey","childValue","LoggedEnvironment","assign","MiniLogger","conf","config","Logging","getConfig","name","createLog","log","date","Date","toISOString","lvl","correlationId","msg","JSON","stringify","split","s","formattedS","filter","confLvl","console","verbosity","e","setConfig","_factory","object","_config","setFactory","global","because","reason","type","loggerLevel","template","individualTheme","actualTheme","logLevels","txt","option","t","c","applyColor","isBg","f","background","foreground","bgColor256","color256","bgRgb","rgb","applyStyle","apply","LoggedClass","_log","for","LogFilter","filters","now","performance","hrtime","bigint","ns","Number","formatMs","ms","sign","abs","Math","hours","floor","minutes","seconds","millis","pad","n","w","padStart","entryMessage","exitMessage","propertyKey","descriptor","logger","bind","originalMethod","fn","thisArg","Promise","then","r","catch","err","final","PatternFilter","replacement","exec","lastIndex","__decorate","autoStart","_startMs","_elapsedMs","_running","_laps","_lastLapTotalMs","start","running","elapsedMs","pause","resume","stop","reset","wasRunning","lap","label","total","index","totalMs","push","laps","toJSON","slice","src","Function","test","protoDesc","proto","getOwnPropertyNames","str","char","padEnd","prefix","suffix","word"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{style as t}from"styled-string-builder";import{ObjectAccumulator as e}from"typed-object-accumulator";import{__decorate as r,__metadata as n}from"tslib";const o="ENV",s="__",i=["${","}"];var a;(t=>{t.benchmark="benchmark",t.error="error",t.warn="warn",t.info="info",t.verbose="verbose",t.debug="debug",t.trace="trace",t.silly="silly"})(a||(a={}));const c={benchmark:0,error:3,warn:6,info:9,verbose:12,debug:15,trace:18,silly:21};var l;(t=>{t.RAW="raw",t.JSON="json"})(l||(l={}));const u={app:{},separator:{},class:{fg:34},id:{fg:36},stack:{},timestamp:{},message:{error:{fg:31}},method:{},logLevel:{benchmark:{fg:32,style:["bold"]},error:{fg:31,style:["bold"]},info:{fg:34,style:["bold"]},verbose:{fg:34,style:["bold"]},debug:{fg:33,style:["bold"]},trace:{fg:33,style:["bold"]},silly:{fg:33,style:["bold"]}}},f={env:"development",verbose:0,level:a.info,logLevel:!0,style:!1,contextSeparator:".",separator:"-",timestamp:!0,timestampFormat:"HH:mm:ss.SSS",context:!0,format:l.RAW,pattern:"{level} [{timestamp}] {app} {context} {separator} {message} {stack}",theme:u};function g(t,e,r=" "){if(1!==r.length)throw Error("Invalid character length for padding. must be one!");return t.padEnd(e,r)}function h(t,e,r="${",n="}",o="g"){return p(t,Object.entries(e).reduce((t,[e,o])=>(t[`${r}${e}${n}`]=o,t),{}),o)}function p(t,e,r="g"){return Object.entries(e).forEach(([e,n])=>{const o=RegExp(w(e),r);t=t.replace(o,n)}),t}function b(t){return t.replace(/(?:^\w|[A-Z]|\b\w)/g,(t,e)=>0===e?t.toLowerCase():t.toUpperCase()).replace(/\s+/g,"")}function y(t){return d(t).toUpperCase()}function d(t){return t.replace(/([a-z])([A-Z])/g,"$1_$2").replace(/[\s-]+/g,"_").toLowerCase()}function m(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").replace(/[\s_]+/g,"-").toLowerCase()}function v(t){return t.replace(/(?:^\w|[A-Z]|\b\w)/g,t=>t.toUpperCase()).replace(/\s+/g,"")}function w(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function _(t,...e){if(e.length>1&&!e.every(t=>"string"==typeof t||"number"==typeof t))throw Error("Only string and number arguments are supported for multiple replacements.");if(1===e.length&&"object"==typeof e[0]){const r=e[0];return Object.entries(r).reduce((t,[e,r])=>t.replace(RegExp(`\\{${e}\\}`,"g"),()=>r),t)}return t.replace(/{(\d+)}/g,(t,r)=>void 0!==e[r]?e[r].toString():"undefined")}const O=_;function E(){return Object.getPrototypeOf(Object.getPrototypeOf(globalThis))!==Object.prototype}const j=Symbol("EnvironmentEmpty"),x=Symbol("EnvironmentModel");class P extends e{static{this.factory=()=>new P}constructor(){super(),Object.defineProperty(this,x,{value:{},writable:!0,enumerable:!1,configurable:!1})}fromEnv(t){let e;return E()?e=globalThis[o]||{}:(e=globalThis.process.env,t=y(t)),this.parseEnvValue(e[t])}parseEnvValue(t){if("string"!=typeof t)return t;if("true"===t)return!0;if("false"===t)return!1;const e=parseFloat(t);return isNaN(e)?t:e}expand(t){Object.entries(t).forEach(([t,e])=>{P.mergeModel(this[x],t,e),Object.defineProperty(this,t,{get:()=>{const r=this.fromEnv(t);return void 0!==r?r:e&&"object"==typeof e?P.buildEnvProxy(e,[t]):""===e?j:e},set:t=>{e=t},configurable:!0,enumerable:!0})})}orThrow(){const t=this[x],e=t=>t.map(t=>y(t)).join(s),r=t=>P.readRuntimeEnv(t),n=t=>void 0!==t?this.parseEnvValue(t):void 0,o=(t,e=!1)=>P.missingEnvError(t,e),i=(t,s)=>new Proxy({},{get(a,c){if("string"!=typeof c)return;const l=[...s,c],u=e(l),f=r(u);if("string"==typeof f&&0===f.length)throw o(u,!0);const g=n(f);if(void 0!==g){if("string"==typeof g&&0===g.length)throw o(u,!0);return g}if(!t||!Object.prototype.hasOwnProperty.call(t,c))throw o(u);const h=t[c];if(void 0!==h){if(""===h)throw o(u);return h&&"object"==typeof h&&!Array.isArray(h)?i(h,l):h}},ownKeys:()=>t?Reflect.ownKeys(t):[],getOwnPropertyDescriptor(e,r){if(t)return Object.prototype.hasOwnProperty.call(t,r)?{enumerable:!0,configurable:!0}:void 0}});return new Proxy(this,{get(s,a,c){if("string"!=typeof a)return Reflect.get(s,a,c);if(!Object.prototype.hasOwnProperty.call(t,a))return Reflect.get(s,a,c);const l=e([a]),u=r(l);if("string"==typeof u&&0===u.length)throw o(l,!0);const f=n(u);if(void 0!==f){if("string"==typeof f&&0===f.length)throw o(l,!0);return f}const g=t[a];if(g&&"object"==typeof g&&!Array.isArray(g))return i(g,[a]);if(void 0===g)return Reflect.get(s,a,c);const h=Reflect.get(s,a);if(void 0===h||""===h)throw o(l,""===h);return h}})}static instance(...t){if(!P._instance){const e=P.factory(...t),r=new Proxy(e,{get(t,e,r){const n=Reflect.get(t,e,r);if(n!==j&&("string"!=typeof e||!Object.prototype.hasOwnProperty.call(t,e)||void 0!==n)){if(void 0!==n)return n;if("string"==typeof e){if("app"===e)return;return P.buildEnvProxy(void 0,[e])}return n}}});P._instance=r}return P._instance}static accumulate(t){const e=P.instance();return Object.keys(e).forEach(t=>{const r=Object.getOwnPropertyDescriptor(e,t);r&&r.configurable&&r.enumerable&&Object.defineProperty(e,t,{...r,enumerable:!1})}),e.accumulate(t)}static get(t){return P._instance.get(t)}static buildEnvProxy(t,e){const r=t=>t.map(t=>y(t)).join(s);return new Proxy({},{get(n,o){if(o===Symbol.toPrimitive)return()=>r(e);if("toString"===o)return()=>r(e);if("valueOf"===o)return()=>r(e);if("symbol"==typeof o)return;const s=!!t&&Object.prototype.hasOwnProperty.call(t,o),i=s?t[o]:void 0,a=[...e,o],c=(l=r(a),P.readRuntimeEnv(l));var l;return void 0!==c?c:i&&"object"==typeof i?P.buildEnvProxy(i,a):s&&""===i||s&&void 0===i?void 0:P.buildEnvProxy(void 0,a)},ownKeys:()=>t?Reflect.ownKeys(t):[],getOwnPropertyDescriptor(e,r){if(t)return Object.prototype.hasOwnProperty.call(t,r)?{enumerable:!0,configurable:!0}:void 0}})}static keys(t=!0){return P.instance().keys().map(e=>t?y(e):e)}static mergeModel(t,e,r){if(t){if(r&&"object"==typeof r&&!Array.isArray(r)){const n=t[e],o=n&&"object"==typeof n&&!Array.isArray(n)?n:{};return t[e]=o,void Object.entries(r).forEach(([t,e])=>{P.mergeModel(o,t,e)})}t[e]=r}}static readRuntimeEnv(t){if(E()){const e=globalThis[o];return e?e[t]:void 0}return globalThis?.process?.env?.[t]}static missingEnvError(t,e){return Error(`Environment variable ${t} is required but was ${e?"an empty string":"undefined"}.`)}}const M=P.accumulate(Object.assign({},f,{env:(E()&&globalThis[o]?globalThis[o].NODE_ENV:globalThis.process.env.NODE_ENV)||"development"}));class k{constructor(t,e){this.context=t,this.conf=e}config(t){return this.conf&&t in this.conf?this.conf[t]:$.getConfig()[t]}for(t,e,...r){return e||"object"!=typeof t?t=t?"string"==typeof t?t:t.name:void 0:(e=t,t=void 0),new Proxy(this,{get:(r,n,o)=>{const s=Reflect.get(r,n,o);return"config"===n?new Proxy(this.config,{get:(t,r)=>e&&r in e?e[r]:Reflect.get(t,r,o)}):"context"===n&&t?[s,t].join("."):s}})}createLog(t,e,r){const n={},o=this.config("style"),s=this.config("separator"),i=this.config("app");if(i&&(n.app=o?$.theme(i,"app",t):i),s&&(n.separator=o?$.theme(s,"separator",t):s),this.config("timestamp")){const e=(new Date).toISOString(),r=o?$.theme(e,"timestamp",t):e;n.timestamp=r}if(this.config("logLevel")){const e=o?$.theme(t,"logLevel",t):t;n.level=e.toUpperCase()}if(this.config("context")){const e=o?$.theme(this.context,"class",t):this.context;n.context=e}if(this.config("correlationId")){const e=o?$.theme(this.config("correlationId").toString(),"id",t):this.config("correlationId").toString();n.correlationId=e}const a=o?$.theme("string"==typeof e?e:e.message,"message",t):"string"==typeof e?e:e.message;if(n.message=a,r||e instanceof Error){const s=o?$.theme(r?.stack||e.stack,"stack",t):r?.stack||"";n.stack=` | ${(r||e).message} - Stack trace:\n${s}`}switch(this.config("format")){case"json":return JSON.stringify(n);case"raw":return this.config("pattern").split(" ").map(t=>{if(!t.match(/\{.*?}/g))return t;const e=_(t,n);return e!==t?e:void 0}).filter(t=>t).join(" ");default:throw Error("Unsupported logging format: "+this.config("format"))}}log(t,e,r){const n=this.config("level");if(c[t]>c[n])return;let o;switch(t){case a.benchmark:case a.info:o=console.log;break;case a.verbose:case a.debug:o=console.debug;break;case a.error:o=console.error;break;case a.trace:case a.silly:o=console.trace;break;default:throw Error("Invalid log level")}o(this.createLog(t,e,r))}benchmark(t){this.log(a.benchmark,t)}silly(t,e=0){this.config("verbose")<e||this.log(a.verbose,t)}verbose(t,e=0){this.config("verbose")<e||this.log(a.verbose,t)}info(t){this.log(a.info,t)}debug(t){this.log(a.debug,t)}error(t,e){this.log(a.error,t,e)}warn(t){this.log(a.warn,t)}trace(t){this.log(a.trace,t)}setConfig(t){this.conf={...this.conf||{},...t}}}class ${static{this._factory=(t,e)=>new k(t,e)}static{this._config=M}constructor(){}static setFactory(t){$._factory=t}static setConfig(t){Object.entries(t).forEach(([t,e])=>{this._config[t]=e})}static getConfig(){return this._config}static get(){return this.global=this.global?this.global:this._factory("Logging"),this.global}static verbose(t,e=0){return this.get().verbose(t,e)}static info(t){return this.get().info(t)}static trace(t){return this.get().trace(t)}static debug(t){return this.get().debug(t)}static benchmark(t){return this.get().benchmark(t)}static silly(t){return this.get().silly(t)}static warn(t){return this.get().warn(t)}static error(t,e){return this.get().error(t,e)}static for(t,e,...r){return t="string"==typeof t?t:t.constructor?t.constructor.name:t.name,this._factory(t,e,...r)}static because(t,e){return this._factory(t,this._config,e)}static theme(e,r,n,o=u){if(!this._config.style)return e;const s=o[r];if(!s||!Object.keys(s).length)return e;let i=s;const c=Object.assign({},a);return Object.keys(s)[0]in c&&(i=s[n]||{}),Object.keys(i).reduce((e,r)=>{const n=i[r];return n?((e,r,n)=>{try{const o=e;let s=t(o);function i(e,r=!1){let i=r?s.background:s.foreground;if(!Array.isArray(e))return i.call(s,n);switch(e.length){case 1:return i=r?s.bgColor256:s.color256,i(e[0]);case 3:return i=r?s.bgRgb:s.rgb,s.rgb(e[0],e[1],e[2]);default:return t(o)}}function a(t){s="number"==typeof t?s.style(t):s[t]}switch(r){case"bg":case"fg":return i(n).text;case"style":return Array.isArray(n)?n.forEach(a):a(n),s.text;default:return o}}catch(c){return e}})(e,r,n):e},e)}}class S{get log(){return this._log||(this._log=$.for(this)),this._log}constructor(){}}class A extends S{get log(){return super.log.for(this,{filters:[]})}}const R="undefined"!=typeof globalThis&&"function"==typeof globalThis.performance?.now?()=>globalThis.performance.now():"undefined"!=typeof process&&"function"==typeof process.hrtime?.bigint?()=>{const t=process.hrtime.bigint();return Number(t)/1e6}:()=>Date.now();class T{constructor(t=!1){this._startMs=null,this._elapsedMs=0,this._running=!1,this._laps=[],this._lastLapTotalMs=0,t&&this.start()}get running(){return this._running}get elapsedMs(){return this._running&&null!=this._startMs?this._elapsedMs+(R()-this._startMs):this._elapsedMs}start(){return this._running||(this._running=!0,this._startMs=R()),this}pause(){return this._running&&null!=this._startMs&&(this._elapsedMs+=R()-this._startMs,this._startMs=null,this._running=!1),this}resume(){return this._running||(this._running=!0,this._startMs=R()),this}stop(){return this.pause(),this._elapsedMs}reset(){const t=this._running;return this._startMs=t?R():null,this._elapsedMs=0,this._laps=[],this._lastLapTotalMs=0,this}lap(t){const e=this.elapsedMs,r=e-this._lastLapTotalMs,n={index:this._laps.length,label:t,ms:r,totalMs:e};return this._laps.push(n),this._lastLapTotalMs=e,n}get laps(){return this._laps}toString(){return L(this.elapsedMs)}toJSON(){return{running:this._running,elapsedMs:this.elapsedMs,laps:this._laps.slice()}}}function L(t){const e=0>t?"-":"",r=Math.abs(t),n=Math.floor(r/36e5),o=Math.floor(r%36e5/6e4),s=Math.floor(r%6e4/1e3),i=Math.floor(r%1e3),a=(t,e)=>t.toString().padStart(e,"0");return`${e}${a(n,2)}:${a(o,2)}:${a(s,2)}.${a(i,3)}`}function C(t=a.info,e=0,r=(...t)=>"called with "+t,n){return(o,s,i)=>{if(!i||"number"==typeof i)throw Error("Logging decoration only applies to methods");const a=o instanceof S?o.log.for(o[s]):$.for(o).for(o[s]),c=a[t].bind(a),l=i.value;return i.value=new Proxy(l,{apply(t,o,s){c(r(...s),e);try{const e=Reflect.apply(t,o,s);return e instanceof Promise?e.then(t=>(n&&c(n(void 0,t)),t)).catch(t=>{throw n&&a.error(n(t)),t}):(n&&c(n(void 0,e)),e)}catch(t){throw n&&a.error(n(t)),t}}}),i}}function N(){return(t,e,r)=>{if(!r||"number"==typeof r)throw Error("benchmark decoration only applies to methods");const n=t instanceof S?t.log.for(t[e]):$.for(t).for(t[e]),o=r.value;return r.value=new Proxy(o,{apply(t,e,r){const o=R();try{const s=Reflect.apply(t,e,r);return s instanceof Promise?s.then(t=>(n.benchmark(`completed in ${R()-o}ms`),t)).catch(t=>{throw n.benchmark(`failed in ${R()-o}ms`),t}):(n.benchmark(`completed in ${R()-o}ms`),s)}catch(t){throw n.benchmark(`failed in ${R()-o}ms`),t}}}),r}}function I(){return C(a.debug,0,(...t)=>"called with "+t,(t,e)=>t?"Failed with: "+t:e?"Completed with "+JSON.stringify(e):"completed")}function D(){return C(a.info)}function F(){return C(a.silly)}function V(){return C(a.trace)}function K(t=0){return t||(t=0),C(a.verbose,t)}function U(){return(t,e,r)=>{if(!r)throw Error("final decorator can only be used on methods");return r?.configurable&&(r.configurable=!1),r}}class J extends A{constructor(t,e){super(),this.regexp=t,this.replacement=e}match(t){const e=this.regexp.exec(t);return this.regexp.lastIndex=0,e}filter(t,e,r){const n=this.log.for(this.filter);if(!this.match(e))return e;try{return e.replace(this.regexp,this.replacement)}catch(t){n.error("PatternFilter replacement error: "+t)}return""}}function Z(t){if("function"!=typeof t)return!1;try{const e=Function.prototype.toString.call(t);if(/^\s*class[\s{]/.test(e))return!0}catch{}const e=Object.getOwnPropertyDescriptor(t,"prototype");if(!e||!e.value)return!1;if(!1===e.writable)return!0;const r=t.prototype;return!!Object.prototype.hasOwnProperty.call(r,"constructor")&&Object.getOwnPropertyNames(r).filter(t=>"constructor"!==t).length>0}r([U(),n("design:type",Function),n("design:paramtypes",[String]),n("design:returntype",void 0)],J.prototype,"match",null);const z="##VERSION##",H="##PACKAGE##";export{o as BrowserEnvKey,f as DefaultLoggingConfig,i as DefaultPlaceholderWrappers,u as DefaultTheme,s as ENV_PATH_DELIMITER,P as Environment,A as LogFilter,a as LogLevel,S as LoggedClass,M as LoggedEnvironment,$ as Logging,l as LoggingMode,k as MiniLogger,c as NumericLogLevels,H as PACKAGE_NAME,J as PatternFilter,T as StopWatch,z as VERSION,N as benchmark,I as debug,w as escapeRegExp,U as final,L as formatMs,D as info,E as isBrowser,Z as isClass,C as log,R as now,g as padEnd,h as patchPlaceholders,p as patchString,_ as sf,F as silly,O as stringFormat,b as toCamelCase,y as toENVFormat,m as toKebabCase,v as toPascalCase,d as toSnakeCase,V as trace,K as verbose};
2
+ //# sourceMappingURL=logging.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.js","sources":["../src/constants.ts","../src/text.ts","../src/web.ts","../src/environment.ts","../src/logging.ts","../src/LoggedClass.ts","../src/filters/LogFilter.ts","../src/time.ts","../src/decorators.ts","../src/filters/PatternFilter.ts","../src/utils.ts","../src/index.ts"],"sourcesContent":[null,null,null,null,null,null,null,null,null,null,null,null],"names":["BrowserEnvKey","ENV_PATH_DELIMITER","DefaultPlaceholderWrappers","LogLevel","NumericLogLevels","benchmark","error","warn","info","verbose","debug","trace","silly","LoggingMode","DefaultTheme","app","separator","class","fg","id","stack","timestamp","message","method","logLevel","style","DefaultLoggingConfig","env","level","contextSeparator","timestampFormat","context","format","RAW","pattern","theme","padEnd","str","length","char","Error","patchPlaceholders","input","values","prefix","suffix","flags","patchString","Object","entries","reduce","acc","key","val","forEach","regexp","RegExp","escapeRegExp","replace","toCamelCase","text","word","index","toLowerCase","toUpperCase","toENVFormat","toSnakeCase","toKebabCase","toPascalCase","string","sf","args","every","arg","obj","match","number","toString","stringFormat","isBrowser","getPrototypeOf","globalThis","prototype","EmptyValue","Symbol","ModelSymbol","Environment","ObjectAccumulator","this","factory","constructor","super","defineProperty","value","writable","enumerable","configurable","fromEnv","k","process","parseEnvValue","result","parseFloat","isNaN","expand","v","mergeModel","get","buildEnvProxy","set","orThrow","modelRoot","buildKey","path","map","segment","join","readRuntime","readRuntimeEnv","parseRuntime","raw","undefined","missing","empty","missingEnvError","createNestedProxy","model","Proxy","_target","prop","nextPath","envKey","runtimeRaw","runtimeValue","hasOwnProperty","call","modelValue","Array","isArray","ownKeys","Reflect","getOwnPropertyDescriptor","target","receiver","actual","instance","_instance","base","proxied","accumulate","keys","desc","current","p","seg","toPrimitive","hasProp","nextModel","envValue","_t","toEnv","existing","childKey","childValue","LoggedEnvironment","assign","MiniLogger","conf","config","Logging","getConfig","name","createLog","log","date","Date","toISOString","lvl","correlationId","msg","JSON","stringify","split","s","formattedS","filter","confLvl","console","verbosity","e","setConfig","_factory","object","_config","setFactory","global","because","reason","type","loggerLevel","template","individualTheme","actualTheme","logLevels","txt","option","t","c","applyColor","isBg","f","background","foreground","bgColor256","color256","bgRgb","rgb","applyStyle","apply","LoggedClass","_log","for","LogFilter","filters","now","performance","hrtime","bigint","ns","Number","StopWatch","autoStart","_startMs","_elapsedMs","_running","_laps","_lastLapTotalMs","start","running","elapsedMs","pause","resume","stop","reset","wasRunning","lap","label","total","ms","totalMs","push","laps","formatMs","toJSON","slice","sign","abs","Math","hours","floor","minutes","seconds","millis","pad","n","w","padStart","entryMessage","exitMessage","propertyKey","descriptor","logger","bind","originalMethod","fn","thisArg","Promise","then","r","catch","err","final","PatternFilter","replacement","exec","lastIndex","isClass","src","Function","test","protoDesc","proto","getOwnPropertyNames","__decorate","VERSION","PACKAGE_NAME"],"mappings":"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"}
@@ -44,4 +44,4 @@ class LoggedClass {
44
44
  constructor() { }
45
45
  }
46
46
  exports.LoggedClass = LoggedClass;
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9nZ2VkQ2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvTG9nZ2VkQ2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsMkNBQW9DO0FBR3BDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EyQkc7QUFDSCxNQUFzQixXQUFXO0lBRy9COzs7O09BSUc7SUFDSCxJQUFjLEdBQUc7UUFDZixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUk7WUFBRSxJQUFJLENBQUMsSUFBSSxHQUFHLGlCQUFPLENBQUMsR0FBRyxDQUFDLElBQVcsQ0FBQyxDQUFDO1FBQ3JELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0lBRUQsZ0JBQXlCLENBQUM7Q0FDM0I7QUFkRCxrQ0FjQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvZ2dpbmcgfSBmcm9tIFwiLi9sb2dnaW5nXCI7XG5pbXBvcnQgeyBMb2dnZXIgfSBmcm9tIFwiLi90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBCYXNlIGNsYXNzIHRoYXQgcHJvdmlkZXMgYSByZWFkeS10by11c2UgbG9nZ2VyIGluc3RhbmNlLlxuICogQHN1bW1hcnkgU3VwcGxpZXMgaW5oZXJpdGluZyBjbGFzc2VzIHdpdGggYSBsYXppbHkgY3JlYXRlZCwgY29udGV4dC1hd2FyZSB7QGxpbmsgTG9nZ2VyfSB2aWEgdGhlIHByb3RlY3RlZCBgbG9nYCBnZXR0ZXIsIHByb21vdGluZyBjb25zaXN0ZW50IHN0cnVjdHVyZWQgbG9nZ2luZyB3aXRob3V0IG1hbnVhbCB3aXJpbmcuXG4gKiBAY2xhc3MgTG9nZ2VkQ2xhc3NcbiAqIEBleGFtcGxlXG4gKiBjbGFzcyBVc2VyU2VydmljZSBleHRlbmRzIExvZ2dlZENsYXNzIHtcbiAqICAgY3JlYXRlKHVzZXI6IFVzZXIpIHtcbiAqICAgICB0aGlzLmxvZy5pbmZvKGBDcmVhdGluZyB1c2VyICR7dXNlci5pZH1gKTtcbiAqICAgfVxuICogfVxuICpcbiAqIGNvbnN0IHN2YyA9IG5ldyBVc2VyU2VydmljZSgpO1xuICogc3ZjLmNyZWF0ZSh7IGlkOiBcIjQyXCIgfSk7XG4gKiBAbWVybWFpZFxuICogc2VxdWVuY2VEaWFncmFtXG4gKiAgIHBhcnRpY2lwYW50IENsaWVudFxuICogICBwYXJ0aWNpcGFudCBJbnN0YW5jZSBhcyBTdWJjbGFzcyBJbnN0YW5jZVxuICogICBwYXJ0aWNpcGFudCBHZXR0ZXIgYXMgTG9nZ2VkQ2xhc3MubG9nXG4gKiAgIHBhcnRpY2lwYW50IExvZ2dpbmcgYXMgTG9nZ2luZ1xuICogICBwYXJ0aWNpcGFudCBMb2dnZXIgYXMgTG9nZ2VyXG4gKlxuICogICBDbGllbnQtPj5JbnN0YW5jZTogY2FsbCBzb21lTWV0aG9kKClcbiAqICAgSW5zdGFuY2UtPj5HZXR0ZXI6IGFjY2VzcyB0aGlzLmxvZ1xuICogICBHZXR0ZXItPj5Mb2dnaW5nOiBMb2dnaW5nLmZvcih0aGlzKVxuICogICBMb2dnaW5nLS0+PkdldHRlcjogcmV0dXJuIExvZ2dlclxuICogICBHZXR0ZXItLT4+SW5zdGFuY2U6IHJldHVybiBMb2dnZXJcbiAqICAgSW5zdGFuY2UtPj5Mb2dnZXI6IGluZm8vZGVidWcvZXJyb3IoLi4uKVxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTG9nZ2VkQ2xhc3Mge1xuICBwcml2YXRlIF9sb2c/OiBMb2dnZXI7XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBMYXppbHkgcHJvdmlkZXMgYSBjb250ZXh0LWF3YXJlIGxvZ2dlciBmb3IgdGhlIGN1cnJlbnQgaW5zdGFuY2UuXG4gICAqIEBzdW1tYXJ5IENhbGxzIHtAbGluayBMb2dnaW5nLmZvcn0gd2l0aCB0aGUgc3ViY2xhc3MgaW5zdGFuY2UgdG8gb2J0YWluIGEgbG9nZ2VyIHdob3NlIGNvbnRleHQgbWF0Y2hlcyB0aGUgc3ViY2xhc3MgbmFtZS5cbiAgICogQHJldHVybiB7TG9nZ2VyfSBMb2dnZXIgYm91bmQgdG8gdGhlIHN1YmNsYXNzIGNvbnRleHQuXG4gICAqL1xuICBwcm90ZWN0ZWQgZ2V0IGxvZygpOiBMb2dnZXIge1xuICAgIGlmICghdGhpcy5fbG9nKSB0aGlzLl9sb2cgPSBMb2dnaW5nLmZvcih0aGlzIGFzIGFueSk7XG4gICAgcmV0dXJuIHRoaXMuX2xvZztcbiAgfVxuXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
47
+ //# sourceMappingURL=LoggedClass.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LoggedClass.js","sourceRoot":"","sources":["../src/LoggedClass.ts"],"names":[],"mappings":";;;AAAA,2CAAoC;AAGpC;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,MAAsB,WAAW;IAG/B;;;;OAIG;IACH,IAAc,GAAG;QACf,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,IAAI,CAAC,IAAI,GAAG,iBAAO,CAAC,GAAG,CAAC,IAAW,CAAC,CAAC;QACrD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,gBAAyB,CAAC;CAC3B;AAdD,kCAcC"}
package/lib/constants.cjs CHANGED
@@ -198,4 +198,4 @@ exports.DefaultLoggingConfig = {
198
198
  pattern: "{level} [{timestamp}] {app} {context} {separator} {message} {stack}",
199
199
  theme: exports.DefaultTheme,
200
200
  };
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { LoggingConfig, Theme } from \"./types\";\n\n/**\n * @description Global key used to store environment variables in browser contexts.\n * @summary Enables the logging environment helpers to locate serialized environment configuration on `globalThis`.\n * @const BrowserEnvKey\n * @type {string}\n * @memberOf module:Logging\n */\nexport const BrowserEnvKey = \"ENV\";\n\n/**\n * @description Delimiter used for composing nested environment variable names.\n * @summary Joins parent and child keys when mapping object paths to ENV strings.\n * @const ENV_PATH_DELIMITER\n * @type {string}\n * @memberOf module:Logging\n */\nexport const ENV_PATH_DELIMITER = \"__\";\n\n/**\n * @description Default prefix and suffix used for template placeholders.\n * @summary Provides wrapper strings applied when interpolating messages with {@link patchPlaceholders}.\n * @const DefaultPlaceholderWrappers\n * @type {string[]}\n * @memberOf module:Logging\n */\nexport const DefaultPlaceholderWrappers = [\"${\", \"}\"];\n\n/**\n * @description Enum for log levels.\n * @summary Defines different levels of logging for the application.\n * @enum {string}\n * @readonly\n * @memberOf module:Logging\n */\nexport enum LogLevel {\n  /** @description Benchmark events that capture performance metrics. */\n  benchmark = \"benchmark\",\n  /** @description Error events that indicate failures requiring attention. */\n  error = \"error\",\n  /** @description Warning events that may indicate issues. */\n  warn = \"warn\",\n  /** @description Informational events describing normal operation. */\n  info = \"info\",\n  /** @description Verbose diagnostic information for detailed tracing. */\n  verbose = \"verbose\",\n  /** @description Debug or trace details aimed at developers. */\n  debug = \"debug\",\n  /** @description trace details aimed at developers */\n  trace = \"trace\",\n  /** @description Extremely chatty or playful log entries. */\n  silly = \"silly\",\n}\n\n/**\n * @description Numeric values associated with log levels.\n * @summary Provides a numeric representation of log levels for comparison and filtering.\n * @typedef {Object} NumericLogLevelsShape\n * @property {number} benchmark - Numeric value for benchmark level (0).\n * @property {number} error - Numeric value for error level (2).\n * @property {number} info - Numeric value for info level (4).\n * @property {number} verbose - Numeric value for verbose level (6).\n * @property {number} debug - Numeric value for debug level (7).\n * @property {number} silly - Numeric value for silly level (9).\n * @memberOf module:Logging\n */\n/**\n * @description Numeric values associated with log levels.\n * @summary Provides a numeric representation of log levels for comparison and filtering.\n * @const NumericLogLevels\n * @type {NumericLogLevelsShape}\n * @memberOf module:Logging\n */\nexport const NumericLogLevels = {\n  benchmark: 0,\n  error: 3,\n  warn: 6,\n  info: 9,\n  verbose: 12,\n  debug: 15,\n  trace: 18,\n  silly: 21,\n};\n\n/**\n * @description Enum for logging output modes.\n * @summary Defines different output formats for log messages.\n * @enum {string}\n * @memberOf module:Logging\n */\nexport enum LoggingMode {\n  /** Raw text format for human readability */\n  RAW = \"raw\",\n  /** JSON format for machine parsing */\n  JSON = \"json\",\n}\n\n/**\n * @description Default theme for styling log output.\n * @summary Defines the default color and style settings for various components of log messages.\n * @typedef {Theme} DefaultTheme\n * @property {Object} class - Styling for class names.\n * @property {number} class.fg - Foreground color code for class names (34).\n * @property {Object} id - Styling for identifiers.\n * @property {number} id.fg - Foreground color code for identifiers (36).\n * @property {Object} stack - Styling for stack traces (empty object).\n * @property {Object} timestamp - Styling for timestamps (empty object).\n * @property {Object} message - Styling for different types of messages.\n * @property {Object} message.error - Styling for error messages.\n * @property {number} message.error.fg - Foreground color code for error messages (31).\n * @property {Object} method - Styling for method names (empty object).\n * @property {Object} logLevel - Styling for different log levels.\n * @property {Object} logLevel.error - Styling for error level logs.\n * @property {number} logLevel.error.fg - Foreground color code for error level logs (31).\n * @property {string[]} logLevel.error.style - Style attributes for error level logs ([\"bold\"]).\n * @property {Object} logLevel.info - Styling for info level logs (empty object).\n * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).\n * @property {Object} logLevel.debug - Styling for debug level logs.\n * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (33).\n * @const DefaultTheme\n * @memberOf module:Logging\n */\nexport const DefaultTheme: Theme = {\n  app: {},\n  separator: {},\n  class: {\n    fg: 34,\n  },\n  id: {\n    fg: 36,\n  },\n  stack: {},\n  timestamp: {},\n  message: {\n    error: {\n      fg: 31,\n    },\n  },\n  method: {},\n  logLevel: {\n    benchmark: {\n      fg: 32,\n      style: [\"bold\"],\n    },\n    error: {\n      fg: 31,\n      style: [\"bold\"],\n    },\n    info: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    verbose: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    debug: {\n      fg: 33,\n      style: [\"bold\"],\n    },\n    trace: {\n      fg: 33,\n      style: [\"bold\"],\n    },\n    silly: {\n      fg: 33,\n      style: [\"bold\"],\n    },\n  },\n};\n\n/**\n * @description Default configuration for logging.\n * @summary Defines the default settings for the logging system, including verbosity, log level, styling, and timestamp format.\n * @const DefaultLoggingConfig\n * @typedef {LoggingConfig} DefaultLoggingConfig\n * @property {number} verbose - Verbosity level (0).\n * @property {LogLevel} level - Default log level (LogLevel.info).\n * @property {boolean} logLevel - Whether to display log level in output (true).\n * @property {LoggingMode} mode - Output format mode (LoggingMode.RAW).\n * @property {boolean} style - Whether to apply styling to log output (false).\n * @property {string} separator - Separator between log components (\" - \").\n * @property {boolean} timestamp - Whether to include timestamps in log messages (true).\n * @property {string} timestampFormat - Format for timestamps (\"HH:mm:ss.SSS\").\n * @property {boolean} context - Whether to include context information in log messages (true).\n * @property {Theme} theme - The theme to use for styling log messages (DefaultTheme).\n * @memberOf module:Logging\n */\nexport const DefaultLoggingConfig: LoggingConfig = {\n  env: \"development\",\n  verbose: 0,\n  level: LogLevel.info,\n  logLevel: true,\n  style: false,\n  contextSeparator: \".\",\n  separator: \"-\",\n  timestamp: true,\n  timestampFormat: \"HH:mm:ss.SSS\",\n  context: true,\n  format: LoggingMode.RAW,\n  pattern:\n    \"{level} [{timestamp}] {app} {context} {separator} {message} {stack}\",\n  theme: DefaultTheme,\n};\n"]}
201
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"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"}
@@ -219,4 +219,4 @@ function final() {
219
219
  return descriptor;
220
220
  };
221
221
  }
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogLevel } from \"./constants\";\nimport { Logging } from \"./logging\";\nimport { now } from \"./time\";\nimport { LoggedClass } from \"./LoggedClass\";\nimport { Logger } from \"./types\";\n\nexport type ArgFormatFunction = (...args: any[]) => string;\nexport type ReturnFormatFunction = (e?: Error, result?: any) => string;\n\n/**\n * @description Method decorator for logging function calls.\n * @summary Wraps class methods to automatically log entry, exit, timing, and optional custom messages at a configurable {@link LogLevel}.\n * @param {LogLevel} level - Log level applied to the generated log statements (defaults to `LogLevel.info`).\n * @param {number} [verbosity=0] - Verbosity threshold required for the entry log to appear.\n * @param {ArgFormatFunction} [entryMessage] - Formatter invoked with the original method arguments to describe the invocation.\n * @param {ReturnFormatFunction} [exitMessage] - Optional formatter that describes the outcome or failure of the call.\n * @return {function(any, any, PropertyDescriptor): void} Method decorator proxy that injects logging behavior.\n * @function log\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as log decorator\n *   participant Method as Original Method\n *   participant Logger as Logging instance\n *\n *   Client->>Decorator: call decorated method\n *   Decorator->>Logger: log method call\n *   Decorator->>Method: call original method\n *   alt result is Promise\n *     Method-->>Decorator: return Promise\n *     Decorator->>Decorator: attach then handler\n *     Note over Decorator: Promise resolves\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   else result is not Promise\n *     Method-->>Decorator: return result\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   end\n * @category Method Decorators\n */\nexport function log(\n  level: LogLevel = LogLevel.info,\n  verbosity = 0,\n  entryMessage: ArgFormatFunction = (...args: any[]) => `called with ${args}`,\n  exitMessage?: ReturnFormatFunction\n) {\n  return function log(target: any, propertyKey?: any, descriptor?: any) {\n    if (!descriptor || typeof descriptor === \"number\")\n      throw new Error(`Logging decoration only applies to methods`);\n    const logger: Logger =\n      target instanceof LoggedClass\n        ? target[\"log\"].for(target[propertyKey as keyof typeof target])\n        : Logging.for(target).for(target[propertyKey]);\n    const method = logger[level].bind(logger) as any;\n    const originalMethod = descriptor.value;\n\n    descriptor.value = new Proxy(originalMethod, {\n      apply(fn, thisArg, args: any[]) {\n        method(entryMessage(...args), verbosity);\n        try {\n          const result = Reflect.apply(fn, thisArg, args);\n          if (result instanceof Promise) {\n            return result\n              .then((r: any) => {\n                if (exitMessage) method(exitMessage(undefined, r));\n                return r;\n              })\n              .catch((e) => {\n                if (exitMessage) logger.error(exitMessage(e as Error));\n                throw e;\n              });\n          }\n          if (exitMessage) method(exitMessage(undefined, result));\n          return result;\n        } catch (err: unknown) {\n          if (exitMessage) logger.error(exitMessage(err as Error));\n          throw err;\n        }\n      },\n    });\n    return descriptor;\n  };\n}\n\n/**\n * @description Method decorator that records execution time at the benchmark level.\n * @summary Wraps the target method to emit {@link Logger.benchmark} entries capturing completion time or failure latency.\n * @return {function(any, any,  PropertyDescriptor): void} Method decorator proxy that benchmarks the original implementation.\n * @function benchmark\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant Decorator as benchmark\n *   participant Method as Original Method\n *   Caller->>Decorator: invoke()\n *   Decorator->>Method: Reflect.apply(...)\n *   alt Promise result\n *     Method-->>Decorator: Promise\n *     Decorator->>Decorator: attach then()\n *     Decorator->>Decorator: log completion duration\n *   else Synchronous result\n *     Method-->>Decorator: value\n *     Decorator->>Decorator: log completion duration\n *   end\n *   Decorator-->>Caller: return result\n * @category Method Decorators\n */\nexport function benchmark() {\n  return function benchmark(target: any, propertyKey?: any, descriptor?: any) {\n    if (!descriptor || typeof descriptor === \"number\")\n      throw new Error(`benchmark decoration only applies to methods`);\n    const logger: Logger =\n      target instanceof LoggedClass\n        ? target[\"log\"].for(target[propertyKey as keyof typeof target])\n        : Logging.for(target).for(target[propertyKey]);\n    const originalMethod = descriptor.value;\n\n    descriptor.value = new Proxy(originalMethod, {\n      apply(fn, thisArg, args: any[]) {\n        const start = now();\n        try {\n          const result = Reflect.apply(fn, thisArg, args);\n          if (result instanceof Promise) {\n            return result\n              .then((r: any) => {\n                logger.benchmark(`completed in ${now() - start}ms`);\n                return r;\n              })\n              .catch((e) => {\n                logger.benchmark(`failed in ${now() - start}ms`);\n                throw e;\n              });\n          }\n          logger.benchmark(`completed in ${now() - start}ms`);\n          return result;\n        } catch (err: unknown) {\n          logger.benchmark(`failed in ${now() - start}ms`);\n          throw err;\n        }\n      },\n    });\n\n    return descriptor;\n  };\n}\n\n/**\n * @description Method decorator for logging function calls with debug level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.debug`.\n * @return {function(any, any, PropertyDescriptor): void} Debug-level logging decorator.\n * @function debug\n * @category Method Decorators\n */\nexport function debug() {\n  return log(\n    LogLevel.debug,\n    0,\n    (...args: any[]) => `called with ${args}`,\n    (e?: Error, result?: any) =>\n      e\n        ? `Failed with: ${e}`\n        : result\n          ? `Completed with ${JSON.stringify(result)}`\n          : \"completed\"\n  );\n}\n\n/**\n * @description Method decorator for logging function calls with info level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.info`.\n * @return {function(any, any, PropertyDescriptor): void} Info-level logging decorator.\n * @function info\n * @category Method Decorators\n */\nexport function info() {\n  return log(LogLevel.info);\n}\n\n/**\n * @description Method decorator for logging function calls with silly level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.silly`.\n * @return {function(any, any, PropertyDescriptor): void} Silly-level logging decorator.\n * @function silly\n * @category Method Decorators\n */\nexport function silly() {\n  return log(LogLevel.silly);\n}\n\n/**\n * @description Method decorator for logging function calls with trace level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.trace`.\n * @return {function(any, any, PropertyDescriptor): void} Trace-level logging decorator.\n * @function trace\n * @category Method Decorators\n */\nexport function trace() {\n  return log(LogLevel.trace);\n}\n\n/**\n * @description Method decorator for logging function calls with verbose level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` with configurable verbosity.\n * @return {function(any, any, PropertyDescriptor): void} Verbose logging decorator.\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(): (\n  target: any,\n  propertyKey?: any,\n  descriptor?: any\n) => void;\n\n/**\n * @description Method decorator for logging function calls with verbose level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` while toggling benchmarking.\n * @return {function(any, PropertyDescriptor): void} Verbose logging decorator.\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(): (\n  target: any,\n  propertyKey?: any,\n  descriptor?: any\n) => void;\n\n/**\n * @description Method decorator for logging function calls with verbose level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` with configurable verbosity and optional benchmarking.\n * @param {number|boolean} verbosity - Verbosity level for log filtering or flag to enable benchmarking.\n * @return {function(any, any,PropertyDescriptor): void} Verbose logging decorator.\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(verbosity: number | boolean = 0) {\n  if (!verbosity) {\n    verbosity = 0;\n  }\n  return log(LogLevel.verbose, verbosity as number);\n}\n\n/**\n * @description Creates a decorator that makes a method non-configurable.\n * @summary Prevents overriding by marking the method descriptor as non-configurable, throwing if applied to non-method targets.\n * @return {function(object, any, PropertyDescriptor): PropertyDescriptor|undefined} Decorator that hardens the method descriptor.\n * @function final\n * @category Method Decorators\n */\nexport function final() {\n  return (target: object, propertyKey?: any, descriptor?: any) => {\n    if (!descriptor)\n      throw new Error(\"final decorator can only be used on methods\");\n    if (descriptor?.configurable) {\n      descriptor.configurable = false;\n    }\n    return descriptor;\n  };\n}\n"]}
222
+ //# sourceMappingURL=decorators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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"}
@@ -398,4 +398,4 @@ exports.LoggedEnvironment = Environment.accumulate(Object.assign({}, constants_1
398
398
  ? globalThis[constants_1.BrowserEnvKey]["NODE_ENV"]
399
399
  : globalThis.process.env["NODE_ENV"]) || "development",
400
400
  }));
401
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"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","sourcesContent":["import { ObjectAccumulator } from \"typed-object-accumulator\";\nimport { toENVFormat } from \"./text\";\nimport { isBrowser } from \"./web\";\nimport {\n  BrowserEnvKey,\n  DefaultLoggingConfig,\n  ENV_PATH_DELIMITER,\n} from \"./constants\";\n\n/**\n * @description Factory type for creating Environment instances.\n * @summary Describes factories that construct {@link Environment} derivatives with custom initialization.\n * @template T - The type of object the Environment will accumulate.\n * @template E - The specific Environment type to be created, extending Environment<T>.\n * @typedef {function(unknown[]): E} EnvironmentFactory\n * @memberOf module:Logging\n */\nexport type EnvironmentFactory<T extends object, E extends Environment<T>> = (\n  ...args: unknown[]\n) => E;\n\nexport type EnvironmentInstance<T extends object> = Environment<T> &\n  T & { orThrow(): EnvironmentInstance<T> };\n\n/**\n * @description Environment accumulator that lazily reads from runtime sources.\n * @summary Extends {@link ObjectAccumulator} to merge configuration objects while resolving values from Node or browser environment variables on demand.\n * @template T\n * @class Environment\n * @example\n * const Config = Environment.accumulate({ logging: { level: \"info\" } });\n * console.log(Config.logging.level);\n * console.log(String(Config.logging.level)); // => LOGGING__LEVEL key when serialized\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Env as Environment\n *   participant Process as process.env\n *   participant Browser as globalThis.ENV\n *   Client->>Env: accumulate(partialConfig)\n *   Env->>Env: expand(values)\n *   Client->>Env: Config.logging.level\n *   alt Browser runtime\n *     Env->>Browser: lookup ENV key\n *     Browser-->>Env: resolved value\n *   else Node runtime\n *     Env->>Process: lookup ENV key\n *     Process-->>Env: resolved value\n *   end\n *   Env-->>Client: merged value\n */\nconst EmptyValue = Symbol(\"EnvironmentEmpty\");\nconst ModelSymbol = Symbol(\"EnvironmentModel\");\n\nexport class Environment<T extends object> extends ObjectAccumulator<T> {\n  /**\n   * @static\n   * @protected\n   * @description A factory function for creating Environment instances.\n   * @summary Defines how new instances of the Environment class should be created.\n   * @return {Environment<any>} A new instance of the Environment class.\n   */\n  protected static factory: EnvironmentFactory<any, any> =\n    (): Environment<any> => new Environment();\n\n  /**\n   * @static\n   * @private\n   * @description The singleton instance of the Environment class.\n   * @type {Environment<any>}\n   */\n  private static _instance: Environment<any>;\n\n  protected constructor() {\n    super();\n    Object.defineProperty(this, ModelSymbol, {\n      value: {},\n      writable: true,\n      enumerable: false,\n      configurable: false,\n    });\n  }\n\n  /**\n   * @description Retrieves a value from the runtime environment.\n   * @summary Handles browser and Node.js environments by normalizing keys and parsing values.\n   * @param {string} k - Key to resolve from the environment.\n   * @return {unknown} Value resolved from the environment or `undefined` when absent.\n   */\n  protected fromEnv(k: string) {\n    let env: Record<string, unknown>;\n    if (isBrowser()) {\n      env =\n        (\n          globalThis as typeof globalThis & {\n            [BrowserEnvKey]: Record<string, any>;\n          }\n        )[BrowserEnvKey] || {};\n    } else {\n      env = globalThis.process.env;\n      k = toENVFormat(k);\n    }\n    return this.parseEnvValue(env[k]);\n  }\n\n  /**\n   * @description Converts stringified environment values into native types.\n   * @summary Interprets booleans and numbers while leaving other types unchanged.\n   * @param {unknown} val - Raw value retrieved from the environment.\n   * @return {unknown} Parsed value converted to boolean, number, or left as-is.\n   */\n  protected parseEnvValue(val: unknown) {\n    if (typeof val !== \"string\") return val;\n    if (val === \"true\") return true;\n    if (val === \"false\") return false;\n    const result = parseFloat(val);\n    if (!isNaN(result)) return result;\n    return val;\n  }\n\n  /**\n   * @description Expands an object into the environment.\n   * @summary Defines lazy properties that first consult runtime variables before falling back to seeded values.\n   * @template V - Type of the object being expanded.\n   * @param {V} value - Object to expose through environment getters and setters.\n   * @return {void}\n   */\n  protected override expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Environment.mergeModel((this as any)[ModelSymbol], k, v);\n      Object.defineProperty(this, k, {\n        get: () => {\n          const fromEnv = this.fromEnv(k);\n          if (typeof fromEnv !== \"undefined\") return fromEnv;\n          if (v && typeof v === \"object\") {\n            return Environment.buildEnvProxy(v as any, [k]);\n          }\n          // If the model provides an empty string, mark with EmptyValue so instance proxy can return undefined without enabling key composition\n          if (v === \"\") {\n            return EmptyValue as unknown as V[keyof V];\n          }\n          return v;\n        },\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @description Returns a proxy enforcing required environment variables.\n   * @summary Accessing a property that resolves to `undefined` or an empty string when declared in the model throws an error.\n   * @return {this} Proxy of the environment enforcing required variables.\n   */\n  orThrow(): EnvironmentInstance<T> {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const base = this;\n    const modelRoot = (base as any)[ModelSymbol] as Record<string, any>;\n    const buildKey = (path: string[]) =>\n      path.map((segment) => toENVFormat(segment)).join(ENV_PATH_DELIMITER);\n    const readRuntime = (key: string) => Environment.readRuntimeEnv(key);\n    const parseRuntime = (raw: unknown) =>\n      typeof raw !== \"undefined\" ? this.parseEnvValue(raw) : undefined;\n\n    const missing = (key: string, empty: boolean = false) =>\n      Environment.missingEnvError(key, empty);\n\n    const createNestedProxy = (model: any, path: string[]): any => {\n      const handler: ProxyHandler<any> = {\n        get(_target, prop) {\n          if (typeof prop !== \"string\") return undefined;\n          const nextPath = [...path, prop];\n          const envKey = buildKey(nextPath);\n          const runtimeRaw = readRuntime(envKey);\n          if (typeof runtimeRaw === \"string\" && runtimeRaw.length === 0)\n            throw missing(envKey, true);\n          const runtimeValue = parseRuntime(runtimeRaw);\n          if (typeof runtimeValue !== \"undefined\") {\n            if (typeof runtimeValue === \"string\" && runtimeValue.length === 0)\n              throw missing(envKey, true);\n            return runtimeValue;\n          }\n\n          const hasProp =\n            model && Object.prototype.hasOwnProperty.call(model, prop);\n          if (!hasProp) throw missing(envKey);\n\n          const modelValue = model[prop];\n          if (typeof modelValue === \"undefined\") return undefined;\n          if (modelValue === \"\") throw missing(envKey);\n\n          if (\n            modelValue &&\n            typeof modelValue === \"object\" &&\n            !Array.isArray(modelValue)\n          ) {\n            return createNestedProxy(modelValue, nextPath);\n          }\n\n          return modelValue;\n        },\n        ownKeys() {\n          return model ? Reflect.ownKeys(model) : [];\n        },\n        getOwnPropertyDescriptor(_target, prop) {\n          if (!model) return undefined;\n          if (Object.prototype.hasOwnProperty.call(model, prop)) {\n            return {\n              enumerable: true,\n              configurable: true,\n            } as PropertyDescriptor;\n          }\n          return undefined;\n        },\n      };\n      return new Proxy({}, handler);\n    };\n\n    const handler: ProxyHandler<any> = {\n      get(target, prop, receiver) {\n        if (typeof prop !== \"string\")\n          return Reflect.get(target, prop, receiver);\n        const hasModelProp = Object.prototype.hasOwnProperty.call(\n          modelRoot,\n          prop\n        );\n        if (!hasModelProp) return Reflect.get(target, prop, receiver);\n\n        const envKey = buildKey([prop]);\n        const runtimeRaw = readRuntime(envKey);\n        if (typeof runtimeRaw === \"string\" && runtimeRaw.length === 0)\n          throw missing(envKey, true);\n        const runtimeValue = parseRuntime(runtimeRaw);\n        if (typeof runtimeValue !== \"undefined\") {\n          if (typeof runtimeValue === \"string\" && runtimeValue.length === 0)\n            throw missing(envKey, true);\n          return runtimeValue;\n        }\n\n        const modelValue = modelRoot[prop];\n        if (\n          modelValue &&\n          typeof modelValue === \"object\" &&\n          !Array.isArray(modelValue)\n        ) {\n          return createNestedProxy(modelValue, [prop]);\n        }\n\n        if (typeof modelValue === \"undefined\")\n          return Reflect.get(target, prop, receiver);\n\n        const actual = Reflect.get(target, prop);\n        if (typeof actual === \"undefined\" || actual === \"\")\n          throw missing(envKey, actual === \"\");\n\n        return actual;\n      },\n    };\n\n    return new Proxy(base, handler) as EnvironmentInstance<T>;\n  }\n\n  /**\n   * @protected\n   * @static\n   * @description Retrieves or creates the singleton instance of the Environment class.\n   * @summary Ensures only one {@link Environment} instance is created, wrapping it in a proxy to compose ENV keys on demand.\n   * @template E\n   * @param {...unknown[]} args - Arguments forwarded to the factory when instantiating the singleton.\n   * @return {E} Singleton environment instance.\n   */\n  protected static instance<E extends Environment<any>>(\n    ...args: unknown[]\n  ): E {\n    if (!Environment._instance) {\n      const base = Environment.factory(...args) as E;\n      const proxied = new Proxy(base as any, {\n        get(target, prop, receiver) {\n          const value = Reflect.get(target, prop, receiver);\n          if (value === EmptyValue) return undefined;\n          // If the property exists on the instance but resolves to undefined, return undefined (no proxy)\n          if (\n            typeof prop === \"string\" &&\n            Object.prototype.hasOwnProperty.call(target, prop)\n          ) {\n            if (typeof value === \"undefined\") return undefined;\n          }\n          if (typeof value !== \"undefined\") return value;\n          if (typeof prop === \"string\") {\n            // Avoid interfering with logging config lookups for optional fields like 'app'\n            if (prop === \"app\") return undefined;\n            return Environment.buildEnvProxy(undefined, [prop]);\n          }\n          return value;\n        },\n      });\n      Environment._instance = proxied as any;\n    }\n    return Environment._instance as E;\n  }\n\n  /**\n   * @static\n   * @description Accumulates the given value into the environment.\n   * @summary Adds new properties, hiding raw descriptors to avoid leaking enumeration semantics.\n   * @template T\n   * @template V\n   * @param {V} value - Object to merge into the environment.\n   * @return {Environment} Updated environment reference.\n   */\n  static accumulate<V extends object, TBase extends object = object>(\n    value: V\n  ): EnvironmentInstance<TBase & V> {\n    const instance = Environment.instance<Environment<TBase & V>>();\n    Object.keys(instance as any).forEach((key) => {\n      const desc = Object.getOwnPropertyDescriptor(instance as any, key);\n      if (desc && desc.configurable && desc.enumerable) {\n        Object.defineProperty(instance as any, key, {\n          ...desc,\n          enumerable: false,\n        });\n      }\n    });\n    return instance.accumulate(value) as unknown as EnvironmentInstance<\n      TBase &\n        V\n    >;\n  }\n\n  /**\n   * @description Retrieves a value using a dot-path key from the accumulated environment.\n   * @summary Delegates to the singleton instance to access stored configuration.\n   * @param {string} key - Key to resolve from the environment store.\n   * @return {unknown} Stored value corresponding to the provided key.\n   */\n  static get(key: string) {\n    return Environment._instance.get(key);\n  }\n\n  /**\n   * @description Builds a proxy that composes environment keys for nested properties.\n   * @summary Allows chained property access to emit uppercase ENV identifiers while honoring existing runtime overrides.\n   * @param {any} current - Seed model segment used when projecting nested structures.\n   * @param {string[]} path - Accumulated path segments leading to the proxy.\n   * @return {any} Proxy that resolves environment values or composes additional proxies for deeper paths.\n   */\n  private static buildEnvProxy(current: any, path: string[]): any {\n    const buildKey = (p: string[]) =>\n      p.map((seg) => toENVFormat(seg)).join(ENV_PATH_DELIMITER);\n\n    // Helper to read from the active environment given a composed key\n    const readEnv = (key: string): unknown => {\n      return Environment.readRuntimeEnv(key);\n    };\n\n    const handler: ProxyHandler<any> = {\n      get(_target, prop: string | symbol) {\n        if (prop === Symbol.toPrimitive) {\n          return () => buildKey(path);\n        }\n        if (prop === \"toString\") {\n          return () => buildKey(path);\n        }\n        if (prop === \"valueOf\") {\n          return () => buildKey(path);\n        }\n        if (typeof prop === \"symbol\") return undefined;\n\n        const hasProp =\n          !!current && Object.prototype.hasOwnProperty.call(current, prop);\n        const nextModel = hasProp ? (current as any)[prop] : undefined;\n        const nextPath = [...path, prop];\n        const composedKey = buildKey(nextPath);\n\n        // If an ENV value exists for this path, return it directly\n        const envValue = readEnv(composedKey);\n        if (typeof envValue !== \"undefined\") return envValue;\n\n        // Otherwise, if the model has an object at this path, keep drilling with a proxy\n        const isNextObject = nextModel && typeof nextModel === \"object\";\n        if (isNextObject) return Environment.buildEnvProxy(nextModel, nextPath);\n\n        // If the model marks this leaf as an empty string, treat as undefined (no proxy)\n        if (hasProp && nextModel === \"\") return undefined;\n        // If the model explicitly contains the property with value undefined, treat as undefined (no proxy)\n        if (hasProp && typeof nextModel === \"undefined\") return undefined;\n\n        // Always return a proxy for further path composition when no ENV value;\n        // do not surface primitive model defaults here (this API is for key composition).\n        return Environment.buildEnvProxy(undefined, nextPath);\n      },\n      ownKeys() {\n        return current ? Reflect.ownKeys(current) : [];\n      },\n      getOwnPropertyDescriptor(_t, p) {\n        if (!current) return undefined as any;\n        if (Object.prototype.hasOwnProperty.call(current, p)) {\n          return { enumerable: true, configurable: true } as PropertyDescriptor;\n        }\n        return undefined as any;\n      },\n    };\n\n    const target = {} as any;\n    return new Proxy(target, handler);\n  }\n\n  /**\n   * @static\n   * @description Retrieves the keys of the environment, optionally converting them to ENV format.\n   * @summary Gets all keys in the environment, with an option to format them for environment variables.\n   * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.\n   * @return {string[]} An array of keys from the environment.\n   */\n  static keys(toEnv: boolean = true): string[] {\n    return Environment.instance()\n      .keys()\n      .map((k) => (toEnv ? toENVFormat(k) : k));\n  }\n\n  private static mergeModel(\n    model: Record<string, any>,\n    key: string,\n    value: any\n  ) {\n    if (!model) return;\n    if (value && typeof value === \"object\" && !Array.isArray(value)) {\n      const existing = model[key];\n      const target =\n        existing && typeof existing === \"object\" && !Array.isArray(existing)\n          ? existing\n          : {};\n      model[key] = target;\n      Object.entries(value).forEach(([childKey, childValue]) => {\n        Environment.mergeModel(target, childKey, childValue);\n      });\n      return;\n    }\n    model[key] = value;\n  }\n\n  private static readRuntimeEnv(key: string): unknown {\n    if (isBrowser()) {\n      const env = (\n        globalThis as typeof globalThis & {\n          [BrowserEnvKey]?: Record<string, unknown>;\n        }\n      )[BrowserEnvKey];\n      return env ? env[key] : undefined;\n    }\n    return (globalThis as any)?.process?.env?.[key];\n  }\n\n  private static missingEnvError(key: string, empty: boolean): Error {\n    const suffix = empty ? \"an empty string\" : \"undefined\";\n    return new Error(\n      `Environment variable ${key} is required but was ${suffix}.`\n    );\n  }\n}\n\n/**\n * @description Singleton environment instance seeded with default logging configuration.\n * @summary Combines {@link DefaultLoggingConfig} with runtime environment variables to provide consistent logging defaults across platforms.\n * @const LoggedEnvironment\n * @memberOf module:Logging\n */\nexport const LoggedEnvironment = Environment.accumulate(\n  Object.assign({}, DefaultLoggingConfig, {\n    env:\n      (isBrowser() && (globalThis as any)[BrowserEnvKey]\n        ? (globalThis as any)[BrowserEnvKey][\"NODE_ENV\"]\n        : (globalThis as any).process.env[\"NODE_ENV\"]) || \"development\",\n  })\n);\n"]}
401
+ //# sourceMappingURL=environment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"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"}
@@ -40,4 +40,4 @@ export class LoggedClass {
40
40
  }
41
41
  constructor() { }
42
42
  }
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9nZ2VkQ2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvTG9nZ2VkQ2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxxQkFBa0I7QUFHcEM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTJCRztBQUNILE1BQU0sT0FBZ0IsV0FBVztJQUcvQjs7OztPQUlHO0lBQ0gsSUFBYyxHQUFHO1FBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO1lBQUUsSUFBSSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQVcsQ0FBQyxDQUFDO1FBQ3JELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0lBRUQsZ0JBQXlCLENBQUM7Q0FDM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2dnaW5nIH0gZnJvbSBcIi4vbG9nZ2luZ1wiO1xuaW1wb3J0IHsgTG9nZ2VyIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gQmFzZSBjbGFzcyB0aGF0IHByb3ZpZGVzIGEgcmVhZHktdG8tdXNlIGxvZ2dlciBpbnN0YW5jZS5cbiAqIEBzdW1tYXJ5IFN1cHBsaWVzIGluaGVyaXRpbmcgY2xhc3NlcyB3aXRoIGEgbGF6aWx5IGNyZWF0ZWQsIGNvbnRleHQtYXdhcmUge0BsaW5rIExvZ2dlcn0gdmlhIHRoZSBwcm90ZWN0ZWQgYGxvZ2AgZ2V0dGVyLCBwcm9tb3RpbmcgY29uc2lzdGVudCBzdHJ1Y3R1cmVkIGxvZ2dpbmcgd2l0aG91dCBtYW51YWwgd2lyaW5nLlxuICogQGNsYXNzIExvZ2dlZENsYXNzXG4gKiBAZXhhbXBsZVxuICogY2xhc3MgVXNlclNlcnZpY2UgZXh0ZW5kcyBMb2dnZWRDbGFzcyB7XG4gKiAgIGNyZWF0ZSh1c2VyOiBVc2VyKSB7XG4gKiAgICAgdGhpcy5sb2cuaW5mbyhgQ3JlYXRpbmcgdXNlciAke3VzZXIuaWR9YCk7XG4gKiAgIH1cbiAqIH1cbiAqXG4gKiBjb25zdCBzdmMgPSBuZXcgVXNlclNlcnZpY2UoKTtcbiAqIHN2Yy5jcmVhdGUoeyBpZDogXCI0MlwiIH0pO1xuICogQG1lcm1haWRcbiAqIHNlcXVlbmNlRGlhZ3JhbVxuICogICBwYXJ0aWNpcGFudCBDbGllbnRcbiAqICAgcGFydGljaXBhbnQgSW5zdGFuY2UgYXMgU3ViY2xhc3MgSW5zdGFuY2VcbiAqICAgcGFydGljaXBhbnQgR2V0dGVyIGFzIExvZ2dlZENsYXNzLmxvZ1xuICogICBwYXJ0aWNpcGFudCBMb2dnaW5nIGFzIExvZ2dpbmdcbiAqICAgcGFydGljaXBhbnQgTG9nZ2VyIGFzIExvZ2dlclxuICpcbiAqICAgQ2xpZW50LT4+SW5zdGFuY2U6IGNhbGwgc29tZU1ldGhvZCgpXG4gKiAgIEluc3RhbmNlLT4+R2V0dGVyOiBhY2Nlc3MgdGhpcy5sb2dcbiAqICAgR2V0dGVyLT4+TG9nZ2luZzogTG9nZ2luZy5mb3IodGhpcylcbiAqICAgTG9nZ2luZy0tPj5HZXR0ZXI6IHJldHVybiBMb2dnZXJcbiAqICAgR2V0dGVyLS0+Pkluc3RhbmNlOiByZXR1cm4gTG9nZ2VyXG4gKiAgIEluc3RhbmNlLT4+TG9nZ2VyOiBpbmZvL2RlYnVnL2Vycm9yKC4uLilcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIExvZ2dlZENsYXNzIHtcbiAgcHJpdmF0ZSBfbG9nPzogTG9nZ2VyO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gTGF6aWx5IHByb3ZpZGVzIGEgY29udGV4dC1hd2FyZSBsb2dnZXIgZm9yIHRoZSBjdXJyZW50IGluc3RhbmNlLlxuICAgKiBAc3VtbWFyeSBDYWxscyB7QGxpbmsgTG9nZ2luZy5mb3J9IHdpdGggdGhlIHN1YmNsYXNzIGluc3RhbmNlIHRvIG9idGFpbiBhIGxvZ2dlciB3aG9zZSBjb250ZXh0IG1hdGNoZXMgdGhlIHN1YmNsYXNzIG5hbWUuXG4gICAqIEByZXR1cm4ge0xvZ2dlcn0gTG9nZ2VyIGJvdW5kIHRvIHRoZSBzdWJjbGFzcyBjb250ZXh0LlxuICAgKi9cbiAgcHJvdGVjdGVkIGdldCBsb2coKTogTG9nZ2VyIHtcbiAgICBpZiAoIXRoaXMuX2xvZykgdGhpcy5fbG9nID0gTG9nZ2luZy5mb3IodGhpcyBhcyBhbnkpO1xuICAgIHJldHVybiB0aGlzLl9sb2c7XG4gIH1cblxuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IoKSB7fVxufVxuIl19
43
+ //# sourceMappingURL=LoggedClass.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LoggedClass.js","sourceRoot":"","sources":["../../src/LoggedClass.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,qBAAkB;AAGpC;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,MAAM,OAAgB,WAAW;IAG/B;;;;OAIG;IACH,IAAc,GAAG;QACf,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,IAAW,CAAC,CAAC;QACrD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,gBAAyB,CAAC;CAC3B"}
@@ -195,4 +195,4 @@ export const DefaultLoggingConfig = {
195
195
  pattern: "{level} [{timestamp}] {app} {context} {separator} {message} {stack}",
196
196
  theme: DefaultTheme,
197
197
  };
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { LoggingConfig, Theme } from \"./types\";\n\n/**\n * @description Global key used to store environment variables in browser contexts.\n * @summary Enables the logging environment helpers to locate serialized environment configuration on `globalThis`.\n * @const BrowserEnvKey\n * @type {string}\n * @memberOf module:Logging\n */\nexport const BrowserEnvKey = \"ENV\";\n\n/**\n * @description Delimiter used for composing nested environment variable names.\n * @summary Joins parent and child keys when mapping object paths to ENV strings.\n * @const ENV_PATH_DELIMITER\n * @type {string}\n * @memberOf module:Logging\n */\nexport const ENV_PATH_DELIMITER = \"__\";\n\n/**\n * @description Default prefix and suffix used for template placeholders.\n * @summary Provides wrapper strings applied when interpolating messages with {@link patchPlaceholders}.\n * @const DefaultPlaceholderWrappers\n * @type {string[]}\n * @memberOf module:Logging\n */\nexport const DefaultPlaceholderWrappers = [\"${\", \"}\"];\n\n/**\n * @description Enum for log levels.\n * @summary Defines different levels of logging for the application.\n * @enum {string}\n * @readonly\n * @memberOf module:Logging\n */\nexport enum LogLevel {\n  /** @description Benchmark events that capture performance metrics. */\n  benchmark = \"benchmark\",\n  /** @description Error events that indicate failures requiring attention. */\n  error = \"error\",\n  /** @description Warning events that may indicate issues. */\n  warn = \"warn\",\n  /** @description Informational events describing normal operation. */\n  info = \"info\",\n  /** @description Verbose diagnostic information for detailed tracing. */\n  verbose = \"verbose\",\n  /** @description Debug or trace details aimed at developers. */\n  debug = \"debug\",\n  /** @description trace details aimed at developers */\n  trace = \"trace\",\n  /** @description Extremely chatty or playful log entries. */\n  silly = \"silly\",\n}\n\n/**\n * @description Numeric values associated with log levels.\n * @summary Provides a numeric representation of log levels for comparison and filtering.\n * @typedef {Object} NumericLogLevelsShape\n * @property {number} benchmark - Numeric value for benchmark level (0).\n * @property {number} error - Numeric value for error level (2).\n * @property {number} info - Numeric value for info level (4).\n * @property {number} verbose - Numeric value for verbose level (6).\n * @property {number} debug - Numeric value for debug level (7).\n * @property {number} silly - Numeric value for silly level (9).\n * @memberOf module:Logging\n */\n/**\n * @description Numeric values associated with log levels.\n * @summary Provides a numeric representation of log levels for comparison and filtering.\n * @const NumericLogLevels\n * @type {NumericLogLevelsShape}\n * @memberOf module:Logging\n */\nexport const NumericLogLevels = {\n  benchmark: 0,\n  error: 3,\n  warn: 6,\n  info: 9,\n  verbose: 12,\n  debug: 15,\n  trace: 18,\n  silly: 21,\n};\n\n/**\n * @description Enum for logging output modes.\n * @summary Defines different output formats for log messages.\n * @enum {string}\n * @memberOf module:Logging\n */\nexport enum LoggingMode {\n  /** Raw text format for human readability */\n  RAW = \"raw\",\n  /** JSON format for machine parsing */\n  JSON = \"json\",\n}\n\n/**\n * @description Default theme for styling log output.\n * @summary Defines the default color and style settings for various components of log messages.\n * @typedef {Theme} DefaultTheme\n * @property {Object} class - Styling for class names.\n * @property {number} class.fg - Foreground color code for class names (34).\n * @property {Object} id - Styling for identifiers.\n * @property {number} id.fg - Foreground color code for identifiers (36).\n * @property {Object} stack - Styling for stack traces (empty object).\n * @property {Object} timestamp - Styling for timestamps (empty object).\n * @property {Object} message - Styling for different types of messages.\n * @property {Object} message.error - Styling for error messages.\n * @property {number} message.error.fg - Foreground color code for error messages (31).\n * @property {Object} method - Styling for method names (empty object).\n * @property {Object} logLevel - Styling for different log levels.\n * @property {Object} logLevel.error - Styling for error level logs.\n * @property {number} logLevel.error.fg - Foreground color code for error level logs (31).\n * @property {string[]} logLevel.error.style - Style attributes for error level logs ([\"bold\"]).\n * @property {Object} logLevel.info - Styling for info level logs (empty object).\n * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).\n * @property {Object} logLevel.debug - Styling for debug level logs.\n * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (33).\n * @const DefaultTheme\n * @memberOf module:Logging\n */\nexport const DefaultTheme: Theme = {\n  app: {},\n  separator: {},\n  class: {\n    fg: 34,\n  },\n  id: {\n    fg: 36,\n  },\n  stack: {},\n  timestamp: {},\n  message: {\n    error: {\n      fg: 31,\n    },\n  },\n  method: {},\n  logLevel: {\n    benchmark: {\n      fg: 32,\n      style: [\"bold\"],\n    },\n    error: {\n      fg: 31,\n      style: [\"bold\"],\n    },\n    info: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    verbose: {\n      fg: 34,\n      style: [\"bold\"],\n    },\n    debug: {\n      fg: 33,\n      style: [\"bold\"],\n    },\n    trace: {\n      fg: 33,\n      style: [\"bold\"],\n    },\n    silly: {\n      fg: 33,\n      style: [\"bold\"],\n    },\n  },\n};\n\n/**\n * @description Default configuration for logging.\n * @summary Defines the default settings for the logging system, including verbosity, log level, styling, and timestamp format.\n * @const DefaultLoggingConfig\n * @typedef {LoggingConfig} DefaultLoggingConfig\n * @property {number} verbose - Verbosity level (0).\n * @property {LogLevel} level - Default log level (LogLevel.info).\n * @property {boolean} logLevel - Whether to display log level in output (true).\n * @property {LoggingMode} mode - Output format mode (LoggingMode.RAW).\n * @property {boolean} style - Whether to apply styling to log output (false).\n * @property {string} separator - Separator between log components (\" - \").\n * @property {boolean} timestamp - Whether to include timestamps in log messages (true).\n * @property {string} timestampFormat - Format for timestamps (\"HH:mm:ss.SSS\").\n * @property {boolean} context - Whether to include context information in log messages (true).\n * @property {Theme} theme - The theme to use for styling log messages (DefaultTheme).\n * @memberOf module:Logging\n */\nexport const DefaultLoggingConfig: LoggingConfig = {\n  env: \"development\",\n  verbose: 0,\n  level: LogLevel.info,\n  logLevel: true,\n  style: false,\n  contextSeparator: \".\",\n  separator: \"-\",\n  timestamp: true,\n  timestampFormat: \"HH:mm:ss.SSS\",\n  context: true,\n  format: LoggingMode.RAW,\n  pattern:\n    \"{level} [{timestamp}] {app} {context} {separator} {message} {stack}\",\n  theme: DefaultTheme,\n};\n"]}
198
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"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"}
@@ -209,4 +209,4 @@ export function final() {
209
209
  return descriptor;
210
210
  };
211
211
  }
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogLevel } from \"./constants\";\nimport { Logging } from \"./logging\";\nimport { now } from \"./time\";\nimport { LoggedClass } from \"./LoggedClass\";\nimport { Logger } from \"./types\";\n\nexport type ArgFormatFunction = (...args: any[]) => string;\nexport type ReturnFormatFunction = (e?: Error, result?: any) => string;\n\n/**\n * @description Method decorator for logging function calls.\n * @summary Wraps class methods to automatically log entry, exit, timing, and optional custom messages at a configurable {@link LogLevel}.\n * @param {LogLevel} level - Log level applied to the generated log statements (defaults to `LogLevel.info`).\n * @param {number} [verbosity=0] - Verbosity threshold required for the entry log to appear.\n * @param {ArgFormatFunction} [entryMessage] - Formatter invoked with the original method arguments to describe the invocation.\n * @param {ReturnFormatFunction} [exitMessage] - Optional formatter that describes the outcome or failure of the call.\n * @return {function(any, any, PropertyDescriptor): void} Method decorator proxy that injects logging behavior.\n * @function log\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as log decorator\n *   participant Method as Original Method\n *   participant Logger as Logging instance\n *\n *   Client->>Decorator: call decorated method\n *   Decorator->>Logger: log method call\n *   Decorator->>Method: call original method\n *   alt result is Promise\n *     Method-->>Decorator: return Promise\n *     Decorator->>Decorator: attach then handler\n *     Note over Decorator: Promise resolves\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   else result is not Promise\n *     Method-->>Decorator: return result\n *     Decorator->>Logger: log benchmark (if enabled)\n *     Decorator-->>Client: return result\n *   end\n * @category Method Decorators\n */\nexport function log(\n  level: LogLevel = LogLevel.info,\n  verbosity = 0,\n  entryMessage: ArgFormatFunction = (...args: any[]) => `called with ${args}`,\n  exitMessage?: ReturnFormatFunction\n) {\n  return function log(target: any, propertyKey?: any, descriptor?: any) {\n    if (!descriptor || typeof descriptor === \"number\")\n      throw new Error(`Logging decoration only applies to methods`);\n    const logger: Logger =\n      target instanceof LoggedClass\n        ? target[\"log\"].for(target[propertyKey as keyof typeof target])\n        : Logging.for(target).for(target[propertyKey]);\n    const method = logger[level].bind(logger) as any;\n    const originalMethod = descriptor.value;\n\n    descriptor.value = new Proxy(originalMethod, {\n      apply(fn, thisArg, args: any[]) {\n        method(entryMessage(...args), verbosity);\n        try {\n          const result = Reflect.apply(fn, thisArg, args);\n          if (result instanceof Promise) {\n            return result\n              .then((r: any) => {\n                if (exitMessage) method(exitMessage(undefined, r));\n                return r;\n              })\n              .catch((e) => {\n                if (exitMessage) logger.error(exitMessage(e as Error));\n                throw e;\n              });\n          }\n          if (exitMessage) method(exitMessage(undefined, result));\n          return result;\n        } catch (err: unknown) {\n          if (exitMessage) logger.error(exitMessage(err as Error));\n          throw err;\n        }\n      },\n    });\n    return descriptor;\n  };\n}\n\n/**\n * @description Method decorator that records execution time at the benchmark level.\n * @summary Wraps the target method to emit {@link Logger.benchmark} entries capturing completion time or failure latency.\n * @return {function(any, any,  PropertyDescriptor): void} Method decorator proxy that benchmarks the original implementation.\n * @function benchmark\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant Decorator as benchmark\n *   participant Method as Original Method\n *   Caller->>Decorator: invoke()\n *   Decorator->>Method: Reflect.apply(...)\n *   alt Promise result\n *     Method-->>Decorator: Promise\n *     Decorator->>Decorator: attach then()\n *     Decorator->>Decorator: log completion duration\n *   else Synchronous result\n *     Method-->>Decorator: value\n *     Decorator->>Decorator: log completion duration\n *   end\n *   Decorator-->>Caller: return result\n * @category Method Decorators\n */\nexport function benchmark() {\n  return function benchmark(target: any, propertyKey?: any, descriptor?: any) {\n    if (!descriptor || typeof descriptor === \"number\")\n      throw new Error(`benchmark decoration only applies to methods`);\n    const logger: Logger =\n      target instanceof LoggedClass\n        ? target[\"log\"].for(target[propertyKey as keyof typeof target])\n        : Logging.for(target).for(target[propertyKey]);\n    const originalMethod = descriptor.value;\n\n    descriptor.value = new Proxy(originalMethod, {\n      apply(fn, thisArg, args: any[]) {\n        const start = now();\n        try {\n          const result = Reflect.apply(fn, thisArg, args);\n          if (result instanceof Promise) {\n            return result\n              .then((r: any) => {\n                logger.benchmark(`completed in ${now() - start}ms`);\n                return r;\n              })\n              .catch((e) => {\n                logger.benchmark(`failed in ${now() - start}ms`);\n                throw e;\n              });\n          }\n          logger.benchmark(`completed in ${now() - start}ms`);\n          return result;\n        } catch (err: unknown) {\n          logger.benchmark(`failed in ${now() - start}ms`);\n          throw err;\n        }\n      },\n    });\n\n    return descriptor;\n  };\n}\n\n/**\n * @description Method decorator for logging function calls with debug level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.debug`.\n * @return {function(any, any, PropertyDescriptor): void} Debug-level logging decorator.\n * @function debug\n * @category Method Decorators\n */\nexport function debug() {\n  return log(\n    LogLevel.debug,\n    0,\n    (...args: any[]) => `called with ${args}`,\n    (e?: Error, result?: any) =>\n      e\n        ? `Failed with: ${e}`\n        : result\n          ? `Completed with ${JSON.stringify(result)}`\n          : \"completed\"\n  );\n}\n\n/**\n * @description Method decorator for logging function calls with info level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.info`.\n * @return {function(any, any, PropertyDescriptor): void} Info-level logging decorator.\n * @function info\n * @category Method Decorators\n */\nexport function info() {\n  return log(LogLevel.info);\n}\n\n/**\n * @description Method decorator for logging function calls with silly level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.silly`.\n * @return {function(any, any, PropertyDescriptor): void} Silly-level logging decorator.\n * @function silly\n * @category Method Decorators\n */\nexport function silly() {\n  return log(LogLevel.silly);\n}\n\n/**\n * @description Method decorator for logging function calls with trace level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.trace`.\n * @return {function(any, any, PropertyDescriptor): void} Trace-level logging decorator.\n * @function trace\n * @category Method Decorators\n */\nexport function trace() {\n  return log(LogLevel.trace);\n}\n\n/**\n * @description Method decorator for logging function calls with verbose level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` with configurable verbosity.\n * @return {function(any, any, PropertyDescriptor): void} Verbose logging decorator.\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(): (\n  target: any,\n  propertyKey?: any,\n  descriptor?: any\n) => void;\n\n/**\n * @description Method decorator for logging function calls with verbose level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` while toggling benchmarking.\n * @return {function(any, PropertyDescriptor): void} Verbose logging decorator.\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(): (\n  target: any,\n  propertyKey?: any,\n  descriptor?: any\n) => void;\n\n/**\n * @description Method decorator for logging function calls with verbose level.\n * @summary Convenience wrapper around {@link log} that logs using `LogLevel.verbose` with configurable verbosity and optional benchmarking.\n * @param {number|boolean} verbosity - Verbosity level for log filtering or flag to enable benchmarking.\n * @return {function(any, any,PropertyDescriptor): void} Verbose logging decorator.\n * @function verbose\n * @category Method Decorators\n */\nexport function verbose(verbosity: number | boolean = 0) {\n  if (!verbosity) {\n    verbosity = 0;\n  }\n  return log(LogLevel.verbose, verbosity as number);\n}\n\n/**\n * @description Creates a decorator that makes a method non-configurable.\n * @summary Prevents overriding by marking the method descriptor as non-configurable, throwing if applied to non-method targets.\n * @return {function(object, any, PropertyDescriptor): PropertyDescriptor|undefined} Decorator that hardens the method descriptor.\n * @function final\n * @category Method Decorators\n */\nexport function final() {\n  return (target: object, propertyKey?: any, descriptor?: any) => {\n    if (!descriptor)\n      throw new Error(\"final decorator can only be used on methods\");\n    if (descriptor?.configurable) {\n      descriptor.configurable = false;\n    }\n    return descriptor;\n  };\n}\n"]}
212
+ //# sourceMappingURL=decorators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/decorators.ts"],"names":[],"mappings":"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"}