@adaas/a-utils 0.1.40 → 0.2.1

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 (34) hide show
  1. package/dist/index.cjs +16 -16
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.d.mts +6 -0
  4. package/dist/index.d.ts +6 -0
  5. package/dist/index.mjs +16 -16
  6. package/dist/index.mjs.map +1 -1
  7. package/package.json +3 -2
  8. package/src/lib/A-Channel/A-Channel.component.ts +6 -0
  9. package/src/lib/A-Channel/A-ChannelRequest.context.ts +7 -0
  10. package/src/lib/A-Command/A-Command.entity.ts +7 -1
  11. package/src/lib/A-Command/A-Command.error.ts +0 -1
  12. package/src/lib/A-Config/A-Config.container.ts +7 -0
  13. package/src/lib/A-Config/A-Config.context.ts +7 -0
  14. package/src/lib/A-Config/components/ConfigReader.component.ts +6 -0
  15. package/src/lib/A-Config/components/ENVConfigReader.component.ts +7 -0
  16. package/src/lib/A-Config/components/FileConfigReader.component.ts +8 -0
  17. package/src/lib/A-Execution/A-Execution.context.ts +7 -0
  18. package/src/lib/A-Logger/A-Logger.component.ts +30 -24
  19. package/src/lib/A-Manifest/A-Manifest.context.ts +6 -0
  20. package/src/lib/A-Memory/A-Memory.component.ts +7 -0
  21. package/src/lib/A-Memory/A-Memory.context.ts +6 -0
  22. package/src/lib/A-Operation/A-Operation.context.ts +8 -0
  23. package/src/lib/A-Polyfill/A-Polyfill.component.ts +9 -0
  24. package/src/lib/A-Route/A-Route.entity.ts +7 -0
  25. package/src/lib/A-Schedule/A-Schedule.component.ts +8 -1
  26. package/src/lib/A-Service/A-Service.container.ts +6 -0
  27. package/src/lib/A-Signal/components/A-SignalBus.component.ts +6 -0
  28. package/src/lib/A-Signal/context/A-SignalConfig.context.ts +6 -0
  29. package/src/lib/A-Signal/context/A-SignalState.context.ts +6 -0
  30. package/src/lib/A-Signal/entities/A-Signal.entity.ts +6 -0
  31. package/src/lib/A-Signal/entities/A-SignalVector.entity.ts +6 -0
  32. package/src/lib/A-StateMachine/A-StateMachine.component.ts +11 -0
  33. package/src/lib/A-StateMachine/A-StateMachineTransition.context.ts +11 -5
  34. package/src/lib/A-Command/A-CommandExecution.context.ts +0 -0
package/dist/index.cjs CHANGED
@@ -1,16 +1,16 @@
1
- 'use strict';var aConcept=require('@adaas/a-concept');var wt=Object.defineProperty;var Yt=Object.getOwnPropertyDescriptor;var i=(j,t)=>wt(j,"name",{value:t,configurable:true});var c=(j,t,e,r)=>{for(var o=r>1?void 0:r?Yt(t,e):t,n=j.length-1,s;n>=0;n--)(s=j[n])&&(o=(r?s(t,e,o):s(o))||o);return r&&o&&wt(t,e,o),o},l=(j,t)=>(e,r)=>t(e,r,j);var $e=class $e extends aConcept.A_Fragment{constructor(t,e){super({name:t}),this._meta=new aConcept.A_Meta;for(let r in e)this._meta.set(r,e[r]);}[Symbol.iterator](){return this._meta[Symbol.iterator]()}get meta(){return this._meta}get(t){return this._meta.get(t)}set(t,e){return this._meta.set(t,e),this}has(t){return this._meta.has(t)}drop(t){this._meta.delete(t);}clear(){return this._meta.clear(),this}toRaw(){return this._meta.toJSON()}toJSON(){return {name:this.name,...this.meta.toJSON()}}};i($e,"A_ExecutionContext");var b=$e;var Ue=class Ue extends b{constructor(t,e){super("operation-context"),this.meta.set("name",t),this.meta.set("params",e||{});}get name(){return this._meta.get("name")||this._name}get result(){return this._meta.get("result")}get error(){return this._meta.get("error")}get params(){return this._meta.get("params")||{}}fail(t){this._meta.set("error",t);}succeed(t){this._meta.set("result",t);}toJSON(){return {name:this.name,params:this.params,result:this.result||{},error:this.error?.toJSON()}}};i(Ue,"A_OperationContext");var u=Ue;var ye=class ye extends aConcept.A_Error{constructor(t,e){aConcept.A_TypeGuards.isString(e)?super(t,e):super(t),e instanceof u&&(this._context=e);}get context(){return this._context}};i(ye,"A_ChannelError"),ye.MethodNotImplemented="A-Channel Method Not Implemented";var q=ye;var Ht=(m=>(m.onTimeout="_A_Channel_onTimeout",m.onRetry="_A_Channel_onRetry",m.onCircuitBreakerOpen="_A_Channel_onCircuitBreakerOpen",m.onCache="_A_Channel_onCache",m.onConnect="_A_Channel_onConnect",m.onDisconnect="_A_Channel_onDisconnect",m.onBeforeRequest="_A_Channel_onBeforeRequest",m.onRequest="_A_Channel_onRequest",m.onAfterRequest="_A_Channel_onAfterRequest",m.onError="_A_Channel_onError",m.onSend="_A_Channel_onSend",m.onConsume="_A_Channel_onConsume",m))(Ht||{}),jt=(r=>(r.PENDING="PENDING",r.SUCCESS="SUCCESS",r.FAILED="FAILED",r))(jt||{});var Ye=class Ye extends u{constructor(t){super("request",t);}get status(){return this.result?.status}get data(){return this.result?.data}succeed(t){let e=this.result;super.succeed({...e,data:t,status:"SUCCESS"});}};i(Ye,"A_ChannelRequest");var le=Ye;var M=class M extends aConcept.A_Component{constructor(){super();this._processing=false;this._cache=new Map;}get processing(){return this._processing}get initialize(){return this._initialized||(this._initialized=this.connect()),this._initialized}async onConnect(...e){}async onDisconnect(...e){}async onBeforeRequest(...e){}async onRequest(...e){}async onAfterRequest(...e){}async onError(...e){}async onSend(...e){}async connect(){await this.call("_A_Channel_onConnect");}async disconnect(){await this.call("_A_Channel_onDisconnect");}async request(e){await this.initialize,this._processing=true;let r=new aConcept.A_Scope({name:`a-channel@scope:request:${aConcept.A_IdentityHelper.generateTimeId()}`}).inherit(aConcept.A_Context.scope(this)),o=new le(e);try{return r.register(o),await this.call("_A_Channel_onBeforeRequest",r),await this.call("_A_Channel_onRequest",r),await this.call("_A_Channel_onAfterRequest",r),this._processing=!1,o}catch(n){this._processing=false;let s=new q(n);throw o.fail(s),r.register(s),await this.call("_A_Channel_onError",r),r.destroy(),s}}async send(e){await this.initialize,this._processing=true;let r=new aConcept.A_Scope({name:`a-channel@scope:send:${aConcept.A_IdentityHelper.generateTimeId()}`}).inherit(aConcept.A_Context.scope(this)),o=new u("send",e);try{r.inherit(aConcept.A_Context.scope(this)),r.register(o),await this.call("_A_Channel_onSend",r),this._processing=!1;}catch(n){this._processing=false;let s=new q(n);r.register(s),o.fail(s),await this.call("_A_Channel_onError",r),r.destroy();}}async consume(){await this.initialize,this._processing=true;let e=new aConcept.A_Scope({name:`a-channel@scope:consume:${aConcept.A_IdentityHelper.generateTimeId()}`}).inherit(aConcept.A_Context.scope(this)),r=new u("consume",{});try{return e.inherit(aConcept.A_Context.scope(this)),e.register(r),await this.call("_A_Channel_onConsume",e),this._processing=!1,r}catch(o){this._processing=false;let n=new q(o);return r.fail(n),await this.call("_A_Channel_onError",e),r}}};i(M,"A_Channel"),c([aConcept.A_Feature.Extend({name:"_A_Channel_onConnect"})],M.prototype,"onConnect",1),c([aConcept.A_Feature.Extend({name:"_A_Channel_onDisconnect"})],M.prototype,"onDisconnect",1),c([aConcept.A_Feature.Extend({name:"_A_Channel_onBeforeRequest"})],M.prototype,"onBeforeRequest",1),c([aConcept.A_Feature.Extend({name:"_A_Channel_onRequest"})],M.prototype,"onRequest",1),c([aConcept.A_Feature.Extend({name:"_A_Channel_onAfterRequest"})],M.prototype,"onAfterRequest",1),c([aConcept.A_Feature.Extend({name:"_A_Channel_onError"})],M.prototype,"onError",1),c([aConcept.A_Feature.Extend({name:"_A_Channel_onSend"})],M.prototype,"onSend",1);var Be=M;var Kt=(s=>(s.CREATED="CREATED",s.INITIALIZED="INITIALIZED",s.COMPILED="COMPILED",s.EXECUTING="EXECUTING",s.COMPLETED="COMPLETED",s.FAILED="FAILED",s))(Kt||{}),Wt=(o=>(o.CREATED_TO_INITIALIZED="created_initialized",o.INITIALIZED_TO_EXECUTING="initialized_executing",o.EXECUTING_TO_COMPLETED="executing_completed",o.EXECUTING_TO_FAILED="executing_failed",o))(Wt||{}),Jt=(a=>(a.onInit="_A_Command_onInit",a.onBeforeExecute="_A_Command_onBeforeExecute",a.onExecute="_A_Command_onExecute",a.onAfterExecute="_A_Command_onAfterExecute",a.onComplete="_A_Command_onComplete",a.onFail="_A_Command_onFail",a.onError="_A_Command_onError",a))(Jt||{}),Xt=(a=>(a.onInit="onInit",a.onBeforeExecute="onBeforeExecute",a.onExecute="onExecute",a.onAfterExecute="onAfterExecute",a.onComplete="onComplete",a.onFail="onFail",a.onError="onError",a))(Xt||{});var W=class W extends aConcept.A_Error{};i(W,"A_CommandError"),W.CommandScopeBindingError="A-Command Scope Binding Error",W.ExecutionError="A-Command Execution Error",W.ResultProcessingError="A-Command Result Processing Error",W.CommandInterruptedError="A-Command Interrupted Error";var Y=W;var pe=class pe extends aConcept.A_Error{};i(pe,"A_StateMachineError"),pe.InitializationError="A-StateMachine Initialization Error",pe.TransitionError="A-StateMachine Transition Error";var Z=pe;var er=(o=>(o.onError="_A_StateMachine_onError",o.onInitialize="_A_StateMachine_onInitialize",o.onBeforeTransition="_A_StateMachine_onBeforeTransition",o.onAfterTransition="_A_StateMachine_onAfterTransition",o))(er||{});var Ve=class Ve extends u{constructor(t){super("a-state-machine-transition",t),this._meta.set("from",t.from),this._meta.set("to",t.to);}get from(){return this._meta.get("from")}get to(){return this._meta.get("to")}};i(Ve,"A_StateMachineTransition");var N=Ve;var nr,ir,sr,ar,J=class J extends aConcept.A_Component{get ready(){return this._initialized||(this._initialized=this.call("_A_StateMachine_onInitialize")),this._initialized}async[ar="_A_StateMachine_onInitialize"](...t){}async[sr="_A_StateMachine_onBeforeTransition"](...t){}async[ir="_A_StateMachine_onAfterTransition"](...t){}async[nr="_A_StateMachine_onError"](...t){}async transition(t,e,r){await this.ready;let o=`${aConcept.A_FormatterHelper.toCamelCase(String(t))}_${aConcept.A_FormatterHelper.toCamelCase(String(e))}`,n=new N({from:String(t),to:String(e),props:r}),s=new aConcept.A_Scope({name:`A-StateMachine-Transition-Scope-${o}`,fragments:[n]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_StateMachine_onBeforeTransition",s),await this.call(o,s),await this.call("_A_StateMachine_onAfterTransition",s),s.destroy(),n.result}catch(a){let _=new Z({title:Z.TransitionError,description:`An error occurred while transitioning to "${o}"`,originalError:a});throw s.register(_),await this.call("_A_StateMachine_onError",s),s.destroy(),_}}};i(J,"A_StateMachine"),c([aConcept.A_Feature.Extend()],J.prototype,ar,1),c([aConcept.A_Feature.Extend()],J.prototype,sr,1),c([aConcept.A_Feature.Extend()],J.prototype,ir,1),c([aConcept.A_Feature.Extend()],J.prototype,nr,1);var G=J;var bn={},Q=[];var Ee=class Ee extends aConcept.A_Error{};i(Ee,"A_ConfigError"),Ee.InitializationError="A-Config Initialization Error";var $=Ee;var je=class je extends b{constructor(e){super("a-config");this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...Q];this._strict=e.strict??false,this._configProperties=e.variables??[];for(let r in e.defaults)this.set(aConcept.A_FormatterHelper.toUpperSnakeCase(r),e.defaults[r]);}get strict(){return this._strict}get(e){if(this._configProperties.includes(e)||this.DEFAULT_ALLOWED_TO_READ_PROPERTIES.includes(e)||!this._strict)return super.get(aConcept.A_FormatterHelper.toUpperSnakeCase(e));throw new $("Property not exists or not allowed to read")}set(e,r){let o=Array.isArray(e)?e:typeof e=="string"?[{property:e,value:r}]:Object.keys(e).map(n=>({property:n,value:e[n]}));for(let{property:n,value:s}of o)super.set(aConcept.A_FormatterHelper.toUpperSnakeCase(n),s);}};i(je,"A_Config");var A=je;var Lt=20,Vn="all",vt={red:"31",yellow:"33",green:"32",blue:"34",cyan:"36",magenta:"35",gray:"90",brightBlue:"94",brightCyan:"96",brightMagenta:"95",darkGray:"30",lightGray:"37",indigo:"38;5;54",violet:"38;5;93",purple:"38;5;129",lavender:"38;5;183",skyBlue:"38;5;117",steelBlue:"38;5;67",slateBlue:"38;5;62",deepBlue:"38;5;18",lightBlue:"38;5;153",periwinkle:"38;5;111",cornflower:"38;5;69",powder:"38;5;152",charcoal:"38;5;236",silver:"38;5;250",smoke:"38;5;244",slate:"38;5;240"},It=["blue","cyan","magenta","gray","brightBlue","brightCyan","brightMagenta","darkGray","lightGray","indigo","violet","purple","lavender","skyBlue","steelBlue","slateBlue","deepBlue","lightBlue","periwinkle","cornflower","powder","charcoal","silver","smoke","slate"],V={RESET:"\x1B[0m",PREFIX:"\x1B[",SUFFIX:"m"},ee={MINUTES_PAD:2,SECONDS_PAD:2,MILLISECONDS_PAD:3,SEPARATOR:":"},y={SCOPE_OPEN:"[",SCOPE_CLOSE:"]",TIME_OPEN:"|",TIME_CLOSE:"|",SEPARATOR:"-------------------------------",INDENT_BASE:3,PIPE:"| "},te={DEFAULT_WIDTH:80,MIN_WIDTH:40,MAX_LINE_LENGTH_RATIO:.8,BROWSER_DEFAULT_WIDTH:120},de={LOG_LEVEL:"A_LOGGER_LEVEL",DEFAULT_SCOPE_LENGTH:"A_LOGGER_DEFAULT_SCOPE_LENGTH",DEFAULT_SCOPE_COLOR:"A_LOGGER_DEFAULT_SCOPE_COLOR",DEFAULT_LOG_COLOR:"A_LOGGER_DEFAULT_LOG_COLOR"};exports.A_Logger=class T extends aConcept.A_Component{constructor(e,r){super();this.scope=e;this.config=r;this.COLORS=vt,this.STANDARD_SCOPE_LENGTH=r?.get(de.DEFAULT_SCOPE_LENGTH)||20;let o=r?.get(de.DEFAULT_SCOPE_COLOR),n=r?.get(de.DEFAULT_LOG_COLOR);if(o||n)this.DEFAULT_SCOPE_COLOR=o||this.generateColorFromScopeName(this.scope.name),this.DEFAULT_LOG_COLOR=n||this.generateColorFromScopeName(this.scope.name);else {let s=this.generateComplementaryColorsFromScope(this.scope.name);this.DEFAULT_SCOPE_COLOR=s.scopeColor,this.DEFAULT_LOG_COLOR=s.logColor;}this.TERMINAL_WIDTH=this.detectTerminalWidth(),this.MAX_CONTENT_WIDTH=Math.floor(this.TERMINAL_WIDTH*te.MAX_LINE_LENGTH_RATIO);}simpleHash(e){let r=0;for(let o=0;o<e.length;o++){let n=e.charCodeAt(o);r=(r<<5)-r+n,r=r&r;}return Math.abs(r)}generateColorFromScopeName(e){let r=It,n=this.simpleHash(e)%r.length;return r[n]}generateComplementaryColorsFromScope(e){let r=[{scopeColor:"indigo",logColor:"lightBlue"},{scopeColor:"deepBlue",logColor:"cyan"},{scopeColor:"purple",logColor:"lavender"},{scopeColor:"steelBlue",logColor:"skyBlue"},{scopeColor:"slateBlue",logColor:"periwinkle"},{scopeColor:"charcoal",logColor:"silver"},{scopeColor:"violet",logColor:"brightMagenta"},{scopeColor:"darkGray",logColor:"lightGray"},{scopeColor:"cornflower",logColor:"powder"},{scopeColor:"slate",logColor:"smoke"}],n=this.simpleHash(e)%r.length;return r[n]}detectTerminalWidth(){try{if(aConcept.A_Context.environment==="browser")return te.BROWSER_DEFAULT_WIDTH;if(typeof process<"u"&&process.stdout&&process.stdout.columns){let e=process.stdout.columns;return Math.max(e,te.MIN_WIDTH)}return te.DEFAULT_WIDTH}catch{return te.DEFAULT_WIDTH}}wrapText(e,r,o=true){if(aConcept.A_Context.environment==="browser")return [e];let n=this.formattedScope.length+4+this.getTime().length+4,s=`${r}${y.PIPE}`,a=Math.max(this.TERMINAL_WIDTH-n-1,20),_=Math.max(this.TERMINAL_WIDTH-s.length,20);if(o&&e.length<=a)return [e];let d=[],p=e.split(" "),h="",m=o?a:_;for(let k of p){let Me=h?1:0;if(h.length+Me+k.length>m)if(h)d.push(h),h=k,m=_;else {if(k.length>m){let Ge=this.splitLongWord(k,m);d.push(...Ge.slice(0,-1)),h=Ge[Ge.length-1];}else h=k;m=_;}else h+=(h?" ":"")+k;}return h&&d.push(h),d.length?d:[e]}splitLongWord(e,r){let o=[];for(let n=0;n<e.length;n+=r)o.push(e.slice(n,n+r));return o}get scopeLength(){return Math.max(this.scope.name.length,this.STANDARD_SCOPE_LENGTH)}get formattedScope(){let e=this.scope.name,r=this.STANDARD_SCOPE_LENGTH;if(e.length>=r)return e.substring(0,r);let o=r-e.length,n=Math.floor(o/2),s=o-n;return " ".repeat(n)+e+" ".repeat(s)}compile(e,...r){let o=this.getTime(),n=" ".repeat(this.STANDARD_SCOPE_LENGTH+3),s=r.length>1;return [`${V.PREFIX}${this.COLORS[this.DEFAULT_SCOPE_COLOR]}${V.SUFFIX}${y.SCOPE_OPEN}${this.formattedScope}${y.SCOPE_CLOSE}${V.RESET} ${V.PREFIX}${this.COLORS[e]}${V.SUFFIX}${y.TIME_OPEN}${o}${y.TIME_CLOSE}`,s?`
2
- ${n}${y.TIME_OPEN}${y.SEPARATOR}`:"",...r.map((a,_)=>{let d=_>0||s;switch(true){case a instanceof aConcept.A_Error:return this.compile_A_Error(a);case a instanceof Error:return this.compile_Error(a);case(typeof a=="object"&&a!==null):return this.formatObject(a,d,n);default:return this.formatString(String(a),d,n)}}),s?`
3
- ${n}${y.TIME_OPEN}${y.SEPARATOR}${V.RESET}`:V.RESET]}formatObject(e,r,o){if(aConcept.A_Context.environment==="browser")return e;if(e===null)return r?`
4
- ${o}${y.PIPE}null`:"null";if(e===void 0)return r?`
5
- ${o}${y.PIPE}undefined`:"undefined";let n;try{n=JSON.stringify(e,null,2);}catch{try{let h=new WeakSet;n=JSON.stringify(e,(m,O)=>{if(typeof O=="object"&&O!==null){if(h.has(O))return "[Circular Reference]";h.add(O);}return O},2);}catch{n=String(e);}}let s=`${o}${y.PIPE}`,a=this.TERMINAL_WIDTH-s.length-4,d=n.split(`
6
- `).map(p=>{let h=p.match(/^(\s*"[^"]+":\s*")([^"]+)(".*)?$/);if(h&&h[2].length>a-h[1].length-(h[3]||"").length){let[,m,O,k=""]=h;if(O.length>a-m.length-k.length){let Me=this.wrapJsonStringValue(O,a-m.length-k.length);return m+Me+k}}return p}).join(`
1
+ 'use strict';var aConcept=require('@adaas/a-concept'),aFrame=require('@adaas/a-frame');var it=Object.defineProperty;var Tt=Object.getOwnPropertyDescriptor;var i=(ee,t)=>it(ee,"name",{value:t,configurable:true});var a=(ee,t,e,r)=>{for(var o=r>1?void 0:r?Tt(t,e):t,n=ee.length-1,s;n>=0;n--)(s=ee[n])&&(o=(r?s(t,e,o):s(o))||o);return r&&o&&it(t,e,o),o},l=(ee,t)=>(e,r)=>t(e,r,ee);exports.A_ExecutionContext=class v extends aConcept.A_Fragment{constructor(t,e){super({name:t}),this._meta=new aConcept.A_Meta;for(let r in e)this._meta.set(r,e[r]);}[Symbol.iterator](){return this._meta[Symbol.iterator]()}get meta(){return this._meta}get(t){return this._meta.get(t)}set(t,e){return this._meta.set(t,e),this}has(t){return this._meta.has(t)}drop(t){this._meta.delete(t);}clear(){return this._meta.clear(),this}toRaw(){return this._meta.toJSON()}toJSON(){return {name:this.name,...this.meta.toJSON()}}};i(exports.A_ExecutionContext,"A_ExecutionContext"),exports.A_ExecutionContext=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-ExecutionContext",description:"Execution context fragment that provides a structured way to manage metadata and serialized data for execution environments. It allows storing and retrieving key-value pairs, facilitating context-aware operations within the application. It useful in cases when it's necessary to share some runtime data across multiple steps of thee features, or components."})],exports.A_ExecutionContext);exports.A_OperationContext=class d extends exports.A_ExecutionContext{constructor(t,e){super("operation-context"),this.meta.set("name",t),this.meta.set("params",e||{});}get name(){return this._meta.get("name")||this._name}get result(){return this._meta.get("result")}get error(){return this._meta.get("error")}get params(){return this._meta.get("params")||{}}fail(t){this._meta.set("error",t);}succeed(t){this._meta.set("result",t);}toJSON(){return {name:this.name,params:this.params,result:this.result||{},error:this.error?.toJSON()}}};i(exports.A_OperationContext,"A_OperationContext"),exports.A_OperationContext=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-OperationContext",description:"Operation execution context that encapsulates the metadata and serialized data related to a specific operation. It provides structured access to operation parameters, results, and error handling, facilitating the management of operation lifecycles within the application."})],exports.A_OperationContext);var Se=class Se extends aConcept.A_Error{constructor(t,e){aConcept.A_TypeGuards.isString(e)?super(t,e):super(t),e instanceof exports.A_OperationContext&&(this._context=e);}get context(){return this._context}};i(Se,"A_ChannelError"),Se.MethodNotImplemented="A-Channel Method Not Implemented";var te=Se;var Rt=(u=>(u.onTimeout="_A_Channel_onTimeout",u.onRetry="_A_Channel_onRetry",u.onCircuitBreakerOpen="_A_Channel_onCircuitBreakerOpen",u.onCache="_A_Channel_onCache",u.onConnect="_A_Channel_onConnect",u.onDisconnect="_A_Channel_onDisconnect",u.onBeforeRequest="_A_Channel_onBeforeRequest",u.onRequest="_A_Channel_onRequest",u.onAfterRequest="_A_Channel_onAfterRequest",u.onError="_A_Channel_onError",u.onSend="_A_Channel_onSend",u.onConsume="_A_Channel_onConsume",u))(Rt||{}),Pt=(r=>(r.PENDING="PENDING",r.SUCCESS="SUCCESS",r.FAILED="FAILED",r))(Pt||{});exports.A_ChannelRequest=class B extends exports.A_OperationContext{constructor(t){super("request",t);}get status(){return this.result?.status}get data(){return this.result?.data}succeed(t){let e=this.result;super.succeed({...e,data:t,status:"SUCCESS"});}};i(exports.A_ChannelRequest,"A_ChannelRequest"),exports.A_ChannelRequest=a([aFrame.A_Frame.Fragment({name:"A-ChannelRequest",description:"Context for managing channel requests. It encapsulates the request parameters and the result including status and data."})],exports.A_ChannelRequest);exports.A_Channel=class L extends aConcept.A_Component{constructor(){super();this._processing=false;this._cache=new Map;}get processing(){return this._processing}get initialize(){return this._initialized||(this._initialized=this.connect()),this._initialized}async onConnect(...e){}async onDisconnect(...e){}async onBeforeRequest(...e){}async onRequest(...e){}async onAfterRequest(...e){}async onError(...e){}async onSend(...e){}async connect(){await this.call("_A_Channel_onConnect");}async disconnect(){await this.call("_A_Channel_onDisconnect");}async request(e){await this.initialize,this._processing=true;let r=new aConcept.A_Scope({name:`a-channel@scope:request:${aConcept.A_IdentityHelper.generateTimeId()}`}).inherit(aConcept.A_Context.scope(this)),o=new exports.A_ChannelRequest(e);try{return r.register(o),await this.call("_A_Channel_onBeforeRequest",r),await this.call("_A_Channel_onRequest",r),await this.call("_A_Channel_onAfterRequest",r),this._processing=!1,o}catch(n){this._processing=false;let s=new te(n);throw o.fail(s),r.register(s),await this.call("_A_Channel_onError",r),r.destroy(),s}}async send(e){await this.initialize,this._processing=true;let r=new aConcept.A_Scope({name:`a-channel@scope:send:${aConcept.A_IdentityHelper.generateTimeId()}`}).inherit(aConcept.A_Context.scope(this)),o=new exports.A_OperationContext("send",e);try{r.inherit(aConcept.A_Context.scope(this)),r.register(o),await this.call("_A_Channel_onSend",r),this._processing=!1;}catch(n){this._processing=false;let s=new te(n);r.register(s),o.fail(s),await this.call("_A_Channel_onError",r),r.destroy();}}async consume(){await this.initialize,this._processing=true;let e=new aConcept.A_Scope({name:`a-channel@scope:consume:${aConcept.A_IdentityHelper.generateTimeId()}`}).inherit(aConcept.A_Context.scope(this)),r=new exports.A_OperationContext("consume",{});try{return e.inherit(aConcept.A_Context.scope(this)),e.register(r),await this.call("_A_Channel_onConsume",e),this._processing=!1,r}catch(o){this._processing=false;let n=new te(o);return r.fail(n),await this.call("_A_Channel_onError",e),r}}};i(exports.A_Channel,"A_Channel"),a([aConcept.A_Feature.Extend({name:"_A_Channel_onConnect"})],exports.A_Channel.prototype,"onConnect",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onDisconnect"})],exports.A_Channel.prototype,"onDisconnect",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onBeforeRequest"})],exports.A_Channel.prototype,"onBeforeRequest",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onRequest"})],exports.A_Channel.prototype,"onRequest",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onAfterRequest"})],exports.A_Channel.prototype,"onAfterRequest",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onError"})],exports.A_Channel.prototype,"onError",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onSend"})],exports.A_Channel.prototype,"onSend",1),exports.A_Channel=a([aFrame.A_Frame.Namespace("A-Utils"),aFrame.A_Frame.Component({name:"A-Channel",description:"Component uses as abstract channel for communication patterns. Can be inherited and extended to implement custom channels."})],exports.A_Channel);var Ot=(s=>(s.CREATED="CREATED",s.INITIALIZED="INITIALIZED",s.COMPILED="COMPILED",s.EXECUTING="EXECUTING",s.COMPLETED="COMPLETED",s.FAILED="FAILED",s))(Ot||{}),bt=(o=>(o.CREATED_TO_INITIALIZED="created_initialized",o.INITIALIZED_TO_EXECUTING="initialized_executing",o.EXECUTING_TO_COMPLETED="executing_completed",o.EXECUTING_TO_FAILED="executing_failed",o))(bt||{}),Nt=(c=>(c.onInit="_A_Command_onInit",c.onBeforeExecute="_A_Command_onBeforeExecute",c.onExecute="_A_Command_onExecute",c.onAfterExecute="_A_Command_onAfterExecute",c.onComplete="_A_Command_onComplete",c.onFail="_A_Command_onFail",c.onError="_A_Command_onError",c))(Nt||{}),Dt=(c=>(c.onInit="onInit",c.onBeforeExecute="onBeforeExecute",c.onExecute="onExecute",c.onAfterExecute="onAfterExecute",c.onComplete="onComplete",c.onFail="onFail",c.onError="onError",c))(Dt||{});var oe=class oe extends aConcept.A_Error{};i(oe,"A_CommandError"),oe.CommandScopeBindingError="A-Command Scope Binding Error",oe.ExecutionError="A-Command Execution Error",oe.ResultProcessingError="A-Command Result Processing Error",oe.CommandInterruptedError="A-Command Interrupted Error";var V=oe;var fe=class fe extends aConcept.A_Error{};i(fe,"A_StateMachineError"),fe.InitializationError="A-StateMachine Initialization Error",fe.TransitionError="A-StateMachine Transition Error";var ce=fe;var Gt=(o=>(o.onError="_A_StateMachine_onError",o.onInitialize="_A_StateMachine_onInitialize",o.onBeforeTransition="_A_StateMachine_onBeforeTransition",o.onAfterTransition="_A_StateMachine_onAfterTransition",o))(Gt||{});exports.A_StateMachineTransition=class R extends exports.A_OperationContext{constructor(t){super("a-state-machine-transition",t),this._meta.set("from",t.from),this._meta.set("to",t.to);}get from(){return this._meta.get("from")}get to(){return this._meta.get("to")}};i(exports.A_StateMachineTransition,"A_StateMachineTransition"),exports.A_StateMachineTransition=a([aFrame.A_Frame.Fragment({name:"A-StateMachineTransition",description:"Context for managing state machine transitions."})],exports.A_StateMachineTransition);var zt,Bt,Vt,Ht;exports.A_StateMachine=class E extends aConcept.A_Component{get ready(){return this._initialized||(this._initialized=this.call("_A_StateMachine_onInitialize")),this._initialized}async[Ht="_A_StateMachine_onInitialize"](...t){}async[Vt="_A_StateMachine_onBeforeTransition"](...t){}async[Bt="_A_StateMachine_onAfterTransition"](...t){}async[zt="_A_StateMachine_onError"](...t){}async transition(t,e,r){await this.ready;let o=`${aConcept.A_FormatterHelper.toCamelCase(String(t))}_${aConcept.A_FormatterHelper.toCamelCase(String(e))}`,n=new exports.A_StateMachineTransition({from:String(t),to:String(e),props:r}),s=new aConcept.A_Scope({name:`A-StateMachine-Transition-Scope-${o}`,fragments:[n]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_StateMachine_onBeforeTransition",s),await this.call(o,s),await this.call("_A_StateMachine_onAfterTransition",s),s.destroy(),n.result}catch(c){let p=new ce({title:ce.TransitionError,description:`An error occurred while transitioning to "${o}"`,originalError:c});throw s.register(p),await this.call("_A_StateMachine_onError",s),s.destroy(),p}}};i(exports.A_StateMachine,"A_StateMachine"),a([aConcept.A_Feature.Extend()],exports.A_StateMachine.prototype,Ht,1),a([aConcept.A_Feature.Extend()],exports.A_StateMachine.prototype,Vt,1),a([aConcept.A_Feature.Extend()],exports.A_StateMachine.prototype,Bt,1),a([aConcept.A_Feature.Extend()],exports.A_StateMachine.prototype,zt,1),a([aFrame.A_Frame.Method({name:"transition",description:"Executes a state transition from one state to another."})],exports.A_StateMachine.prototype,"transition",1),exports.A_StateMachine=a([aFrame.A_Frame.Namespace("A-Utils"),aFrame.A_Frame.Component({name:"A-StateMachine",description:"A powerful state machine component for managing complex state transitions."})],exports.A_StateMachine);var Yn={},le=[];var Ce=class Ce extends aConcept.A_Error{};i(Ce,"A_ConfigError"),Ce.InitializationError="A-Config Initialization Error";var $=Ce;exports.A_Config=class h extends exports.A_ExecutionContext{constructor(e){super("a-config");this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...le];this._strict=e.strict??false,this._configProperties=e.variables??[];for(let r in e.defaults)this.set(aConcept.A_FormatterHelper.toUpperSnakeCase(r),e.defaults[r]);}get strict(){return this._strict}get(e){if(this._configProperties.includes(e)||this.DEFAULT_ALLOWED_TO_READ_PROPERTIES.includes(e)||!this._strict)return super.get(aConcept.A_FormatterHelper.toUpperSnakeCase(e));throw new $("Property not exists or not allowed to read")}set(e,r){let o=Array.isArray(e)?e:typeof e=="string"?[{property:e,value:r}]:Object.keys(e).map(n=>({property:n,value:e[n]}));for(let{property:n,value:s}of o)super.set(aConcept.A_FormatterHelper.toUpperSnakeCase(n),s);}};i(exports.A_Config,"A_Config"),exports.A_Config=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-Config",description:"Configuration management context that provides structured access to application configuration variables, supporting defaults and strict mode for enhanced reliability. Default environment variables are included for comprehensive configuration handling."})],exports.A_Config);var ct=20,ei="all",lt={red:"31",yellow:"33",green:"32",blue:"34",cyan:"36",magenta:"35",gray:"90",brightBlue:"94",brightCyan:"96",brightMagenta:"95",darkGray:"30",lightGray:"37",indigo:"38;5;54",violet:"38;5;93",purple:"38;5;129",lavender:"38;5;183",skyBlue:"38;5;117",steelBlue:"38;5;67",slateBlue:"38;5;62",deepBlue:"38;5;18",lightBlue:"38;5;153",periwinkle:"38;5;111",cornflower:"38;5;69",powder:"38;5;152",charcoal:"38;5;236",silver:"38;5;250",smoke:"38;5;244",slate:"38;5;240"},pt=["blue","cyan","magenta","gray","brightBlue","brightCyan","brightMagenta","darkGray","lightGray","indigo","violet","purple","lavender","skyBlue","steelBlue","slateBlue","deepBlue","lightBlue","periwinkle","cornflower","powder","charcoal","silver","smoke","slate"],J={RESET:"\x1B[0m",PREFIX:"\x1B[",SUFFIX:"m"},pe={MINUTES_PAD:2,SECONDS_PAD:2,MILLISECONDS_PAD:3,SEPARATOR:":"},S={SCOPE_OPEN:"[",SCOPE_CLOSE:"]",TIME_OPEN:"|",TIME_CLOSE:"|",SEPARATOR:"-------------------------------",INDENT_BASE:3,PIPE:"| "},_e={DEFAULT_WIDTH:80,MIN_WIDTH:40,MAX_LINE_LENGTH_RATIO:.8,BROWSER_DEFAULT_WIDTH:120},ye={LOG_LEVEL:"A_LOGGER_LEVEL",DEFAULT_SCOPE_LENGTH:"A_LOGGER_DEFAULT_SCOPE_LENGTH",DEFAULT_SCOPE_COLOR:"A_LOGGER_DEFAULT_SCOPE_COLOR",DEFAULT_LOG_COLOR:"A_LOGGER_DEFAULT_LOG_COLOR"};exports.A_Logger=class P extends aConcept.A_Component{constructor(e,r){super();this.scope=e;this.config=r;this.COLORS=lt,this.STANDARD_SCOPE_LENGTH=r?.get(ye.DEFAULT_SCOPE_LENGTH)||20;let o=r?.get(ye.DEFAULT_SCOPE_COLOR),n=r?.get(ye.DEFAULT_LOG_COLOR);if(o||n)this.DEFAULT_SCOPE_COLOR=o||this.generateColorFromScopeName(this.scope.name),this.DEFAULT_LOG_COLOR=n||this.generateColorFromScopeName(this.scope.name);else {let s=this.generateComplementaryColorsFromScope(this.scope.name);this.DEFAULT_SCOPE_COLOR=s.scopeColor,this.DEFAULT_LOG_COLOR=s.logColor;}this.TERMINAL_WIDTH=this.detectTerminalWidth(),this.MAX_CONTENT_WIDTH=Math.floor(this.TERMINAL_WIDTH*_e.MAX_LINE_LENGTH_RATIO);}simpleHash(e){let r=0;for(let o=0;o<e.length;o++){let n=e.charCodeAt(o);r=(r<<5)-r+n,r=r&r;}return Math.abs(r)}generateColorFromScopeName(e){let r=pt,n=this.simpleHash(e)%r.length;return r[n]}generateComplementaryColorsFromScope(e){let r=[{scopeColor:"indigo",logColor:"lightBlue"},{scopeColor:"deepBlue",logColor:"cyan"},{scopeColor:"purple",logColor:"lavender"},{scopeColor:"steelBlue",logColor:"skyBlue"},{scopeColor:"slateBlue",logColor:"periwinkle"},{scopeColor:"charcoal",logColor:"silver"},{scopeColor:"violet",logColor:"brightMagenta"},{scopeColor:"darkGray",logColor:"lightGray"},{scopeColor:"cornflower",logColor:"powder"},{scopeColor:"slate",logColor:"smoke"}],n=this.simpleHash(e)%r.length;return r[n]}detectTerminalWidth(){try{if(aConcept.A_Context.environment==="browser")return _e.BROWSER_DEFAULT_WIDTH;if(typeof process<"u"&&process.stdout&&process.stdout.columns){let e=process.stdout.columns;return Math.max(e,_e.MIN_WIDTH)}return _e.DEFAULT_WIDTH}catch{return _e.DEFAULT_WIDTH}}wrapText(e,r,o=true){if(aConcept.A_Context.environment==="browser")return [e];let n=this.formattedScope.length+4+this.getTime().length+4,s=`${r}${S.PIPE}`,c=Math.max(this.TERMINAL_WIDTH-n-1,20),p=Math.max(this.TERMINAL_WIDTH-s.length,20);if(o&&e.length<=c)return [e];let m=[],_=e.split(" "),g="",u=o?c:p;for(let U of _){let Ge=g?1:0;if(g.length+Ge+U.length>u)if(g)m.push(g),g=U,u=p;else {if(U.length>u){let Ue=this.splitLongWord(U,u);m.push(...Ue.slice(0,-1)),g=Ue[Ue.length-1];}else g=U;u=p;}else g+=(g?" ":"")+U;}return g&&m.push(g),m.length?m:[e]}splitLongWord(e,r){let o=[];for(let n=0;n<e.length;n+=r)o.push(e.slice(n,n+r));return o}get scopeLength(){return Math.max(this.scope.name.length,this.STANDARD_SCOPE_LENGTH)}get formattedScope(){let e=this.scope.name,r=this.STANDARD_SCOPE_LENGTH;if(e.length>=r)return e.substring(0,r);let o=r-e.length,n=Math.floor(o/2),s=o-n;return " ".repeat(n)+e+" ".repeat(s)}compile(e,...r){let o=this.getTime(),n=" ".repeat(this.STANDARD_SCOPE_LENGTH+3),s=r.length>1;return [`${J.PREFIX}${this.COLORS[this.DEFAULT_SCOPE_COLOR]}${J.SUFFIX}${S.SCOPE_OPEN}${this.formattedScope}${S.SCOPE_CLOSE}${J.RESET} ${J.PREFIX}${this.COLORS[e]}${J.SUFFIX}${S.TIME_OPEN}${o}${S.TIME_CLOSE}`,s?`
2
+ ${n}${S.TIME_OPEN}${S.SEPARATOR}`:"",...r.map((c,p)=>{let m=p>0||s;switch(true){case c instanceof aConcept.A_Error:return this.compile_A_Error(c);case c instanceof Error:return this.compile_Error(c);case(typeof c=="object"&&c!==null):return this.formatObject(c,m,n);default:return this.formatString(String(c),m,n)}}),s?`
3
+ ${n}${S.TIME_OPEN}${S.SEPARATOR}${J.RESET}`:J.RESET]}formatObject(e,r,o){if(aConcept.A_Context.environment==="browser")return e;if(e===null)return r?`
4
+ ${o}${S.PIPE}null`:"null";if(e===void 0)return r?`
5
+ ${o}${S.PIPE}undefined`:"undefined";let n;try{n=JSON.stringify(e,null,2);}catch{try{let g=new WeakSet;n=JSON.stringify(e,(u,k)=>{if(typeof k=="object"&&k!==null){if(g.has(k))return "[Circular Reference]";g.add(k);}return k},2);}catch{n=String(e);}}let s=`${o}${S.PIPE}`,c=this.TERMINAL_WIDTH-s.length-4,m=n.split(`
6
+ `).map(_=>{let g=_.match(/^(\s*"[^"]+":\s*")([^"]+)(".*)?$/);if(g&&g[2].length>c-g[1].length-(g[3]||"").length){let[,u,k,U=""]=g;if(k.length>c-u.length-U.length){let Ge=this.wrapJsonStringValue(k,c-u.length-U.length);return u+Ge+U}}return _}).join(`
7
7
  `+s);return r?`
8
- `+s+d:d}wrapJsonStringValue(e,r){return e.length<=r?e:r>6?e.substring(0,r-3)+"...":e.substring(0,Math.max(1,r))}formatString(e,r,o){if(aConcept.A_Context.environment==="browser")return ((r?`
8
+ `+s+m:m}wrapJsonStringValue(e,r){return e.length<=r?e:r>6?e.substring(0,r-3)+"...":e.substring(0,Math.max(1,r))}formatString(e,r,o){if(aConcept.A_Context.environment==="browser")return ((r?`
9
9
  `:"")+e).replace(/\n/g,`
10
- ${o}${y.PIPE}`);let n=this.wrapText(e,o,!r),s=`${o}${y.PIPE}`,a=n.map((_,d)=>d===0&&!r?_:`${s}${_}`);return r?`
11
- `+a.join(`
12
- `):a.join(`
13
- `)}shouldLog(e){switch(this.config?.get(de.LOG_LEVEL)||"info"){case "debug":return true;case "info":return e==="info"||e==="warning"||e==="error";case "warn":return e==="warning"||e==="error";case "error":return e==="error";case "all":return true;default:return false}}debug(e,...r){this.shouldLog("debug")&&(typeof e=="string"&&this.COLORS[e]?console.log(...this.compile(e,...r)):console.log(...this.compile(this.DEFAULT_LOG_COLOR,e,...r)));}info(e,...r){this.shouldLog("info")&&(typeof e=="string"&&this.COLORS[e]?console.log(...this.compile(e,...r)):console.log(...this.compile(this.DEFAULT_LOG_COLOR,e,...r)));}log(e,...r){this.info(e,...r);}warning(...e){this.shouldLog("warning")&&console.log(...this.compile("yellow",...e));}error(...e){this.shouldLog("error")&&console.log(...this.compile("red",...e));}log_A_Error(e){let r=this.getTime(),o=" ".repeat(this.STANDARD_SCOPE_LENGTH+3);console.log(`\x1B[31m[${this.formattedScope}] |${r}| ERROR ${e.code}
10
+ ${o}${S.PIPE}`);let n=this.wrapText(e,o,!r),s=`${o}${S.PIPE}`,c=n.map((p,m)=>m===0&&!r?p:`${s}${p}`);return r?`
11
+ `+c.join(`
12
+ `):c.join(`
13
+ `)}shouldLog(e){switch(this.config?.get(ye.LOG_LEVEL)||"info"){case "debug":return true;case "info":return e==="info"||e==="warning"||e==="error";case "warn":return e==="warning"||e==="error";case "error":return e==="error";case "all":return true;default:return false}}debug(e,...r){this.shouldLog("debug")&&(typeof e=="string"&&this.COLORS[e]?console.log(...this.compile(e,...r)):console.log(...this.compile(this.DEFAULT_LOG_COLOR,e,...r)));}info(e,...r){this.shouldLog("info")&&(typeof e=="string"&&this.COLORS[e]?console.log(...this.compile(e,...r)):console.log(...this.compile(this.DEFAULT_LOG_COLOR,e,...r)));}log(e,...r){this.info(e,...r);}warning(...e){this.shouldLog("warning")&&console.log(...this.compile("yellow",...e));}error(...e){this.shouldLog("error")&&console.log(...this.compile("red",...e));}log_A_Error(e){let r=this.getTime(),o=" ".repeat(this.STANDARD_SCOPE_LENGTH+3);console.log(`\x1B[31m[${this.formattedScope}] |${r}| ERROR ${e.code}
14
14
  ${o}| ${e.message}
15
15
  ${o}| ${e.description}
16
16
  ${o}|-------------------------------
@@ -26,10 +26,10 @@ ${o}| ${e.originalError.stack?.split(`
26
26
  ${o}|-------------------------------
27
27
  \x1B[0m`:"")+(e.link?`\x1B[31m${o}| Read in docs: ${e.link}
28
28
  ${o}|-------------------------------
29
- \x1B[0m`:""));}compile_A_Error(e){let r=`${" ".repeat(this.STANDARD_SCOPE_LENGTH+3)}${y.PIPE}`,o=`${r}-------------------------------`,n=[];n.push(""),n.push(o),n.push(`${r}A_ERROR: ${e.code}`),n.push(o);let s=this.wrapText(`Message: ${e.message}`,r,false),a=this.wrapText(`Description: ${e.description}`,r,false);if(n.push(...s.map(_=>`${r}${_}`)),n.push(...a.map(_=>`${r}${_}`)),e.originalError){n.push(o),n.push(`${r}ORIGINAL ERROR:`),n.push(o);let _=this.wrapText(`${e.originalError.name}: ${e.originalError.message}`,r,false);if(n.push(..._.map(d=>`${r}${d}`)),e.originalError.stack){n.push(`${r}Stack trace:`);let d=this.formatStackTrace(e.originalError.stack,r);n.push(...d);}}if(e.stack){n.push(o),n.push(`${r}A_ERROR STACK:`),n.push(o);let _=this.formatStackTrace(e.stack,r);n.push(..._);}if(e.link){n.push(o);let _=this.wrapText(`Documentation: ${e.link}`,r,false);n.push(..._.map(d=>`${r}${d}`));}return n.push(o),n.join(`
29
+ \x1B[0m`:""));}compile_A_Error(e){let r=`${" ".repeat(this.STANDARD_SCOPE_LENGTH+3)}${S.PIPE}`,o=`${r}-------------------------------`,n=[];n.push(""),n.push(o),n.push(`${r}A_ERROR: ${e.code}`),n.push(o);let s=this.wrapText(`Message: ${e.message}`,r,false),c=this.wrapText(`Description: ${e.description}`,r,false);if(n.push(...s.map(p=>`${r}${p}`)),n.push(...c.map(p=>`${r}${p}`)),e.originalError){n.push(o),n.push(`${r}ORIGINAL ERROR:`),n.push(o);let p=this.wrapText(`${e.originalError.name}: ${e.originalError.message}`,r,false);if(n.push(...p.map(m=>`${r}${m}`)),e.originalError.stack){n.push(`${r}Stack trace:`);let m=this.formatStackTrace(e.originalError.stack,r);n.push(...m);}}if(e.stack){n.push(o),n.push(`${r}A_ERROR STACK:`),n.push(o);let p=this.formatStackTrace(e.stack,r);n.push(...p);}if(e.link){n.push(o);let p=this.wrapText(`Documentation: ${e.link}`,r,false);n.push(...p.map(m=>`${r}${m}`));}return n.push(o),n.join(`
30
30
  `)}formatStackTrace(e,r){let o=e.split(`
31
- `),n=[];return o.forEach((s,a)=>{if(s.trim()){let _=a===0?r:`${r} `,d=this.wrapText(s.trim(),_,false);n.push(...d.map(p=>a===0&&p===d[0]?`${r}${p}`:`${r} ${p}`));}}),n}compile_Error(e){let r=`${" ".repeat(this.STANDARD_SCOPE_LENGTH+3)}${y.PIPE}`,o=`${r}-------------------------------`,n=[];n.push(""),n.push(o),n.push(`${r}ERROR: ${e.name}`),n.push(o);let s=this.wrapText(`Message: ${e.message}`,r,false);if(n.push(...s.map(a=>`${r}${a}`)),e.stack){n.push(o),n.push(`${r}STACK TRACE:`),n.push(o);let a=this.formatStackTrace(e.stack,r);n.push(...a);}return n.push(o),n.join(`
32
- `)}getTime(){let e=new Date,r=String(e.getMinutes()).padStart(ee.MINUTES_PAD,"0"),o=String(e.getSeconds()).padStart(ee.SECONDS_PAD,"0"),n=String(e.getMilliseconds()).padStart(ee.MILLISECONDS_PAD,"0");return `${r}${ee.SEPARATOR}${o}${ee.SEPARATOR}${n}`}};i(exports.A_Logger,"A_Logger"),exports.A_Logger=c([l(0,aConcept.A_Inject(aConcept.A_Scope)),l(1,aConcept.A_Inject(A))],exports.A_Logger);var mr,hr,gr,fr,yr,Ar,Er,Tr,Sr,xr,Cr,C=class C extends aConcept.A_Entity{constructor(e){super(e);this._listeners=new Map;}static get code(){return super.entity}get duration(){return this._endTime&&this._startTime?this._endTime.getTime()-this._startTime.getTime():this._startTime?new Date().getTime()-this._startTime.getTime():void 0}get idleTime(){return this._startTime&&this._createdAt?this._startTime.getTime()-this._createdAt.getTime():void 0}get scope(){return this._executionScope}get context(){return this.scope.resolve(b)}get code(){return this.constructor.code}get status(){return this._status}get createdAt(){return this._createdAt}get startedAt(){return this._startTime}get endedAt(){return this._endTime}get result(){return this._result}get error(){return this._error}get params(){return this._params}get isProcessed(){return this._status==="COMPLETED"||this._status==="FAILED"}async[Cr="_A_StateMachine_onBeforeTransition"](e,r,...o){this.checkScopeInheritance(),r?.debug("yellow",`Command ${this.aseid.toString()} transitioning from ${e.from} to ${e.to}`);}async[xr="created_initialized"](e,...r){this._status==="CREATED"&&(this._createdAt=new Date,this._status="INITIALIZED",this.emit("onInit"));}async[Sr="initialized_executing"](e,...r){this._status!=="INITIALIZED"&&this._status!=="CREATED"||(this._startTime=new Date,this._status="EXECUTING",this.emit("onExecute"));}async[Tr="executing_completed"](e,...r){this._endTime=new Date,this._status="COMPLETED",this.emit("onComplete");}async[Er="executing_failed"](e,r,...o){this._endTime=new Date,this._status="FAILED",this.emit("onFail");}async[Ar="_A_Command_onInit"](e,...r){await e.transition("CREATED","INITIALIZED");}async[yr="_A_Command_onBeforeExecute"](e,...r){await e.transition("INITIALIZED","EXECUTING");}async[fr="_A_Command_onExecute"](...e){}async[gr="_A_Command_onAfterExecute"](...e){}async[hr="_A_Command_onComplete"](e,...r){await e.transition("EXECUTING","COMPLETED");}async[mr="_A_Command_onFail"](e,r,...o){await e.transition("EXECUTING","FAILED");}async init(){await this.call("_A_Command_onInit",this.scope);}async execute(){if(!this.isProcessed)try{this.checkScopeInheritance();let e=new b("execute-command");this.scope.register(e),await new Promise(async(r,o)=>{try{let n=new aConcept.A_Feature({name:"_A_Command_onBeforeExecute",component:this,scope:this.scope}),s=new aConcept.A_Feature({name:"_A_Command_onExecute",component:this,scope:this.scope}),a=new aConcept.A_Feature({name:"_A_Command_onAfterExecute",component:this,scope:this.scope});this.on("onComplete",()=>{n.interrupt(),s.interrupt(),a.interrupt(),r();}),this.on("onFail",()=>{n.interrupt(),s.interrupt(),a.interrupt(),o(this.error);}),await n.process(this.scope),await s.process(this.scope),await a.process(this.scope),this._origin==="invoked"&&await this.complete(),r();}catch(n){o(n);}});}catch(e){let r=e instanceof aConcept.A_Error?e:new Y({title:Y.ExecutionError,description:`An error occurred while executing command "${this.aseid.toString()}".`,originalError:e});await this.fail(r);}}async complete(e){this.isProcessed||(this._status="COMPLETED",this._result=e,await this.call("_A_Command_onComplete",this.scope),this.scope.destroy());}async fail(e){this.isProcessed||(this._status="FAILED",e&&(this._error=e,this.scope.register(e)),await this.call("_A_Command_onFail",this.scope),this.scope.destroy());}on(e,r){this._listeners.has(e)||this._listeners.set(e,new Set),this._listeners.get(e).add(r);}off(e,r){this._listeners.get(e)?.delete(r);}emit(e){this._listeners.get(e)?.forEach(async r=>{r(this);});}fromNew(e){super.fromNew(e),this._origin="invoked",this._executionScope=new aConcept.A_Scope({name:`A-Command-Execution-Scope-${this.aseid.toString()}`,components:[G]}),this._createdAt=new Date,this._params=e,this._status="CREATED";}fromJSON(e){super.fromJSON(e),this._origin="serialized",this._executionScope=new aConcept.A_Scope({name:`A-Command-Execution-Scope-${this.aseid.toString()}`,components:[G]}),e.createdAt&&(this._createdAt=new Date(e.createdAt)),e.startedAt&&(this._startTime=new Date(e.startedAt)),e.endedAt&&(this._endTime=new Date(e.endedAt)),this._params=e.params,this._status=e.status,e.error&&(this._error=new Y(e.error)),e.result&&(this._result=e.result);}toJSON(){return {...super.toJSON(),code:this.code,status:this._status,params:this._params,createdAt:this._createdAt.toISOString(),startedAt:this._startTime?this._startTime.toISOString():void 0,endedAt:this._endTime?this._endTime.toISOString():void 0,duration:this.duration,idleTime:this.idleTime,result:this.result,error:this.error?this.error.toJSON():void 0}}checkScopeInheritance(){let e;try{e=aConcept.A_Context.scope(this);}catch(r){throw new Y({title:Y.CommandScopeBindingError,description:`Command ${this.aseid.toString()} is not bound to any context scope. Ensure the command is properly registered within a context before execution.`,originalError:r})}this.scope.isInheritedFrom(aConcept.A_Context.scope(this))||this.scope.inherit(aConcept.A_Context.scope(this));}};i(C,"A_Command"),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(N)),l(1,aConcept.A_Inject(exports.A_Logger))],C.prototype,Cr,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(N))],C.prototype,xr,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(N))],C.prototype,Sr,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(N))],C.prototype,Tr,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(N)),l(1,aConcept.A_Inject(aConcept.A_Error))],C.prototype,Er,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(G))],C.prototype,Ar,1),c([aConcept.A_Feature.Extend({after:/.*/}),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(G))],C.prototype,yr,1),c([aConcept.A_Feature.Extend()],C.prototype,fr,1),c([aConcept.A_Feature.Extend()],C.prototype,gr,1),c([aConcept.A_Feature.Extend({after:/.*/}),l(0,aConcept.A_Inject(G))],C.prototype,hr,1),c([aConcept.A_Feature.Extend({after:/.*/}),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(G)),l(1,aConcept.A_Inject(b))],C.prototype,mr,1);var Ke=C;var We=class We{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._fs}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){this._fs=await import('fs');}initBrowser(){this._fs={readFileSync:i((t,e)=>(this.logger.warning("fs.readFileSync not available in browser environment"),""),"readFileSync"),existsSync:i(t=>(this.logger.warning("fs.existsSync not available in browser environment"),false),"existsSync"),createReadStream:i(t=>(this.logger.warning("fs.createReadStream not available in browser environment"),null),"createReadStream")};}};i(We,"A_FSPolyfillClass");var Se=We;var Je=class Je{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(t){return this._initialized||(this._fsPolyfill=t,await this.init()),this._crypto}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('crypto');this._crypto={createTextHash:i((e,r="sha384")=>Promise.resolve(`${r}-${t.createHash(r).update(e).digest("base64")}`),"createTextHash"),createFileHash:i((e,r="sha384")=>new Promise(async(o,n)=>{try{if(!this._fsPolyfill)throw new Error("FS polyfill is required for file hashing");let s=t.createHash(r),a=this._fsPolyfill.createReadStream(e);a.on("data",_=>s.update(_)),a.on("end",()=>o(`${r}-${s.digest("base64")}`)),a.on("error",_=>n(_));}catch(s){n(s);}}),"createFileHash")};}initBrowser(){this._crypto={createFileHash:i(()=>(this.logger.warning("File hash not available in browser environment"),Promise.resolve("")),"createFileHash"),createTextHash:i((t,e="SHA-384")=>new Promise(async(r,o)=>{try{if(!crypto.subtle)throw new Error("SubtleCrypto not available");let s=new TextEncoder().encode(t),a=await crypto.subtle.digest(e,s),_=Array.from(new Uint8Array(a)),d=btoa(String.fromCharCode(..._));r(`${e}-${d}`);}catch(n){o(n);}}),"createTextHash")};}};i(Je,"A_CryptoPolyfillClass");var xe=Je;var Xe=class Xe{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._http}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('http');this._http={request:t.request,get:t.get,createServer:t.createServer};}initBrowser(){this._http={request:i((t,e)=>(this.logger.warning("http.request not available in browser/test environment, use fetch instead"),this.createMockRequest(t,e,false)),"request"),get:i((t,e)=>(this.logger.warning("http.get not available in browser/test environment, use fetch instead"),this.createMockRequest(typeof t=="string"?{hostname:t}:t,e,false)),"get"),createServer:i(()=>(this.logger.error("http.createServer not available in browser/test environment"),null),"createServer")};}createMockRequest(t,e,r=false){return {end:i(()=>{if(e){let n={statusCode:200,headers:{},on:i((s,a)=>{s==="data"?setTimeout(()=>a("mock data"),0):s==="end"&&setTimeout(()=>a(),0);},"on"),pipe:i(s=>{s.write&&s.write("mock data"),s.end&&s.end();},"pipe")};setTimeout(()=>e(n),0);}},"end"),write:i(n=>{},"write"),on:i((n,s)=>{},"on")}}};i(Xe,"A_HttpPolyfillClass");var Ce=Xe;var Ze=class Ze{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._https}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('https');this._https={request:t.request,get:t.get,createServer:t.createServer};}initBrowser(){this._https={request:i((t,e)=>(this.logger.warning("https.request not available in browser/test environment, use fetch instead"),this.createMockRequest(t,e,true)),"request"),get:i((t,e)=>(this.logger.warning("https.get not available in browser/test environment, use fetch instead"),this.createMockRequest(typeof t=="string"?{hostname:t}:t,e,true)),"get"),createServer:i(()=>(this.logger.error("https.createServer not available in browser/test environment"),null),"createServer")};}createMockRequest(t,e,r=true){return {end:i(()=>{if(e){let n={statusCode:200,headers:{},on:i((s,a)=>{s==="data"?setTimeout(()=>a("mock data"),0):s==="end"&&setTimeout(()=>a(),0);},"on"),pipe:i(s=>{s.write&&s.write("mock data"),s.end&&s.end();},"pipe")};setTimeout(()=>e(n),0);}},"end"),write:i(n=>{},"write"),on:i((n,s)=>{},"on")}}};i(Ze,"A_HttpsPolyfillClass");var Re=Ze;var Qe=class Qe{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._path}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){this._path=await import('path');}initBrowser(){this._path={join:i((...t)=>t.join("/").replace(/\/+/g,"/"),"join"),resolve:i((...t)=>{let e="";for(let r of t)r.startsWith("/")?e=r:e=this._path.join(e,r);return e||"/"},"resolve"),dirname:i(t=>t.split("/").slice(0,-1).join("/")||"/","dirname"),basename:i((t,e)=>{let r=t.split("/").pop()||"";return e&&r.endsWith(e)?r.slice(0,-e.length):r},"basename"),extname:i(t=>{let e=t.split(".");return e.length>1?"."+e.pop():""},"extname"),relative:i((t,e)=>e.replace(t,"").replace(/^\//,""),"relative"),normalize:i(t=>t.replace(/\/+/g,"/").replace(/\/$/,"")||"/","normalize"),isAbsolute:i(t=>t.startsWith("/")||/^[a-zA-Z]:/.test(t),"isAbsolute"),parse:i(t=>{let e=this._path.extname(t),r=this._path.basename(t),o=this._path.basename(t,e);return {root:"/",dir:this._path.dirname(t),base:r,ext:e,name:o}},"parse"),format:i(t=>this._path.join(t.dir||"",t.base||""),"format"),sep:"/",delimiter:":"};}};i(Qe,"A_PathPolyfillClass");var we=Qe;var et=class et{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._url}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('url');this._url={parse:t.parse,format:t.format,resolve:t.resolve,URL:t.URL||globalThis.URL,URLSearchParams:t.URLSearchParams||globalThis.URLSearchParams};}initBrowser(){this._url={parse:i(t=>{try{let e=new URL(t);return {protocol:e.protocol,hostname:e.hostname,port:e.port,pathname:e.pathname,search:e.search,hash:e.hash,host:e.host,href:e.href}}catch{return {}}},"parse"),format:i(t=>{try{return new URL("",t.href||`${t.protocol}//${t.host}${t.pathname}${t.search}${t.hash}`).href}catch{return ""}},"format"),resolve:i((t,e)=>{try{return new URL(e,t).href}catch{return e}},"resolve"),URL:globalThis.URL,URLSearchParams:globalThis.URLSearchParams};}};i(et,"A_UrlPolyfillClass");var Pe=et;var tt=class tt{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._buffer}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('buffer');this._buffer={from:t.Buffer.from,alloc:t.Buffer.alloc,allocUnsafe:t.Buffer.allocUnsafe,isBuffer:t.Buffer.isBuffer,concat:t.Buffer.concat};}initBrowser(){this._buffer={from:i((t,e)=>typeof t=="string"?new TextEncoder().encode(t):new Uint8Array(t),"from"),alloc:i((t,e)=>{let r=new Uint8Array(t);return e!==void 0&&r.fill(e),r},"alloc"),allocUnsafe:i(t=>new Uint8Array(t),"allocUnsafe"),isBuffer:i(t=>t instanceof Uint8Array||t instanceof ArrayBuffer,"isBuffer"),concat:i((t,e)=>{let r=e||t.reduce((s,a)=>s+a.length,0),o=new Uint8Array(r),n=0;for(let s of t)o.set(s,n),n+=s.length;return o},"concat")};}};i(tt,"A_BufferPolyfillClass");var Le=tt;var rt=class rt{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._process}async init(){try{aConcept.A_Context.environment==="server"?this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}initServer(){this._process={env:process.env,argv:process.argv,platform:process.platform,version:process.version,versions:process.versions,cwd:process.cwd,exit:process.exit,nextTick:process.nextTick};}initBrowser(){this._process={env:{NODE_ENV:"browser",...globalThis.process?.env||{}},argv:["browser"],platform:"browser",version:"browser",versions:{node:"browser"},cwd:i(()=>"/","cwd"),exit:i(t=>{throw this.logger.warning("process.exit not available in browser"),new Error(`Process exit with code ${t}`)},"exit"),nextTick:i((t,...e)=>{setTimeout(()=>t(...e),0);},"nextTick")};}};i(rt,"A_ProcessPolyfillClass");var ve=rt;exports.A_Polyfill=class f extends aConcept.A_Component{constructor(e){super();this.logger=e;this._initializing=null;}get ready(){return this._initialized||(this._initialized=this._loadInternal()),this._initialized}async load(){await this.ready;}async attachToWindow(){aConcept.A_Context.environment==="browser"&&(globalThis.A_Polyfill=this,globalThis.process={env:{NODE_ENV:"production"},cwd:i(()=>"/","cwd")},globalThis.__dirname="/");}async _loadInternal(){this._fsPolyfill=new Se(this.logger),this._cryptoPolyfill=new xe(this.logger),this._httpPolyfill=new Ce(this.logger),this._httpsPolyfill=new Re(this.logger),this._pathPolyfill=new we(this.logger),this._urlPolyfill=new Pe(this.logger),this._bufferPolyfill=new Le(this.logger),this._processPolyfill=new ve(this.logger),await this._fsPolyfill.get(),await this._cryptoPolyfill.get(await this._fsPolyfill.get()),await this._httpPolyfill.get(),await this._httpsPolyfill.get(),await this._pathPolyfill.get(),await this._urlPolyfill.get(),await this._bufferPolyfill.get(),await this._processPolyfill.get();}async fs(){return await this.ready,await this._fsPolyfill.get()}async crypto(){return await this.ready,await this._cryptoPolyfill.get()}async http(){return await this.ready,await this._httpPolyfill.get()}async https(){return await this.ready,await this._httpsPolyfill.get()}async path(){return await this.ready,await this._pathPolyfill.get()}async url(){return await this.ready,await this._urlPolyfill.get()}async buffer(){return await this.ready,await this._bufferPolyfill.get()}async process(){return await this.ready,await this._processPolyfill.get()}};i(exports.A_Polyfill,"A_Polyfill"),c([aConcept.A_Concept.Load()],exports.A_Polyfill.prototype,"load",1),c([aConcept.A_Concept.Load()],exports.A_Polyfill.prototype,"attachToWindow",1),exports.A_Polyfill=c([l(0,aConcept.A_Inject(exports.A_Logger))],exports.A_Polyfill);exports.ConfigReader=class R extends aConcept.A_Component{constructor(e){super();this.polyfill=e;this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...Q];}async attachContext(e,r,o){o||(o=new A({defaults:{}}),e.scope.register(o));let n=await this.getProjectRoot();o.set("A_CONCEPT_ROOT_FOLDER",n);}async initialize(e){let r=await this.read();for(let o in r)e.set(o,r[o]);}resolve(e){return e}async read(e=[]){return {}}async getProjectRoot(e=__dirname){return (await this.polyfill.process()).cwd()}};i(exports.ConfigReader,"ConfigReader"),c([aConcept.A_Concept.Load(),l(0,aConcept.A_Inject(aConcept.A_Container)),l(1,aConcept.A_Inject(aConcept.A_Scope)),l(2,aConcept.A_Inject(A))],exports.ConfigReader.prototype,"attachContext",1),c([aConcept.A_Concept.Load(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(A))],exports.ConfigReader.prototype,"initialize",1),exports.ConfigReader=c([l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_Polyfill))],exports.ConfigReader);var ot=class ot extends exports.ConfigReader{constructor(){super(...arguments);this.FileData=new Map;}getConfigurationProperty_File_Alias(e){return aConcept.A_FormatterHelper.toCamelCase(e)}resolve(e){return this.FileData.get(this.getConfigurationProperty_File_Alias(e))}async read(e){let r=await this.polyfill.fs();try{let o=r.readFileSync(`${aConcept.A_Context.concept}.conf.json`,"utf8"),n=JSON.parse(o);return this.FileData=new Map(Object.entries(n)),n}catch{return {}}}};i(ot,"FileConfigReader");var me=ot;var Ie=class Ie extends exports.ConfigReader{async readEnvFile(t,e,r){let o=await e.fs();o.existsSync(".env")&&o.readFileSync(`${t.get("A_CONCEPT_ROOT_FOLDER")}/.env`,"utf-8").split(`
33
- `).forEach(n=>{let[s,a]=n.split("=");s&&a&&(process.env[s.trim()]=a.trim());});}getConfigurationProperty_ENV_Alias(t){return aConcept.A_FormatterHelper.toUpperSnakeCase(t)}resolve(t){return process.env[this.getConfigurationProperty_ENV_Alias(t)]}async read(t=[]){let e=[...t,...Object.keys(process.env)],r={};return e.forEach(o=>{r[o]=this.resolve(o);}),r}};i(Ie,"ENVConfigReader"),c([aConcept.A_Concept.Load({before:["ENVConfigReader.initialize"]}),l(0,aConcept.A_Inject(A)),l(1,aConcept.A_Inject(exports.A_Polyfill)),l(2,aConcept.A_Inject(aConcept.A_Feature))],Ie.prototype,"readEnvFile",1);var re=Ie;var Oe=class Oe extends aConcept.A_Container{async prepare(t){if(!this.scope.has(A)){let r=new A({variables:[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...Q],defaults:{}});this.scope.register(r);}let e=await t.fs();try{switch(!0){case(aConcept.A_Context.environment==="server"&&!!e.existsSync(`${aConcept.A_Context.concept}.conf.json`)):this.reader=this.scope.resolve(me);break;case(aConcept.A_Context.environment==="server"&&!e.existsSync(`${aConcept.A_Context.concept}.conf.json`)):this.reader=this.scope.resolve(re);break;case aConcept.A_Context.environment==="browser":this.reader=this.scope.resolve(re);break;default:throw new $($.InitializationError,`Environment ${aConcept.A_Context.environment} is not supported`)}}catch(r){if(r instanceof aConcept.A_ScopeError)throw new $({title:$.InitializationError,description:`Failed to initialize A_ConfigLoader. Reader not found for environment ${aConcept.A_Context.environment}`,originalError:r})}}};i(Oe,"A_ConfigLoader"),c([aConcept.A_Concept.Load({before:/.*/}),l(0,aConcept.A_Inject(exports.A_Polyfill))],Oe.prototype,"prepare",1);var it=Oe;var Jr=(j=>j)(Jr||{});var be={A_LOGGER_LEVEL:"A_LOGGER_LEVEL",A_LOGGER_DEFAULT_SCOPE_LENGTH:"A_LOGGER_DEFAULT_SCOPE_LENGTH",A_LOGGER_DEFAULT_SCOPE_COLOR:"A_LOGGER_DEFAULT_SCOPE_COLOR",A_LOGGER_DEFAULT_LOG_COLOR:"A_LOGGER_DEFAULT_LOG_COLOR"},As=[be.A_LOGGER_LEVEL,be.A_LOGGER_DEFAULT_SCOPE_LENGTH,be.A_LOGGER_DEFAULT_SCOPE_COLOR,be.A_LOGGER_DEFAULT_LOG_COLOR];var Ne=class Ne extends aConcept.A_Error{};i(Ne,"A_ManifestError"),Ne.ManifestInitializationError="A-Manifest Initialization Error";var H=Ne;var st=class st{constructor(t,e,r,o=false){this.manifest=t;this.component=e;this.method=r;this.checkExclusion=o;}for(t){let e=this.manifest.internal_checkAccess({component:this.component,method:this.method,target:t});return this.checkExclusion?!e:e}};i(st,"A_ManifestChecker");var oe=st;var ct=class ct extends aConcept.A_Fragment{constructor(e=[]){super({name:"A-Manifest"});this.rules=[];this.prepare(e);}prepare(e){if(!aConcept.A_TypeGuards.isArray(e))throw new H(H.ManifestInitializationError,"A-Manifest configuration should be an array of configurations");for(let r of e)this.processConfigItem(r);}processConfigItem(e){if(!aConcept.A_TypeGuards.isComponentConstructor(e.component))throw new H(H.ManifestInitializationError,"A-Manifest configuration item should be a A-Component constructor");let r=this.constructorToRegex(e.component);if(e.apply||e.exclude){let o=/.*/;this.rules.push({componentRegex:r,methodRegex:o,applyRegex:e.apply?this.allowedComponentsToRegex(e.apply):void 0,excludeRegex:e.exclude?this.allowedComponentsToRegex(e.exclude):void 0});}if(e.methods&&e.methods.length>0)for(let o of e.methods){let n=this.methodToRegex(o.method);this.rules.push({componentRegex:r,methodRegex:n,applyRegex:o.apply?this.allowedComponentsToRegex(o.apply):void 0,excludeRegex:o.exclude?this.allowedComponentsToRegex(o.exclude):void 0});}}constructorToRegex(e){return new RegExp(`^${this.escapeRegex(e.name)}$`)}methodToRegex(e){return e instanceof RegExp?e:new RegExp(`^${this.escapeRegex(e)}$`)}allowedComponentsToRegex(e){if(e instanceof RegExp)return e;let r=e.map(o=>this.escapeRegex(o.name));return new RegExp(`^(${r.join("|")})$`)}escapeRegex(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}configItemToRegexp(e){return this.constructorToRegex(e)}ID(e,r){return `${e.name}.${r}`}isAllowed(e,r){let o=typeof e=="function"?e:e.constructor;return new oe(this,o,r)}internal_checkAccess(e){let r=e.component.name,o=e.method,n=e.target.name,s=this.rules.filter(a=>a.componentRegex.test(r)&&a.methodRegex.test(o)).sort((a,_)=>{let d=a.methodRegex.source===".*",p=_.methodRegex.source===".*";return d&&!p?1:!d&&p?-1:0});if(s.length===0)return true;for(let a of s){if(a.excludeRegex&&a.excludeRegex.test(n))return false;if(a.applyRegex)return a.applyRegex.test(n)}return true}isExcluded(e,r){let o=typeof e=="function"?e:e.constructor;return new oe(this,o,r,true)}};i(ct,"A_Manifest");var at=ct;var Qr=(p=>(p.onInit="_A_Memory_onInit",p.onDestroy="_A_Memory_onDestroy",p.onExpire="_A_Memory_onExpire",p.onError="_A_Memory_onError",p.onSerialize="_A_Memory_onSerialize",p.onSet="_A_Memory_onSet",p.onGet="_A_Memory_onGet",p.onDrop="_A_Memory_onDrop",p.onClear="_A_Memory_onClear",p.onHas="_A_Memory_onHas",p))(Qr||{});var lt=class lt extends aConcept.A_Fragment{constructor(){super(...arguments);this._storage=new Map;}set(e,r){this._storage.set(e,r);}get(e){return this._storage.get(e)}delete(e){this._storage.delete(e);}has(e){return this._storage.has(e)}clear(){this._storage.clear();}};i(lt,"A_MemoryContext");var v=lt;var D=class D extends aConcept.A_Error{};i(D,"A_MemoryError"),D.MemoryInitializationError="Memory initialization error",D.MemoryDestructionError="Memory destruction error",D.MemoryGetError="Memory GET operation failed",D.MemorySetError="Memory SET operation failed",D.MemoryDropError="Memory DROP operation failed",D.MemoryClearError="Memory CLEAR operation failed",D.MemoryHasError="Memory HAS operation failed",D.MemorySerializeError="Memory toJSON operation failed";var g=D;var oo,no,io,so,ao,co,lo,_o,po,I=class I extends aConcept.A_Component{get ready(){return this._ready||(this._ready=this.init()),this._ready}async[po="_A_Memory_onError"](...t){}async[_o="_A_Memory_onExpire"](...t){}async[lo="_A_Memory_onInit"](t,...e){t||(t=new v,aConcept.A_Context.scope(this).register(t));}async[co="_A_Memory_onDestroy"](t,...e){t.clear();}async[ao="_A_Memory_onGet"](t,e,...r){t.succeed(e.get(t.params.key));}async[so="_A_Memory_onHas"](t,e,...r){t.succeed(e.has(t.params.key));}async[io="_A_Memory_onSet"](t,e,r,...o){e.set(t.params.key,t.params.value);}async[no="_A_Memory_onDrop"](t,e,...r){e.delete(t.params.key);}async[oo="_A_Memory_onClear"](t,e,...r){e.clear();}async init(){if(this._ready)return this._ready;let t=new aConcept.A_Scope({name:"A-Memory-Init-Scope"}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onInit",t);}catch(e){let r=new g({title:g.MemoryInitializationError,description:"An error occurred during memory initialization",originalError:e});throw t.register(r),await this.call("_A_Memory_onError",t),t.destroy(),r}}async destroy(){let t=new aConcept.A_Scope({name:"A-Memory-Destroy-Scope"}).inherit(aConcept.A_Context.scope(this));try{this._ready=void 0,await this.call("_A_Memory_onDestroy",t);}catch(e){let r=new g({title:g.MemoryDestructionError,description:"An error occurred during memory destruction",originalError:e});throw t.register(r),await this.call("_A_Memory_onError",t),t.destroy(),r}}async get(t){let e=new u("get",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Get-Operation-Scope",fragments:[e]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_Memory_onGet",r),r.destroy(),e.result}catch(o){let n=new g({title:g.MemoryGetError,description:`An error occurred while getting the value for key "${String(t)}"`,originalError:o});throw r.register(n),await this.call("_A_Memory_onError",r),r.destroy(),n}}async has(t){let e=new u("has",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Has-Operation-Scope",fragments:[e]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_Memory_onHas",r),r.destroy(),e.result}catch(o){let n=new g({title:g.MemoryHasError,description:`An error occurred while checking existence for key "${String(t)}"`,originalError:o});throw r.register(n),await this.call("_A_Memory_onError",r),r.destroy(),n}}async set(t,e){let r=new u("set",{key:t,value:e}),o=new aConcept.A_Scope({name:"A-Memory-Set-Operation-Scope",fragments:[r]}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onSet",o);}catch(n){let s=new g({title:g.MemorySetError,description:`An error occurred while setting the value for key "${String(t)}"`,originalError:n});throw o.register(s),await this.call("_A_Memory_onError",o),o.destroy(),s}}async drop(t){let e=new u("drop",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Drop-Operation-Scope",fragments:[e]}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onDrop",r);}catch(o){let n=new g({title:g.MemoryDropError,description:`An error occurred while dropping the value for key "${String(t)}"`,originalError:o});throw r.register(n),await this.call("_A_Memory_onError",r),r.destroy(),n}}async clear(){let t=new u("clear"),e=new aConcept.A_Scope({name:"A-Memory-Clear-Operation-Scope",fragments:[t]}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onClear",e);}catch(r){let o=new g({title:g.MemoryClearError,description:"An error occurred while clearing the memory",originalError:r});throw e.register(o),await this.call("_A_Memory_onError",e),e.destroy(),o}}async toJSON(){let t=new u("serialize"),e=new aConcept.A_Scope({name:"A-Memory-Serialize-Operation-Scope",fragments:[t]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_Memory_onSerialize",e),t.result}catch(r){let o=new g({title:g.MemorySerializeError,description:"An error occurred while serializing the memory",originalError:r});throw e.register(o),await this.call("_A_Memory_onError",e),e.destroy(),o}}};i(I,"A_Memory"),c([aConcept.A_Feature.Extend()],I.prototype,po,1),c([aConcept.A_Feature.Extend()],I.prototype,_o,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(v))],I.prototype,lo,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(v))],I.prototype,co,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(u)),l(1,aConcept.A_Inject(v))],I.prototype,ao,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(u)),l(1,aConcept.A_Inject(v))],I.prototype,so,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(u)),l(1,aConcept.A_Inject(v)),l(2,aConcept.A_Inject(aConcept.A_Scope))],I.prototype,io,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(u)),l(1,aConcept.A_Inject(v))],I.prototype,no,1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(u)),l(1,aConcept.A_Inject(v))],I.prototype,oo,1);var _t=I;var uo=(p=>(p.onBeforeLoad="_A_Service_onBeforeLoad",p.onLoad="_A_Service_onLoad",p.onAfterLoad="_A_Service_onAfterLoad",p.onBeforeStart="_A_Service_onBeforeStart",p.onStart="_A_Service_onStart",p.onAfterStart="_A_Service_onAfterStart",p.onBeforeStop="_A_Service_onBeforeStop",p.onStop="_A_Service_onStop",p.onAfterStop="_A_Service_onAfterStop",p.onError="_A_Service_onError",p))(uo||{});var ne=class ne extends aConcept.A_Error{};i(ne,"A_Service_Error"),ne.ServiceLoadError="Service load error",ne.ServiceStartError="Service start error",ne.ServiceStopError="Service stop error";var S=ne;var go,fo,yo,Ao,Eo,To,So,xo,Co,Ro,E=class E extends aConcept.A_Container{async load(){try{await this.call("_A_Service_onBeforeLoad"),await this.call("_A_Service_onLoad"),await this.call("_A_Service_onAfterLoad");}catch(t){let e;switch(true){case t instanceof S:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof S):e=t.originalError;break;default:e=new S({title:S.ServiceLoadError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async start(){try{await this.call("_A_Service_onBeforeStart"),await this.call("_A_Service_onStart"),await this.call("_A_Service_onAfterStart");}catch(t){let e;switch(true){case t instanceof S:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof S):e=t.originalError;break;default:e=new S({title:S.ServiceStartError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async stop(){try{await this.call("_A_Service_onBeforeStop"),await this.call("_A_Service_onStop"),await this.call("_A_Service_onAfterStop");}catch(t){let e;switch(true){case t instanceof S:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof S):e=t.originalError;break;default:e=new S({title:S.ServiceStopError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async[Ro="_A_Service_onBeforeLoad"](t,...e){t||(this.scope.register(exports.A_Polyfill),t=this.scope.resolve(exports.A_Polyfill));}async[Co="_A_Service_onLoad"](...t){}async[xo="_A_Service_onAfterLoad"](...t){}async[So="_A_Service_onBeforeStart"](...t){}async[To="_A_Service_onStart"](...t){}async[Eo="_A_Service_onAfterStart"](...t){}async[Ao="_A_Service_onBeforeStop"](...t){}async[yo="_A_Service_onStop"](...t){}async[fo="_A_Service_onAfterStop"](...t){}async[go="_A_Service_onError"](t,e,...r){e?.error(t);}};i(E,"A_Service"),c([aConcept.A_Concept.Load()],E.prototype,"load",1),c([aConcept.A_Concept.Start()],E.prototype,"start",1),c([aConcept.A_Concept.Stop()],E.prototype,"stop",1),c([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_Polyfill))],E.prototype,Ro,1),c([aConcept.A_Feature.Extend()],E.prototype,Co,1),c([aConcept.A_Feature.Extend()],E.prototype,xo,1),c([aConcept.A_Feature.Extend()],E.prototype,So,1),c([aConcept.A_Feature.Extend()],E.prototype,To,1),c([aConcept.A_Feature.Extend()],E.prototype,Eo,1),c([aConcept.A_Feature.Extend()],E.prototype,Ao,1),c([aConcept.A_Feature.Extend()],E.prototype,yo,1),c([aConcept.A_Feature.Extend()],E.prototype,fo,1),c([aConcept.A_Feature.Extend({before:/.*/}),l(0,aConcept.A_Inject(aConcept.A_Error)),l(1,aConcept.A_Inject(exports.A_Logger))],E.prototype,go,1);var ut=E;var ht=class ht extends aConcept.A_Fragment{constructor(t){super(),this.url=t instanceof RegExp?t.source:t;}get path(){let t=this.url.split("?")[0].split("#")[0];if(t.includes("://")){let e=t.indexOf("/",t.indexOf("://")+3);if(e===-1)return "/";{let r=t.slice(e);return r.endsWith("/")?r.slice(0,-1):r}}return t.endsWith("/")?t.slice(0,-1):t}get params(){return this.path.match(/:([^\/]+)/g)?.map(t=>t.slice(1))||[]}get protocol(){switch(true){case this.url.startsWith("http://"):return "http";case this.url.startsWith("https://"):return "https";case this.url.startsWith("ws://"):return "ws";case this.url.startsWith("wss://"):return "wss";default:return this.url.includes("://")?this.url.split("://")[0]:"http"}}extractParams(t){let r=t.split("?")[0].split("/").filter(Boolean),o=this.path.split("/").filter(Boolean),n={};for(let s=0;s<o.length;s++){let a=o[s],_=r[s];if(a.startsWith(":")){let d=a.slice(1);n[d]=_;}else if(a!==_)return {}}return n}extractQuery(t){let e={},r=t.split("?")[1];if(!r)return e;let o=r.split("#")[0];for(let n of o.split("&")){if(!n)continue;let[s,a=""]=n.split("=");e[decodeURIComponent(s)]=decodeURIComponent(a);}return e}toString(){return `${this.path}`}toRegExp(){return new RegExp(`^${this.path.replace(/\/:([^\/]+)/g,"/([^/]+)")}$`)}toAFeatureExtension(t=[]){return new RegExp(`^${t.length?`(${t.join("|")})`:".*"}\\.${this.path.replace(/\/:([^\/]+)/g,"/([^/]+)")}$`)}};i(ht,"A_Route");var mt=ht;var Po=(t=>(t.Next="_A_SignalFeatures_Next",t))(Po||{}),Lo=(t=>(t.Next="_A_SignalVectorFeatures_Next",t))(Lo||{});var gt=class gt extends aConcept.A_Entity{static async default(){}fromJSON(t){super.fromJSON(t),this.data=t.data;}fromNew(t){this.aseid=this.generateASEID({entity:t.name}),this.data=t.data;}async next(t){await this.call("_A_SignalFeatures_Next",t);}toJSON(){return {...super.toJSON(),data:this.data}}};i(gt,"A_Signal");var P=gt;var yt=class yt extends aConcept.A_Entity{fromNew(t){super.fromNew(t),this._structure=t.structure,this._signals=t.values;}get structure(){return this._structure||this._signals.map(t=>t.constructor)}get length(){return this.structure.length}[Symbol.iterator](){let t=0,e=this.structure.map(r=>{let o=this._signals.findIndex(n=>n.constructor===r);return o!==-1?this._signals[o]:void 0});return {next(){return t<e.length?{done:false,value:e[t++]}:{done:true,value:void 0}}}}async next(t){return await this.call("_A_SignalVectorFeatures_Next",t)}has(t){let e;return t instanceof aConcept.A_Entity?e=t.constructor:e=t,this.structure.includes(e)}get(t){let e;t instanceof aConcept.A_Entity?e=t.constructor:e=t;let r=this._signals.findIndex(o=>o.constructor===e);if(r!==-1)return this._signals[r]}async toVector(t){return (t||this.structure).map(r=>{let o=this._signals.findIndex(n=>n.constructor===r);return o!==-1?this._signals[o]:void 0})}async toDataVector(t){let e=t||this.structure,r=[];for(let o of e){let n=this._signals.findIndex(a=>a.constructor===o),s;n===-1?s=await o.default():s=this._signals[n],r.push(s?.toJSON().data);}return r}async toObject(t){let e=t||this.structure,r={};return e.forEach(o=>{let n=o.name,s=this._signals.findIndex(a=>a.constructor===o);if(s!==-1){let a=this._signals[s];r[n]=a.toJSON().data;}else r[n]=void 0;}),r}toJSON(){return {...super.toJSON(),structure:this.structure.map(t=>t.name),values:this._signals.map(t=>t.toJSON())}}};i(yt,"A_SignalVector");var ge=yt;var At=class At extends aConcept.A_Fragment{constructor(e){super({name:"A_SignalState"});this._state=new Map;this._structure=e;}get structure(){return this._structure||[]}set(e,r){let o=e instanceof P?e.constructor:e,n=e instanceof P?e:r;this._state.set(o,n);}get(e){let r=e instanceof P?e.constructor:e;return this._state.get(r)}has(e){let r=e instanceof P?e.constructor:e;return this.structure.includes(r)}delete(e){let r=e instanceof P?e.constructor:e;return this._state.delete(r)}toVector(){let e=[];return this._state.forEach((r,o)=>{e.push(r);}),new ge({structure:this.structure,values:e})}toObject(){let e={};return this.structure.forEach(r=>{let o=this._state.get(r);if(o===void 0)throw new Error(`Signal ${r.name} has no value in state`);e[r.name]=o;}),e}};i(At,"A_SignalState");var ie=At;var Et=class Et extends aConcept.A_Fragment{get structure(){if(this._structure)return this._structure;let t=aConcept.A_Context.scope(this);return [...t.allowedEntities].filter(r=>aConcept.A_CommonHelper.isInheritedFrom(r,P)).sort((r,o)=>r.constructor.name.localeCompare(o.name)).map(r=>t.resolveConstructor(r.name)).filter(r=>r)}get ready(){return this._ready}constructor(t){super({name:"A_SignalConfig"}),this._config=t;}async initialize(){return this._ready||(this._ready=this._initialize()),this._ready}async _initialize(){if(this._config.structure)this._structure=this._config.structure;else if(this._config.stringStructure){let t=this._config.stringStructure.split(",").map(e=>e.trim());this._structure=t.map(e=>aConcept.A_Context.scope(this).resolveConstructor(e)).filter(e=>e);}}};i(Et,"A_SignalConfig");var se=Et;var $o,ke=class ke extends aConcept.A_Component{async[$o="_A_SignalFeatures_Next"](t,e,r,o,n,s){let a=aConcept.A_Context.scope(this);if(s||(s=new se({stringStructure:r?.get("A_SIGNAL_VECTOR_STRUCTURE")||void 0}),a.register(s)),s.ready||await s.initialize(),n||(n=new ie(s.structure),a.register(n)),!n.has(t))return;o?.debug(`A_SignalBus: Updating state for signal '${t.constructor.name}' with data:`,t.data),n.set(t),await n.toVector().next(e);}};i(ke,"A_SignalBus"),c([aConcept.A_Feature.Extend({scope:[P]}),l(0,aConcept.A_Inject(aConcept.A_Caller)),l(1,aConcept.A_Inject(aConcept.A_Scope)),l(2,aConcept.A_Inject(A)),l(3,aConcept.A_Inject(exports.A_Logger)),l(4,aConcept.A_Inject(ie)),l(5,aConcept.A_Inject(se))],ke.prototype,$o,1);var Tt=ke;var St=class St{constructor(){this.promise=new Promise((t,e)=>{this.resolveFn=t,this.rejectFn=e;});}resolve(t){this.resolveFn(t);}reject(t){this.rejectFn(t);}};i(St,"A_Deferred");var fe=St;var xt=class xt{constructor(t,e,r){this.config={resolveOnClear:false};r&&(this.config={...this.config,...r}),this.deferred=new fe,this.timeout=setTimeout(()=>e().then((...o)=>this.deferred.resolve(...o)).catch((...o)=>this.deferred.reject(...o)),t);}get promise(){return this.deferred.promise}clear(){this.timeout&&(clearTimeout(this.timeout),this.config.resolveOnClear?this.deferred.resolve(void 0):this.deferred.reject(new aConcept.A_Error("Timeout Cleared")));}};i(xt,"A_ScheduleObject");var ce=xt;var Rt=class Rt extends aConcept.A_Component{async schedule(t,e,r){let o=aConcept.A_TypeGuards.isString(t)?new Date(t).getTime():t;return new ce(o-Date.now(),e,r)}async delay(t,e,r){return new ce(t,e,r)}};i(Rt,"A_Schedule");var Ct=Rt;
34
- exports.A_CONSTANTS__CONFIG_ENV_VARIABLES=bn;exports.A_CONSTANTS__CONFIG_ENV_VARIABLES_ARRAY=Q;exports.A_Channel=Be;exports.A_ChannelError=q;exports.A_ChannelFeatures=Ht;exports.A_ChannelRequest=le;exports.A_ChannelRequestStatuses=jt;exports.A_Command=Ke;exports.A_CommandError=Y;exports.A_CommandEvent=Xt;exports.A_CommandFeatures=Jt;exports.A_CommandTransitions=Wt;exports.A_Command_Status=Kt;exports.A_Config=A;exports.A_ConfigError=$;exports.A_ConfigLoader=it;exports.A_Deferred=fe;exports.A_ExecutionContext=b;exports.A_LOGGER_ANSI=V;exports.A_LOGGER_COLORS=vt;exports.A_LOGGER_DEFAULT_LEVEL=Vn;exports.A_LOGGER_DEFAULT_SCOPE_LENGTH=Lt;exports.A_LOGGER_ENV_KEYS=de;exports.A_LOGGER_FORMAT=y;exports.A_LOGGER_SAFE_RANDOM_COLORS=It;exports.A_LOGGER_TERMINAL=te;exports.A_LOGGER_TIME_FORMAT=ee;exports.A_LoggerEnvVariables=be;exports.A_LoggerEnvVariablesArray=As;exports.A_Manifest=at;exports.A_ManifestChecker=oe;exports.A_ManifestError=H;exports.A_Memory=_t;exports.A_MemoryContext=v;exports.A_MemoryError=g;exports.A_MemoryFeatures=Qr;exports.A_OperationContext=u;exports.A_Route=mt;exports.A_Schedule=Ct;exports.A_ScheduleObject=ce;exports.A_Service=ut;exports.A_ServiceFeatures=uo;exports.A_Signal=P;exports.A_SignalBus=Tt;exports.A_SignalConfig=se;exports.A_SignalFeatures=Po;exports.A_SignalState=ie;exports.A_SignalVector=ge;exports.A_SignalVectorFeatures=Lo;exports.A_StateMachine=G;exports.A_StateMachineError=Z;exports.A_StateMachineFeatures=er;exports.A_StateMachineTransition=N;exports.A_TYPES__ConfigFeature=Jr;exports.ENVConfigReader=re;exports.FileConfigReader=me;//# sourceMappingURL=index.cjs.map
31
+ `),n=[];return o.forEach((s,c)=>{if(s.trim()){let p=c===0?r:`${r} `,m=this.wrapText(s.trim(),p,false);n.push(...m.map(_=>c===0&&_===m[0]?`${r}${_}`:`${r} ${_}`));}}),n}compile_Error(e){let r=`${" ".repeat(this.STANDARD_SCOPE_LENGTH+3)}${S.PIPE}`,o=`${r}-------------------------------`,n=[];n.push(""),n.push(o),n.push(`${r}ERROR: ${e.name}`),n.push(o);let s=this.wrapText(`Message: ${e.message}`,r,false);if(n.push(...s.map(c=>`${r}${c}`)),e.stack){n.push(o),n.push(`${r}STACK TRACE:`),n.push(o);let c=this.formatStackTrace(e.stack,r);n.push(...c);}return n.push(o),n.join(`
32
+ `)}getTime(){let e=new Date,r=String(e.getMinutes()).padStart(pe.MINUTES_PAD,"0"),o=String(e.getSeconds()).padStart(pe.SECONDS_PAD,"0"),n=String(e.getMilliseconds()).padStart(pe.MILLISECONDS_PAD,"0");return `${r}${pe.SEPARATOR}${o}${pe.SEPARATOR}${n}`}};i(exports.A_Logger,"A_Logger"),exports.A_Logger=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"A_Logger",description:"Advanced Logging Component with Scope-based Output Formatting that provides color-coded console output, multi-type support, and configurable log levels for enhanced debugging and monitoring."}),l(0,aConcept.A_Inject(aConcept.A_Scope)),l(1,aConcept.A_Inject(exports.A_Config))],exports.A_Logger);var tr,rr,or,nr,ir,sr,ar,cr,lr,pr,_r;exports.A_Command=class A extends aConcept.A_Entity{constructor(e){super(e);this._listeners=new Map;}static get code(){return super.entity}get duration(){return this._endTime&&this._startTime?this._endTime.getTime()-this._startTime.getTime():this._startTime?new Date().getTime()-this._startTime.getTime():void 0}get idleTime(){return this._startTime&&this._createdAt?this._startTime.getTime()-this._createdAt.getTime():void 0}get scope(){return this._executionScope}get context(){return this.scope.resolve(exports.A_ExecutionContext)}get code(){return this.constructor.code}get status(){return this._status}get createdAt(){return this._createdAt}get startedAt(){return this._startTime}get endedAt(){return this._endTime}get result(){return this._result}get error(){return this._error}get params(){return this._params}get isProcessed(){return this._status==="COMPLETED"||this._status==="FAILED"}async[_r="_A_StateMachine_onBeforeTransition"](e,r,...o){this.checkScopeInheritance(),r?.debug("yellow",`Command ${this.aseid.toString()} transitioning from ${e.from} to ${e.to}`);}async[pr="created_initialized"](e,...r){this._status==="CREATED"&&(this._createdAt=new Date,this._status="INITIALIZED",this.emit("onInit"));}async[lr="initialized_executing"](e,...r){this._status!=="INITIALIZED"&&this._status!=="CREATED"||(this._startTime=new Date,this._status="EXECUTING",this.emit("onExecute"));}async[cr="executing_completed"](e,...r){this._endTime=new Date,this._status="COMPLETED",this.emit("onComplete");}async[ar="executing_failed"](e,r,...o){this._endTime=new Date,this._status="FAILED",this.emit("onFail");}async[sr="_A_Command_onInit"](e,...r){await e.transition("CREATED","INITIALIZED");}async[ir="_A_Command_onBeforeExecute"](e,...r){await e.transition("INITIALIZED","EXECUTING");}async[nr="_A_Command_onExecute"](...e){}async[or="_A_Command_onAfterExecute"](...e){}async[rr="_A_Command_onComplete"](e,...r){await e.transition("EXECUTING","COMPLETED");}async[tr="_A_Command_onFail"](e,r,...o){await e.transition("EXECUTING","FAILED");}async init(){await this.call("_A_Command_onInit",this.scope);}async execute(){if(!this.isProcessed)try{this.checkScopeInheritance();let e=new exports.A_ExecutionContext("execute-command");this.scope.register(e),await new Promise(async(r,o)=>{try{let n=new aConcept.A_Feature({name:"_A_Command_onBeforeExecute",component:this,scope:this.scope}),s=new aConcept.A_Feature({name:"_A_Command_onExecute",component:this,scope:this.scope}),c=new aConcept.A_Feature({name:"_A_Command_onAfterExecute",component:this,scope:this.scope});this.on("onComplete",()=>{n.interrupt(),s.interrupt(),c.interrupt(),r();}),this.on("onFail",()=>{n.interrupt(),s.interrupt(),c.interrupt(),o(this.error);}),await n.process(this.scope),await s.process(this.scope),await c.process(this.scope),this._origin==="invoked"&&await this.complete(),r();}catch(n){o(n);}});}catch(e){let r=e instanceof aConcept.A_Error?e:new V({title:V.ExecutionError,description:`An error occurred while executing command "${this.aseid.toString()}".`,originalError:e});await this.fail(r);}}async complete(e){this.isProcessed||(this._status="COMPLETED",this._result=e,await this.call("_A_Command_onComplete",this.scope),this.scope.destroy());}async fail(e){this.isProcessed||(this._status="FAILED",e&&(this._error=e,this.scope.register(e)),await this.call("_A_Command_onFail",this.scope),this.scope.destroy());}on(e,r){this._listeners.has(e)||this._listeners.set(e,new Set),this._listeners.get(e).add(r);}off(e,r){this._listeners.get(e)?.delete(r);}emit(e){this._listeners.get(e)?.forEach(async r=>{r(this);});}fromNew(e){super.fromNew(e),this._origin="invoked",this._executionScope=new aConcept.A_Scope({name:`A-Command-Execution-Scope-${this.aseid.toString()}`,components:[exports.A_StateMachine]}),this._createdAt=new Date,this._params=e,this._status="CREATED";}fromJSON(e){super.fromJSON(e),this._origin="serialized",this._executionScope=new aConcept.A_Scope({name:`A-Command-Execution-Scope-${this.aseid.toString()}`,components:[exports.A_StateMachine]}),e.createdAt&&(this._createdAt=new Date(e.createdAt)),e.startedAt&&(this._startTime=new Date(e.startedAt)),e.endedAt&&(this._endTime=new Date(e.endedAt)),this._params=e.params,this._status=e.status,e.error&&(this._error=new V(e.error)),e.result&&(this._result=e.result);}toJSON(){return {...super.toJSON(),code:this.code,status:this._status,params:this._params,createdAt:this._createdAt.toISOString(),startedAt:this._startTime?this._startTime.toISOString():void 0,endedAt:this._endTime?this._endTime.toISOString():void 0,duration:this.duration,idleTime:this.idleTime,result:this.result,error:this.error?this.error.toJSON():void 0}}checkScopeInheritance(){let e;try{e=aConcept.A_Context.scope(this);}catch(r){throw new V({title:V.CommandScopeBindingError,description:`Command ${this.aseid.toString()} is not bound to any context scope. Ensure the command is properly registered within a context before execution.`,originalError:r})}this.scope.isInheritedFrom(aConcept.A_Context.scope(this))||this.scope.inherit(aConcept.A_Context.scope(this));}};i(exports.A_Command,"A_Command"),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_StateMachineTransition)),l(1,aConcept.A_Inject(exports.A_Logger))],exports.A_Command.prototype,_r,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_StateMachineTransition))],exports.A_Command.prototype,pr,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_StateMachineTransition))],exports.A_Command.prototype,lr,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_StateMachineTransition))],exports.A_Command.prototype,cr,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_StateMachineTransition)),l(1,aConcept.A_Inject(aConcept.A_Error))],exports.A_Command.prototype,ar,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_StateMachine))],exports.A_Command.prototype,sr,1),a([aConcept.A_Feature.Extend({after:/.*/}),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_StateMachine))],exports.A_Command.prototype,ir,1),a([aConcept.A_Feature.Extend()],exports.A_Command.prototype,nr,1),a([aConcept.A_Feature.Extend()],exports.A_Command.prototype,or,1),a([aConcept.A_Feature.Extend({after:/.*/}),l(0,aConcept.A_Inject(exports.A_StateMachine))],exports.A_Command.prototype,rr,1),a([aConcept.A_Feature.Extend({after:/.*/}),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_StateMachine)),l(1,aConcept.A_Inject(exports.A_ExecutionContext))],exports.A_Command.prototype,tr,1),exports.A_Command=a([aFrame.A_Frame.Entity({namespace:"A-Utils",name:"A-Command",description:"Advanced Command Pattern Implementation with full lifecycle management, event handling, and state persistence. This entity allows to execute commands in distributed environment across multiple services."})],exports.A_Command);var Ve=class Ve{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._fs}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){this._fs=await import('fs');}initBrowser(){this._fs={readFileSync:i((t,e)=>(this.logger.warning("fs.readFileSync not available in browser environment"),""),"readFileSync"),existsSync:i(t=>(this.logger.warning("fs.existsSync not available in browser environment"),false),"existsSync"),createReadStream:i(t=>(this.logger.warning("fs.createReadStream not available in browser environment"),null),"createReadStream")};}};i(Ve,"A_FSPolyfillClass");var ve=Ve;var He=class He{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(t){return this._initialized||(this._fsPolyfill=t,await this.init()),this._crypto}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('crypto');this._crypto={createTextHash:i((e,r="sha384")=>Promise.resolve(`${r}-${t.createHash(r).update(e).digest("base64")}`),"createTextHash"),createFileHash:i((e,r="sha384")=>new Promise(async(o,n)=>{try{if(!this._fsPolyfill)throw new Error("FS polyfill is required for file hashing");let s=t.createHash(r),c=this._fsPolyfill.createReadStream(e);c.on("data",p=>s.update(p)),c.on("end",()=>o(`${r}-${s.digest("base64")}`)),c.on("error",p=>n(p));}catch(s){n(s);}}),"createFileHash")};}initBrowser(){this._crypto={createFileHash:i(()=>(this.logger.warning("File hash not available in browser environment"),Promise.resolve("")),"createFileHash"),createTextHash:i((t,e="SHA-384")=>new Promise(async(r,o)=>{try{if(!crypto.subtle)throw new Error("SubtleCrypto not available");let s=new TextEncoder().encode(t),c=await crypto.subtle.digest(e,s),p=Array.from(new Uint8Array(c)),m=btoa(String.fromCharCode(...p));r(`${e}-${m}`);}catch(n){o(n);}}),"createTextHash")};}};i(He,"A_CryptoPolyfillClass");var Re=He;var je=class je{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._http}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('http');this._http={request:t.request,get:t.get,createServer:t.createServer};}initBrowser(){this._http={request:i((t,e)=>(this.logger.warning("http.request not available in browser/test environment, use fetch instead"),this.createMockRequest(t,e,false)),"request"),get:i((t,e)=>(this.logger.warning("http.get not available in browser/test environment, use fetch instead"),this.createMockRequest(typeof t=="string"?{hostname:t}:t,e,false)),"get"),createServer:i(()=>(this.logger.error("http.createServer not available in browser/test environment"),null),"createServer")};}createMockRequest(t,e,r=false){return {end:i(()=>{if(e){let n={statusCode:200,headers:{},on:i((s,c)=>{s==="data"?setTimeout(()=>c("mock data"),0):s==="end"&&setTimeout(()=>c(),0);},"on"),pipe:i(s=>{s.write&&s.write("mock data"),s.end&&s.end();},"pipe")};setTimeout(()=>e(n),0);}},"end"),write:i(n=>{},"write"),on:i((n,s)=>{},"on")}}};i(je,"A_HttpPolyfillClass");var Pe=je;var qe=class qe{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._https}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('https');this._https={request:t.request,get:t.get,createServer:t.createServer};}initBrowser(){this._https={request:i((t,e)=>(this.logger.warning("https.request not available in browser/test environment, use fetch instead"),this.createMockRequest(t,e,true)),"request"),get:i((t,e)=>(this.logger.warning("https.get not available in browser/test environment, use fetch instead"),this.createMockRequest(typeof t=="string"?{hostname:t}:t,e,true)),"get"),createServer:i(()=>(this.logger.error("https.createServer not available in browser/test environment"),null),"createServer")};}createMockRequest(t,e,r=true){return {end:i(()=>{if(e){let n={statusCode:200,headers:{},on:i((s,c)=>{s==="data"?setTimeout(()=>c("mock data"),0):s==="end"&&setTimeout(()=>c(),0);},"on"),pipe:i(s=>{s.write&&s.write("mock data"),s.end&&s.end();},"pipe")};setTimeout(()=>e(n),0);}},"end"),write:i(n=>{},"write"),on:i((n,s)=>{},"on")}}};i(qe,"A_HttpsPolyfillClass");var Ie=qe;var Ke=class Ke{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._path}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){this._path=await import('path');}initBrowser(){this._path={join:i((...t)=>t.join("/").replace(/\/+/g,"/"),"join"),resolve:i((...t)=>{let e="";for(let r of t)r.startsWith("/")?e=r:e=this._path.join(e,r);return e||"/"},"resolve"),dirname:i(t=>t.split("/").slice(0,-1).join("/")||"/","dirname"),basename:i((t,e)=>{let r=t.split("/").pop()||"";return e&&r.endsWith(e)?r.slice(0,-e.length):r},"basename"),extname:i(t=>{let e=t.split(".");return e.length>1?"."+e.pop():""},"extname"),relative:i((t,e)=>e.replace(t,"").replace(/^\//,""),"relative"),normalize:i(t=>t.replace(/\/+/g,"/").replace(/\/$/,"")||"/","normalize"),isAbsolute:i(t=>t.startsWith("/")||/^[a-zA-Z]:/.test(t),"isAbsolute"),parse:i(t=>{let e=this._path.extname(t),r=this._path.basename(t),o=this._path.basename(t,e);return {root:"/",dir:this._path.dirname(t),base:r,ext:e,name:o}},"parse"),format:i(t=>this._path.join(t.dir||"",t.base||""),"format"),sep:"/",delimiter:":"};}};i(Ke,"A_PathPolyfillClass");var Le=Ke;var We=class We{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._url}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('url');this._url={parse:t.parse,format:t.format,resolve:t.resolve,URL:t.URL||globalThis.URL,URLSearchParams:t.URLSearchParams||globalThis.URLSearchParams};}initBrowser(){this._url={parse:i(t=>{try{let e=new URL(t);return {protocol:e.protocol,hostname:e.hostname,port:e.port,pathname:e.pathname,search:e.search,hash:e.hash,host:e.host,href:e.href}}catch{return {}}},"parse"),format:i(t=>{try{return new URL("",t.href||`${t.protocol}//${t.host}${t.pathname}${t.search}${t.hash}`).href}catch{return ""}},"format"),resolve:i((t,e)=>{try{return new URL(e,t).href}catch{return e}},"resolve"),URL:globalThis.URL,URLSearchParams:globalThis.URLSearchParams};}};i(We,"A_UrlPolyfillClass");var Oe=We;var Je=class Je{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._buffer}async init(){try{aConcept.A_Context.environment==="server"?await this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}async initServer(){let t=await import('buffer');this._buffer={from:t.Buffer.from,alloc:t.Buffer.alloc,allocUnsafe:t.Buffer.allocUnsafe,isBuffer:t.Buffer.isBuffer,concat:t.Buffer.concat};}initBrowser(){this._buffer={from:i((t,e)=>typeof t=="string"?new TextEncoder().encode(t):new Uint8Array(t),"from"),alloc:i((t,e)=>{let r=new Uint8Array(t);return e!==void 0&&r.fill(e),r},"alloc"),allocUnsafe:i(t=>new Uint8Array(t),"allocUnsafe"),isBuffer:i(t=>t instanceof Uint8Array||t instanceof ArrayBuffer,"isBuffer"),concat:i((t,e)=>{let r=e||t.reduce((s,c)=>s+c.length,0),o=new Uint8Array(r),n=0;for(let s of t)o.set(s,n),n+=s.length;return o},"concat")};}};i(Je,"A_BufferPolyfillClass");var be=Je;var Xe=class Xe{constructor(t){this.logger=t;this._initialized=false;}get isInitialized(){return this._initialized}async get(){return this._initialized||await this.init(),this._process}async init(){try{aConcept.A_Context.environment==="server"?this.initServer():this.initBrowser(),this._initialized=!0;}catch{this.initBrowser(),this._initialized=true;}}initServer(){this._process={env:process.env,argv:process.argv,platform:process.platform,version:process.version,versions:process.versions,cwd:process.cwd,exit:process.exit,nextTick:process.nextTick};}initBrowser(){this._process={env:{NODE_ENV:"browser",...globalThis.process?.env||{}},argv:["browser"],platform:"browser",version:"browser",versions:{node:"browser"},cwd:i(()=>"/","cwd"),exit:i(t=>{throw this.logger.warning("process.exit not available in browser"),new Error(`Process exit with code ${t}`)},"exit"),nextTick:i((t,...e)=>{setTimeout(()=>t(...e),0);},"nextTick")};}};i(Xe,"A_ProcessPolyfillClass");var Ne=Xe;exports.A_Polyfill=class T extends aConcept.A_Component{constructor(e){super();this.logger=e;this._initializing=null;}get ready(){return this._initialized||(this._initialized=this._loadInternal()),this._initialized}async load(){await this.ready;}async attachToWindow(){aConcept.A_Context.environment==="browser"&&(globalThis.A_Polyfill=this,globalThis.process={env:{NODE_ENV:"production"},cwd:i(()=>"/","cwd")},globalThis.__dirname="/");}async _loadInternal(){this._fsPolyfill=new ve(this.logger),this._cryptoPolyfill=new Re(this.logger),this._httpPolyfill=new Pe(this.logger),this._httpsPolyfill=new Ie(this.logger),this._pathPolyfill=new Le(this.logger),this._urlPolyfill=new Oe(this.logger),this._bufferPolyfill=new be(this.logger),this._processPolyfill=new Ne(this.logger),await this._fsPolyfill.get(),await this._cryptoPolyfill.get(await this._fsPolyfill.get()),await this._httpPolyfill.get(),await this._httpsPolyfill.get(),await this._pathPolyfill.get(),await this._urlPolyfill.get(),await this._bufferPolyfill.get(),await this._processPolyfill.get();}async fs(){return await this.ready,await this._fsPolyfill.get()}async crypto(){return await this.ready,await this._cryptoPolyfill.get()}async http(){return await this.ready,await this._httpPolyfill.get()}async https(){return await this.ready,await this._httpsPolyfill.get()}async path(){return await this.ready,await this._pathPolyfill.get()}async url(){return await this.ready,await this._urlPolyfill.get()}async buffer(){return await this.ready,await this._bufferPolyfill.get()}async process(){return await this.ready,await this._processPolyfill.get()}};i(exports.A_Polyfill,"A_Polyfill"),a([aConcept.A_Concept.Load()],exports.A_Polyfill.prototype,"load",1),a([aConcept.A_Concept.Load()],exports.A_Polyfill.prototype,"attachToWindow",1),exports.A_Polyfill=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"A-Polyfill",description:"Polyfill component that provides cross-environment compatibility for Node.js core modules such as fs, crypto, http, https, path, url, buffer, and process. It dynamically loads appropriate polyfills based on the execution environment (Node.js or browser), enabling seamless usage of these modules in different contexts."}),l(0,aConcept.A_Inject(exports.A_Logger))],exports.A_Polyfill);exports.ConfigReader=class b extends aConcept.A_Component{constructor(e){super();this.polyfill=e;this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...le];}async attachContext(e,r,o){o||(o=new exports.A_Config({defaults:{}}),e.scope.register(o));let n=await this.getProjectRoot();o.set("A_CONCEPT_ROOT_FOLDER",n);}async initialize(e){let r=await this.read();for(let o in r)e.set(o,r[o]);}resolve(e){return e}async read(e=[]){return {}}async getProjectRoot(e=__dirname){return (await this.polyfill.process()).cwd()}};i(exports.ConfigReader,"ConfigReader"),a([aConcept.A_Concept.Load(),l(0,aConcept.A_Inject(aConcept.A_Container)),l(1,aConcept.A_Inject(aConcept.A_Scope)),l(2,aConcept.A_Inject(exports.A_Config))],exports.ConfigReader.prototype,"attachContext",1),a([aConcept.A_Concept.Load(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_Config))],exports.ConfigReader.prototype,"initialize",1),exports.ConfigReader=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"ConfigReader",description:"Abstract component for reading configuration data from various sources such as files, environment variables, or remote services. This component can be extended to implement specific configuration reading strategies."}),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_Polyfill))],exports.ConfigReader);exports.FileConfigReader=class H extends exports.ConfigReader{constructor(){super(...arguments);this.FileData=new Map;}getConfigurationProperty_File_Alias(e){return aConcept.A_FormatterHelper.toCamelCase(e)}resolve(e){return this.FileData.get(this.getConfigurationProperty_File_Alias(e))}async read(e){let r=await this.polyfill.fs();try{let o=r.readFileSync(`${aConcept.A_Context.concept}.conf.json`,"utf8"),n=JSON.parse(o);return this.FileData=new Map(Object.entries(n)),n}catch{return {}}}};i(exports.FileConfigReader,"FileConfigReader"),exports.FileConfigReader=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"FileConfigReader",description:"Configuration reader that loads configuration data from a JSON file located in the application root directory. It reads the file named after the current concept with a .conf.json extension and parses its contents into the configuration context."})],exports.FileConfigReader);exports.ENVConfigReader=class M extends exports.ConfigReader{async readEnvFile(t,e,r){let o=await e.fs();o.existsSync(".env")&&o.readFileSync(`${t.get("A_CONCEPT_ROOT_FOLDER")}/.env`,"utf-8").split(`
33
+ `).forEach(n=>{let[s,c]=n.split("=");s&&c&&(process.env[s.trim()]=c.trim());});}getConfigurationProperty_ENV_Alias(t){return aConcept.A_FormatterHelper.toUpperSnakeCase(t)}resolve(t){return process.env[this.getConfigurationProperty_ENV_Alias(t)]}async read(t=[]){let e=[...t,...Object.keys(process.env)],r={};return e.forEach(o=>{r[o]=this.resolve(o);}),r}};i(exports.ENVConfigReader,"ENVConfigReader"),a([aConcept.A_Concept.Load({before:["ENVConfigReader.initialize"]}),l(0,aConcept.A_Inject(exports.A_Config)),l(1,aConcept.A_Inject(exports.A_Polyfill)),l(2,aConcept.A_Inject(aConcept.A_Feature))],exports.ENVConfigReader.prototype,"readEnvFile",1),exports.ENVConfigReader=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"ENVConfigReader",description:"Configuration reader that sources configuration data from environment variables. It supports loading variables from a .env file and maps them to the configuration context, making it suitable for applications running in diverse environments such as local development, staging, and production."})],exports.ENVConfigReader);exports.A_ConfigLoader=class X extends aConcept.A_Container{async prepare(t){if(!this.scope.has(exports.A_Config)){let r=new exports.A_Config({variables:[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...le],defaults:{}});this.scope.register(r);}let e=await t.fs();try{switch(!0){case(aConcept.A_Context.environment==="server"&&!!e.existsSync(`${aConcept.A_Context.concept}.conf.json`)):this.reader=this.scope.resolve(exports.FileConfigReader);break;case(aConcept.A_Context.environment==="server"&&!e.existsSync(`${aConcept.A_Context.concept}.conf.json`)):this.reader=this.scope.resolve(exports.ENVConfigReader);break;case aConcept.A_Context.environment==="browser":this.reader=this.scope.resolve(exports.ENVConfigReader);break;default:throw new $($.InitializationError,`Environment ${aConcept.A_Context.environment} is not supported`)}}catch(r){if(r instanceof aConcept.A_ScopeError)throw new $({title:$.InitializationError,description:`Failed to initialize A_ConfigLoader. Reader not found for environment ${aConcept.A_Context.environment}`,originalError:r})}}};i(exports.A_ConfigLoader,"A_ConfigLoader"),a([aConcept.A_Concept.Load({before:/.*/}),l(0,aConcept.A_Inject(exports.A_Polyfill))],exports.A_ConfigLoader.prototype,"prepare",1),exports.A_ConfigLoader=a([aFrame.A_Frame.Container({namespace:"A-Utils",name:"A-ConfigLoader",description:"Container responsible for loading and initializing the A_Config component based on the environment and available configuration sources. It can be useful for application that need a separated configuration management and sharable across multiple containers."})],exports.A_ConfigLoader);var zr=(ee=>ee)(zr||{});var De={A_LOGGER_LEVEL:"A_LOGGER_LEVEL",A_LOGGER_DEFAULT_SCOPE_LENGTH:"A_LOGGER_DEFAULT_SCOPE_LENGTH",A_LOGGER_DEFAULT_SCOPE_COLOR:"A_LOGGER_DEFAULT_SCOPE_COLOR",A_LOGGER_DEFAULT_LOG_COLOR:"A_LOGGER_DEFAULT_LOG_COLOR"},Ms=[De.A_LOGGER_LEVEL,De.A_LOGGER_DEFAULT_SCOPE_LENGTH,De.A_LOGGER_DEFAULT_SCOPE_COLOR,De.A_LOGGER_DEFAULT_LOG_COLOR];var ke=class ke extends aConcept.A_Error{};i(ke,"A_ManifestError"),ke.ManifestInitializationError="A-Manifest Initialization Error";var Z=ke;var Qe=class Qe{constructor(t,e,r,o=false){this.manifest=t;this.component=e;this.method=r;this.checkExclusion=o;}for(t){let e=this.manifest.internal_checkAccess({component:this.component,method:this.method,target:t});return this.checkExclusion?!e:e}};i(Qe,"A_ManifestChecker");var me=Qe;exports.A_Manifest=class ie extends aConcept.A_Fragment{constructor(e=[]){super({name:"A-Manifest"});this.rules=[];this.prepare(e);}prepare(e){if(!aConcept.A_TypeGuards.isArray(e))throw new Z(Z.ManifestInitializationError,"A-Manifest configuration should be an array of configurations");for(let r of e)this.processConfigItem(r);}processConfigItem(e){if(!aConcept.A_TypeGuards.isComponentConstructor(e.component))throw new Z(Z.ManifestInitializationError,"A-Manifest configuration item should be a A-Component constructor");let r=this.constructorToRegex(e.component);if(e.apply||e.exclude){let o=/.*/;this.rules.push({componentRegex:r,methodRegex:o,applyRegex:e.apply?this.allowedComponentsToRegex(e.apply):void 0,excludeRegex:e.exclude?this.allowedComponentsToRegex(e.exclude):void 0});}if(e.methods&&e.methods.length>0)for(let o of e.methods){let n=this.methodToRegex(o.method);this.rules.push({componentRegex:r,methodRegex:n,applyRegex:o.apply?this.allowedComponentsToRegex(o.apply):void 0,excludeRegex:o.exclude?this.allowedComponentsToRegex(o.exclude):void 0});}}constructorToRegex(e){return new RegExp(`^${this.escapeRegex(e.name)}$`)}methodToRegex(e){return e instanceof RegExp?e:new RegExp(`^${this.escapeRegex(e)}$`)}allowedComponentsToRegex(e){if(e instanceof RegExp)return e;let r=e.map(o=>this.escapeRegex(o.name));return new RegExp(`^(${r.join("|")})$`)}escapeRegex(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}configItemToRegexp(e){return this.constructorToRegex(e)}ID(e,r){return `${e.name}.${r}`}isAllowed(e,r){let o=typeof e=="function"?e:e.constructor;return new me(this,o,r)}internal_checkAccess(e){let r=e.component.name,o=e.method,n=e.target.name,s=this.rules.filter(c=>c.componentRegex.test(r)&&c.methodRegex.test(o)).sort((c,p)=>{let m=c.methodRegex.source===".*",_=p.methodRegex.source===".*";return m&&!_?1:!m&&_?-1:0});if(s.length===0)return true;for(let c of s){if(c.excludeRegex&&c.excludeRegex.test(n))return false;if(c.applyRegex)return c.applyRegex.test(n)}return true}isExcluded(e,r){let o=typeof e=="function"?e:e.constructor;return new me(this,o,r,true)}};i(exports.A_Manifest,"A_Manifest"),exports.A_Manifest=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-Manifest",description:"A-Manifest is a configuration fragment that allows to include or exclude component application for particular methods. It provides fine-grained control over which components are applied to which targets and methods within the application, enabling flexible and dynamic behavior based on defined rules."})],exports.A_Manifest);var jr=(_=>(_.onInit="_A_Memory_onInit",_.onDestroy="_A_Memory_onDestroy",_.onExpire="_A_Memory_onExpire",_.onError="_A_Memory_onError",_.onSerialize="_A_Memory_onSerialize",_.onSet="_A_Memory_onSet",_.onGet="_A_Memory_onGet",_.onDrop="_A_Memory_onDrop",_.onClear="_A_Memory_onClear",_.onHas="_A_Memory_onHas",_))(jr||{});exports.A_MemoryContext=class C extends aConcept.A_Fragment{constructor(){super(...arguments);this._storage=new Map;}set(e,r){this._storage.set(e,r);}get(e){return this._storage.get(e)}delete(e){this._storage.delete(e);}has(e){return this._storage.has(e)}clear(){this._storage.clear();}};i(exports.A_MemoryContext,"A_MemoryContext"),exports.A_MemoryContext=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-MemoryContext",description:"In-memory context fragment that provides a simple key-value store for temporary data storage during application runtime. It allows setting, getting, deleting, and checking the existence of key-value pairs, facilitating quick access to transient data without persistent storage. This context is useful for scenarios where data needs to be shared across different components or operations within the same execution context."})],exports.A_MemoryContext);var G=class G extends aConcept.A_Error{};i(G,"A_MemoryError"),G.MemoryInitializationError="Memory initialization error",G.MemoryDestructionError="Memory destruction error",G.MemoryGetError="Memory GET operation failed",G.MemorySetError="Memory SET operation failed",G.MemoryDropError="Memory DROP operation failed",G.MemoryClearError="Memory CLEAR operation failed",G.MemoryHasError="Memory HAS operation failed",G.MemorySerializeError="Memory toJSON operation failed";var f=G;var Zr,Qr,eo,to,ro,oo,no,io,so;exports.A_Memory=class w extends aConcept.A_Component{get ready(){return this._ready||(this._ready=this.init()),this._ready}async[so="_A_Memory_onError"](...t){}async[io="_A_Memory_onExpire"](...t){}async[no="_A_Memory_onInit"](t,...e){t||(t=new exports.A_MemoryContext,aConcept.A_Context.scope(this).register(t));}async[oo="_A_Memory_onDestroy"](t,...e){t.clear();}async[ro="_A_Memory_onGet"](t,e,...r){t.succeed(e.get(t.params.key));}async[to="_A_Memory_onHas"](t,e,...r){t.succeed(e.has(t.params.key));}async[eo="_A_Memory_onSet"](t,e,r,...o){e.set(t.params.key,t.params.value);}async[Qr="_A_Memory_onDrop"](t,e,...r){e.delete(t.params.key);}async[Zr="_A_Memory_onClear"](t,e,...r){e.clear();}async init(){if(this._ready)return this._ready;let t=new aConcept.A_Scope({name:"A-Memory-Init-Scope"}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onInit",t);}catch(e){let r=new f({title:f.MemoryInitializationError,description:"An error occurred during memory initialization",originalError:e});throw t.register(r),await this.call("_A_Memory_onError",t),t.destroy(),r}}async destroy(){let t=new aConcept.A_Scope({name:"A-Memory-Destroy-Scope"}).inherit(aConcept.A_Context.scope(this));try{this._ready=void 0,await this.call("_A_Memory_onDestroy",t);}catch(e){let r=new f({title:f.MemoryDestructionError,description:"An error occurred during memory destruction",originalError:e});throw t.register(r),await this.call("_A_Memory_onError",t),t.destroy(),r}}async get(t){let e=new exports.A_OperationContext("get",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Get-Operation-Scope",fragments:[e]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_Memory_onGet",r),r.destroy(),e.result}catch(o){let n=new f({title:f.MemoryGetError,description:`An error occurred while getting the value for key "${String(t)}"`,originalError:o});throw r.register(n),await this.call("_A_Memory_onError",r),r.destroy(),n}}async has(t){let e=new exports.A_OperationContext("has",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Has-Operation-Scope",fragments:[e]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_Memory_onHas",r),r.destroy(),e.result}catch(o){let n=new f({title:f.MemoryHasError,description:`An error occurred while checking existence for key "${String(t)}"`,originalError:o});throw r.register(n),await this.call("_A_Memory_onError",r),r.destroy(),n}}async set(t,e){let r=new exports.A_OperationContext("set",{key:t,value:e}),o=new aConcept.A_Scope({name:"A-Memory-Set-Operation-Scope",fragments:[r]}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onSet",o);}catch(n){let s=new f({title:f.MemorySetError,description:`An error occurred while setting the value for key "${String(t)}"`,originalError:n});throw o.register(s),await this.call("_A_Memory_onError",o),o.destroy(),s}}async drop(t){let e=new exports.A_OperationContext("drop",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Drop-Operation-Scope",fragments:[e]}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onDrop",r);}catch(o){let n=new f({title:f.MemoryDropError,description:`An error occurred while dropping the value for key "${String(t)}"`,originalError:o});throw r.register(n),await this.call("_A_Memory_onError",r),r.destroy(),n}}async clear(){let t=new exports.A_OperationContext("clear"),e=new aConcept.A_Scope({name:"A-Memory-Clear-Operation-Scope",fragments:[t]}).inherit(aConcept.A_Context.scope(this));try{await this.call("_A_Memory_onClear",e);}catch(r){let o=new f({title:f.MemoryClearError,description:"An error occurred while clearing the memory",originalError:r});throw e.register(o),await this.call("_A_Memory_onError",e),e.destroy(),o}}async toJSON(){let t=new exports.A_OperationContext("serialize"),e=new aConcept.A_Scope({name:"A-Memory-Serialize-Operation-Scope",fragments:[t]}).inherit(aConcept.A_Context.scope(this));try{return await this.call("_A_Memory_onSerialize",e),t.result}catch(r){let o=new f({title:f.MemorySerializeError,description:"An error occurred while serializing the memory",originalError:r});throw e.register(o),await this.call("_A_Memory_onError",e),e.destroy(),o}}};i(exports.A_Memory,"A_Memory"),a([aConcept.A_Feature.Extend()],exports.A_Memory.prototype,so,1),a([aConcept.A_Feature.Extend()],exports.A_Memory.prototype,io,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_MemoryContext))],exports.A_Memory.prototype,no,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_MemoryContext))],exports.A_Memory.prototype,oo,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_OperationContext)),l(1,aConcept.A_Inject(exports.A_MemoryContext))],exports.A_Memory.prototype,ro,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_OperationContext)),l(1,aConcept.A_Inject(exports.A_MemoryContext))],exports.A_Memory.prototype,to,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_OperationContext)),l(1,aConcept.A_Inject(exports.A_MemoryContext)),l(2,aConcept.A_Inject(aConcept.A_Scope))],exports.A_Memory.prototype,eo,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_OperationContext)),l(1,aConcept.A_Inject(exports.A_MemoryContext))],exports.A_Memory.prototype,Qr,1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Dependency.Required()),l(0,aConcept.A_Inject(exports.A_OperationContext)),l(1,aConcept.A_Inject(exports.A_MemoryContext))],exports.A_Memory.prototype,Zr,1),exports.A_Memory=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"A-Memory",description:"In-memory data storage component that provides a simple key-value store with asynchronous operations. It supports basic memory operations such as get, set, has, drop, and clear, along with lifecycle management and error handling features. This components features can be extended with other components to provide ability store data across multiple storage, or extract data from multiple external sources. Good example is to store some runtime data that needs to be shared across multiple containers or concepts."})],exports.A_Memory);var ao=(_=>(_.onBeforeLoad="_A_Service_onBeforeLoad",_.onLoad="_A_Service_onLoad",_.onAfterLoad="_A_Service_onAfterLoad",_.onBeforeStart="_A_Service_onBeforeStart",_.onStart="_A_Service_onStart",_.onAfterStart="_A_Service_onAfterStart",_.onBeforeStop="_A_Service_onBeforeStop",_.onStop="_A_Service_onStop",_.onAfterStop="_A_Service_onAfterStop",_.onError="_A_Service_onError",_))(ao||{});var de=class de extends aConcept.A_Error{};i(de,"A_Service_Error"),de.ServiceLoadError="Service load error",de.ServiceStartError="Service start error",de.ServiceStopError="Service stop error";var I=de;var _o,mo,uo,go,ho,fo,yo,Eo,To,Ao;exports.A_Service=class y extends aConcept.A_Container{async load(){try{await this.call("_A_Service_onBeforeLoad"),await this.call("_A_Service_onLoad"),await this.call("_A_Service_onAfterLoad");}catch(t){let e;switch(true){case t instanceof I:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof I):e=t.originalError;break;default:e=new I({title:I.ServiceLoadError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async start(){try{await this.call("_A_Service_onBeforeStart"),await this.call("_A_Service_onStart"),await this.call("_A_Service_onAfterStart");}catch(t){let e;switch(true){case t instanceof I:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof I):e=t.originalError;break;default:e=new I({title:I.ServiceStartError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async stop(){try{await this.call("_A_Service_onBeforeStop"),await this.call("_A_Service_onStop"),await this.call("_A_Service_onAfterStop");}catch(t){let e;switch(true){case t instanceof I:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof I):e=t.originalError;break;default:e=new I({title:I.ServiceStopError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async[Ao="_A_Service_onBeforeLoad"](t,...e){t||(this.scope.register(exports.A_Polyfill),t=this.scope.resolve(exports.A_Polyfill));}async[To="_A_Service_onLoad"](...t){}async[Eo="_A_Service_onAfterLoad"](...t){}async[yo="_A_Service_onBeforeStart"](...t){}async[fo="_A_Service_onStart"](...t){}async[ho="_A_Service_onAfterStart"](...t){}async[go="_A_Service_onBeforeStop"](...t){}async[uo="_A_Service_onStop"](...t){}async[mo="_A_Service_onAfterStop"](...t){}async[_o="_A_Service_onError"](t,e,...r){e?.error(t);}};i(exports.A_Service,"A_Service"),a([aConcept.A_Concept.Load()],exports.A_Service.prototype,"load",1),a([aConcept.A_Concept.Start()],exports.A_Service.prototype,"start",1),a([aConcept.A_Concept.Stop()],exports.A_Service.prototype,"stop",1),a([aConcept.A_Feature.Extend(),l(0,aConcept.A_Inject(exports.A_Polyfill))],exports.A_Service.prototype,Ao,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,To,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,Eo,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,yo,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,fo,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,ho,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,go,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,uo,1),a([aConcept.A_Feature.Extend()],exports.A_Service.prototype,mo,1),a([aConcept.A_Feature.Extend({before:/.*/}),l(0,aConcept.A_Inject(aConcept.A_Error)),l(1,aConcept.A_Inject(exports.A_Logger))],exports.A_Service.prototype,_o,1),exports.A_Service=a([aFrame.A_Frame.Container({namespace:"A-Utils",name:"A-Service",description:"Service container that manages the lifecycle of various types of services, such as HTTP servers and workers or UI loader. It dynamically loads necessary components based on the provided configuration and orchestrates the start and stop processes, ensuring proper error handling and extensibility through feature hooks."})],exports.A_Service);exports.A_Route=class se extends aConcept.A_Fragment{constructor(t){super(),this.url=t instanceof RegExp?t.source:t;}get path(){let t=this.url.split("?")[0].split("#")[0];if(t.includes("://")){let e=t.indexOf("/",t.indexOf("://")+3);if(e===-1)return "/";{let r=t.slice(e);return r.endsWith("/")?r.slice(0,-1):r}}return t.endsWith("/")?t.slice(0,-1):t}get params(){return this.path.match(/:([^\/]+)/g)?.map(t=>t.slice(1))||[]}get protocol(){switch(true){case this.url.startsWith("http://"):return "http";case this.url.startsWith("https://"):return "https";case this.url.startsWith("ws://"):return "ws";case this.url.startsWith("wss://"):return "wss";default:return this.url.includes("://")?this.url.split("://")[0]:"http"}}extractParams(t){let r=t.split("?")[0].split("/").filter(Boolean),o=this.path.split("/").filter(Boolean),n={};for(let s=0;s<o.length;s++){let c=o[s],p=r[s];if(c.startsWith(":")){let m=c.slice(1);n[m]=p;}else if(c!==p)return {}}return n}extractQuery(t){let e={},r=t.split("?")[1];if(!r)return e;let o=r.split("#")[0];for(let n of o.split("&")){if(!n)continue;let[s,c=""]=n.split("=");e[decodeURIComponent(s)]=decodeURIComponent(c);}return e}toString(){return `${this.path}`}toRegExp(){return new RegExp(`^${this.path.replace(/\/:([^\/]+)/g,"/([^/]+)")}$`)}toAFeatureExtension(t=[]){return new RegExp(`^${t.length?`(${t.join("|")})`:".*"}\\.${this.path.replace(/\/:([^\/]+)/g,"/([^/]+)")}$`)}};i(exports.A_Route,"A_Route"),exports.A_Route=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-Route",description:"Route fragment that defines URL patterns for routing purposes. It supports dynamic parameters and query extraction, allowing for flexible route definitions. This fragment can be used in routing systems to match incoming URLs against defined routes and extract relevant parameters and query strings."})],exports.A_Route);var Co=(t=>(t.Next="_A_SignalFeatures_Next",t))(Co||{}),wo=(t=>(t.Next="_A_SignalVectorFeatures_Next",t))(wo||{});exports.A_Signal=class x extends aConcept.A_Entity{static async default(){}fromJSON(t){super.fromJSON(t),this.data=t.data;}fromNew(t){this.aseid=this.generateASEID({entity:t.name}),this.data=t.data;}async next(t){await this.call("_A_SignalFeatures_Next",t);}toJSON(){return {...super.toJSON(),data:this.data}}};i(exports.A_Signal,"A_Signal"),exports.A_Signal=a([aFrame.A_Frame.Entity({namespace:"A-Utils",name:"A-Signal",description:"A Signal Entity represents an individual signal instance that carries data, used for managing state within an application context. Signals are designed to reflect the current state rather than individual events, making them suitable for scenarios where state monitoring and real-time updates are essential."})],exports.A_Signal);exports.A_SignalVector=class W extends aConcept.A_Entity{fromNew(t){super.fromNew(t),this._structure=t.structure,this._signals=t.values;}get structure(){return this._structure||this._signals.map(t=>t.constructor)}get length(){return this.structure.length}[Symbol.iterator](){let t=0,e=this.structure.map(r=>{let o=this._signals.findIndex(n=>n.constructor===r);return o!==-1?this._signals[o]:void 0});return {next(){return t<e.length?{done:false,value:e[t++]}:{done:true,value:void 0}}}}async next(t){return await this.call("_A_SignalVectorFeatures_Next",t)}has(t){let e;return t instanceof aConcept.A_Entity?e=t.constructor:e=t,this.structure.includes(e)}get(t){let e;t instanceof aConcept.A_Entity?e=t.constructor:e=t;let r=this._signals.findIndex(o=>o.constructor===e);if(r!==-1)return this._signals[r]}async toVector(t){return (t||this.structure).map(r=>{let o=this._signals.findIndex(n=>n.constructor===r);return o!==-1?this._signals[o]:void 0})}async toDataVector(t){let e=t||this.structure,r=[];for(let o of e){let n=this._signals.findIndex(c=>c.constructor===o),s;n===-1?s=await o.default():s=this._signals[n],r.push(s?.toJSON().data);}return r}async toObject(t){let e=t||this.structure,r={};return e.forEach(o=>{let n=o.name,s=this._signals.findIndex(c=>c.constructor===o);if(s!==-1){let c=this._signals[s];r[n]=c.toJSON().data;}else r[n]=void 0;}),r}toJSON(){return {...super.toJSON(),structure:this.structure.map(t=>t.name),values:this._signals.map(t=>t.toJSON())}}};i(exports.A_SignalVector,"A_SignalVector"),exports.A_SignalVector=a([aFrame.A_Frame.Entity({namespace:"A-Utils",name:"A-SignalVector",description:"A Signal Vector Entity represents a collection of signals structured in a specific way, allowing for batch processing and transmission of related signals as a unified state representation."})],exports.A_SignalVector);exports.A_SignalState=class Y extends aConcept.A_Fragment{constructor(e){super({name:"A_SignalState"});this._state=new Map;this._structure=e;}get structure(){return this._structure||[]}set(e,r){let o=e instanceof exports.A_Signal?e.constructor:e,n=e instanceof exports.A_Signal?e:r;this._state.set(o,n);}get(e){let r=e instanceof exports.A_Signal?e.constructor:e;return this._state.get(r)}has(e){let r=e instanceof exports.A_Signal?e.constructor:e;return this.structure.includes(r)}delete(e){let r=e instanceof exports.A_Signal?e.constructor:e;return this._state.delete(r)}toVector(){let e=[];return this._state.forEach((r,o)=>{e.push(r);}),new exports.A_SignalVector({structure:this.structure,values:e})}toObject(){let e={};return this.structure.forEach(r=>{let o=this._state.get(r);if(o===void 0)throw new Error(`Signal ${r.name} has no value in state`);e[r.name]=o;}),e}};i(exports.A_SignalState,"A_SignalState"),exports.A_SignalState=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-SignalState",description:"Manages the latest state of all signals within a given scope, maintaining a mapping between signal constructors and their most recently emitted values."})],exports.A_SignalState);exports.A_SignalConfig=class z extends aConcept.A_Fragment{get structure(){if(this._structure)return this._structure;let t=aConcept.A_Context.scope(this);return [...t.allowedEntities].filter(r=>aConcept.A_CommonHelper.isInheritedFrom(r,exports.A_Signal)).sort((r,o)=>r.constructor.name.localeCompare(o.name)).map(r=>t.resolveConstructor(r.name)).filter(r=>r)}get ready(){return this._ready}constructor(t){super({name:"A_SignalConfig"}),this._config=t;}async initialize(){return this._ready||(this._ready=this._initialize()),this._ready}async _initialize(){if(this._config.structure)this._structure=this._config.structure;else if(this._config.stringStructure){let t=this._config.stringStructure.split(",").map(e=>e.trim());this._structure=t.map(e=>aConcept.A_Context.scope(this).resolveConstructor(e)).filter(e=>e);}}};i(exports.A_SignalConfig,"A_SignalConfig"),exports.A_SignalConfig=a([aFrame.A_Frame.Fragment({namespace:"A-Utils",name:"A-SignalConfig",description:"Signal configuration fragment that defines the structure and types of signals within a given scope. It allows specifying the expected signal constructors and their order, facilitating consistent signal management and processing across components that emit or listen to signals."})],exports.A_SignalConfig);var Fo;exports.A_SignalBus=class Q extends aConcept.A_Component{async[Fo="_A_SignalFeatures_Next"](t,e,r,o,n,s){let c=aConcept.A_Context.scope(this);if(s||(s=new exports.A_SignalConfig({stringStructure:r?.get("A_SIGNAL_VECTOR_STRUCTURE")||void 0}),c.register(s)),s.ready||await s.initialize(),n||(n=new exports.A_SignalState(s.structure),c.register(n)),!n.has(t))return;o?.debug(`A_SignalBus: Updating state for signal '${t.constructor.name}' with data:`,t.data),n.set(t),await n.toVector().next(e);}};i(exports.A_SignalBus,"A_SignalBus"),a([aConcept.A_Feature.Extend({scope:[exports.A_Signal]}),l(0,aConcept.A_Inject(aConcept.A_Caller)),l(1,aConcept.A_Inject(aConcept.A_Scope)),l(2,aConcept.A_Inject(exports.A_Config)),l(3,aConcept.A_Inject(exports.A_Logger)),l(4,aConcept.A_Inject(exports.A_SignalState)),l(5,aConcept.A_Inject(exports.A_SignalConfig))],exports.A_SignalBus.prototype,Fo,1),exports.A_SignalBus=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"A-SignalBus",description:"Signal bus component that manages the emission and state of signals within a given scope. It listens for emitted signals, updates their state, and forwards them to registered watchers. The bus ensures a consistent signal vector structure based on the defined configuration, facilitating signal management across multiple components."})],exports.A_SignalBus);var ot=class ot{constructor(){this.promise=new Promise((t,e)=>{this.resolveFn=t,this.rejectFn=e;});}resolve(t){this.resolveFn(t);}reject(t){this.rejectFn(t);}};i(ot,"A_Deferred");var Ae=ot;var nt=class nt{constructor(t,e,r){this.config={resolveOnClear:false};r&&(this.config={...this.config,...r}),this.deferred=new Ae,this.timeout=setTimeout(()=>e().then((...o)=>this.deferred.resolve(...o)).catch((...o)=>this.deferred.reject(...o)),t);}get promise(){return this.deferred.promise}clear(){this.timeout&&(clearTimeout(this.timeout),this.config.resolveOnClear?this.deferred.resolve(void 0):this.deferred.reject(new aConcept.A_Error("Timeout Cleared")));}};i(nt,"A_ScheduleObject");var ge=nt;exports.A_Schedule=class ae extends aConcept.A_Component{async schedule(t,e,r){let o=aConcept.A_TypeGuards.isString(t)?new Date(t).getTime():t;return new ge(o-Date.now(),e,r)}async delay(t,e,r){return new ge(t,e,r)}};i(exports.A_Schedule,"A_Schedule"),exports.A_Schedule=a([aFrame.A_Frame.Component({namespace:"A-Utils",name:"A-Schedule",description:"Scheduling component that allows scheduling of callbacks to be executed at specific times or after certain delays. It provides methods to schedule callbacks based on Unix timestamps or ISO date strings, as well as a method to execute callbacks after a specified delay in milliseconds. This component is useful for managing timed operations within an application."})],exports.A_Schedule);
34
+ exports.A_CONSTANTS__CONFIG_ENV_VARIABLES=Yn;exports.A_CONSTANTS__CONFIG_ENV_VARIABLES_ARRAY=le;exports.A_ChannelError=te;exports.A_ChannelFeatures=Rt;exports.A_ChannelRequestStatuses=Pt;exports.A_CommandError=V;exports.A_CommandEvent=Dt;exports.A_CommandFeatures=Nt;exports.A_CommandTransitions=bt;exports.A_Command_Status=Ot;exports.A_ConfigError=$;exports.A_Deferred=Ae;exports.A_LOGGER_ANSI=J;exports.A_LOGGER_COLORS=lt;exports.A_LOGGER_DEFAULT_LEVEL=ei;exports.A_LOGGER_DEFAULT_SCOPE_LENGTH=ct;exports.A_LOGGER_ENV_KEYS=ye;exports.A_LOGGER_FORMAT=S;exports.A_LOGGER_SAFE_RANDOM_COLORS=pt;exports.A_LOGGER_TERMINAL=_e;exports.A_LOGGER_TIME_FORMAT=pe;exports.A_LoggerEnvVariables=De;exports.A_LoggerEnvVariablesArray=Ms;exports.A_ManifestChecker=me;exports.A_ManifestError=Z;exports.A_MemoryError=f;exports.A_MemoryFeatures=jr;exports.A_ScheduleObject=ge;exports.A_ServiceFeatures=ao;exports.A_SignalFeatures=Co;exports.A_SignalVectorFeatures=wo;exports.A_StateMachineError=ce;exports.A_StateMachineFeatures=Gt;exports.A_TYPES__ConfigFeature=zr;//# sourceMappingURL=index.cjs.map
35
35
  //# sourceMappingURL=index.cjs.map