@adaas/a-utils 0.1.25 → 0.1.26

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.
package/dist/index.cjs CHANGED
@@ -1,21 +1,21 @@
1
- 'use strict';var aConcept=require('@adaas/a-concept');var Je=Object.defineProperty;var lt=Object.getOwnPropertyDescriptor;var i=($,t)=>Je($,"name",{value:t,configurable:true});var p=($,t,e,r)=>{for(var o=r>1?void 0:r?lt(t,e):t,n=$.length-1,s;n>=0;n--)(s=$[n])&&(o=(r?s(t,e,o):s(o))||o);return r&&o&&Je(t,e,o),o},c=($,t)=>(e,r)=>t(e,r,$);var ge=class ge 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){this._meta.set(t,e);}has(t){return this._meta.has(t)}drop(t){this._meta.delete(t);}clear(){this._meta.clear();}toRaw(){return this._meta.toJSON()}toJSON(){return {name:this.name,...this.meta.toJSON()}}};i(ge,"A_ExecutionContext");var R=ge;var Ee=class Ee extends R{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(Ee,"A_OperationContext");var l=Ee;var oe=class oe extends aConcept.A_Error{constructor(t,e){aConcept.A_TypeGuards.isString(e)?super(t,e):super(t),e instanceof l&&(this._context=e);}get context(){return this._context}};i(oe,"A_ChannelError"),oe.MethodNotImplemented="A-Channel Method Not Implemented";var F=oe;var yt=(E=>(E.onTimeout="_A_Channel_onTimeout",E.onRetry="_A_Channel_onRetry",E.onCircuitBreakerOpen="_A_Channel_onCircuitBreakerOpen",E.onCache="_A_Channel_onCache",E.onConnect="_A_Channel_onConnect",E.onDisconnect="_A_Channel_onDisconnect",E.onBeforeRequest="_A_Channel_onBeforeRequest",E.onRequest="_A_Channel_onRequest",E.onAfterRequest="_A_Channel_onAfterRequest",E.onError="_A_Channel_onError",E.onSend="_A_Channel_onSend",E.onConsume="_A_Channel_onConsume",E))(yt||{}),ft=(r=>(r.PENDING="PENDING",r.SUCCESS="SUCCESS",r.FAILED="FAILED",r))(ft||{});var Te=class Te extends l{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(Te,"A_ChannelRequest");var J=Te;var O=class O 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()}`}),o=new J(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 F(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()}`}),o=new l("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 F(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()}`}),r=new l("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 F(o);return r.fail(n),await this.call("_A_Channel_onError",e),r}}};i(O,"A_Channel"),p([aConcept.A_Feature.Extend({name:"_A_Channel_onConnect"})],O.prototype,"onConnect",1),p([aConcept.A_Feature.Extend({name:"_A_Channel_onDisconnect"})],O.prototype,"onDisconnect",1),p([aConcept.A_Feature.Extend({name:"_A_Channel_onBeforeRequest"})],O.prototype,"onBeforeRequest",1),p([aConcept.A_Feature.Extend({name:"_A_Channel_onRequest"})],O.prototype,"onRequest",1),p([aConcept.A_Feature.Extend({name:"_A_Channel_onAfterRequest"})],O.prototype,"onAfterRequest",1),p([aConcept.A_Feature.Extend({name:"_A_Channel_onError"})],O.prototype,"onError",1),p([aConcept.A_Feature.Extend({name:"_A_Channel_onSend"})],O.prototype,"onSend",1);var xe=O;var gt=(s=>(s.CREATED="CREATED",s.INITIALIZED="INITIALIZED",s.COMPILED="COMPILED",s.EXECUTING="EXECUTING",s.COMPLETED="COMPLETED",s.FAILED="FAILED",s))(gt||{}),Et=(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))(Et||{}),Tt=(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))(Tt||{}),At=(a=>(a.onInit="onInit",a.onBeforeExecute="onBeforeExecute",a.onExecute="onExecute",a.onAfterExecute="onAfterExecute",a.onComplete="onComplete",a.onFail="onFail",a.onError="onError",a))(At||{});var z=class z extends aConcept.A_Error{};i(z,"A_CommandError"),z.CommandScopeBindingError="A-Command Scope Binding Error",z.ExecutionError="A-Command Execution Error",z.ResultProcessingError="A-Command Result Processing Error",z.CommandInterruptedError="A-Command Interrupted Error";var b=z;var W=class W extends aConcept.A_Error{};i(W,"A_StateMachineError"),W.InitializationError="A-StateMachine Initialization Error",W.TransitionError="A-StateMachine Transition Error";var V=W;var Ct=(o=>(o.onError="_A_StateMachine_onError",o.onInitialize="_A_StateMachine_onInitialize",o.onBeforeTransition="_A_StateMachine_onBeforeTransition",o.onAfterTransition="_A_StateMachine_onAfterTransition",o))(Ct||{});var Ce=class Ce extends l{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(Ce,"A_StateMachineTransition");var v=Ce;var wt,Pt,Ot,Lt,B=class B extends aConcept.A_Component{get ready(){return this._initialized||(this._initialized=this.call("_A_StateMachine_onInitialize")),this._initialized}async[Lt="_A_StateMachine_onInitialize"](...t){}async[Ot="_A_StateMachine_onBeforeTransition"](...t){}async[Pt="_A_StateMachine_onAfterTransition"](...t){}async[wt="_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 v({from:String(t),to:String(e),props:r}),s=new aConcept.A_Scope({name:`A-StateMachine-Transition-Scope-${o}`,fragments:[n]});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 d=new V({title:V.TransitionError,description:`An error occurred while transitioning to "${o}"`,originalError:a});throw s.register(d),await this.call("_A_StateMachine_onError",s),s.destroy(),d}}};i(B,"A_StateMachine"),p([aConcept.A_Feature.Extend()],B.prototype,Lt,1),p([aConcept.A_Feature.Extend()],B.prototype,Ot,1),p([aConcept.A_Feature.Extend()],B.prototype,Pt,1),p([aConcept.A_Feature.Extend()],B.prototype,wt,1);var L=B;var Po={},j=[];var ne=class ne extends aConcept.A_Error{};i(ne,"A_ConfigError"),ne.InitializationError="A-Config Initialization Error";var I=ne;var ve=class ve extends R{constructor(e){super("a-config");this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...j];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 I("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(ve,"A_Config");var y=ve;var Qe=20,Uo="all",et={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"},tt=["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"],k={RESET:"\x1B[0m",PREFIX:"\x1B[",SUFFIX:"m"},q={MINUTES_PAD:2,SECONDS_PAD:2,MILLISECONDS_PAD:3,SEPARATOR:":"},T={SCOPE_OPEN:"[",SCOPE_CLOSE:"]",TIME_OPEN:"|",TIME_CLOSE:"|",SEPARATOR:"-------------------------------",INDENT_BASE:3,PIPE:"| "},Z={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 w extends aConcept.A_Component{constructor(e,r){super();this.scope=e;this.config=r;this.COLORS=et,this.STANDARD_SCOPE_LENGTH=r?.get(Z.DEFAULT_SCOPE_LENGTH)||20;let o=r?.get(Z.DEFAULT_SCOPE_COLOR),n=r?.get(Z.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;}}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=tt,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]}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.scopeLength+3),s=r.length>1;return [`${k.PREFIX}${this.COLORS[this.DEFAULT_SCOPE_COLOR]}${k.SUFFIX}${T.SCOPE_OPEN}${this.formattedScope}${T.SCOPE_CLOSE}${k.RESET} ${k.PREFIX}${this.COLORS[e]}${k.SUFFIX}${T.TIME_OPEN}${o}${T.TIME_CLOSE}`,s?`
2
- ${n}${T.TIME_OPEN}${T.SEPARATOR}`:"",...r.map((a,d)=>{let D=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}${T.TIME_OPEN}${T.SEPARATOR}${k.RESET}`:k.RESET]}formatObject(e,r,o){let n;try{n=JSON.stringify(e,null,2);}catch{let d=new WeakSet;n=JSON.stringify(e,(D,m)=>{if(typeof m=="object"&&m!==null){if(d.has(m))return "[Circular Reference]";d.add(m);}return m},2);}let s=n.replace(/\n/g,`
4
- ${o}${T.PIPE}`);return r?`
5
- ${o}${T.PIPE}`+s:s}formatString(e,r,o){return ((r?`
1
+ 'use strict';var aConcept=require('@adaas/a-concept');var ot=Object.defineProperty;var ut=Object.getOwnPropertyDescriptor;var n=(F,t)=>ot(F,"name",{value:t,configurable:true});var a=(F,t,e,r)=>{for(var o=r>1?void 0:r?ut(t,e):t,i=F.length-1,s;i>=0;i--)(s=F[i])&&(o=(r?s(t,e,o):s(o))||o);return r&&o&&ot(t,e,o),o},p=(F,t)=>(e,r)=>t(e,r,F);var Se=class Se 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){this._meta.set(t,e);}has(t){return this._meta.has(t)}drop(t){this._meta.delete(t);}clear(){this._meta.clear();}toRaw(){return this._meta.toJSON()}toJSON(){return {name:this.name,...this.meta.toJSON()}}};n(Se,"A_ExecutionContext");var L=Se;var xe=class xe extends L{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()}}};n(xe,"A_OperationContext");var _=xe;var ae=class ae extends aConcept.A_Error{constructor(t,e){aConcept.A_TypeGuards.isString(e)?super(t,e):super(t),e instanceof _&&(this._context=e);}get context(){return this._context}};n(ae,"A_ChannelError"),ae.MethodNotImplemented="A-Channel Method Not Implemented";var B=ae;var xt=(A=>(A.onTimeout="_A_Channel_onTimeout",A.onRetry="_A_Channel_onRetry",A.onCircuitBreakerOpen="_A_Channel_onCircuitBreakerOpen",A.onCache="_A_Channel_onCache",A.onConnect="_A_Channel_onConnect",A.onDisconnect="_A_Channel_onDisconnect",A.onBeforeRequest="_A_Channel_onBeforeRequest",A.onRequest="_A_Channel_onRequest",A.onAfterRequest="_A_Channel_onAfterRequest",A.onError="_A_Channel_onError",A.onSend="_A_Channel_onSend",A.onConsume="_A_Channel_onConsume",A))(xt||{}),Ct=(r=>(r.PENDING="PENDING",r.SUCCESS="SUCCESS",r.FAILED="FAILED",r))(Ct||{});var Ce=class Ce extends _{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"});}};n(Ce,"A_ChannelRequest");var Q=Ce;var I=class I 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()}`}),o=new Q(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(i){this._processing=false;let s=new B(i);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()}`}),o=new _("send",e);try{r.inherit(aConcept.A_Context.scope(this)),r.register(o),await this.call("_A_Channel_onSend",r),this._processing=!1;}catch(i){this._processing=false;let s=new B(i);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()}`}),r=new _("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 i=new B(o);return r.fail(i),await this.call("_A_Channel_onError",e),r}}};n(I,"A_Channel"),a([aConcept.A_Feature.Extend({name:"_A_Channel_onConnect"})],I.prototype,"onConnect",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onDisconnect"})],I.prototype,"onDisconnect",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onBeforeRequest"})],I.prototype,"onBeforeRequest",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onRequest"})],I.prototype,"onRequest",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onAfterRequest"})],I.prototype,"onAfterRequest",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onError"})],I.prototype,"onError",1),a([aConcept.A_Feature.Extend({name:"_A_Channel_onSend"})],I.prototype,"onSend",1);var Le=I;var Rt=(s=>(s.CREATED="CREATED",s.INITIALIZED="INITIALIZED",s.COMPILED="COMPILED",s.EXECUTING="EXECUTING",s.COMPLETED="COMPLETED",s.FAILED="FAILED",s))(Rt||{}),Lt=(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))(Lt||{}),Pt=(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))(Pt||{}),vt=(c=>(c.onInit="onInit",c.onBeforeExecute="onBeforeExecute",c.onExecute="onExecute",c.onAfterExecute="onAfterExecute",c.onComplete="onComplete",c.onFail="onFail",c.onError="onError",c))(vt||{});var V=class V extends aConcept.A_Error{};n(V,"A_CommandError"),V.CommandScopeBindingError="A-Command Scope Binding Error",V.ExecutionError="A-Command Execution Error",V.ResultProcessingError="A-Command Result Processing Error",V.CommandInterruptedError="A-Command Interrupted Error";var k=V;var ee=class ee extends aConcept.A_Error{};n(ee,"A_StateMachineError"),ee.InitializationError="A-StateMachine Initialization Error",ee.TransitionError="A-StateMachine Transition Error";var H=ee;var bt=(o=>(o.onError="_A_StateMachine_onError",o.onInitialize="_A_StateMachine_onInitialize",o.onBeforeTransition="_A_StateMachine_onBeforeTransition",o.onAfterTransition="_A_StateMachine_onAfterTransition",o))(bt||{});var Pe=class Pe extends _{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")}};n(Pe,"A_StateMachineTransition");var P=Pe;var kt,Mt,Gt,$t,q=class q extends aConcept.A_Component{get ready(){return this._initialized||(this._initialized=this.call("_A_StateMachine_onInitialize")),this._initialized}async[$t="_A_StateMachine_onInitialize"](...t){}async[Gt="_A_StateMachine_onBeforeTransition"](...t){}async[Mt="_A_StateMachine_onAfterTransition"](...t){}async[kt="_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))}`,i=new P({from:String(t),to:String(e),props:r}),s=new aConcept.A_Scope({name:`A-StateMachine-Transition-Scope-${o}`,fragments:[i]});try{return await this.call("_A_StateMachine_onBeforeTransition",s),await this.call(o,s),await this.call("_A_StateMachine_onAfterTransition",s),s.destroy(),i.result}catch(c){let h=new H({title:H.TransitionError,description:`An error occurred while transitioning to "${o}"`,originalError:c});throw s.register(h),await this.call("_A_StateMachine_onError",s),s.destroy(),h}}};n(q,"A_StateMachine"),a([aConcept.A_Feature.Extend()],q.prototype,$t,1),a([aConcept.A_Feature.Extend()],q.prototype,Gt,1),a([aConcept.A_Feature.Extend()],q.prototype,Mt,1),a([aConcept.A_Feature.Extend()],q.prototype,kt,1);var b=q;var Xo={},K=[];var pe=class pe extends aConcept.A_Error{};n(pe,"A_ConfigError"),pe.InitializationError="A-Config Initialization Error";var N=pe;var Oe=class Oe extends L{constructor(e){super("a-config");this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...K];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 N("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(i=>({property:i,value:e[i]}));for(let{property:i,value:s}of o)super.set(aConcept.A_FormatterHelper.toUpperSnakeCase(i),s);}};n(Oe,"A_Config");var y=Oe;var st=20,cn="all",at={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"},ct=["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"],$={RESET:"\x1B[0m",PREFIX:"\x1B[",SUFFIX:"m"},X={MINUTES_PAD:2,SECONDS_PAD:2,MILLISECONDS_PAD:3,SEPARATOR:":"},S={SCOPE_OPEN:"[",SCOPE_CLOSE:"]",TIME_OPEN:"|",TIME_CLOSE:"|",SEPARATOR:"-------------------------------",INDENT_BASE:3,PIPE:"| "},te={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 E extends aConcept.A_Component{constructor(e,r){super();this.scope=e;this.config=r;this.COLORS=at,this.STANDARD_SCOPE_LENGTH=r?.get(te.DEFAULT_SCOPE_LENGTH)||20;let o=r?.get(te.DEFAULT_SCOPE_COLOR),i=r?.get(te.DEFAULT_LOG_COLOR);if(o||i)this.DEFAULT_SCOPE_COLOR=o||this.generateColorFromScopeName(this.scope.name),this.DEFAULT_LOG_COLOR=i||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;}}simpleHash(e){let r=0;for(let o=0;o<e.length;o++){let i=e.charCodeAt(o);r=(r<<5)-r+i,r=r&r;}return Math.abs(r)}generateColorFromScopeName(e){let r=ct,i=this.simpleHash(e)%r.length;return r[i]}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"}],i=this.simpleHash(e)%r.length;return r[i]}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,i=Math.floor(o/2),s=o-i;return " ".repeat(i)+e+" ".repeat(s)}compile(e,...r){let o=this.getTime(),i=" ".repeat(this.scopeLength+3),s=r.length>1;return [`${$.PREFIX}${this.COLORS[this.DEFAULT_SCOPE_COLOR]}${$.SUFFIX}${S.SCOPE_OPEN}${this.formattedScope}${S.SCOPE_CLOSE}${$.RESET} ${$.PREFIX}${this.COLORS[e]}${$.SUFFIX}${S.TIME_OPEN}${o}${S.TIME_CLOSE}`,s?`
2
+ ${i}${S.TIME_OPEN}${S.SEPARATOR}`:"",...r.map((c,h)=>{let G=h>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,G,i);default:return this.formatString(String(c),G,i)}}),s?`
3
+ ${i}${S.TIME_OPEN}${S.SEPARATOR}${$.RESET}`:$.RESET]}formatObject(e,r,o){let i;try{i=JSON.stringify(e,null,2);}catch{let h=new WeakSet;i=JSON.stringify(e,(G,l)=>{if(typeof l=="object"&&l!==null){if(h.has(l))return "[Circular Reference]";h.add(l);}return l},2);}let s=i.replace(/\n/g,`
4
+ ${o}${S.PIPE}`);return r?`
5
+ ${o}${S.PIPE}`+s:s}formatString(e,r,o){return ((r?`
6
6
  `:"")+e).replace(/\n/g,`
7
- ${o}${T.PIPE}`)}shouldLog(e){switch(this.config?.get(Z.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.scopeLength+3);console.log(`\x1B[31m[${this.formattedScope}] |${r}| ERROR ${e.code}
7
+ ${o}${S.PIPE}`)}shouldLog(e){switch(this.config?.get(te.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.scopeLength+3);console.log(`\x1B[31m[${this.formattedScope}] |${r}| ERROR ${e.code}
8
8
  ${o}| ${e.message}
9
9
  ${o}| ${e.description}
10
10
  ${o}|-------------------------------
11
11
  ${o}| ${e.stack?.split(`
12
- `).map((n,s)=>s===0?n:`${o}| ${n}`).join(`
12
+ `).map((i,s)=>s===0?i:`${o}| ${i}`).join(`
13
13
  `)||"No stack trace"}
14
14
  ${o}|-------------------------------
15
15
  \x1B[0m`+(e.originalError?`\x1B[31m${o}| Wrapped From ${e.originalError.message}
16
16
  ${o}|-------------------------------
17
17
  ${o}| ${e.originalError.stack?.split(`
18
- `).map((n,s)=>s===0?n:`${o}| ${n}`).join(`
18
+ `).map((i,s)=>s===0?i:`${o}| ${i}`).join(`
19
19
  `)||"No stack trace"}
20
20
  ${o}|-------------------------------
21
21
  \x1B[0m`:"")+(e.link?`\x1B[31m${o}| Read in docs: ${e.link}
@@ -28,18 +28,18 @@ ${r}|${" ".repeat(10)}| ${e.message}
28
28
  ${r}|${" ".repeat(10)}| ${e.description}
29
29
  ${r}|-------------------------------
30
30
  ${r}| ${e.stack?.split(`
31
- `).map((o,n)=>n===0?o:`${r}| ${o}`).join(`
31
+ `).map((o,i)=>i===0?o:`${r}| ${o}`).join(`
32
32
  `)||"No stack trace"}
33
33
  ${r}|-------------------------------`+(e.originalError?`${r}| Wrapped From ${e.originalError.message}
34
34
  ${r}|-------------------------------
35
35
  ${r}| ${e.originalError.stack?.split(`
36
- `).map((o,n)=>n===0?o:`${r}| ${o}`).join(`
36
+ `).map((o,i)=>i===0?o:`${r}| ${o}`).join(`
37
37
  `)||"No stack trace"}
38
38
  ${r}|-------------------------------`:"")+(e.link?`${r}| Read in docs: ${e.link}
39
39
  ${r}|-------------------------------`:"")}compile_Error(e){let r=" ".repeat(this.scopeLength+3);return JSON.stringify({name:e.name,message:e.message,stack:e.stack?.split(`
40
- `).map((o,n)=>n===0?o:`${r}| ${o}`).join(`
40
+ `).map((o,i)=>i===0?o:`${r}| ${o}`).join(`
41
41
  `)},null,2).replace(/\n/g,`
42
42
  ${r}| `).replace(/\\n/g,`
43
- `)}getTime(){let e=new Date,r=String(e.getMinutes()).padStart(q.MINUTES_PAD,"0"),o=String(e.getSeconds()).padStart(q.SECONDS_PAD,"0"),n=String(e.getMilliseconds()).padStart(q.MILLISECONDS_PAD,"0");return `${r}${q.SEPARATOR}${o}${q.SEPARATOR}${n}`}};i(exports.A_Logger,"A_Logger"),exports.A_Logger=p([c(0,aConcept.A_Inject(aConcept.A_Scope)),c(1,aConcept.A_Inject(y))],exports.A_Logger);var Gt,$t,Ft,Ut,zt,Bt,Yt,Vt,jt,qt,Ht,u=class u 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(R)}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[Ht="_A_StateMachine_onBeforeTransition"](e,r,...o){this.checkScopeInheritance(),r?.debug("yellow",`Command ${this.aseid.toString()} transitioning from ${e.from} to ${e.to}`);}async[qt="created_initialized"](e,...r){this._status==="CREATED"&&(this._createdAt=new Date,this._status="INITIALIZED",this.emit("onInit"));}async[jt="initialized_executing"](e,...r){this._status!=="INITIALIZED"&&this._status!=="CREATED"||(this._startTime=new Date,this._status="EXECUTING",this.emit("onExecute"));}async[Vt="executing_completed"](e,...r){this._endTime=new Date,this._status="COMPLETED",this.emit("onComplete");}async[Yt="executing_failed"](e,r,...o){this._endTime=new Date,this._status="FAILED",this.emit("onFail");}async[Bt="_A_Command_onInit"](e,...r){await e.transition("CREATED","INITIALIZED");}async[zt="_A_Command_onBeforeExecute"](e,...r){await e.transition("INITIALIZED","EXECUTING");}async[Ut="_A_Command_onExecute"](...e){}async[Ft="_A_Command_onAfterExecute"](...e){}async[$t="_A_Command_onComplete"](e,...r){await e.transition("EXECUTING","COMPLETED");}async[Gt="_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 R("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 b({title:b.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:[L]}),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:[L]}),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 b(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 b({title:b.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(u,"A_Command"),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(v)),c(1,aConcept.A_Inject(exports.A_Logger))],u.prototype,Ht,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(v))],u.prototype,qt,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(v))],u.prototype,jt,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(v))],u.prototype,Vt,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(v)),c(1,aConcept.A_Inject(aConcept.A_Error))],u.prototype,Yt,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(L))],u.prototype,Bt,1),p([aConcept.A_Feature.Extend({after:/.*/}),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(L))],u.prototype,zt,1),p([aConcept.A_Feature.Extend()],u.prototype,Ut,1),p([aConcept.A_Feature.Extend()],u.prototype,Ft,1),p([aConcept.A_Feature.Extend({after:/.*/}),c(0,aConcept.A_Inject(L))],u.prototype,$t,1),p([aConcept.A_Feature.Extend({after:/.*/}),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(L)),c(1,aConcept.A_Inject(R))],u.prototype,Gt,1);var Pe=u;var Oe=class Oe{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(Oe,"A_FSPolyfillClass");var se=Oe;var Le=class Le{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",d=>s.update(d)),a.on("end",()=>o(`${r}-${s.digest("base64")}`)),a.on("error",d=>n(d));}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),d=Array.from(new Uint8Array(a)),D=btoa(String.fromCharCode(...d));r(`${e}-${D}`);}catch(n){o(n);}}),"createTextHash")};}};i(Le,"A_CryptoPolyfillClass");var ae=Le;var Ie=class Ie{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(Ie,"A_HttpPolyfillClass");var ce=Ie;var be=class be{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(be,"A_HttpsPolyfillClass");var pe=be;var Ne=class Ne{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(Ne,"A_PathPolyfillClass");var le=Ne;var De=class De{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(De,"A_UrlPolyfillClass");var _e=De;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._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(ke,"A_BufferPolyfillClass");var me=ke;var Me=class Me{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(Me,"A_ProcessPolyfillClass");var de=Me;exports.A_Polyfill=class h 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 ae(this.logger),this._httpPolyfill=new ce(this.logger),this._httpsPolyfill=new pe(this.logger),this._pathPolyfill=new le(this.logger),this._urlPolyfill=new _e(this.logger),this._bufferPolyfill=new me(this.logger),this._processPolyfill=new de(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"),p([aConcept.A_Concept.Load()],exports.A_Polyfill.prototype,"load",1),p([aConcept.A_Concept.Load()],exports.A_Polyfill.prototype,"attachToWindow",1),exports.A_Polyfill=p([c(0,aConcept.A_Inject(exports.A_Logger))],exports.A_Polyfill);exports.ConfigReader=class g extends aConcept.A_Component{constructor(e){super();this.polyfill=e;this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...j];}async attachContext(e,r,o){o||(o=new y({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"),p([aConcept.A_Concept.Load(),c(0,aConcept.A_Inject(aConcept.A_Container)),c(1,aConcept.A_Inject(aConcept.A_Scope)),c(2,aConcept.A_Inject(y))],exports.ConfigReader.prototype,"attachContext",1),p([aConcept.A_Concept.Load(),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(y))],exports.ConfigReader.prototype,"initialize",1),exports.ConfigReader=p([c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(exports.A_Polyfill))],exports.ConfigReader);var Ge=class Ge 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(Ge,"FileConfigReader");var ee=Ge;var he=class he 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(`
44
- `).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(he,"ENVConfigReader"),p([aConcept.A_Concept.Load({before:["ENVConfigReader.initialize"]}),c(0,aConcept.A_Inject(y)),c(1,aConcept.A_Inject(exports.A_Polyfill)),c(2,aConcept.A_Inject(aConcept.A_Feature))],he.prototype,"readEnvFile",1);var H=he;var ye=class ye extends aConcept.A_Container{async prepare(t){if(!this.scope.has(y)){let r=new y({variables:[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...j],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(ee);break;case(aConcept.A_Context.environment==="server"&&!e.existsSync(`${aConcept.A_Context.concept}.conf.json`)):this.reader=this.scope.resolve(H);break;case aConcept.A_Context.environment==="browser":this.reader=this.scope.resolve(H);break;default:throw new I(I.InitializationError,`Environment ${aConcept.A_Context.environment} is not supported`)}}catch(r){if(r instanceof aConcept.A_ScopeError)throw new I({title:I.InitializationError,description:`Failed to initialize A_ConfigLoader. Reader not found for environment ${aConcept.A_Context.environment}`,originalError:r})}}};i(ye,"A_ConfigLoader"),p([aConcept.A_Concept.Load({before:/.*/}),c(0,aConcept.A_Inject(exports.A_Polyfill))],ye.prototype,"prepare",1);var Fe=ye;var Er=($=>$)(Er||{});var fe={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"},fn=[fe.A_LOGGER_LEVEL,fe.A_LOGGER_DEFAULT_SCOPE_LENGTH,fe.A_LOGGER_DEFAULT_SCOPE_COLOR,fe.A_LOGGER_DEFAULT_LOG_COLOR];var ue=class ue extends aConcept.A_Error{};i(ue,"A_ManifestError"),ue.ManifestInitializationError="A-Manifest Initialization Error";var M=ue;var Ue=class Ue{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(Ue,"A_ManifestChecker");var K=Ue;var Be=class Be 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 M(M.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 M(M.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 K(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,d)=>{let D=a.methodRegex.source===".*",m=d.methodRegex.source===".*";return D&&!m?1:!D&&m?-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 K(this,o,r,true)}};i(Be,"A_Manifest");var ze=Be;var Sr=(m=>(m.onInit="_A_Memory_onInit",m.onDestroy="_A_Memory_onDestroy",m.onExpire="_A_Memory_onExpire",m.onError="_A_Memory_onError",m.onSerialize="_A_Memory_onSerialize",m.onSet="_A_Memory_onSet",m.onGet="_A_Memory_onGet",m.onDrop="_A_Memory_onDrop",m.onClear="_A_Memory_onClear",m.onHas="_A_Memory_onHas",m))(Sr||{});var Ye=class Ye 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(Ye,"A_MemoryContext");var S=Ye;var P=class P extends aConcept.A_Error{};i(P,"A_MemoryError"),P.MemoryInitializationError="Memory initialization error",P.MemoryDestructionError="Memory destruction error",P.MemoryGetError="Memory GET operation failed",P.MemorySetError="Memory SET operation failed",P.MemoryDropError="Memory DROP operation failed",P.MemoryClearError="Memory CLEAR operation failed",P.MemoryHasError="Memory HAS operation failed",P.MemorySerializeError="Memory toJSON operation failed";var _=P;var vr,wr,Pr,Or,Lr,Ir,br,Nr,Dr,C=class C extends aConcept.A_Component{get ready(){return this._ready||(this._ready=this.init()),this._ready}async[Dr="_A_Memory_onError"](...t){}async[Nr="_A_Memory_onExpire"](...t){}async[br="_A_Memory_onInit"](t,...e){t||(t=new S,aConcept.A_Context.scope(this).register(t));}async[Ir="_A_Memory_onDestroy"](t,...e){t.clear();}async[Lr="_A_Memory_onGet"](t,e,...r){t.succeed(e.get(t.params.key));}async[Or="_A_Memory_onHas"](t,e,...r){t.succeed(e.has(t.params.key));}async[Pr="_A_Memory_onSet"](t,e,...r){e.set(t.params.key,t.params.value);}async[wr="_A_Memory_onDrop"](t,e,...r){e.delete(t.params.key);}async[vr="_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 _({title:_.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 _({title:_.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 l("get",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Get-Operation-Scope",fragments:[e]});try{return await this.call("_A_Memory_onGet",r),r.destroy(),e.result}catch(o){let n=new _({title:_.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 l("has",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Has-Operation-Scope",fragments:[e]});try{return await this.call("_A_Memory_onHas",r),r.destroy(),e.result}catch(o){let n=new _({title:_.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 l("set",{key:t,value:e}),o=new aConcept.A_Scope({name:"A-Memory-Set-Operation-Scope",fragments:[r]});try{await this.call("_A_Memory_onSet",o);}catch(n){let s=new _({title:_.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 l("drop",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Drop-Operation-Scope",fragments:[e]});try{await this.call("_A_Memory_onDrop",r);}catch(o){let n=new _({title:_.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 l("clear"),e=new aConcept.A_Scope({name:"A-Memory-Clear-Operation-Scope",fragments:[t]});try{await this.call("_A_Memory_onClear",e);}catch(r){let o=new _({title:_.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 l("serialize"),e=new aConcept.A_Scope({name:"A-Memory-Serialize-Operation-Scope",fragments:[t]});try{return await this.call("_A_Memory_onSerialize",e),t.result}catch(r){let o=new _({title:_.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(C,"A_Memory"),p([aConcept.A_Feature.Extend()],C.prototype,Dr,1),p([aConcept.A_Feature.Extend()],C.prototype,Nr,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(S))],C.prototype,br,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Inject(S))],C.prototype,Ir,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(l)),c(1,aConcept.A_Inject(S))],C.prototype,Lr,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(l)),c(1,aConcept.A_Inject(S))],C.prototype,Or,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(l)),c(1,aConcept.A_Inject(S))],C.prototype,Pr,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(l)),c(1,aConcept.A_Inject(S))],C.prototype,wr,1),p([aConcept.A_Feature.Extend(),c(0,aConcept.A_Dependency.Required()),c(0,aConcept.A_Inject(l)),c(1,aConcept.A_Inject(S))],C.prototype,vr,1);var je=C;var qe=class qe{constructor(){this.promise=new Promise((t,e)=>{this.resolveFn=t,this.rejectFn=e;});}resolve(t){this.resolveFn(t);}reject(t){this.rejectFn(t);}};i(qe,"A_Deferred");var re=qe;var He=class He{constructor(t,e,r){this.config={resolveOnClear:false};r&&(this.config={...this.config,...r}),this.deferred=new re,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(He,"A_ScheduleObject");var X=He;var Xe=class Xe extends aConcept.A_Component{async schedule(t,e,r){let o=aConcept.A_TypeGuards.isString(t)?new Date(t).getTime():t;return new X(o-Date.now(),e,r)}async delay(t,e,r){return new X(t,e,r)}};i(Xe,"A_Schedule");var Ke=Xe;exports.A_CONSTANTS__CONFIG_ENV_VARIABLES=Po;exports.A_CONSTANTS__CONFIG_ENV_VARIABLES_ARRAY=j;exports.A_Channel=xe;exports.A_ChannelError=F;exports.A_ChannelFeatures=yt;exports.A_ChannelRequest=J;exports.A_ChannelRequestStatuses=ft;exports.A_Command=Pe;exports.A_CommandError=b;exports.A_CommandEvent=At;exports.A_CommandFeatures=Tt;exports.A_CommandTransitions=Et;exports.A_Command_Status=gt;exports.A_Config=y;exports.A_ConfigError=I;exports.A_ConfigLoader=Fe;exports.A_Deferred=re;exports.A_ExecutionContext=R;exports.A_LOGGER_ANSI=k;exports.A_LOGGER_COLORS=et;exports.A_LOGGER_DEFAULT_LEVEL=Uo;exports.A_LOGGER_DEFAULT_SCOPE_LENGTH=Qe;exports.A_LOGGER_ENV_KEYS=Z;exports.A_LOGGER_FORMAT=T;exports.A_LOGGER_SAFE_RANDOM_COLORS=tt;exports.A_LOGGER_TIME_FORMAT=q;exports.A_LoggerEnvVariables=fe;exports.A_LoggerEnvVariablesArray=fn;exports.A_Manifest=ze;exports.A_ManifestChecker=K;exports.A_ManifestError=M;exports.A_Memory=je;exports.A_MemoryContext=S;exports.A_MemoryError=_;exports.A_MemoryFeatures=Sr;exports.A_OperationContext=l;exports.A_Schedule=Ke;exports.A_ScheduleObject=X;exports.A_StateMachine=L;exports.A_StateMachineError=V;exports.A_StateMachineFeatures=Ct;exports.A_StateMachineTransition=v;exports.A_TYPES__ConfigFeature=Er;exports.ENVConfigReader=H;exports.FileConfigReader=ee;//# sourceMappingURL=index.cjs.map
43
+ `)}getTime(){let e=new Date,r=String(e.getMinutes()).padStart(X.MINUTES_PAD,"0"),o=String(e.getSeconds()).padStart(X.SECONDS_PAD,"0"),i=String(e.getMilliseconds()).padStart(X.MILLISECONDS_PAD,"0");return `${r}${X.SEPARATOR}${o}${X.SEPARATOR}${i}`}};n(exports.A_Logger,"A_Logger"),exports.A_Logger=a([p(0,aConcept.A_Inject(aConcept.A_Scope)),p(1,aConcept.A_Inject(y))],exports.A_Logger);var qt,jt,Ht,Kt,Xt,Jt,Wt,Zt,Qt,er,tr,u=class u 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(L)}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[tr="_A_StateMachine_onBeforeTransition"](e,r,...o){this.checkScopeInheritance(),r?.debug("yellow",`Command ${this.aseid.toString()} transitioning from ${e.from} to ${e.to}`);}async[er="created_initialized"](e,...r){this._status==="CREATED"&&(this._createdAt=new Date,this._status="INITIALIZED",this.emit("onInit"));}async[Qt="initialized_executing"](e,...r){this._status!=="INITIALIZED"&&this._status!=="CREATED"||(this._startTime=new Date,this._status="EXECUTING",this.emit("onExecute"));}async[Zt="executing_completed"](e,...r){this._endTime=new Date,this._status="COMPLETED",this.emit("onComplete");}async[Wt="executing_failed"](e,r,...o){this._endTime=new Date,this._status="FAILED",this.emit("onFail");}async[Jt="_A_Command_onInit"](e,...r){await e.transition("CREATED","INITIALIZED");}async[Xt="_A_Command_onBeforeExecute"](e,...r){await e.transition("INITIALIZED","EXECUTING");}async[Kt="_A_Command_onExecute"](...e){}async[Ht="_A_Command_onAfterExecute"](...e){}async[jt="_A_Command_onComplete"](e,...r){await e.transition("EXECUTING","COMPLETED");}async[qt="_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 L("execute-command");this.scope.register(e),await new Promise(async(r,o)=>{try{let i=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",()=>{i.interrupt(),s.interrupt(),c.interrupt(),r();}),this.on("onFail",()=>{i.interrupt(),s.interrupt(),c.interrupt(),o(this.error);}),await i.process(this.scope),await s.process(this.scope),await c.process(this.scope),this._origin==="invoked"&&await this.complete(),r();}catch(i){o(i);}});}catch(e){let r=e instanceof aConcept.A_Error?e:new k({title:k.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:[b]}),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:[b]}),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 k(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 k({title:k.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));}};n(u,"A_Command"),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(P)),p(1,aConcept.A_Inject(exports.A_Logger))],u.prototype,tr,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(P))],u.prototype,er,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(P))],u.prototype,Qt,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(P))],u.prototype,Zt,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(P)),p(1,aConcept.A_Inject(aConcept.A_Error))],u.prototype,Wt,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(b))],u.prototype,Jt,1),a([aConcept.A_Feature.Extend({after:/.*/}),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(b))],u.prototype,Xt,1),a([aConcept.A_Feature.Extend()],u.prototype,Kt,1),a([aConcept.A_Feature.Extend()],u.prototype,Ht,1),a([aConcept.A_Feature.Extend({after:/.*/}),p(0,aConcept.A_Inject(b))],u.prototype,jt,1),a([aConcept.A_Feature.Extend({after:/.*/}),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(b)),p(1,aConcept.A_Inject(L))],u.prototype,qt,1);var be=u;var Ne=class Ne{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:n((t,e)=>(this.logger.warning("fs.readFileSync not available in browser environment"),""),"readFileSync"),existsSync:n(t=>(this.logger.warning("fs.existsSync not available in browser environment"),false),"existsSync"),createReadStream:n(t=>(this.logger.warning("fs.createReadStream not available in browser environment"),null),"createReadStream")};}};n(Ne,"A_FSPolyfillClass");var le=Ne;var De=class De{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:n((e,r="sha384")=>Promise.resolve(`${r}-${t.createHash(r).update(e).digest("base64")}`),"createTextHash"),createFileHash:n((e,r="sha384")=>new Promise(async(o,i)=>{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",h=>s.update(h)),c.on("end",()=>o(`${r}-${s.digest("base64")}`)),c.on("error",h=>i(h));}catch(s){i(s);}}),"createFileHash")};}initBrowser(){this._crypto={createFileHash:n(()=>(this.logger.warning("File hash not available in browser environment"),Promise.resolve("")),"createFileHash"),createTextHash:n((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),h=Array.from(new Uint8Array(c)),G=btoa(String.fromCharCode(...h));r(`${e}-${G}`);}catch(i){o(i);}}),"createTextHash")};}};n(De,"A_CryptoPolyfillClass");var _e=De;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._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:n((t,e)=>(this.logger.warning("http.request not available in browser/test environment, use fetch instead"),this.createMockRequest(t,e,false)),"request"),get:n((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:n(()=>(this.logger.error("http.createServer not available in browser/test environment"),null),"createServer")};}createMockRequest(t,e,r=false){return {end:n(()=>{if(e){let i={statusCode:200,headers:{},on:n((s,c)=>{s==="data"?setTimeout(()=>c("mock data"),0):s==="end"&&setTimeout(()=>c(),0);},"on"),pipe:n(s=>{s.write&&s.write("mock data"),s.end&&s.end();},"pipe")};setTimeout(()=>e(i),0);}},"end"),write:n(i=>{},"write"),on:n((i,s)=>{},"on")}}};n(ke,"A_HttpPolyfillClass");var me=ke;var Me=class Me{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:n((t,e)=>(this.logger.warning("https.request not available in browser/test environment, use fetch instead"),this.createMockRequest(t,e,true)),"request"),get:n((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:n(()=>(this.logger.error("https.createServer not available in browser/test environment"),null),"createServer")};}createMockRequest(t,e,r=true){return {end:n(()=>{if(e){let i={statusCode:200,headers:{},on:n((s,c)=>{s==="data"?setTimeout(()=>c("mock data"),0):s==="end"&&setTimeout(()=>c(),0);},"on"),pipe:n(s=>{s.write&&s.write("mock data"),s.end&&s.end();},"pipe")};setTimeout(()=>e(i),0);}},"end"),write:n(i=>{},"write"),on:n((i,s)=>{},"on")}}};n(Me,"A_HttpsPolyfillClass");var de=Me;var Ge=class Ge{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:n((...t)=>t.join("/").replace(/\/+/g,"/"),"join"),resolve:n((...t)=>{let e="";for(let r of t)r.startsWith("/")?e=r:e=this._path.join(e,r);return e||"/"},"resolve"),dirname:n(t=>t.split("/").slice(0,-1).join("/")||"/","dirname"),basename:n((t,e)=>{let r=t.split("/").pop()||"";return e&&r.endsWith(e)?r.slice(0,-e.length):r},"basename"),extname:n(t=>{let e=t.split(".");return e.length>1?"."+e.pop():""},"extname"),relative:n((t,e)=>e.replace(t,"").replace(/^\//,""),"relative"),normalize:n(t=>t.replace(/\/+/g,"/").replace(/\/$/,"")||"/","normalize"),isAbsolute:n(t=>t.startsWith("/")||/^[a-zA-Z]:/.test(t),"isAbsolute"),parse:n(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:n(t=>this._path.join(t.dir||"",t.base||""),"format"),sep:"/",delimiter:":"};}};n(Ge,"A_PathPolyfillClass");var he=Ge;var $e=class $e{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:n(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:n(t=>{try{return new URL("",t.href||`${t.protocol}//${t.host}${t.pathname}${t.search}${t.hash}`).href}catch{return ""}},"format"),resolve:n((t,e)=>{try{return new URL(e,t).href}catch{return e}},"resolve"),URL:globalThis.URL,URLSearchParams:globalThis.URLSearchParams};}};n($e,"A_UrlPolyfillClass");var fe=$e;var Ue=class Ue{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:n((t,e)=>typeof t=="string"?new TextEncoder().encode(t):new Uint8Array(t),"from"),alloc:n((t,e)=>{let r=new Uint8Array(t);return e!==void 0&&r.fill(e),r},"alloc"),allocUnsafe:n(t=>new Uint8Array(t),"allocUnsafe"),isBuffer:n(t=>t instanceof Uint8Array||t instanceof ArrayBuffer,"isBuffer"),concat:n((t,e)=>{let r=e||t.reduce((s,c)=>s+c.length,0),o=new Uint8Array(r),i=0;for(let s of t)o.set(s,i),i+=s.length;return o},"concat")};}};n(Ue,"A_BufferPolyfillClass");var ye=Ue;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._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:n(()=>"/","cwd"),exit:n(t=>{throw this.logger.warning("process.exit not available in browser"),new Error(`Process exit with code ${t}`)},"exit"),nextTick:n((t,...e)=>{setTimeout(()=>t(...e),0);},"nextTick")};}};n(ze,"A_ProcessPolyfillClass");var ge=ze;exports.A_Polyfill=class d 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:n(()=>"/","cwd")},globalThis.__dirname="/");}async _loadInternal(){this._fsPolyfill=new le(this.logger),this._cryptoPolyfill=new _e(this.logger),this._httpPolyfill=new me(this.logger),this._httpsPolyfill=new de(this.logger),this._pathPolyfill=new he(this.logger),this._urlPolyfill=new fe(this.logger),this._bufferPolyfill=new ye(this.logger),this._processPolyfill=new ge(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()}};n(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([p(0,aConcept.A_Inject(exports.A_Logger))],exports.A_Polyfill);exports.ConfigReader=class T extends aConcept.A_Component{constructor(e){super();this.polyfill=e;this.DEFAULT_ALLOWED_TO_READ_PROPERTIES=[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...K];}async attachContext(e,r,o){o||(o=new y({defaults:{}}),e.scope.register(o));let i=await this.getProjectRoot();o.set("A_CONCEPT_ROOT_FOLDER",i);}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()}};n(exports.ConfigReader,"ConfigReader"),a([aConcept.A_Concept.Load(),p(0,aConcept.A_Inject(aConcept.A_Container)),p(1,aConcept.A_Inject(aConcept.A_Scope)),p(2,aConcept.A_Inject(y))],exports.ConfigReader.prototype,"attachContext",1),a([aConcept.A_Concept.Load(),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(y))],exports.ConfigReader.prototype,"initialize",1),exports.ConfigReader=a([p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(exports.A_Polyfill))],exports.ConfigReader);var Fe=class Fe 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"),i=JSON.parse(o);return this.FileData=new Map(Object.entries(i)),i}catch{return {}}}};n(Fe,"FileConfigReader");var oe=Fe;var ue=class ue 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(`
44
+ `).forEach(i=>{let[s,c]=i.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}};n(ue,"ENVConfigReader"),a([aConcept.A_Concept.Load({before:["ENVConfigReader.initialize"]}),p(0,aConcept.A_Inject(y)),p(1,aConcept.A_Inject(exports.A_Polyfill)),p(2,aConcept.A_Inject(aConcept.A_Feature))],ue.prototype,"readEnvFile",1);var J=ue;var Ee=class Ee extends aConcept.A_Container{async prepare(t){if(!this.scope.has(y)){let r=new y({variables:[...aConcept.A_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY,...K],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(oe);break;case(aConcept.A_Context.environment==="server"&&!e.existsSync(`${aConcept.A_Context.concept}.conf.json`)):this.reader=this.scope.resolve(J);break;case aConcept.A_Context.environment==="browser":this.reader=this.scope.resolve(J);break;default:throw new N(N.InitializationError,`Environment ${aConcept.A_Context.environment} is not supported`)}}catch(r){if(r instanceof aConcept.A_ScopeError)throw new N({title:N.InitializationError,description:`Failed to initialize A_ConfigLoader. Reader not found for environment ${aConcept.A_Context.environment}`,originalError:r})}}};n(Ee,"A_ConfigLoader"),a([aConcept.A_Concept.Load({before:/.*/}),p(0,aConcept.A_Inject(exports.A_Polyfill))],Ee.prototype,"prepare",1);var Ye=Ee;var Lr=(F=>F)(Lr||{});var Te={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"},Gi=[Te.A_LOGGER_LEVEL,Te.A_LOGGER_DEFAULT_SCOPE_LENGTH,Te.A_LOGGER_DEFAULT_SCOPE_COLOR,Te.A_LOGGER_DEFAULT_LOG_COLOR];var Ae=class Ae extends aConcept.A_Error{};n(Ae,"A_ManifestError"),Ae.ManifestInitializationError="A-Manifest Initialization Error";var U=Ae;var Ve=class Ve{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}};n(Ve,"A_ManifestChecker");var W=Ve;var je=class je 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 U(U.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 U(U.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 i=this.methodToRegex(o.method);this.rules.push({componentRegex:r,methodRegex:i,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 W(this,o,r)}internal_checkAccess(e){let r=e.component.name,o=e.method,i=e.target.name,s=this.rules.filter(c=>c.componentRegex.test(r)&&c.methodRegex.test(o)).sort((c,h)=>{let G=c.methodRegex.source===".*",l=h.methodRegex.source===".*";return G&&!l?1:!G&&l?-1:0});if(s.length===0)return true;for(let c of s){if(c.excludeRegex&&c.excludeRegex.test(i))return false;if(c.applyRegex)return c.applyRegex.test(i)}return true}isExcluded(e,r){let o=typeof e=="function"?e:e.constructor;return new W(this,o,r,true)}};n(je,"A_Manifest");var qe=je;var Or=(l=>(l.onInit="_A_Memory_onInit",l.onDestroy="_A_Memory_onDestroy",l.onExpire="_A_Memory_onExpire",l.onError="_A_Memory_onError",l.onSerialize="_A_Memory_onSerialize",l.onSet="_A_Memory_onSet",l.onGet="_A_Memory_onGet",l.onDrop="_A_Memory_onDrop",l.onClear="_A_Memory_onClear",l.onHas="_A_Memory_onHas",l))(Or||{});var He=class He 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();}};n(He,"A_MemoryContext");var C=He;var v=class v extends aConcept.A_Error{};n(v,"A_MemoryError"),v.MemoryInitializationError="Memory initialization error",v.MemoryDestructionError="Memory destruction error",v.MemoryGetError="Memory GET operation failed",v.MemorySetError="Memory SET operation failed",v.MemoryDropError="Memory DROP operation failed",v.MemoryClearError="Memory CLEAR operation failed",v.MemoryHasError="Memory HAS operation failed",v.MemorySerializeError="Memory toJSON operation failed";var m=v;var Dr,kr,Mr,Gr,$r,Ur,zr,Fr,Br,R=class R extends aConcept.A_Component{get ready(){return this._ready||(this._ready=this.init()),this._ready}async[Br="_A_Memory_onError"](...t){}async[Fr="_A_Memory_onExpire"](...t){}async[zr="_A_Memory_onInit"](t,...e){t||(t=new C,aConcept.A_Context.scope(this).register(t));}async[Ur="_A_Memory_onDestroy"](t,...e){t.clear();}async[$r="_A_Memory_onGet"](t,e,...r){t.succeed(e.get(t.params.key));}async[Gr="_A_Memory_onHas"](t,e,...r){t.succeed(e.has(t.params.key));}async[Mr="_A_Memory_onSet"](t,e,...r){e.set(t.params.key,t.params.value);}async[kr="_A_Memory_onDrop"](t,e,...r){e.delete(t.params.key);}async[Dr="_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 m({title:m.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 m({title:m.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 _("get",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Get-Operation-Scope",fragments:[e]});try{return await this.call("_A_Memory_onGet",r),r.destroy(),e.result}catch(o){let i=new m({title:m.MemoryGetError,description:`An error occurred while getting the value for key "${String(t)}"`,originalError:o});throw r.register(i),await this.call("_A_Memory_onError",r),r.destroy(),i}}async has(t){let e=new _("has",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Has-Operation-Scope",fragments:[e]});try{return await this.call("_A_Memory_onHas",r),r.destroy(),e.result}catch(o){let i=new m({title:m.MemoryHasError,description:`An error occurred while checking existence for key "${String(t)}"`,originalError:o});throw r.register(i),await this.call("_A_Memory_onError",r),r.destroy(),i}}async set(t,e){let r=new _("set",{key:t,value:e}),o=new aConcept.A_Scope({name:"A-Memory-Set-Operation-Scope",fragments:[r]});try{await this.call("_A_Memory_onSet",o);}catch(i){let s=new m({title:m.MemorySetError,description:`An error occurred while setting the value for key "${String(t)}"`,originalError:i});throw o.register(s),await this.call("_A_Memory_onError",o),o.destroy(),s}}async drop(t){let e=new _("drop",{key:t}),r=new aConcept.A_Scope({name:"A-Memory-Drop-Operation-Scope",fragments:[e]});try{await this.call("_A_Memory_onDrop",r);}catch(o){let i=new m({title:m.MemoryDropError,description:`An error occurred while dropping the value for key "${String(t)}"`,originalError:o});throw r.register(i),await this.call("_A_Memory_onError",r),r.destroy(),i}}async clear(){let t=new _("clear"),e=new aConcept.A_Scope({name:"A-Memory-Clear-Operation-Scope",fragments:[t]});try{await this.call("_A_Memory_onClear",e);}catch(r){let o=new m({title:m.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 _("serialize"),e=new aConcept.A_Scope({name:"A-Memory-Serialize-Operation-Scope",fragments:[t]});try{return await this.call("_A_Memory_onSerialize",e),t.result}catch(r){let o=new m({title:m.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}}};n(R,"A_Memory"),a([aConcept.A_Feature.Extend()],R.prototype,Br,1),a([aConcept.A_Feature.Extend()],R.prototype,Fr,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(C))],R.prototype,zr,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(C))],R.prototype,Ur,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(_)),p(1,aConcept.A_Inject(C))],R.prototype,$r,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(_)),p(1,aConcept.A_Inject(C))],R.prototype,Gr,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(_)),p(1,aConcept.A_Inject(C))],R.prototype,Mr,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(_)),p(1,aConcept.A_Inject(C))],R.prototype,kr,1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Dependency.Required()),p(0,aConcept.A_Inject(_)),p(1,aConcept.A_Inject(C))],R.prototype,Dr,1);var Xe=R;var Yr=(l=>(l.onBeforeLoad="_A_Service_onBeforeLoad",l.onLoad="_A_Service_onLoad",l.onAfterLoad="_A_Service_onAfterLoad",l.onBeforeStart="_A_Service_onBeforeStart",l.onStart="_A_Service_onStart",l.onAfterStart="_A_Service_onAfterStart",l.onBeforeStop="_A_Service_onBeforeStop",l.onStop="_A_Service_onStop",l.onAfterStop="_A_Service_onAfterStop",l.onError="_A_Service_onError",l))(Yr||{});var ie=class ie extends aConcept.A_Error{};n(ie,"A_Service_Error"),ie.ServiceStartError="Service start error",ie.ServiceStopError="Service stop error";var O=ie;var jr,Hr,Kr,Xr,Jr,Wr,Zr,Qr,eo,to,f=class f extends aConcept.A_Container{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 O:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof O):e=t.originalError;break;default:e=new O({title:O.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 O:e=t;break;case(t instanceof aConcept.A_Error&&t.originalError instanceof O):e=t.originalError;break;default:e=new O({title:O.ServiceStopError,description:"An error occurred while processing the request.",originalError:t});break}this.scope.register(e),await this.call("_A_Service_onError");}}async[to="_A_Service_onBeforeLoad"](t){t||(this.scope.register(exports.A_Polyfill),t=this.scope.resolve(exports.A_Polyfill));}async[eo="_A_Service_onLoad"](...t){}async[Qr="_A_Service_onAfterLoad"](...t){}async[Zr="_A_Service_onBeforeStart"](...t){}async[Wr="_A_Service_onStart"](...t){}async[Jr="_A_Service_onAfterStart"](...t){}async[Xr="_A_Service_onBeforeStop"](...t){}async[Kr="_A_Service_onStop"](...t){}async[Hr="_A_Service_onAfterStop"](...t){}async[jr="_A_Service_onError"](t,e,...r){e?.error(t);}};n(f,"A_Service"),a([aConcept.A_Concept.Start()],f.prototype,"start",1),a([aConcept.A_Concept.Stop()],f.prototype,"stop",1),a([aConcept.A_Feature.Extend(),p(0,aConcept.A_Inject(exports.A_Polyfill))],f.prototype,to,1),a([aConcept.A_Feature.Extend()],f.prototype,eo,1),a([aConcept.A_Feature.Extend()],f.prototype,Qr,1),a([aConcept.A_Feature.Extend()],f.prototype,Zr,1),a([aConcept.A_Feature.Extend()],f.prototype,Wr,1),a([aConcept.A_Feature.Extend()],f.prototype,Jr,1),a([aConcept.A_Feature.Extend()],f.prototype,Xr,1),a([aConcept.A_Feature.Extend()],f.prototype,Kr,1),a([aConcept.A_Feature.Extend()],f.prototype,Hr,1),a([aConcept.A_Feature.Extend({before:/.*/}),p(0,aConcept.A_Inject(aConcept.A_Error)),p(1,aConcept.A_Inject(exports.A_Logger))],f.prototype,jr,1);var Ze=f;var Qe=class Qe{constructor(){this.promise=new Promise((t,e)=>{this.resolveFn=t,this.rejectFn=e;});}resolve(t){this.resolveFn(t);}reject(t){this.rejectFn(t);}};n(Qe,"A_Deferred");var se=Qe;var et=class et{constructor(t,e,r){this.config={resolveOnClear:false};r&&(this.config={...this.config,...r}),this.deferred=new se,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")));}};n(et,"A_ScheduleObject");var Z=et;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 Z(o-Date.now(),e,r)}async delay(t,e,r){return new Z(t,e,r)}};n(rt,"A_Schedule");var tt=rt;exports.A_CONSTANTS__CONFIG_ENV_VARIABLES=Xo;exports.A_CONSTANTS__CONFIG_ENV_VARIABLES_ARRAY=K;exports.A_Channel=Le;exports.A_ChannelError=B;exports.A_ChannelFeatures=xt;exports.A_ChannelRequest=Q;exports.A_ChannelRequestStatuses=Ct;exports.A_Command=be;exports.A_CommandError=k;exports.A_CommandEvent=vt;exports.A_CommandFeatures=Pt;exports.A_CommandTransitions=Lt;exports.A_Command_Status=Rt;exports.A_Config=y;exports.A_ConfigError=N;exports.A_ConfigLoader=Ye;exports.A_Deferred=se;exports.A_ExecutionContext=L;exports.A_LOGGER_ANSI=$;exports.A_LOGGER_COLORS=at;exports.A_LOGGER_DEFAULT_LEVEL=cn;exports.A_LOGGER_DEFAULT_SCOPE_LENGTH=st;exports.A_LOGGER_ENV_KEYS=te;exports.A_LOGGER_FORMAT=S;exports.A_LOGGER_SAFE_RANDOM_COLORS=ct;exports.A_LOGGER_TIME_FORMAT=X;exports.A_LoggerEnvVariables=Te;exports.A_LoggerEnvVariablesArray=Gi;exports.A_Manifest=qe;exports.A_ManifestChecker=W;exports.A_ManifestError=U;exports.A_Memory=Xe;exports.A_MemoryContext=C;exports.A_MemoryError=m;exports.A_MemoryFeatures=Or;exports.A_OperationContext=_;exports.A_Schedule=tt;exports.A_ScheduleObject=Z;exports.A_Service=Ze;exports.A_ServiceFeatures=Yr;exports.A_StateMachine=b;exports.A_StateMachineError=H;exports.A_StateMachineFeatures=bt;exports.A_StateMachineTransition=P;exports.A_TYPES__ConfigFeature=Lr;exports.ENVConfigReader=J;exports.FileConfigReader=oe;//# sourceMappingURL=index.cjs.map
45
45
  //# sourceMappingURL=index.cjs.map