@kumori/kdsl 0.0.51 → 0.0.52

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.
@@ -15,6 +15,14 @@ builtin HTTPInbound {
15
15
 
16
16
  config {
17
17
  type "https"
18
+ websocket?: bool = false
19
+ remoteaddressheader?: string = ""
20
+ cleanxforwardedfor?: bool = false
21
+
22
+ accesspolicies?: kumori.AccessPolicies
23
+
24
+ requestHeaders?: kumori.StringMap = {}
25
+ responseHeaders?: kumori.StringMap = {}
18
26
  }
19
27
 
20
28
  resource {
@@ -8,4 +8,11 @@ alias Links struct {
8
8
 
9
9
  alias Channel "udp" | "tcp" | "http" | "grpc"
10
10
  alias Client Channel
11
- alias Server Channel | struct { protocol Channel, port number }
11
+ alias Server Channel | struct { protocol Channel, port number }
12
+
13
+ alias AccessPolicies struct {
14
+ allowediplist?: []string
15
+ deniediplist?: []string
16
+ }
17
+
18
+ alias StringMap struct open[string]
@@ -15,6 +15,14 @@ builtin HTTPInbound {
15
15
 
16
16
  config {
17
17
  type "https"
18
+ websocket?: bool = false
19
+ remoteaddressheader?: string = ""
20
+ cleanxforwardedfor?: bool = false
21
+
22
+ accesspolicies?: kumori.AccessPolicies
23
+
24
+ requestHeaders?: kumori.StringMap = {}
25
+ responseHeaders?: kumori.StringMap = {}
18
26
  }
19
27
 
20
28
  resource {
@@ -8,4 +8,11 @@ alias Links struct {
8
8
 
9
9
  alias Channel "udp" | "tcp" | "http" | "grpc"
10
10
  alias Client Channel
11
- alias Server Channel | struct { protocol Channel, port number }
11
+ alias Server Channel | struct { protocol Channel, port number }
12
+
13
+ alias AccessPolicies struct {
14
+ allowediplist?: []string
15
+ deniediplist?: []string
16
+ }
17
+
18
+ alias StringMap struct open[string]
package/out/main.cjs CHANGED
@@ -761,7 +761,7 @@ Use "kdsl help -a" for a list of available topics.
761
761
  `.trim(),Tq=new Map,pi=(t,e)=>Tq.set(t,e),Kut=async(t,e,r)=>{if(e.all)return Obe();if(!t.length){r.outputHelp();return}let i=t.join(" "),n=Tq.get(i);if(!n)return console.error(`unknown topic '${i}'
762
762
  `),Obe();await n()},Obe=()=>{console.log(`Available topics:
763
763
  `),console.log(Array.from(Tq.keys()).sort().map(t=>" "+t).join(`
764
- `))};pi(...m3e);pi(...g3e);pi(...y3e);pi(...S3e);pi(...I3e);pi(...hbe);pi(...bbe);pi(..._be);pi(...wbe);pi(...xbe);pi(...Sbe);pi(...$be);pi(...kbe);pi(...Ebe);pi(...Tbe);pi(...Pbe);pi(...Rbe);pi(...Cbe);pi(...Abe);pi(...Ibe);var Dbe={name:"@kumori/kdsl",version:"0.0.51",private:!1,files:["bin","out","dist"],type:"module",description:"Kumori DSL command line interface and library",bin:{kdsl:"bin/cli.js"},main:"./out/lib/index.cjs",module:"./dist/lib/index.js",types:"./dist/lib/index.d.ts",exports:{".":{import:"./dist/lib/index.js",require:"./out/lib/index.cjs",types:"./dist/lib/index.d.ts"},"./build":{import:"./dist/lib/build.js",require:"./out/lib/build.cjs",types:"./dist/lib/build.d.ts"},"./deployment":{import:"./dist/lib/deployment.js",require:"./out/lib/deployment.cjs",types:"./dist/lib/deployment.d.ts"},"./check":{import:"./dist/lib/check.js",require:"./out/lib/check.cjs",types:"./dist/lib/check.d.ts"},"./clean":{import:"./dist/lib/clean.js",require:"./out/lib/clean.cjs",types:"./dist/lib/clean.d.ts"},"./mod":{import:"./dist/lib/mod.js",require:"./out/lib/mod.cjs",types:"./dist/lib/mod.d.ts"},"./registry":{import:"./dist/lib/registry.js",require:"./out/lib/registry.cjs",types:"./dist/lib/registry.d.ts"},"./index-cmd":{import:"./dist/lib/index-cmd.js",require:"./out/lib/index-cmd.cjs",types:"./dist/lib/index-cmd.d.ts"}},scripts:{build:"npm run fix && npm run build:types && npm run build:cli && npm run copy-loader","build:types":"tsc -b tsconfig.json","build:cli":"node esbuild.mjs --minify","build:lib":"node esbuild.mjs --minify --target=cjs && node esbuild.mjs --minify --target=esm","copy-loader":"mkdir -p out/lib dist/lib && rsync -av --include='*/' --include='*.kumori' --exclude='*' src/ out/ && rsync -av --include='*/' --include='*.kumori' --exclude='*' src/ dist/ && rsync -av --include='*/' --include='*.kumori' --exclude='*' ../lsp/dist/language/builtin/lib/ out/lib/ && rsync -av --include='*/' --include='*.kumori' --exclude='*' ../lsp/dist/language/builtin/lib/ dist/lib/ && bash -c 'shopt -s globstar && cp src/**/*.kumori out/'",test:"vitest run",clean:"rm -rf dist/ out/ tsconfig.tsbuildinfo",prepublishOnly:"npm run build",lint:"eslint .",prettier:"prettier src/ test/ --write",fix:"npm run lint && npm run prettier"},dependencies:{"@commander-js/extra-typings":"^14.0.0","@inquirer/prompts":"^8.0.2","@kumori/kdsl-lsp":"0.0.1-alpha.23",ajv:"^8.17.1",chalk:"~5.6.2",commander:"~14.0.2",zod:"^4.1.13"},license:"EUPL",keywords:["cli","tool","automation","kumori","dsl"],gitHead:"89bea74c68de5f90f37ccc0e64b340408c90b76d",devDependencies:{"@eslint/js":"^9.39.1",eslint:"^9.39.1",globals:"^16.5.0",jiti:"^2.6.1",prettier:"3.7.3","typescript-eslint":"^8.48.0"}};var Jut="<unknown>",Lbe,Xut=(Lbe=Dbe.version)!=null?Lbe:Jut,Mbe=Xut;var nt=(function(t){return t.info="info",t.warn="warn",t.error="error",t.debug="debug",t.trace="trace",t.fatal="fatal",t})({}),jd={[nt.trace]:10,[nt.debug]:20,[nt.info]:30,[nt.warn]:40,[nt.error]:50,[nt.fatal]:60},Yut={10:nt.trace,20:nt.debug,30:nt.info,40:nt.warn,50:nt.error,60:nt.fatal};var Eo=(function(t){return t.transformLogLevel="transformLogLevel",t.onBeforeDataOut="onBeforeDataOut",t.shouldSendToLogger="shouldSendToLogger",t.onMetadataCalled="onMetadataCalled",t.onBeforeMessageOut="onBeforeMessageOut",t.onContextCalled="onContextCalled",t})({});var jbe=class Fbe{constructor(){It(this,"context",{});It(this,"hasContext",!1)}setContext(e){if(!e){this.context={},this.hasContext=!1;return}this.context=e,this.hasContext=!0}appendContext(e){this.context=T(T({},this.context),e),this.hasContext=!0}getContext(){return this.context}hasContextData(){return this.hasContext}onChildLoggerCreated({parentContextManager:e,childContextManager:r}){if(e.hasContextData()){let i=e.getContext();r.setContext(T({},i))}}clone(){let e=new Fbe;return e.setContext(T({},this.context)),e.hasContext=this.hasContext,e}};var Ube=class Pq{constructor(){It(this,"logLevelEnabledStatus",{info:!0,warn:!0,error:!0,debug:!0,trace:!0,fatal:!0})}setLevel(e){let r=jd[e];for(let i of Object.values(nt)){let n=i,o=jd[i];this.logLevelEnabledStatus[n]=o>=r}}enableIndividualLevel(e){let r=e;r in this.logLevelEnabledStatus&&(this.logLevelEnabledStatus[r]=!0)}disableIndividualLevel(e){let r=e;r in this.logLevelEnabledStatus&&(this.logLevelEnabledStatus[r]=!1)}isLevelEnabled(e){let r=e;return this.logLevelEnabledStatus[r]}enableLogging(){for(let e of Object.keys(this.logLevelEnabledStatus))this.logLevelEnabledStatus[e]=!0}disableLogging(){for(let e of Object.keys(this.logLevelEnabledStatus))this.logLevelEnabledStatus[e]=!1}onChildLoggerCreated({parentLogLevelManager:e,childLogLevelManager:r}){let i=e.logLevelEnabledStatus;r instanceof Pq&&(r.logLevelEnabledStatus=T({},i))}clone(){let e=new Pq;return e.logLevelEnabledStatus=T({},this.logLevelEnabledStatus),e}};var Rq=class{constructor(t){It(this,"id");It(this,"logger");It(this,"enabled");It(this,"consoleDebug");It(this,"level");var e,r,i,n;this.id=(e=t.id)!=null?e:Date.now().toString()+Math.random().toString(),this.logger=t.logger,this.enabled=(r=t.enabled)!=null?r:!0,this.consoleDebug=(i=t.consoleDebug)!=null?i:!1,this.level=(n=t.level)!=null?n:"trace"}_sendToLogger(t){if(!this.enabled||jd[t.logLevel]<jd[this.level])return;let e=this.shipToLogger(t);if(this.consoleDebug)switch(t.logLevel){case nt.info:console.info(...e);break;case nt.warn:console.warn(...e);break;case nt.error:console.error(...e);break;case nt.trace:console.debug(...e);break;case nt.debug:console.debug(...e);break;case nt.fatal:console.debug(...e);break;default:console.log(...e)}}getLoggerInstance(){return this.logger}};var Qut=[Eo.onBeforeDataOut,Eo.onMetadataCalled,Eo.onBeforeMessageOut,Eo.transformLogLevel,Eo.shouldSendToLogger,Eo.onContextCalled],zbe=class{constructor(t){It(this,"idToPlugin");It(this,"transformLogLevel",[]);It(this,"onBeforeDataOut",[]);It(this,"shouldSendToLogger",[]);It(this,"onMetadataCalled",[]);It(this,"onBeforeMessageOut",[]);It(this,"onContextCalled",[]);this.idToPlugin={},this.mapPlugins(t),this.indexPlugins()}mapPlugins(t){for(let e of t){if(e.id||(e.id=Date.now().toString()+Math.random().toString()),this.idToPlugin[e.id])throw new Error(`[LogLayer] Plugin with id ${e.id} already exists.`);e.registeredAt=Date.now(),this.idToPlugin[e.id]=e}}indexPlugins(){this.transformLogLevel=[],this.onBeforeDataOut=[],this.shouldSendToLogger=[],this.onMetadataCalled=[],this.onBeforeMessageOut=[],this.onContextCalled=[];let t=Object.values(this.idToPlugin).sort((e,r)=>e.registeredAt-r.registeredAt);for(let e of t){if(e.disabled)return;for(let r of Qut)e[r]&&e.id&&this[r].push(e.id)}}hasPlugins(t){return this[t].length>0}countPlugins(t){return t?this[t].length:Object.keys(this.idToPlugin).length}addPlugins(t){this.mapPlugins(t),this.indexPlugins()}enablePlugin(t){let e=this.idToPlugin[t];e&&(e.disabled=!1),this.indexPlugins()}disablePlugin(t){let e=this.idToPlugin[t];e&&(e.disabled=!0),this.indexPlugins()}removePlugin(t){delete this.idToPlugin[t],this.indexPlugins()}runTransformLogLevel(t,e){let r=null;for(let i of this.transformLogLevel){let n=this.idToPlugin[i];if(n.transformLogLevel){let o=n.transformLogLevel({data:t.data,logLevel:t.logLevel,messages:t.messages,error:t.error,metadata:t.metadata,context:t.context},e);o!=null&&o!==!1&&(r=o)}}return r!=null&&r!==!1?r:t.logLevel}runOnBeforeDataOut(t,e){let r=T({},t);for(let i of this.onBeforeDataOut){let n=this.idToPlugin[i];if(n.onBeforeDataOut){let o=n.onBeforeDataOut({data:r.data,logLevel:r.logLevel,error:r.error,metadata:r.metadata,context:r.context},e);o&&(r.data||(r.data={}),Object.assign(r.data,o))}}return r.data}runShouldSendToLogger(t,e){return!this.shouldSendToLogger.some(r=>{var i,n;return!((n=(i=this.idToPlugin[r]).shouldSendToLogger)!=null&&n.call(i,t,e))})}runOnMetadataCalled(t,e){var i,n;let r=T({},t);for(let o of this.onMetadataCalled){let a=(n=(i=this.idToPlugin[o]).onMetadataCalled)==null?void 0:n.call(i,r,e);if(a)r=a;else return null}return r}runOnBeforeMessageOut(t,e){var i,n;let r=[...t.messages];for(let o of this.onBeforeMessageOut){let a=(n=(i=this.idToPlugin[o]).onBeforeMessageOut)==null?void 0:n.call(i,{messages:r,logLevel:t.logLevel},e);a&&(r=a)}return r}runOnContextCalled(t,e){var i,n;let r=T({},t);for(let o of this.onContextCalled){let a=(n=(i=this.idToPlugin[o]).onContextCalled)==null?void 0:n.call(i,r,e);if(a)r=a;else return null}return r}},Bbe=class Vbe{constructor(e){It(this,"pluginManager");It(this,"idToTransport");It(this,"hasMultipleTransports");It(this,"singleTransport");It(this,"contextManager");It(this,"logLevelManager");It(this,"_config");var r;this._config=J(T({},e),{enabled:(r=e.enabled)!=null?r:!0}),this.contextManager=new jbe,this.logLevelManager=new Ube,this._config.enabled||this.disableLogging(),this.pluginManager=new zbe([...e.plugins||[],...eb.pluginsToInit]),this._config.errorFieldName||(this._config.errorFieldName="err"),this._config.copyMsgOnOnlyError||(this._config.copyMsgOnOnlyError=!1),this._initializeTransports(this._config.transport),eb.logLayerHandlers.length>0&&eb.logLayerHandlers.forEach(i=>{i.onConstruct&&i.onConstruct(this,e)})}withContextManager(e){return this.contextManager&&typeof this.contextManager[Symbol.dispose]=="function"&&this.contextManager[Symbol.dispose](),this.contextManager=e,this}getContextManager(){return this.contextManager}withLogLevelManager(e){return this.logLevelManager&&typeof this.logLevelManager[Symbol.dispose]=="function"&&this.logLevelManager[Symbol.dispose](),this.logLevelManager=e,this}getLogLevelManager(){return this.logLevelManager}getConfig(){return this._config}_initializeTransports(e){if(this.idToTransport)for(let r in this.idToTransport)this.idToTransport[r]&&typeof this.idToTransport[r][Symbol.dispose]=="function"&&this.idToTransport[r][Symbol.dispose]();this.hasMultipleTransports=Array.isArray(e)&&e.length>1,this.singleTransport=this.hasMultipleTransports?null:Array.isArray(e)?e[0]:e,Array.isArray(e)?this.idToTransport=e.reduce((r,i)=>(r[i.id]=i,r),{}):this.idToTransport={[e.id]:e}}withPrefix(e){let r=this.child();return r._config.prefix=e,r}withContext(e){let r=e;return e?this.pluginManager.hasPlugins(Eo.onContextCalled)&&(r=this.pluginManager.runOnContextCalled(e,this),!r)?(this._config.consoleDebug&&console.debug("[LogLayer] Context was dropped due to plugin returning falsy value."),this):(this.contextManager.appendContext(r),this):(this._config.consoleDebug&&console.debug("[LogLayer] withContext was called with no context; dropping."),this)}clearContext(){return this.contextManager.setContext(void 0),this}getContext(){return this.contextManager.getContext()}addPlugins(e){this.pluginManager.addPlugins(e)}enablePlugin(e){this.pluginManager.enablePlugin(e)}disablePlugin(e){this.pluginManager.disablePlugin(e)}removePlugin(e){this.pluginManager.removePlugin(e)}withMetadata(e){return new qbe(this).withMetadata(e)}withError(e){return new qbe(this).withError(e)}child(){let e=new Vbe(J(T({},this._config),{transport:Array.isArray(this._config.transport)?[...this._config.transport]:this._config.transport})).withPluginManager(this.pluginManager).withContextManager(this.contextManager.clone()).withLogLevelManager(this.logLevelManager.clone());return this.contextManager.onChildLoggerCreated({parentContextManager:this.contextManager,childContextManager:e.contextManager,parentLogger:this,childLogger:e}),this.logLevelManager.onChildLoggerCreated({parentLogLevelManager:this.logLevelManager,childLogLevelManager:e.logLevelManager,parentLogger:this,childLogger:e}),e}withFreshTransports(e){return this._config.transport=e,this._initializeTransports(e),this}withFreshPlugins(e){return this._config.plugins=e,this.pluginManager=new zbe(e),this}withPluginManager(e){return this.pluginManager=e,this}errorOnly(e,r){let i=(r==null?void 0:r.logLevel)||nt.error;if(!this.isLevelEnabled(i))return;let{copyMsgOnOnlyError:n}=this._config,o={logLevel:i,err:e};(n&&(r==null?void 0:r.copyMsg)!==!1||(r==null?void 0:r.copyMsg)===!0)&&(e!=null&&e.message)&&(o.params=[e.message]),this._formatLog(o)}metadataOnly(e,r=nt.info){if(!this.isLevelEnabled(r))return;let{muteMetadata:i,consoleDebug:n}=this._config;if(i)return;if(!e){n&&console.debug("[LogLayer] metadataOnly was called with no metadata; dropping.");return}let o=e;if(this.pluginManager.hasPlugins(Eo.onMetadataCalled)&&(o=this.pluginManager.runOnMetadataCalled(e,this),!o)){n&&console.debug("[LogLayer] Metadata was dropped due to plugin returning falsy value.");return}let a={logLevel:r,metadata:o};this._formatLog(a)}info(...e){this.isLevelEnabled(nt.info)&&(this._formatMessage(e),this._formatLog({logLevel:nt.info,params:e}))}warn(...e){this.isLevelEnabled(nt.warn)&&(this._formatMessage(e),this._formatLog({logLevel:nt.warn,params:e}))}error(...e){this.isLevelEnabled(nt.error)&&(this._formatMessage(e),this._formatLog({logLevel:nt.error,params:e}))}debug(...e){this.isLevelEnabled(nt.debug)&&(this._formatMessage(e),this._formatLog({logLevel:nt.debug,params:e}))}trace(...e){this.isLevelEnabled(nt.trace)&&(this._formatMessage(e),this._formatLog({logLevel:nt.trace,params:e}))}fatal(...e){this.isLevelEnabled(nt.fatal)&&(this._formatMessage(e),this._formatLog({logLevel:nt.fatal,params:e}))}raw(e){if(!this.isLevelEnabled(e.logLevel))return;let r={logLevel:e.logLevel,params:e.messages,metadata:e.metadata,err:e.error,context:e.context};this._formatMessage(e.messages),this._formatLog(r)}disableLogging(){return this.logLevelManager.disableLogging(),this}enableLogging(){return this.logLevelManager.enableLogging(),this}muteContext(){return this._config.muteContext=!0,this}unMuteContext(){return this._config.muteContext=!1,this}muteMetadata(){return this._config.muteMetadata=!0,this}unMuteMetadata(){return this._config.muteMetadata=!1,this}enableIndividualLevel(e){return this.logLevelManager.enableIndividualLevel(e),this}disableIndividualLevel(e){return this.logLevelManager.disableIndividualLevel(e),this}setLevel(e){return this.logLevelManager.setLevel(e),this}isLevelEnabled(e){return this.logLevelManager.isLevelEnabled(e)}formatContext(e){let{contextFieldName:r,muteContext:i}=this._config;return e&&Object.keys(e).length>0&&!i?r?{[r]:T({},e)}:T({},e):{}}formatMetadata(e=null){let{metadataFieldName:r,muteMetadata:i}=this._config;return e&&!i?r?{[r]:T({},e)}:T({},e):{}}getLoggerInstance(e){let r=this.idToTransport[e];if(r)return r.getLoggerInstance()}_formatMessage(e=[]){let{prefix:r}=this._config;r&&typeof e[0]=="string"&&(e[0]=`${r} ${e[0]}`)}_formatLog({logLevel:e,params:r=[],metadata:i=null,err:n,context:o=null}){var m;let{errorSerializer:a,errorFieldInMetadata:s,muteContext:u,contextFieldName:c,metadataFieldName:l,errorFieldName:f}=this._config,d=o!==null?o:this.contextManager.getContext(),p=!!i||(u?!1:o!==null?Object.keys(o).length>0:this.contextManager.hasContextData()),h={};if(p)if(c&&c===l){let g=this.formatContext(d)[c],b=this.formatMetadata(i)[l];h={[c]:T(T({},g),b)}}else h=T(T({},this.formatContext(d)),this.formatMetadata(i));if(n){let g=a?a(n):n;s&&i&&l?h!=null&&h[l]?h[l][f]=g:h=J(T({},h),{[l]:{[f]:g}}):s&&!i&&l?h=J(T({},h),{[l]:{[f]:g}}):h=J(T({},h),{[f]:g}),p=!0}if(this.pluginManager.hasPlugins(Eo.onBeforeDataOut)&&(h=this.pluginManager.runOnBeforeDataOut({data:p?h:void 0,logLevel:e,error:n,metadata:i,context:d},this),h&&!p&&(p=!0)),this.pluginManager.hasPlugins(Eo.onBeforeMessageOut)&&(r=this.pluginManager.runOnBeforeMessageOut({messages:[...r],logLevel:e},this)),this.pluginManager.hasPlugins(Eo.transformLogLevel)&&(e=this.pluginManager.runTransformLogLevel({data:p?h:void 0,logLevel:e,messages:[...r],error:n,metadata:i,context:d},this)),this.hasMultipleTransports){let g=this._config.transport.filter(b=>b.enabled).map(async b=>{let v=e;if(!(this.pluginManager.hasPlugins(Eo.shouldSendToLogger)&&!this.pluginManager.runShouldSendToLogger({messages:[...r],data:p?h:void 0,logLevel:v,transportId:b.id,error:n,metadata:i,context:d},this)))return b._sendToLogger({logLevel:v,messages:[...r],data:p?h:void 0,hasData:p,error:n,metadata:i,context:d})});Promise.all(g).catch(b=>{this._config.consoleDebug&&console.error("[LogLayer] Error executing transports:",b)})}else{if(!((m=this.singleTransport)!=null&&m.enabled)||this.pluginManager.hasPlugins(Eo.shouldSendToLogger)&&!this.pluginManager.runShouldSendToLogger({messages:[...r],data:p?h:void 0,logLevel:e,transportId:this.singleTransport.id,error:n,metadata:i,context:d},this))return;this.singleTransport._sendToLogger({logLevel:e,messages:[...r],data:p?h:void 0,hasData:p,error:n,metadata:i,context:d})}}};var eb={logLayerHandlers:[],pluginsToInit:[],logBuilderHandlers:[]};var qbe=class{constructor(t){It(this,"err");It(this,"metadata");It(this,"structuredLogger");It(this,"hasMetadata");It(this,"pluginManager");this.err=null,this.metadata={},this.structuredLogger=t,this.hasMetadata=!1,this.pluginManager=t.pluginManager,eb.logBuilderHandlers.length>0&&eb.logBuilderHandlers.forEach(e=>{e.onConstruct&&e.onConstruct(this,t)})}withMetadata(t){let{pluginManager:e,structuredLogger:{_config:{consoleDebug:r}}}=this;if(!t)return r&&console.debug("[LogLayer] withMetadata was called with no metadata; dropping."),this;let i=t;return e.hasPlugins(Eo.onMetadataCalled)&&(i=e.runOnMetadataCalled(t,this.structuredLogger),!i)?(r&&console.debug("[LogLayer] Metadata was dropped due to plugin returning falsy value."),this):(this.metadata=T(T({},this.metadata),i),this.hasMetadata=!0,this)}withError(t){return this.err=t,this}info(...t){this.structuredLogger.isLevelEnabled(nt.info)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.info,t))}warn(...t){this.structuredLogger.isLevelEnabled(nt.warn)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.warn,t))}error(...t){this.structuredLogger.isLevelEnabled(nt.error)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.error,t))}debug(...t){this.structuredLogger.isLevelEnabled(nt.debug)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.debug,t))}trace(...t){this.structuredLogger.isLevelEnabled(nt.trace)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.trace,t))}fatal(...t){this.structuredLogger.isLevelEnabled(nt.fatal)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.fatal,t))}disableLogging(){return this.structuredLogger.disableLogging(),this}enableLogging(){return this.structuredLogger.enableLogging(),this}formatLog(t,e){let{muteMetadata:r}=this.structuredLogger._config,i=r?!1:this.hasMetadata;this.structuredLogger._formatLog({logLevel:t,params:e,metadata:i?this.metadata:null,err:this.err})}};var Wbe=class extends Rq{constructor(t){super(t),t.stackDepthLevel!==void 0?this.logger.stackDepthLevel=t.stackDepthLevel:this.logger.stackDepthLevel=9}shipToLogger({logLevel:t,messages:e,data:r,hasData:i}){switch(r&&i&&e.push(r),t){case nt.info:this.logger.info(...e);break;case nt.warn:this.logger.warn(...e);break;case nt.error:this.logger.error(...e);break;case nt.trace:this.logger.trace(...e);break;case nt.debug:this.logger.debug(...e);break;case nt.fatal:this.logger.fatal(...e);break}return e}};function Gbe(t){return{href:t.href,protocol:t.protocol,username:t.username,password:t.password,host:t.host,hostname:t.hostname,port:t.port,pathname:t.pathname,search:t.search,searchParams:[...t.searchParams].map(([e,r])=>({key:e,value:r})),hash:t.hash,origin:t.origin}}var tb={reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29],black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39],bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]};function rb(t,e,r,i=!1){let n=String(e),o=(u,c)=>`\x1B[${c[0]}m${u}\x1B[${c[1]}m`,a=(u,c)=>c!=null&&typeof c=="string"?o(u,tb[c]):c!=null&&Array.isArray(c)?c.reduce((l,f)=>a(l,f),u):c!=null&&c[u.trim()]!=null?a(u,c[u.trim()]):c!=null&&c["*"]!=null?a(u,c["*"]):u,s=null;return n.replace(/{{(.+?)}}/g,(u,c)=>{var f,d;let l=r[c]!=null?String(r[c]):i?"":u;return t.stylePrettyLogs?a(l,(d=(f=t==null?void 0:t.prettyLogStyles)==null?void 0:f[c])!=null?d:s)+o("",tb.reset):l})}function ys(t,e=2,r=0){return t!=null&&isNaN(t)?"":(t=t!=null?t+r:t,e===2?t==null?"--":t<10?"0"+t:t.toString():t==null?"---":t<10?"00"+t:t<100?"0"+t:t.toString())}function Cq(t,e){var s,u,c,l,f,d,p,h,m,g,b,v,y,w,x,R,S,O,E,M,P,N,k,C,L,F,B;if(e==null)return{text:"",template:t.prettyLogTemplate,placeholders:{}};let r=t.prettyLogTemplate,i={};r.includes("{{yyyy}}.{{mm}}.{{dd}} {{hh}}:{{MM}}:{{ss}}:{{ms}}")?r=r.replace("{{yyyy}}.{{mm}}.{{dd}} {{hh}}:{{MM}}:{{ss}}:{{ms}}","{{dateIsoStr}}"):t.prettyLogTimeZone==="UTC"?(i.yyyy=(u=(s=e.date)==null?void 0:s.getUTCFullYear())!=null?u:"----",i.mm=ys((c=e.date)==null?void 0:c.getUTCMonth(),2,1),i.dd=ys((l=e.date)==null?void 0:l.getUTCDate(),2),i.hh=ys((f=e.date)==null?void 0:f.getUTCHours(),2),i.MM=ys((d=e.date)==null?void 0:d.getUTCMinutes(),2),i.ss=ys((p=e.date)==null?void 0:p.getUTCSeconds(),2),i.ms=ys((h=e.date)==null?void 0:h.getUTCMilliseconds(),3)):(i.yyyy=(g=(m=e.date)==null?void 0:m.getFullYear())!=null?g:"----",i.mm=ys((b=e.date)==null?void 0:b.getMonth(),2,1),i.dd=ys((v=e.date)==null?void 0:v.getDate(),2),i.hh=ys((y=e.date)==null?void 0:y.getHours(),2),i.MM=ys((w=e.date)==null?void 0:w.getMinutes(),2),i.ss=ys((x=e.date)==null?void 0:x.getSeconds(),2),i.ms=ys((R=e.date)==null?void 0:R.getMilliseconds(),3));let n=t.prettyLogTimeZone==="UTC"?e.date:e.date!=null?new Date(e.date.getTime()-e.date.getTimezoneOffset()*6e4):void 0;i.rawIsoStr=(S=n==null?void 0:n.toISOString())!=null?S:"",i.dateIsoStr=(O=n==null?void 0:n.toISOString().replace("T"," ").replace("Z",""))!=null?O:"",i.logLevelName=e.logLevelName,i.fileNameWithLine=(M=(E=e.path)==null?void 0:E.fileNameWithLine)!=null?M:"",i.filePathWithLine=(N=(P=e.path)==null?void 0:P.filePathWithLine)!=null?N:"",i.fullFilePath=(C=(k=e.path)==null?void 0:k.fullFilePath)!=null?C:"";let o=(L=t.parentNames)==null?void 0:L.join(t.prettyErrorParentNamesSeparator);o=o!=null&&e.name!=null?o+t.prettyErrorParentNamesSeparator:void 0;let a=e.name!=null||o!=null?`${o!=null?o:""}${(F=e.name)!=null?F:""}`:"";return i.name=a,i.nameWithDelimiterPrefix=a.length>0?t.prettyErrorLoggerNameDelimiter+a:"",i.nameWithDelimiterSuffix=a.length>0?a+t.prettyErrorLoggerNameDelimiter:"",((B=t.overwrite)==null?void 0:B.addPlaceholders)!=null&&t.overwrite.addPlaceholders(e,i),{text:rb(t,r,i),template:r,placeholders:i}}var Hbe=[/(?:^|[\\/])node_modules[\\/].*tslog/i,/(?:^|[\\/])deps[\\/].*tslog/i,/tslog[\\/]+src[\\/]+internal[\\/]/i,/tslog[\\/]+src[\\/]BaseLogger/i,/tslog[\\/]+src[\\/]index/i];function elt(t){let e=typeof(t==null?void 0:t.stack)=="string"?t.stack:void 0;return e==null||e.length===0?[]:e.split(`
764
+ `))};pi(...m3e);pi(...g3e);pi(...y3e);pi(...S3e);pi(...I3e);pi(...hbe);pi(...bbe);pi(..._be);pi(...wbe);pi(...xbe);pi(...Sbe);pi(...$be);pi(...kbe);pi(...Ebe);pi(...Tbe);pi(...Pbe);pi(...Rbe);pi(...Cbe);pi(...Abe);pi(...Ibe);var Dbe={name:"@kumori/kdsl",version:"0.0.52",private:!1,files:["bin","out","dist"],type:"module",description:"Kumori DSL command line interface and library",bin:{kdsl:"bin/cli.js"},main:"./out/lib/index.cjs",module:"./dist/lib/index.js",types:"./dist/lib/index.d.ts",exports:{".":{import:"./dist/lib/index.js",require:"./out/lib/index.cjs",types:"./dist/lib/index.d.ts"},"./build":{import:"./dist/lib/build.js",require:"./out/lib/build.cjs",types:"./dist/lib/build.d.ts"},"./deployment":{import:"./dist/lib/deployment.js",require:"./out/lib/deployment.cjs",types:"./dist/lib/deployment.d.ts"},"./check":{import:"./dist/lib/check.js",require:"./out/lib/check.cjs",types:"./dist/lib/check.d.ts"},"./clean":{import:"./dist/lib/clean.js",require:"./out/lib/clean.cjs",types:"./dist/lib/clean.d.ts"},"./mod":{import:"./dist/lib/mod.js",require:"./out/lib/mod.cjs",types:"./dist/lib/mod.d.ts"},"./registry":{import:"./dist/lib/registry.js",require:"./out/lib/registry.cjs",types:"./dist/lib/registry.d.ts"},"./index-cmd":{import:"./dist/lib/index-cmd.js",require:"./out/lib/index-cmd.cjs",types:"./dist/lib/index-cmd.d.ts"}},scripts:{build:"npm run fix && npm run build:types && npm run build:cli && npm run copy-loader","build:types":"tsc -b tsconfig.json","build:cli":"node esbuild.mjs --minify","build:lib":"node esbuild.mjs --minify --target=cjs && node esbuild.mjs --minify --target=esm","copy-loader":"mkdir -p out/lib dist/lib && rsync -av --include='*/' --include='*.kumori' --exclude='*' src/ out/ && rsync -av --include='*/' --include='*.kumori' --exclude='*' src/ dist/ && rsync -av --include='*/' --include='*.kumori' --exclude='*' ../lsp/dist/language/builtin/lib/ out/lib/ && rsync -av --include='*/' --include='*.kumori' --exclude='*' ../lsp/dist/language/builtin/lib/ dist/lib/ && bash -c 'shopt -s globstar && cp src/**/*.kumori out/'",test:"vitest run",clean:"rm -rf dist/ out/ tsconfig.tsbuildinfo",prepublishOnly:"npm run build",lint:"eslint .",prettier:"prettier src/ test/ --write",fix:"npm run lint && npm run prettier"},dependencies:{"@commander-js/extra-typings":"^14.0.0","@inquirer/prompts":"^8.0.2","@kumori/kdsl-lsp":"0.0.1-alpha.24",ajv:"^8.17.1",chalk:"~5.6.2",commander:"~14.0.2",zod:"^4.1.13"},license:"EUPL",keywords:["cli","tool","automation","kumori","dsl"],gitHead:"89bea74c68de5f90f37ccc0e64b340408c90b76d",devDependencies:{"@eslint/js":"^9.39.1",eslint:"^9.39.1",globals:"^16.5.0",jiti:"^2.6.1",prettier:"3.7.3","typescript-eslint":"^8.48.0"}};var Jut="<unknown>",Lbe,Xut=(Lbe=Dbe.version)!=null?Lbe:Jut,Mbe=Xut;var nt=(function(t){return t.info="info",t.warn="warn",t.error="error",t.debug="debug",t.trace="trace",t.fatal="fatal",t})({}),jd={[nt.trace]:10,[nt.debug]:20,[nt.info]:30,[nt.warn]:40,[nt.error]:50,[nt.fatal]:60},Yut={10:nt.trace,20:nt.debug,30:nt.info,40:nt.warn,50:nt.error,60:nt.fatal};var Eo=(function(t){return t.transformLogLevel="transformLogLevel",t.onBeforeDataOut="onBeforeDataOut",t.shouldSendToLogger="shouldSendToLogger",t.onMetadataCalled="onMetadataCalled",t.onBeforeMessageOut="onBeforeMessageOut",t.onContextCalled="onContextCalled",t})({});var jbe=class Fbe{constructor(){It(this,"context",{});It(this,"hasContext",!1)}setContext(e){if(!e){this.context={},this.hasContext=!1;return}this.context=e,this.hasContext=!0}appendContext(e){this.context=T(T({},this.context),e),this.hasContext=!0}getContext(){return this.context}hasContextData(){return this.hasContext}onChildLoggerCreated({parentContextManager:e,childContextManager:r}){if(e.hasContextData()){let i=e.getContext();r.setContext(T({},i))}}clone(){let e=new Fbe;return e.setContext(T({},this.context)),e.hasContext=this.hasContext,e}};var Ube=class Pq{constructor(){It(this,"logLevelEnabledStatus",{info:!0,warn:!0,error:!0,debug:!0,trace:!0,fatal:!0})}setLevel(e){let r=jd[e];for(let i of Object.values(nt)){let n=i,o=jd[i];this.logLevelEnabledStatus[n]=o>=r}}enableIndividualLevel(e){let r=e;r in this.logLevelEnabledStatus&&(this.logLevelEnabledStatus[r]=!0)}disableIndividualLevel(e){let r=e;r in this.logLevelEnabledStatus&&(this.logLevelEnabledStatus[r]=!1)}isLevelEnabled(e){let r=e;return this.logLevelEnabledStatus[r]}enableLogging(){for(let e of Object.keys(this.logLevelEnabledStatus))this.logLevelEnabledStatus[e]=!0}disableLogging(){for(let e of Object.keys(this.logLevelEnabledStatus))this.logLevelEnabledStatus[e]=!1}onChildLoggerCreated({parentLogLevelManager:e,childLogLevelManager:r}){let i=e.logLevelEnabledStatus;r instanceof Pq&&(r.logLevelEnabledStatus=T({},i))}clone(){let e=new Pq;return e.logLevelEnabledStatus=T({},this.logLevelEnabledStatus),e}};var Rq=class{constructor(t){It(this,"id");It(this,"logger");It(this,"enabled");It(this,"consoleDebug");It(this,"level");var e,r,i,n;this.id=(e=t.id)!=null?e:Date.now().toString()+Math.random().toString(),this.logger=t.logger,this.enabled=(r=t.enabled)!=null?r:!0,this.consoleDebug=(i=t.consoleDebug)!=null?i:!1,this.level=(n=t.level)!=null?n:"trace"}_sendToLogger(t){if(!this.enabled||jd[t.logLevel]<jd[this.level])return;let e=this.shipToLogger(t);if(this.consoleDebug)switch(t.logLevel){case nt.info:console.info(...e);break;case nt.warn:console.warn(...e);break;case nt.error:console.error(...e);break;case nt.trace:console.debug(...e);break;case nt.debug:console.debug(...e);break;case nt.fatal:console.debug(...e);break;default:console.log(...e)}}getLoggerInstance(){return this.logger}};var Qut=[Eo.onBeforeDataOut,Eo.onMetadataCalled,Eo.onBeforeMessageOut,Eo.transformLogLevel,Eo.shouldSendToLogger,Eo.onContextCalled],zbe=class{constructor(t){It(this,"idToPlugin");It(this,"transformLogLevel",[]);It(this,"onBeforeDataOut",[]);It(this,"shouldSendToLogger",[]);It(this,"onMetadataCalled",[]);It(this,"onBeforeMessageOut",[]);It(this,"onContextCalled",[]);this.idToPlugin={},this.mapPlugins(t),this.indexPlugins()}mapPlugins(t){for(let e of t){if(e.id||(e.id=Date.now().toString()+Math.random().toString()),this.idToPlugin[e.id])throw new Error(`[LogLayer] Plugin with id ${e.id} already exists.`);e.registeredAt=Date.now(),this.idToPlugin[e.id]=e}}indexPlugins(){this.transformLogLevel=[],this.onBeforeDataOut=[],this.shouldSendToLogger=[],this.onMetadataCalled=[],this.onBeforeMessageOut=[],this.onContextCalled=[];let t=Object.values(this.idToPlugin).sort((e,r)=>e.registeredAt-r.registeredAt);for(let e of t){if(e.disabled)return;for(let r of Qut)e[r]&&e.id&&this[r].push(e.id)}}hasPlugins(t){return this[t].length>0}countPlugins(t){return t?this[t].length:Object.keys(this.idToPlugin).length}addPlugins(t){this.mapPlugins(t),this.indexPlugins()}enablePlugin(t){let e=this.idToPlugin[t];e&&(e.disabled=!1),this.indexPlugins()}disablePlugin(t){let e=this.idToPlugin[t];e&&(e.disabled=!0),this.indexPlugins()}removePlugin(t){delete this.idToPlugin[t],this.indexPlugins()}runTransformLogLevel(t,e){let r=null;for(let i of this.transformLogLevel){let n=this.idToPlugin[i];if(n.transformLogLevel){let o=n.transformLogLevel({data:t.data,logLevel:t.logLevel,messages:t.messages,error:t.error,metadata:t.metadata,context:t.context},e);o!=null&&o!==!1&&(r=o)}}return r!=null&&r!==!1?r:t.logLevel}runOnBeforeDataOut(t,e){let r=T({},t);for(let i of this.onBeforeDataOut){let n=this.idToPlugin[i];if(n.onBeforeDataOut){let o=n.onBeforeDataOut({data:r.data,logLevel:r.logLevel,error:r.error,metadata:r.metadata,context:r.context},e);o&&(r.data||(r.data={}),Object.assign(r.data,o))}}return r.data}runShouldSendToLogger(t,e){return!this.shouldSendToLogger.some(r=>{var i,n;return!((n=(i=this.idToPlugin[r]).shouldSendToLogger)!=null&&n.call(i,t,e))})}runOnMetadataCalled(t,e){var i,n;let r=T({},t);for(let o of this.onMetadataCalled){let a=(n=(i=this.idToPlugin[o]).onMetadataCalled)==null?void 0:n.call(i,r,e);if(a)r=a;else return null}return r}runOnBeforeMessageOut(t,e){var i,n;let r=[...t.messages];for(let o of this.onBeforeMessageOut){let a=(n=(i=this.idToPlugin[o]).onBeforeMessageOut)==null?void 0:n.call(i,{messages:r,logLevel:t.logLevel},e);a&&(r=a)}return r}runOnContextCalled(t,e){var i,n;let r=T({},t);for(let o of this.onContextCalled){let a=(n=(i=this.idToPlugin[o]).onContextCalled)==null?void 0:n.call(i,r,e);if(a)r=a;else return null}return r}},Bbe=class Vbe{constructor(e){It(this,"pluginManager");It(this,"idToTransport");It(this,"hasMultipleTransports");It(this,"singleTransport");It(this,"contextManager");It(this,"logLevelManager");It(this,"_config");var r;this._config=J(T({},e),{enabled:(r=e.enabled)!=null?r:!0}),this.contextManager=new jbe,this.logLevelManager=new Ube,this._config.enabled||this.disableLogging(),this.pluginManager=new zbe([...e.plugins||[],...eb.pluginsToInit]),this._config.errorFieldName||(this._config.errorFieldName="err"),this._config.copyMsgOnOnlyError||(this._config.copyMsgOnOnlyError=!1),this._initializeTransports(this._config.transport),eb.logLayerHandlers.length>0&&eb.logLayerHandlers.forEach(i=>{i.onConstruct&&i.onConstruct(this,e)})}withContextManager(e){return this.contextManager&&typeof this.contextManager[Symbol.dispose]=="function"&&this.contextManager[Symbol.dispose](),this.contextManager=e,this}getContextManager(){return this.contextManager}withLogLevelManager(e){return this.logLevelManager&&typeof this.logLevelManager[Symbol.dispose]=="function"&&this.logLevelManager[Symbol.dispose](),this.logLevelManager=e,this}getLogLevelManager(){return this.logLevelManager}getConfig(){return this._config}_initializeTransports(e){if(this.idToTransport)for(let r in this.idToTransport)this.idToTransport[r]&&typeof this.idToTransport[r][Symbol.dispose]=="function"&&this.idToTransport[r][Symbol.dispose]();this.hasMultipleTransports=Array.isArray(e)&&e.length>1,this.singleTransport=this.hasMultipleTransports?null:Array.isArray(e)?e[0]:e,Array.isArray(e)?this.idToTransport=e.reduce((r,i)=>(r[i.id]=i,r),{}):this.idToTransport={[e.id]:e}}withPrefix(e){let r=this.child();return r._config.prefix=e,r}withContext(e){let r=e;return e?this.pluginManager.hasPlugins(Eo.onContextCalled)&&(r=this.pluginManager.runOnContextCalled(e,this),!r)?(this._config.consoleDebug&&console.debug("[LogLayer] Context was dropped due to plugin returning falsy value."),this):(this.contextManager.appendContext(r),this):(this._config.consoleDebug&&console.debug("[LogLayer] withContext was called with no context; dropping."),this)}clearContext(){return this.contextManager.setContext(void 0),this}getContext(){return this.contextManager.getContext()}addPlugins(e){this.pluginManager.addPlugins(e)}enablePlugin(e){this.pluginManager.enablePlugin(e)}disablePlugin(e){this.pluginManager.disablePlugin(e)}removePlugin(e){this.pluginManager.removePlugin(e)}withMetadata(e){return new qbe(this).withMetadata(e)}withError(e){return new qbe(this).withError(e)}child(){let e=new Vbe(J(T({},this._config),{transport:Array.isArray(this._config.transport)?[...this._config.transport]:this._config.transport})).withPluginManager(this.pluginManager).withContextManager(this.contextManager.clone()).withLogLevelManager(this.logLevelManager.clone());return this.contextManager.onChildLoggerCreated({parentContextManager:this.contextManager,childContextManager:e.contextManager,parentLogger:this,childLogger:e}),this.logLevelManager.onChildLoggerCreated({parentLogLevelManager:this.logLevelManager,childLogLevelManager:e.logLevelManager,parentLogger:this,childLogger:e}),e}withFreshTransports(e){return this._config.transport=e,this._initializeTransports(e),this}withFreshPlugins(e){return this._config.plugins=e,this.pluginManager=new zbe(e),this}withPluginManager(e){return this.pluginManager=e,this}errorOnly(e,r){let i=(r==null?void 0:r.logLevel)||nt.error;if(!this.isLevelEnabled(i))return;let{copyMsgOnOnlyError:n}=this._config,o={logLevel:i,err:e};(n&&(r==null?void 0:r.copyMsg)!==!1||(r==null?void 0:r.copyMsg)===!0)&&(e!=null&&e.message)&&(o.params=[e.message]),this._formatLog(o)}metadataOnly(e,r=nt.info){if(!this.isLevelEnabled(r))return;let{muteMetadata:i,consoleDebug:n}=this._config;if(i)return;if(!e){n&&console.debug("[LogLayer] metadataOnly was called with no metadata; dropping.");return}let o=e;if(this.pluginManager.hasPlugins(Eo.onMetadataCalled)&&(o=this.pluginManager.runOnMetadataCalled(e,this),!o)){n&&console.debug("[LogLayer] Metadata was dropped due to plugin returning falsy value.");return}let a={logLevel:r,metadata:o};this._formatLog(a)}info(...e){this.isLevelEnabled(nt.info)&&(this._formatMessage(e),this._formatLog({logLevel:nt.info,params:e}))}warn(...e){this.isLevelEnabled(nt.warn)&&(this._formatMessage(e),this._formatLog({logLevel:nt.warn,params:e}))}error(...e){this.isLevelEnabled(nt.error)&&(this._formatMessage(e),this._formatLog({logLevel:nt.error,params:e}))}debug(...e){this.isLevelEnabled(nt.debug)&&(this._formatMessage(e),this._formatLog({logLevel:nt.debug,params:e}))}trace(...e){this.isLevelEnabled(nt.trace)&&(this._formatMessage(e),this._formatLog({logLevel:nt.trace,params:e}))}fatal(...e){this.isLevelEnabled(nt.fatal)&&(this._formatMessage(e),this._formatLog({logLevel:nt.fatal,params:e}))}raw(e){if(!this.isLevelEnabled(e.logLevel))return;let r={logLevel:e.logLevel,params:e.messages,metadata:e.metadata,err:e.error,context:e.context};this._formatMessage(e.messages),this._formatLog(r)}disableLogging(){return this.logLevelManager.disableLogging(),this}enableLogging(){return this.logLevelManager.enableLogging(),this}muteContext(){return this._config.muteContext=!0,this}unMuteContext(){return this._config.muteContext=!1,this}muteMetadata(){return this._config.muteMetadata=!0,this}unMuteMetadata(){return this._config.muteMetadata=!1,this}enableIndividualLevel(e){return this.logLevelManager.enableIndividualLevel(e),this}disableIndividualLevel(e){return this.logLevelManager.disableIndividualLevel(e),this}setLevel(e){return this.logLevelManager.setLevel(e),this}isLevelEnabled(e){return this.logLevelManager.isLevelEnabled(e)}formatContext(e){let{contextFieldName:r,muteContext:i}=this._config;return e&&Object.keys(e).length>0&&!i?r?{[r]:T({},e)}:T({},e):{}}formatMetadata(e=null){let{metadataFieldName:r,muteMetadata:i}=this._config;return e&&!i?r?{[r]:T({},e)}:T({},e):{}}getLoggerInstance(e){let r=this.idToTransport[e];if(r)return r.getLoggerInstance()}_formatMessage(e=[]){let{prefix:r}=this._config;r&&typeof e[0]=="string"&&(e[0]=`${r} ${e[0]}`)}_formatLog({logLevel:e,params:r=[],metadata:i=null,err:n,context:o=null}){var m;let{errorSerializer:a,errorFieldInMetadata:s,muteContext:u,contextFieldName:c,metadataFieldName:l,errorFieldName:f}=this._config,d=o!==null?o:this.contextManager.getContext(),p=!!i||(u?!1:o!==null?Object.keys(o).length>0:this.contextManager.hasContextData()),h={};if(p)if(c&&c===l){let g=this.formatContext(d)[c],b=this.formatMetadata(i)[l];h={[c]:T(T({},g),b)}}else h=T(T({},this.formatContext(d)),this.formatMetadata(i));if(n){let g=a?a(n):n;s&&i&&l?h!=null&&h[l]?h[l][f]=g:h=J(T({},h),{[l]:{[f]:g}}):s&&!i&&l?h=J(T({},h),{[l]:{[f]:g}}):h=J(T({},h),{[f]:g}),p=!0}if(this.pluginManager.hasPlugins(Eo.onBeforeDataOut)&&(h=this.pluginManager.runOnBeforeDataOut({data:p?h:void 0,logLevel:e,error:n,metadata:i,context:d},this),h&&!p&&(p=!0)),this.pluginManager.hasPlugins(Eo.onBeforeMessageOut)&&(r=this.pluginManager.runOnBeforeMessageOut({messages:[...r],logLevel:e},this)),this.pluginManager.hasPlugins(Eo.transformLogLevel)&&(e=this.pluginManager.runTransformLogLevel({data:p?h:void 0,logLevel:e,messages:[...r],error:n,metadata:i,context:d},this)),this.hasMultipleTransports){let g=this._config.transport.filter(b=>b.enabled).map(async b=>{let v=e;if(!(this.pluginManager.hasPlugins(Eo.shouldSendToLogger)&&!this.pluginManager.runShouldSendToLogger({messages:[...r],data:p?h:void 0,logLevel:v,transportId:b.id,error:n,metadata:i,context:d},this)))return b._sendToLogger({logLevel:v,messages:[...r],data:p?h:void 0,hasData:p,error:n,metadata:i,context:d})});Promise.all(g).catch(b=>{this._config.consoleDebug&&console.error("[LogLayer] Error executing transports:",b)})}else{if(!((m=this.singleTransport)!=null&&m.enabled)||this.pluginManager.hasPlugins(Eo.shouldSendToLogger)&&!this.pluginManager.runShouldSendToLogger({messages:[...r],data:p?h:void 0,logLevel:e,transportId:this.singleTransport.id,error:n,metadata:i,context:d},this))return;this.singleTransport._sendToLogger({logLevel:e,messages:[...r],data:p?h:void 0,hasData:p,error:n,metadata:i,context:d})}}};var eb={logLayerHandlers:[],pluginsToInit:[],logBuilderHandlers:[]};var qbe=class{constructor(t){It(this,"err");It(this,"metadata");It(this,"structuredLogger");It(this,"hasMetadata");It(this,"pluginManager");this.err=null,this.metadata={},this.structuredLogger=t,this.hasMetadata=!1,this.pluginManager=t.pluginManager,eb.logBuilderHandlers.length>0&&eb.logBuilderHandlers.forEach(e=>{e.onConstruct&&e.onConstruct(this,t)})}withMetadata(t){let{pluginManager:e,structuredLogger:{_config:{consoleDebug:r}}}=this;if(!t)return r&&console.debug("[LogLayer] withMetadata was called with no metadata; dropping."),this;let i=t;return e.hasPlugins(Eo.onMetadataCalled)&&(i=e.runOnMetadataCalled(t,this.structuredLogger),!i)?(r&&console.debug("[LogLayer] Metadata was dropped due to plugin returning falsy value."),this):(this.metadata=T(T({},this.metadata),i),this.hasMetadata=!0,this)}withError(t){return this.err=t,this}info(...t){this.structuredLogger.isLevelEnabled(nt.info)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.info,t))}warn(...t){this.structuredLogger.isLevelEnabled(nt.warn)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.warn,t))}error(...t){this.structuredLogger.isLevelEnabled(nt.error)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.error,t))}debug(...t){this.structuredLogger.isLevelEnabled(nt.debug)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.debug,t))}trace(...t){this.structuredLogger.isLevelEnabled(nt.trace)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.trace,t))}fatal(...t){this.structuredLogger.isLevelEnabled(nt.fatal)&&(this.structuredLogger._formatMessage(t),this.formatLog(nt.fatal,t))}disableLogging(){return this.structuredLogger.disableLogging(),this}enableLogging(){return this.structuredLogger.enableLogging(),this}formatLog(t,e){let{muteMetadata:r}=this.structuredLogger._config,i=r?!1:this.hasMetadata;this.structuredLogger._formatLog({logLevel:t,params:e,metadata:i?this.metadata:null,err:this.err})}};var Wbe=class extends Rq{constructor(t){super(t),t.stackDepthLevel!==void 0?this.logger.stackDepthLevel=t.stackDepthLevel:this.logger.stackDepthLevel=9}shipToLogger({logLevel:t,messages:e,data:r,hasData:i}){switch(r&&i&&e.push(r),t){case nt.info:this.logger.info(...e);break;case nt.warn:this.logger.warn(...e);break;case nt.error:this.logger.error(...e);break;case nt.trace:this.logger.trace(...e);break;case nt.debug:this.logger.debug(...e);break;case nt.fatal:this.logger.fatal(...e);break}return e}};function Gbe(t){return{href:t.href,protocol:t.protocol,username:t.username,password:t.password,host:t.host,hostname:t.hostname,port:t.port,pathname:t.pathname,search:t.search,searchParams:[...t.searchParams].map(([e,r])=>({key:e,value:r})),hash:t.hash,origin:t.origin}}var tb={reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29],black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39],bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]};function rb(t,e,r,i=!1){let n=String(e),o=(u,c)=>`\x1B[${c[0]}m${u}\x1B[${c[1]}m`,a=(u,c)=>c!=null&&typeof c=="string"?o(u,tb[c]):c!=null&&Array.isArray(c)?c.reduce((l,f)=>a(l,f),u):c!=null&&c[u.trim()]!=null?a(u,c[u.trim()]):c!=null&&c["*"]!=null?a(u,c["*"]):u,s=null;return n.replace(/{{(.+?)}}/g,(u,c)=>{var f,d;let l=r[c]!=null?String(r[c]):i?"":u;return t.stylePrettyLogs?a(l,(d=(f=t==null?void 0:t.prettyLogStyles)==null?void 0:f[c])!=null?d:s)+o("",tb.reset):l})}function ys(t,e=2,r=0){return t!=null&&isNaN(t)?"":(t=t!=null?t+r:t,e===2?t==null?"--":t<10?"0"+t:t.toString():t==null?"---":t<10?"00"+t:t<100?"0"+t:t.toString())}function Cq(t,e){var s,u,c,l,f,d,p,h,m,g,b,v,y,w,x,R,S,O,E,M,P,N,k,C,L,F,B;if(e==null)return{text:"",template:t.prettyLogTemplate,placeholders:{}};let r=t.prettyLogTemplate,i={};r.includes("{{yyyy}}.{{mm}}.{{dd}} {{hh}}:{{MM}}:{{ss}}:{{ms}}")?r=r.replace("{{yyyy}}.{{mm}}.{{dd}} {{hh}}:{{MM}}:{{ss}}:{{ms}}","{{dateIsoStr}}"):t.prettyLogTimeZone==="UTC"?(i.yyyy=(u=(s=e.date)==null?void 0:s.getUTCFullYear())!=null?u:"----",i.mm=ys((c=e.date)==null?void 0:c.getUTCMonth(),2,1),i.dd=ys((l=e.date)==null?void 0:l.getUTCDate(),2),i.hh=ys((f=e.date)==null?void 0:f.getUTCHours(),2),i.MM=ys((d=e.date)==null?void 0:d.getUTCMinutes(),2),i.ss=ys((p=e.date)==null?void 0:p.getUTCSeconds(),2),i.ms=ys((h=e.date)==null?void 0:h.getUTCMilliseconds(),3)):(i.yyyy=(g=(m=e.date)==null?void 0:m.getFullYear())!=null?g:"----",i.mm=ys((b=e.date)==null?void 0:b.getMonth(),2,1),i.dd=ys((v=e.date)==null?void 0:v.getDate(),2),i.hh=ys((y=e.date)==null?void 0:y.getHours(),2),i.MM=ys((w=e.date)==null?void 0:w.getMinutes(),2),i.ss=ys((x=e.date)==null?void 0:x.getSeconds(),2),i.ms=ys((R=e.date)==null?void 0:R.getMilliseconds(),3));let n=t.prettyLogTimeZone==="UTC"?e.date:e.date!=null?new Date(e.date.getTime()-e.date.getTimezoneOffset()*6e4):void 0;i.rawIsoStr=(S=n==null?void 0:n.toISOString())!=null?S:"",i.dateIsoStr=(O=n==null?void 0:n.toISOString().replace("T"," ").replace("Z",""))!=null?O:"",i.logLevelName=e.logLevelName,i.fileNameWithLine=(M=(E=e.path)==null?void 0:E.fileNameWithLine)!=null?M:"",i.filePathWithLine=(N=(P=e.path)==null?void 0:P.filePathWithLine)!=null?N:"",i.fullFilePath=(C=(k=e.path)==null?void 0:k.fullFilePath)!=null?C:"";let o=(L=t.parentNames)==null?void 0:L.join(t.prettyErrorParentNamesSeparator);o=o!=null&&e.name!=null?o+t.prettyErrorParentNamesSeparator:void 0;let a=e.name!=null||o!=null?`${o!=null?o:""}${(F=e.name)!=null?F:""}`:"";return i.name=a,i.nameWithDelimiterPrefix=a.length>0?t.prettyErrorLoggerNameDelimiter+a:"",i.nameWithDelimiterSuffix=a.length>0?a+t.prettyErrorLoggerNameDelimiter:"",((B=t.overwrite)==null?void 0:B.addPlaceholders)!=null&&t.overwrite.addPlaceholders(e,i),{text:rb(t,r,i),template:r,placeholders:i}}var Hbe=[/(?:^|[\\/])node_modules[\\/].*tslog/i,/(?:^|[\\/])deps[\\/].*tslog/i,/tslog[\\/]+src[\\/]+internal[\\/]/i,/tslog[\\/]+src[\\/]BaseLogger/i,/tslog[\\/]+src[\\/]index/i];function elt(t){let e=typeof(t==null?void 0:t.stack)=="string"?t.stack:void 0;return e==null||e.length===0?[]:e.split(`
765
765
  `).map(r=>r.trimEnd())}function tlt(t){return t.filter(e=>e.length>0&&!/^\s*Error\b/.test(e))}function rlt(t,e){let r=[];for(let i of t){let n=e(i);n!=null&&r.push(n)}return r}function Kbe(t,e=Hbe){var r,i;for(let n=0;n<t.length;n+=1){let o=t[n],a=(r=o.filePath)!=null?r:"",s=(i=o.fullFilePath)!=null?i:"";if(!e.some(u=>u.test(a)||u.test(s)))return n}return 0}function nlt(t){return tlt(elt(t))}function ck(t,e){return rlt(nlt(t),e)}function Aq(t,e){return t<0?0:t>=e?Math.max(0,e-1):t}function Iq(){return[...Hbe]}var ilt=5;function Zbe(t,e={}){var s;let r=(s=e.maxDepth)!=null?s:ilt,i=[],n=new Set,o=t,a=0;for(;o!=null&&a<r;){let u=o==null?void 0:o.cause;if(u==null||n.has(u))break;n.add(u),i.push(Oq(u)),o=u,a+=1}return i}function Oq(t){if(t instanceof Error)return t;let e=new Error(typeof t=="string"?t:JSON.stringify(t));return typeof t=="object"&&t!=null&&Object.assign(e,t),e}function uk(t){let e=new Set;return JSON.stringify(t,(r,i)=>{if(typeof i=="object"&&i!==null){if(e.has(i))return"[Circular]";e.add(i)}return typeof i=="bigint"?`${i}`:typeof i=="undefined"?"[undefined]":i})}function To(t,e){let r={seen:[],stylize:Xbe};return e!=null&&t8e(r,e),hy(r.showHidden)&&(r.showHidden=!1),hy(r.depth)&&(r.depth=2),hy(r.colors)&&(r.colors=!0),hy(r.customInspect)&&(r.customInspect=!0),r.colors&&(r.stylize=alt),fk(r,t,r.depth)}To.colors=tb;To.styles={special:"cyan",number:"yellow",boolean:"yellow",undefined:"grey",null:"bold",string:"green",date:"magenta",regexp:"red"};function olt(t){return typeof t=="boolean"}function hy(t){return t===void 0}function Xbe(t){return t}function alt(t,e){var i,n,o,a;let r=To.styles[e];return r!=null&&((n=(i=To==null?void 0:To.colors)==null?void 0:i[r])==null?void 0:n[0])!=null&&((a=(o=To==null?void 0:To.colors)==null?void 0:o[r])==null?void 0:a[1])!=null?"\x1B["+To.colors[r][0]+"m"+t+"\x1B["+To.colors[r][1]+"m":t}function lk(t){return typeof t=="function"}function Ybe(t){return typeof t=="string"}function slt(t){return typeof t=="number"}function Qbe(t){return t===null}function e8e(t,e){return Object.prototype.hasOwnProperty.call(t,e)}function Nq(t){return dk(t)&&jq(t)==="[object RegExp]"}function dk(t){return typeof t=="object"&&t!==null}function Dq(t){return dk(t)&&(jq(t)==="[object Error]"||t instanceof Error)}function Jbe(t){return dk(t)&&jq(t)==="[object Date]"}function jq(t){return Object.prototype.toString.call(t)}function clt(t){let e={};return t.forEach(r=>{e[r]=!0}),e}function ult(t,e,r,i,n){let o=[];for(let a=0,s=e.length;a<s;++a)e8e(e,String(a))?o.push(Mq(t,e,r,i,String(a),!0)):o.push("");return n.forEach(a=>{a.match(/^\d+$/)||o.push(Mq(t,e,r,i,a,!0))}),o}function Lq(t){return"["+Error.prototype.toString.call(t)+"]"}function fk(t,e,r=0){if(t.customInspect&&e!=null&&lk(e)&&(e==null?void 0:e.inspect)!==To&&!(e!=null&&e.constructor&&(e==null?void 0:e.constructor.prototype)===e)){if(typeof e.inspect!="function"&&e.toString!=null)return e.toString();let l=e==null?void 0:e.inspect(r,t);return Ybe(l)||(l=fk(t,l,r)),l}let i=Fd(t,e);if(i)return i;let n=Object.keys(e),o=clt(n);try{t.showHidden&&Object.getOwnPropertyNames&&(n=Object.getOwnPropertyNames(e))}catch(l){}if(Dq(e)&&(n.indexOf("message")>=0||n.indexOf("description")>=0))return Lq(e);if(n.length===0)if(lk(t.stylize)){if(lk(e)){let l=e.name?": "+e.name:"";return t.stylize("[Function"+l+"]","special")}if(Nq(e))return t.stylize(RegExp.prototype.toString.call(e),"regexp");if(Jbe(e))return t.stylize(Date.prototype.toISOString.call(e),"date");if(Dq(e))return Lq(e)}else return e;let a="",s=!1,u=[`{
766
766
  `,`
767
767
  }`];if(Array.isArray(e)&&(s=!0,u=[`[
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kumori/kdsl",
3
- "version": "0.0.51",
3
+ "version": "0.0.52",
4
4
  "private": false,
5
5
  "files": [
6
6
  "bin",
@@ -73,7 +73,7 @@
73
73
  "dependencies": {
74
74
  "@commander-js/extra-typings": "^14.0.0",
75
75
  "@inquirer/prompts": "^8.0.2",
76
- "@kumori/kdsl-lsp": "0.0.1-alpha.23",
76
+ "@kumori/kdsl-lsp": "0.0.1-alpha.24",
77
77
  "ajv": "^8.17.1",
78
78
  "chalk": "~5.6.2",
79
79
  "commander": "~14.0.2",