@fincity/kirun-js 1.0.0 → 1.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (27) hide show
  1. package/__tests__/engine/function/system/array/BinarySearchTest.ts +51 -42
  2. package/__tests__/engine/function/system/array/IndexOfTest.ts +1 -1
  3. package/__tests__/engine/function/system/context/SetFunctionTest.ts +52 -0
  4. package/__tests__/engine/function/system/string/InsertAtGivenPositionTest.ts +2 -2
  5. package/__tests__/engine/function/system/string/StringFunctionRepoTest2.ts +10 -0
  6. package/__tests__/engine/function/system/string/StringFunctionRepoTest3.ts +18 -10
  7. package/__tests__/engine/function/system/string/StringFunctionRepositoryTest.ts +5 -7
  8. package/__tests__/engine/runtime/expression/ExpressionTest.ts +6 -0
  9. package/__tests__/engine/runtime/expression/tokenextractor/OutputMapTokenValueExtractorTest.ts +1 -1
  10. package/dist/index.js +1 -1
  11. package/dist/index.js.map +1 -1
  12. package/dist/module.js +1 -1
  13. package/dist/module.js.map +1 -1
  14. package/dist/types.d.ts +108 -1
  15. package/dist/types.d.ts.map +1 -1
  16. package/package.json +1 -1
  17. package/src/engine/function/system/array/AbstractArrayFunction.ts +12 -0
  18. package/src/engine/function/system/array/BinarySearch.ts +3 -3
  19. package/src/engine/function/system/context/SetFunction.ts +94 -107
  20. package/src/engine/function/system/string/AbstractStringFunction.ts +61 -39
  21. package/src/engine/function/system/string/StringFunctionRepository.ts +2 -2
  22. package/src/engine/json/schema/validator/StringValidator.ts +1 -1
  23. package/src/engine/runtime/expression/Expression.ts +6 -8
  24. package/src/engine/runtime/expression/Operation.ts +26 -4
  25. package/src/engine/util/MapUtil.ts +10 -10
  26. package/src/engine/util/primitive/PrimitiveUtil.ts +2 -1
  27. package/src/index.ts +11 -0
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- function e(e,t){return Object.keys(t).forEach((function(r){"default"===r||"__esModule"===r||e.hasOwnProperty(r)||Object.defineProperty(e,r,{enumerable:!0,get:function(){return t[r]}})})),e}function t(e,t,r,s){Object.defineProperty(e,t,{get:r,set:s,enumerable:!0,configurable:!0})}var r={};t(r,"Tuple2",(()=>s)),t(r,"Tuple3",(()=>n)),t(r,"Tuple4",(()=>i));class s{constructor(e,t){this.f=e,this.s=t}getT1(){return this.f}getT2(){return this.s}}class n extends s{constructor(e,t,r){super(e,t),this.t=r}getT3(){return this.t}}class i extends n{constructor(e,t,r,s){super(e,t,r),this.fr=s}getT4(){return this.fr}}var a={};t(a,"HybridRepository",(()=>o));class o{constructor(...e){this.repos=e}find(e,t){for(let r of this.repos){let s=r.find(e,t);if(s)return s}}}var h={};t(h,"Schema",(()=>S));var u={};t(u,"Namespaces",(()=>l));class l{static SYSTEM="System";static SYSTEM_CTX="System.Context";static SYSTEM_LOOP="System.Loop";static SYSTEM_ARRAY="System.Array";static MATH="System.Math";static STRING="System.String";constructor(){}}function p(e){return null==e}class c{setSingleSchema(e){return this.singleSchema=e,this}setTupleSchema(e){return this.tupleSchema=e,this}getSingleSchema(){return this.singleSchema}getTupleSchema(){return this.tupleSchema}isSingleType(){return!p(this.singleSchema)}static of(...e){return 1==e.length?(new c).setSingleSchema(e[0]):(new c).setTupleSchema(e)}static from(e){if(!e)return;Array.isArray(e)&&c.of(...S.fromListOfSchemas(e));let t=S.from(e);return t?c.of(t):void 0}}class m{getBooleanValue(){return this.booleanValue}getSchemaValue(){return this.schemaValue}setBooleanValue(e){return this.booleanValue=e,this}setSchemaValue(e){return this.schemaValue=e,this}static from(e){if(!e)return;const t=new m;return t.booleanValue=e.booleanValue,t.schemaValue=e.schemaValue,t}}var g={};let f;var E;t(g,"SchemaType",(()=>f)),(E=f||(f={})).INTEGER="Integer",E.LONG="Long",E.FLOAT="Float",E.DOUBLE="Double",E.STRING="String",E.OBJECT="Object",E.ARRAY="Array",E.BOOLEAN="Boolean",E.NULL="Null";class T{}class A extends T{constructor(e){super(),this.type=e}getType(){return this.type}setType(e){return this.type=e,this}getAllowedSchemaTypes(){return this.type}contains(e){return this.type?.has(e)}}class d extends T{constructor(e){super(),this.type=e}getType(){return this.type}getAllowedSchemaTypes(){return new Set([this.type])}contains(e){return this.type==e}}class O{static of(...e){return 1==e.length?new d(e[0]):new A(new Set(e))}static from(e){return"string"==typeof e?O.of(e):Array.isArray(e)?O.of(...Array.of(e).map((e=>e)).map((e=>e))):void 0}}class S{static NULL=(new S).setNamespace(l.SYSTEM).setName("Null").setType(O.of(f.NULL)).setConstant(void 0);static TYPE_SCHEMA=(new S).setType(O.of(f.STRING)).setEnums(["INTEGER","LONG","FLOAT","DOUBLE","STRING","OBJECT","ARRAY","BOOLEAN","NULL"]);static SCHEMA=(new S).setNamespace(l.SYSTEM).setName("Schema").setType(O.of(f.OBJECT)).setProperties(new Map([["namespace",S.of("namespace",f.STRING).setDefaultValue("_")],["name",S.ofString("name")],["version",S.of("version",f.INTEGER).setDefaultValue(1)],["ref",S.ofString("ref")],["type",(new S).setAnyOf([S.TYPE_SCHEMA,S.ofArray("type",S.TYPE_SCHEMA)])],["anyOf",S.ofArray("anyOf",S.ofRef("#/"))],["allOf",S.ofArray("allOf",S.ofRef("#/"))],["oneOf",S.ofArray("oneOf",S.ofRef("#/"))],["not",S.ofRef("#/")],["title",S.ofString("title")],["description",S.ofString("description")],["id",S.ofString("id")],["examples",S.ofAny("examples")],["defaultValue",S.ofAny("defaultValue")],["comment",S.ofString("comment")],["enums",S.ofArray("enums",S.ofString("enums"))],["constant",S.ofAny("constant")],["pattern",S.ofString("pattern")],["format",S.of("format",f.STRING).setEnums(["DATETIME","TIME","DATE","EMAIL","REGEX"])],["minLength",S.ofInteger("minLength")],["maxLength",S.ofInteger("maxLength")],["multipleOf",S.ofLong("multipleOf")],["minimum",S.ofNumber("minimum")],["maximum",S.ofNumber("maximum")],["exclusiveMinimum",S.ofNumber("exclusiveMinimum")],["exclusiveMaximum",S.ofNumber("exclusiveMaximum")],["properties",S.of("properties",f.OBJECT).setAdditionalProperties((new m).setSchemaValue(S.ofRef("#/")))],["additionalProperties",(new S).setName("additionalProperty").setNamespace(l.SYSTEM).setAnyOf([S.ofBoolean("additionalProperty"),S.ofObject("additionalProperty").setRef("#/")]).setDefaultValue(!0)],["required",S.ofArray("required",S.ofString("required")).setDefaultValue([])],["propertyNames",S.ofRef("#/")],["minProperties",S.ofInteger("minProperties")],["maxProperties",S.ofInteger("maxProperties")],["patternProperties",S.of("patternProperties",f.OBJECT).setAdditionalProperties((new m).setSchemaValue(S.ofRef("#/")))],["items",(new S).setName("items").setAnyOf([S.ofRef("#/").setName("item"),S.ofArray("tuple",S.ofRef("#/"))])],["contains",S.ofRef("#/")],["minItems",S.ofInteger("minItems")],["maxItems",S.ofInteger("maxItems")],["uniqueItems",S.ofBoolean("uniqueItems")],["$defs",S.of("$defs",f.OBJECT).setAdditionalProperties((new m).setSchemaValue(S.ofRef("#/")))],["permission",S.ofString("permission")]])).setRequired([]);static ofString(e){return(new S).setType(O.of(f.STRING)).setName(e)}static ofInteger(e){return(new S).setType(O.of(f.INTEGER)).setName(e)}static ofFloat(e){return(new S).setType(O.of(f.FLOAT)).setName(e)}static ofLong(e){return(new S).setType(O.of(f.LONG)).setName(e)}static ofDouble(e){return(new S).setType(O.of(f.DOUBLE)).setName(e)}static ofAny(e){return(new S).setType(O.of(f.INTEGER,f.LONG,f.FLOAT,f.DOUBLE,f.STRING,f.BOOLEAN,f.ARRAY,f.NULL,f.OBJECT)).setName(e)}static ofAnyNotNull(e){return(new S).setType(O.of(f.INTEGER,f.LONG,f.FLOAT,f.DOUBLE,f.STRING,f.BOOLEAN,f.ARRAY,f.OBJECT)).setName(e)}static ofNumber(e){return(new S).setType(O.of(f.INTEGER,f.LONG,f.FLOAT,f.DOUBLE)).setName(e)}static ofBoolean(e){return(new S).setType(O.of(f.BOOLEAN)).setName(e)}static of(e,...t){return(new S).setType(O.of(...t)).setName(e)}static ofObject(e){return(new S).setType(O.of(f.OBJECT)).setName(e)}static ofRef(e){return(new S).setRef(e)}static ofArray(e,...t){return(new S).setType(O.of(f.ARRAY)).setName(e).setItems(c.of(...t))}static fromListOfSchemas(e){if(p(e)&&!Array.isArray(e))return[];let t=[];for(let r of Array.from(e)){let e=S.from(r);e&&t.push(e)}return t}static fromMapOfSchemas(e){if(p(e))return;const t=new Map;return Object.entries(e).forEach((([e,r])=>{let s=S.from(r);s&&t.set(e,s)})),t}static from(e,t=!1){if(p(e))return;let r=new S;return r.namespace=e.namespace,r.name=e.name,r.version=e.version,r.ref=e.ref,r.type=t?new d(f.STRING):O.from(r.type),r.anyOf=S.fromListOfSchemas(e.anyOf),r.allOf=S.fromListOfSchemas(e.allOf),r.oneOf=S.fromListOfSchemas(e.oneOf),r.not=S.from(e.not),r.description=e.description,r.examples=e.examples?[...e.examples]:void 0,r.defaultValue=e.defaultValue,r.comment=e.comment,r.enums=e.enums?[...e.enums]:void 0,r.constant=e.constant,r.pattern=e.pattern,r.format=e.format,r.minLength=e.minLength,r.maxLength=e.maxLength,r.multipleOf=e.multipleOf,r.minimum=e.minimum,r.maximum=e.maximum,r.exclusiveMinimum=e.exclusiveMinimum,r.exclusiveMaximum=e.exclusiveMaximum,r.properties=S.fromMapOfSchemas(e.properties),r.additionalProperties=m.from(e.additionalProperties),r.required=e.required,r.propertyNames=S.from(e.propertyNames,!0),r.minProperties=e.minProperties,r.maxProperties=e.maxProperties,r.patternProperties=S.fromMapOfSchemas(e.patternProperties),r.items=c.from(e.items),r.contains=S.from(e.contains),r.minItems=e.minItems,r.maxItems=e.maxItems,r.uniqueItems=e.uniqueItems,r.$defs=S.fromMapOfSchemas(e.$defs),r.permission=e.permission,r}namespace="_";version=1;getTitle(){return this.getFullName()}getFullName(){return this.namespace&&"_"!=this.namespace?this.namespace+"."+this.name:this.name}get$defs(){return this.$defs}set$defs(e){return this.$defs=e,this}getNamespace(){return this.namespace}setNamespace(e){return this.namespace=e,this}getName(){return this.name}setName(e){return this.name=e,this}getVersion(){return this.version}setVersion(e){return this.version=e,this}getRef(){return this.ref}setRef(e){return this.ref=e,this}getType(){return this.type}setType(e){return this.type=e,this}getAnyOf(){return this.anyOf}setAnyOf(e){return this.anyOf=e,this}getAllOf(){return this.allOf}setAllOf(e){return this.allOf=e,this}getOneOf(){return this.oneOf}setOneOf(e){return this.oneOf=e,this}getNot(){return this.not}setNot(e){return this.not=e,this}getDescription(){return this.description}setDescription(e){return this.description=e,this}getExamples(){return this.examples}setExamples(e){return this.examples=e,this}getDefaultValue(){return this.defaultValue}setDefaultValue(e){return this.defaultValue=e,this}getComment(){return this.comment}setComment(e){return this.comment=e,this}getEnums(){return this.enums}setEnums(e){return this.enums=e,this}getConstant(){return this.constant}setConstant(e){return this.constant=e,this}getPattern(){return this.pattern}setPattern(e){return this.pattern=e,this}getFormat(){return this.format}setFormat(e){return this.format=e,this}getMinLength(){return this.minLength}setMinLength(e){return this.minLength=e,this}getMaxLength(){return this.maxLength}setMaxLength(e){return this.maxLength=e,this}getMultipleOf(){return this.multipleOf}setMultipleOf(e){return this.multipleOf=e,this}getMinimum(){return this.minimum}setMinimum(e){return this.minimum=e,this}getMaximum(){return this.maximum}setMaximum(e){return this.maximum=e,this}getExclusiveMinimum(){return this.exclusiveMinimum}setExclusiveMinimum(e){return this.exclusiveMinimum=e,this}getExclusiveMaximum(){return this.exclusiveMaximum}setExclusiveMaximum(e){return this.exclusiveMaximum=e,this}getProperties(){return this.properties}setProperties(e){return this.properties=e,this}getAdditionalProperties(){return this.additionalProperties}setAdditionalProperties(e){return this.additionalProperties=e,this}getRequired(){return this.required}setRequired(e){return this.required=e,this}getPropertyNames(){return this.propertyNames}setPropertyNames(e){return this.propertyNames=e,this.propertyNames.type=new d(f.STRING),this}getMinProperties(){return this.minProperties}setMinProperties(e){return this.minProperties=e,this}getMaxProperties(){return this.maxProperties}setMaxProperties(e){return this.maxProperties=e,this}getPatternProperties(){return this.patternProperties}setPatternProperties(e){return this.patternProperties=e,this}getItems(){return this.items}setItems(e){return this.items=e,this}getContains(){return this.contains}setContains(e){return this.contains=e,this}getMinItems(){return this.minItems}setMinItems(e){return this.minItems=e,this}getMaxItems(){return this.maxItems}setMaxItems(e){return this.maxItems=e,this}getUniqueItems(){return this.uniqueItems}setUniqueItems(e){return this.uniqueItems=e,this}getPermission(){return this.permission}setPermission(e){return this.permission=e,this}}var N={};t(N,"SchemaValidator",(()=>D));var I={};t(I,"KIRuntimeException",(()=>R));class R extends Error{constructor(e,t){super(e),this.cause=t}getCause(){return this.cause}}class w{static format(e,...t){if(!t||0==t.length)return e;let r="",s=0,n="",i=n,a=e.length;for(let o=0;o<a;o++)n=e.charAt(o),"$"==n&&"\\"==i?r=r.substring(0,o-1)+n:"$"==n&&s<t.length?r+=t[s++]:r+=n,i=n;return r.toString()}constructor(){}}class y{constructor(){}static nthIndex(e,t,r=0,s){if(!e)throw new R("String cannot be null");if(r<0||r>=e.length)throw new R(w.format("Cannot search from index : $",r));if(s<=0||s>e.length)throw new R(w.format("Cannot search for occurance : $",s));for(;r<e.length;){if(e.charAt(r)==t&&0==--s)return r;++r}return-1}static splitAtFirstOccurance(e,t){if(!e)return[void 0,void 0];let r=e.indexOf(t);return-1==r?[e,void 0]:[e.substring(0,r),e.substring(r+1)]}static isNullOrBlank(e){return!e||""==e.trim()}}class x extends Error{constructor(e,t,r){super(e.trim()?e+"-"+t:t),this.schemaPath=e,this.cause=r}getSchemaPath(){return this.schemaPath}getCause(){return this.cause}}class _ extends Error{constructor(e,t,r=[],s){super(t+(r?r.map((e=>e.message)).reduce(((e,t)=>e+"\n"+t),""):"")),this.schemaPath=e,this.cause=s}getSchemaPath(){return this.schemaPath}getCause(){return this.cause}}class v{static UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH="Unable to retrive schema from referenced path";static CYCLIC_REFERENCE_LIMIT_COUNTER=20;static getDefaultValue(e,t){if(e)return e.getConstant()?e.getConstant():e.getDefaultValue()?e.getDefaultValue():v.getDefaultValue(v.getSchemaFromRef(e,t,e.getRef()),t)}static getSchemaFromRef(e,t,r,s=0){if(++s==v.CYCLIC_REFERENCE_LIMIT_COUNTER)throw new _(r??"","Schema has a cyclic reference");if(!e||!r||y.isNullOrBlank(r))return;if(!r.startsWith("#")){var n=v.resolveExternalSchema(e,t,r);n&&(e=n.getT1(),r=n.getT2())}let i=r.split("/");return e=v.resolveInternalSchema(e,t,r,s,i,1)}static resolveInternalSchema(e,t,r,s,n,i){let a=e;for(;i<n.length;){if("$defs"===n[i]){if(++i>=n.length||!a.get$defs())throw new x(r,v.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH);a=a.get$defs()?.get(n[i])}else{if(a&&(!a.getType()?.contains(f.OBJECT)||!a.getProperties()))throw new x(r,"Cannot retrievie schema from non Object type schemas");a=a.getProperties()?.get(n[i])}if(i++,!a)throw new x(r,v.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH);if(!y.isNullOrBlank(a.getRef())&&(a=v.getSchemaFromRef(a,t,a.getRef(),s),!a))throw new x(r,v.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH)}return a}static resolveExternalSchema(e,t,r){if(!t)return;let n=y.splitAtFirstOccurance(e?.getRef()??"","/");if(!n[0])return;let i=y.splitAtFirstOccurance(n[0],".");if(!i[0]||!i[1])return;let a=t.find(i[0],i[1]);if(a){if(!n[1]||""===n[1])return new s(a,r);if(r="#/"+n[1],!a)throw new x(r,v.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH);return new s(a,r)}}constructor(){}}class P{static validate(e,t,r,s){let n=[];return t.getOneOf()&&!t.getOneOf()?P.oneOf(e,t,r,s,n):t.getAllOf()&&!t.getAllOf()?P.allOf(e,t,r,s,n):t.getAnyOf()&&!t.getAnyOf()&&P.anyOf(e,t,r,s,n),s}static anyOf(e,t,r,s,n){let i=!1;for(let a of t.getAnyOf()??[])try{P.validate(e,a,r,s),i=!0;break}catch(e){i=!1,n.push(e)}if(!i)throw new _(D.path(e),"The value don't satisfy any of the schemas.",n)}static allOf(e,t,r,s,n){let i=0;for(let a of t.getAllOf()??[])try{P.validate(e,a,r,s),i++}catch(e){n.push(e)}if(i!==t.getAllOf()?.length)throw new _(D.path(e),"The value doesn't satisfy some of the schemas.",n)}static oneOf(e,t,r,s,n){let i=0;for(let a of t.getOneOf()??[])try{P.validate(e,a,r,s),i++}catch(e){n.push(e)}if(1!=i)throw new _(D.path(e),0==i?"The value does not satisfy any schema":"The value satisfy more than one schema",n)}constructor(){}}class M{static validate(e,t,r,s){if(p(s))throw new _(D.path(e),"Expected an array but found null");if(!Array.isArray(s))throw new _(D.path(e),s.toString()+" is not an Array");let n=s;return M.checkMinMaxItems(e,t,n),M.checkItems(e,t,r,n),M.checkUniqueItems(e,t,n),M.checkContains(e,t,r,n),s}static checkContains(e,t,r,s){if(!t.getContains())return;let n=!1;for(let i=0;i<s.length;i++){let a=e?[...e]:[];try{D.validate(a,t.getContains(),r,s[i]),n=!0;break}catch(e){n=!1}}if(!n)throw new _(D.path(e),"None of the items are of type contains schema")}static checkUniqueItems(e,t,r){if(t.getUniqueItems()&&t.getUniqueItems()){if(new Set(r).size!==r.length)throw new _(D.path(e),"Items on the array are not unique")}}static checkMinMaxItems(e,t,r){if(t.getMinItems()&&t.getMinItems()>r.length)throw new _(D.path(e),"Array should have minimum of "+t.getMinItems()+" elements");if(t.getMaxItems()&&t.getMaxItems()<r.length)throw new _(D.path(e),"Array can have maximum of "+t.getMaxItems()+" elements")}static checkItems(e,t,r,s){if(!t.getItems())return;let n=t.getItems();if(n.getSingleSchema())for(let t=0;t<s.length;t++){let i=e?[...e]:[],a=D.validate(i,n.getSingleSchema(),r,s[t]);s[t]=a}if(n.getTupleSchema()){if(n.getTupleSchema().length!==s.length)throw new _(D.path(e),"Expected an array with only "+n.getTupleSchema().length+" but found "+s.length);for(let t=0;t<s.length;t++){let i=e?[...e]:[],a=D.validate(i,n.getTupleSchema()[t],r,s[t]);s[t]=a}}}constructor(){}}class L{static validate(e,t,r,s){if(p(s))throw new _(D.path(t),"Expected a number but found null");if("number"!=typeof s)throw new _(D.path(t),s.toString()+" is not a "+e);let n=L.extractNumber(e,t,r,s);return L.checkRange(t,r,s,n),L.checkMultipleOf(t,r,s,n),s}static extractNumber(e,t,r,s){let n=s;try{e!=f.LONG&&e!=f.INTEGER||(n=Math.round(n))}catch(r){throw new _(D.path(t),s+" is not a number of type "+e,r)}if(p(n)||(e==f.LONG||e==f.INTEGER)&&n!=s)throw new _(D.path(t),s.toString()+" is not a number of type "+e);return n}static checkMultipleOf(e,t,r,s){if(t.getMultipleOf()){if(s%t.getMultipleOf()!=0)throw new _(D.path(e),r.toString()+" is not multiple of "+t.getMultipleOf())}}static checkRange(e,t,r,s){if(t.getMinimum()&&L.numberCompare(s,t.getMinimum())<0)throw new _(D.path(e),r.toString()+" should be greater than or equal to "+t.getMinimum());if(t.getMaximum()&&L.numberCompare(s,t.getMaximum())>0)throw new _(D.path(e),r.toString()+" should be less than or equal to "+t.getMaximum());if(t.getExclusiveMinimum()&&L.numberCompare(s,t.getExclusiveMinimum())<=0)throw new _(D.path(e),r.toString()+" should be greater than "+t.getExclusiveMinimum());if(t.getExclusiveMaximum()&&L.numberCompare(s,t.getExclusiveMaximum())>0)throw new _(D.path(e),r.toString()+" should be less than "+t.getExclusiveMaximum())}static numberCompare(e,t){return e-t}constructor(){}}class U{static validate(e,t,r,s){if(p(s))throw new _(D.path(e),"Expected an object but found null");if("object"!=typeof s||Array.isArray(s))throw new _(D.path(e),s.toString()+" is not an Object");let n=s,i=new Set(Object.keys(n));U.checkMinMaxProperties(e,t,i),t.getPropertyNames()&&U.checkPropertyNameSchema(e,t,r,i),t.getRequired()&&U.checkRequired(e,t,n),t.getProperties()&&U.checkProperties(e,t,r,n,i),t.getPatternProperties()&&U.checkPatternProperties(e,t,r,n,i),t.getAdditionalProperties()&&U.checkAddtionalProperties(e,t,r,n,i)}static checkPropertyNameSchema(e,t,r,s){for(let n of Array.from(s.values()))try{D.validate(e,t.getPropertyNames(),r,n)}catch(t){throw new _(D.path(e),"Property name '"+n+"' does not fit the property schema")}}static checkRequired(e,t,r){for(const s of t.getRequired()??[])if(p(r[s]))throw new _(D.path(e),s+" is mandatory")}static checkAddtionalProperties(e,t,r,s,n){let i=t.getAdditionalProperties();if(i.getSchemaValue())for(let t of Array.from(n.values())){let n=e?[...e]:[],a=D.validate(n,i.getSchemaValue(),r,s.get(t));s[t]=a}else if(!1===i.getBooleanValue()&&n.size)throw new _(D.path(e),n.toString()+" are additional properties which are not allowed.")}static checkPatternProperties(e,t,r,s,n){const i=new Map;for(const e of Array.from(t.getPatternProperties().keys()))i.set(e,new RegExp(e));for(const a of Array.from(n.values())){const o=e?[...e]:[];for(const e of Array.from(i.entries()))if(e[1].test(a)){const i=D.validate(o,t.getPatternProperties().get(e[0]),r,s[a]);s[a]=i,n.delete(a);break}}}static checkProperties(e,t,r,s,n){for(const i of Array.from(t.getProperties())){let t=s[i[0]];if(p(t))continue;let a=e?[...e]:[],o=D.validate(a,i[1],r,t);s[i[0]]=o,n.delete(i[0])}}static checkMinMaxProperties(e,t,r){if(t.getMinProperties()&&r.size<t.getMinProperties())throw new _(D.path(e),"Object should have minimum of "+t.getMinProperties()+" properties");if(t.getMaxProperties()&&r.size>t.getMaxProperties())throw new _(D.path(e),"Object can have maximum of "+t.getMaxProperties()+" properties")}constructor(){}}let C;var B;(B=C||(C={})).DATETIME="DATETIME",B.TIME="TIME",B.DATE="DATE",B.EMAIL="EMAIL",B.REGEX="REGEX";class b{static TIME=/^([01]?[0-9]|2[0-3]):[0-5][0-9](:[0-5][0-9])?([+-][01][0-9]:[0-5][0-9])?$/;static DATE=/^[0-9]{4,4}-([0][0-9]|[1][0-2])-(0[1-9]|[1-2][1-9]|3[01])$/;static DATETIME=/^[0-9]{4,4}-([0][0-9]|[1][0-2])-(0[1-9]|[1-2][1-9]|3[01])T([01]?[0-9]|2[0-3]):[0-5][0-9](:[0-5][0-9])?([+-][01][0-9]:[0-5][0-9])?$/;static validate(e,t,r){if(p(r))throw new _(D.path(e),"Expected a string but found null");if("string"!=typeof r)throw new _(D.path(e),r.toString()+" is not String");t.getFormat()==C.TIME?b.patternMatcher(e,t,r,b.TIME,"time pattern"):t.getFormat()==C.DATE?b.patternMatcher(e,t,r,b.DATE,"date pattern"):t.getFormat()==C.DATETIME?b.patternMatcher(e,t,r,b.DATETIME,"date time pattern"):t.getPattern()&&b.patternMatcher(e,t,r,new RegExp(t.getPattern()),"pattern "+t.getPattern());let s=r.length;if(t.getMinLength()&&s<t.getMinLength())throw new _(D.path(e),"Expected a minimum of "+t.getMinLength()+" characters");if(t.getMaxLength()&&s>t.getMinLength())throw new _(D.path(e),"Expected a maximum of "+t.getMaxLength()+" characters");return r}static patternMatcher(e,t,r,s,n){if(!s.test(r))throw new _(D.path(e),r.toString()+" is not matched with the "+n)}constructor(){}}class V{static validate(e,t,r,s,n){if(t==f.STRING)b.validate(e,r,n);else if(t==f.LONG||t==f.INTEGER||t==f.DOUBLE||t==f.FLOAT)L.validate(t,e,r,n);else if(t==f.BOOLEAN)(class{static validate(e,t,r){if(p(r))throw new _(D.path(e),"Expected a boolean but found null");if("boolean"!=typeof r)throw new _(D.path(e),r.toString()+" is not a boolean");return r}constructor(){}}).validate(e,r,n);else if(t==f.OBJECT)U.validate(e,r,s,n);else if(t==f.ARRAY)M.validate(e,r,s,n);else{if(t!=f.NULL)throw new _(D.path(e),t+" is not a valid type.");(class{static validate(e,t,r){if(r)throw new _(D.path(e),"Expected a null but found "+r);return r}constructor(){}}).validate(e,r,n)}return n}constructor(){}}class D{static path(e){return e?e.map((e=>e.getTitle()??"")).filter((e=>!!e)).reduce(((e,t,r)=>e+(0===r?"":".")+t),""):""}static validate(e,t,r,s){if(!t)return s;if(e||(e=new Array),e.push(t),p(s)&&!p(t.getDefaultValue()))return JSON.parse(JSON.stringify(t.getDefaultValue()));if(t.getConstant())return D.constantValidation(e,t,s);if(t.getEnums()&&!t.getEnums()?.length)return D.enumCheck(e,t,s);if(t.getType()&&D.typeValidation(e,t,r,s),!y.isNullOrBlank(t.getRef()))return D.validate(e,v.getSchemaFromRef(e[0],r,t.getRef()),r,s);if((t.getOneOf()||t.getAllOf()||t.getAnyOf())&&P.validate(e,t,r,s),t.getNot()){let n=!1;try{D.validate(e,t.getNot(),r,s),n=!0}catch(e){n=!1}if(n)throw new _(D.path(e),"Schema validated value in not condition.")}return s}static constantValidation(e,t,r){if(!t.getConstant().equals(r))throw new _(D.path(e),"Expecting a constant value : "+r);return r}static enumCheck(e,t,r){let s=!1;for(let e of t.getEnums()??[])if(e===r){s=!0;break}if(s)return r;throw new _(D.path(e),"Value is not one of "+t.getEnums())}static typeValidation(e,t,r,s){let n=!1,i=[];for(const a of Array.from(t.getType()?.getAllowedSchemaTypes()?.values()??[]))try{V.validate(e,a,t,r,s),n=!0;break}catch(e){n=!1,i.push(e)}if(!n)throw new _(D.path(e),"Value "+JSON.stringify(s)+" is not of valid type(s)",i)}constructor(){}}var k={};t(k,"KIRunConstants",(()=>G));class G{static NAMESPACE="namespace";static NAME="name";static ID="id";constructor(){}}var F={};t(F,"ExecutionException",(()=>$));class $ extends Error{constructor(e,t){super(e),this.cause=t}getCause(){return this.cause}}var Y={};t(Y,"AbstractFunction",(()=>H));class H{validateArguments(e){return Array.from(this.getSignature().getParameters().entries()).map((t=>{let r,n=t[0],i=t[1],a=e.get(t[0]);if(p(a))return new s(n,D.validate(void 0,i.getSchema(),void 0,void 0));if(!i?.isVariableArgument())return new s(n,D.validate(void 0,i.getSchema(),void 0,a));Array.isArray(a)?r=a:(r=[],r.push(a));for(const e of r)D.validate(void 0,i.getSchema(),void 0,e);return new s(n,a)})).reduce(((e,t)=>(e.set(t.getT1(),t.getT2()),e)),new Map)}execute(e){return e.setArguments(this.validateArguments(e.getArguments()??new Map)),this.internalExecute(e)}getProbableEventSignature(e){return this.getSignature().getEvents()}}var W={};t(W,"KIRuntime",(()=>ze));class j{constructor(e){this.expression=e}getExpression(){return this.expression}}class q{static OUTPUT="output";static ERROR="error";static ITERATION="iteration";static TRUE="true";static FALSE="false";static SCHEMA_NAME="Event";static SCHEMA=(new S).setNamespace(l.SYSTEM).setName(q.SCHEMA_NAME).setType(O.of(f.OBJECT)).setProperties(new Map([["name",S.ofString("name")],["parameters",S.ofObject("parameter").setAdditionalProperties((new m).setSchemaValue(S.SCHEMA))]]));constructor(e,t){this.name=e,this.parameters=t}getName(){return this.name}setName(e){return this.name=e,this}getParameters(){return this.parameters}setParameters(e){return this.parameters=e,this}static outputEventMapEntry(e){return q.eventMapEntry(q.OUTPUT,e)}static eventMapEntry(e,t){return[e,new q(e,t)]}}class X{constructor(e,t){this.name=e,this.result=t}getName(){return this.name}setName(e){return this.name=e,this}getResult(){return this.result}setResult(e){return this.result=e,this}static outputOf(e){return X.of(q.OUTPUT,e)}static of(e,t){return new X(e,t)}}class Q{index=0;constructor(e){if(p(e))throw new R("Function output is generating null");Array.isArray(e)&&e.length&&e[0]instanceof X?this.fo=e:(this.fo=[],this.generator=e)}next(){if(!this.generator)return this.index<this.fo.length?this.fo[this.index++]:void 0;const e=this.generator.next();return e&&this.fo.push(e),e}allResults(){return this.fo}}let J;var K;(K=J||(J={})).CONSTANT="CONSTANT",K.EXPRESSION="EXPRESSION";class z{static SCHEMA_NAME="Parameter";static SCHEMA=(new S).setNamespace(l.SYSTEM).setName(z.SCHEMA_NAME).setProperties(new Map([["schema",S.SCHEMA],["parameterName",S.ofString("parameterName")],["variableArgument",S.of("variableArgument",f.BOOLEAN).setDefaultValue(!1)]]));static EXPRESSION=(new S).setNamespace(l.SYSTEM).setName("ParameterExpression").setType(O.of(f.OBJECT)).setProperties(new Map([["isExpression",S.ofBoolean("isExpression").setDefaultValue(!0)],["value",S.ofAny("value")]]));variableArgument=!1;type=J.EXPRESSION;constructor(e,t){this.schema=t,this.parameterName=e}getSchema(){return this.schema}setSchema(e){return this.schema=e,this}getParameterName(){return this.parameterName}setParameterName(e){return this.parameterName=e,this}isVariableArgument(){return this.variableArgument}setVariableArgument(e){return this.variableArgument=e,this}getType(){return this.type}setType(e){return this.type=e,this}static ofEntry(e,t,r=!1,s=J.EXPRESSION){return[e,new z(e,t).setType(s).setVariableArgument(r)]}static of(e,t,r=!1,s=J.EXPRESSION){return new z(e,t).setType(s).setVariableArgument(r)}}let Z;var ee;(ee=Z||(Z={})).VALUE="VALUE",ee.EXPRESSION="EXPRESSION";class te{head=void 0;tail=void 0;length=0;constructor(e){if(e?.length){for(const t of e)if(this.head){const e=new re(t,this.tail);this.tail.next=e,this.tail=e}else this.tail=this.head=new re(t);this.length=e.length}}push(e){const t=new re(e,void 0,this.head);this.head?(this.head.previous=t,this.head=t):this.tail=this.head=t,this.length++}pop(){if(!this.head)throw Error("List is empty and cannot pop further.");const e=this.head.value;if(this.length--,this.head==this.tail)return this.head=this.tail=void 0,e;const t=this.head;return this.head=t.next,t.next=void 0,t.previous=void 0,this.head.previous=void 0,e}isEmpty(){return!this.length}size(){return this.length}get(e){if(e<0||e>=this.length)throw new Error(`${e} is out of bounds [0,${this.length}]`);let t=this.head;for(;e>0;)t=this.head.next,--e;return t.value}set(e,t){if(e<0||e>=this.length)throw new R(w.format("Index $ out of bound to set the value in linked list.",e));let r=this.head;for(;e>0;)r=this.head.next,--e;return r.value=t,this}toString(){let e=this.head,t="";for(;e;)t+=e.value,e=e.next,e&&(t+=", ");return`[${t}]`}toArray(){let e=[],t=this.head;for(;t;)e.push(t.value),t=t.next;return e}peek(){if(!this.head)throw new Error("List is empty so cannot peak");return this.head.value}peekLast(){if(!this.tail)throw new Error("List is empty so cannot peak");return this.tail.value}getFirst(){if(!this.head)throw new Error("List is empty so cannot get first");return this.head.value}removeFirst(){return this.pop()}removeLast(){if(!this.tail)throw new Error("List is empty so cannot remove");--this.length;const e=this.tail.value;if(0==this.length)this.head=this.tail=void 0;else{const e=this.tail.previous;e.next=void 0,this.tail.previous=void 0,this.tail=e}return e}addAll(e){return e&&e.length?(e.forEach(this.add.bind(this)),this):this}add(e){return++this.length,this.tail||this.head?this.head===this.tail?(this.tail=new re(e,this.head),this.head.next=this.tail):(this.tail=new re(e,this.tail),this.tail.previous.next=this.tail):this.head=this.tail=new re(e),this}map(e,t){let r=new te,s=this.head,n=0;for(;s;)r.add(e(s.value,n)),s=s.next,++n;return r}forEach(e,t){let r=this.head,s=0;for(;r;)e(r.value,s),r=r.next,++s}}class re{constructor(e,t,r){this.value=e,this.next=r,this.previous=t}toString(){return""+this.value}}class se{constructor(e){this.str=e??""}append(e){return this.str+=e,this}toString(){return""+this.str}trim(){return this.str=this.str.trim(),this}setLength(e){return this.str=this.str.substring(0,e),this}length(){return this.str.length}charAt(e){return this.str.charAt(e)}deleteCharAt(e){return this.checkIndex(e),this.str=this.str.substring(0,e)+this.str.substring(e+1),this}insert(e,t){return this.str=this.str.substring(0,e)+t+this.str.substring(e),this}checkIndex(e){if(e>=this.str.length)throw new R(`Index ${e} is greater than or equal to ${this.str.length}`)}substring(e,t){return this.str.substring(e,t)}}class ne extends Error{constructor(e,t,r){super(w.format("$ : $",e,t)),this.cause=r}getCause(){return this.cause}}class ie{constructor(e){this.expression=e}getExpression(){return this.expression}toString(){return this.expression}}class ae{static MULTIPLICATION=new ae("*");static DIVISION=new ae("/");static INTEGER_DIVISION=new ae("//");static MOD=new ae("%");static ADDITION=new ae("+");static SUBTRACTION=new ae("-");static NOT=new ae("not");static AND=new ae("and");static OR=new ae("or");static LESS_THAN=new ae("<");static LESS_THAN_EQUAL=new ae("<=");static GREATER_THAN=new ae(">");static GREATER_THAN_EQUAL=new ae(">=");static EQUAL=new ae("=");static NOT_EQUAL=new ae("!=");static BITWISE_AND=new ae("&");static BITWISE_OR=new ae("|");static BITWISE_XOR=new ae("^");static BITWISE_COMPLEMENT=new ae("~");static BITWISE_LEFT_SHIFT=new ae("<<");static BITWISE_RIGHT_SHIFT=new ae(">>");static BITWISE_UNSIGNED_RIGHT_SHIFT=new ae(">>>");static UNARY_PLUS=new ae("UN: +","+");static UNARY_MINUS=new ae("UN: -","-");static UNARY_LOGICAL_NOT=new ae("UN: not","not");static UNARY_BITWISE_COMPLEMENT=new ae("UN: ~","~");static ARRAY_OPERATOR=new ae("[");static OBJECT_OPERATOR=new ae(".");static VALUE_OF=new Map([["MULTIPLICATION",ae.MULTIPLICATION],["DIVISION",ae.DIVISION],["INTEGER_DIVISON",ae.INTEGER_DIVISION],["MOD",ae.MOD],["ADDITION",ae.ADDITION],["SUBTRACTION",ae.SUBTRACTION],["NOT",ae.NOT],["AND",ae.AND],["OR",ae.OR],["LESS_THAN",ae.LESS_THAN],["LESS_THAN_EQUAL",ae.LESS_THAN_EQUAL],["GREATER_THAN",ae.GREATER_THAN],["GREATER_THAN_EQUAL",ae.GREATER_THAN_EQUAL],["EQUAL",ae.EQUAL],["NOT_EQUAL",ae.NOT_EQUAL],["BITWISE_AND",ae.BITWISE_AND],["BITWISE_OR",ae.BITWISE_OR],["BITWISE_XOR",ae.BITWISE_XOR],["BITWISE_COMPLEMENT",ae.BITWISE_COMPLEMENT],["BITWISE_LEFT_SHIFT",ae.BITWISE_LEFT_SHIFT],["BITWISE_RIGHT_SHIFT",ae.BITWISE_RIGHT_SHIFT],["BITWISE_UNSIGNED_RIGHT_SHIFT",ae.BITWISE_UNSIGNED_RIGHT_SHIFT],["UNARY_PLUS",ae.UNARY_PLUS],["UNARY_MINUS",ae.UNARY_MINUS],["UNARY_LOGICAL_NOT",ae.UNARY_LOGICAL_NOT],["UNARY_BITWISE_COMPLEMENT",ae.UNARY_BITWISE_COMPLEMENT],["ARRAY_OPERATOR",ae.ARRAY_OPERATOR],["OBJECT_OPERATOR",ae.OBJECT_OPERATOR]]);static UNARY_OPERATORS=new Set([ae.ADDITION,ae.SUBTRACTION,ae.NOT,ae.BITWISE_COMPLEMENT,ae.UNARY_PLUS,ae.UNARY_MINUS,ae.UNARY_LOGICAL_NOT,ae.UNARY_BITWISE_COMPLEMENT]);static ARITHMETIC_OPERATORS=new Set([ae.MULTIPLICATION,ae.DIVISION,ae.INTEGER_DIVISION,ae.MOD,ae.ADDITION,ae.SUBTRACTION]);static LOGICAL_OPERATORS=new Set([ae.NOT,ae.AND,ae.OR,ae.LESS_THAN,ae.LESS_THAN_EQUAL,ae.GREATER_THAN,ae.GREATER_THAN_EQUAL,ae.EQUAL,ae.NOT_EQUAL]);static BITWISE_OPERATORS=new Set([ae.BITWISE_AND,ae.BITWISE_COMPLEMENT,ae.BITWISE_LEFT_SHIFT,ae.BITWISE_OR,ae.BITWISE_RIGHT_SHIFT,ae.BITWISE_UNSIGNED_RIGHT_SHIFT,ae.BITWISE_XOR]);static OPERATOR_PRIORITY=new Map([[ae.UNARY_PLUS,1],[ae.UNARY_MINUS,1],[ae.UNARY_LOGICAL_NOT,1],[ae.UNARY_BITWISE_COMPLEMENT,1],[ae.ARRAY_OPERATOR,1],[ae.OBJECT_OPERATOR,1],[ae.MULTIPLICATION,2],[ae.DIVISION,2],[ae.INTEGER_DIVISION,2],[ae.MOD,2],[ae.ADDITION,3],[ae.SUBTRACTION,3],[ae.BITWISE_LEFT_SHIFT,4],[ae.BITWISE_RIGHT_SHIFT,4],[ae.BITWISE_UNSIGNED_RIGHT_SHIFT,4],[ae.LESS_THAN,5],[ae.LESS_THAN_EQUAL,5],[ae.GREATER_THAN,5],[ae.GREATER_THAN_EQUAL,5],[ae.EQUAL,6],[ae.NOT_EQUAL,6],[ae.BITWISE_AND,7],[ae.BITWISE_XOR,8],[ae.BITWISE_OR,9],[ae.AND,10],[ae.OR,11]]);static OPERATORS=new Set([...Array.from(ae.ARITHMETIC_OPERATORS),...Array.from(ae.LOGICAL_OPERATORS),...Array.from(ae.BITWISE_OPERATORS),ae.ARRAY_OPERATOR,ae.OBJECT_OPERATOR].map((e=>e.getOperator())));static OPERATION_VALUE_OF=new Map(Array.from(ae.VALUE_OF.entries()).map((([e,t])=>[t.getOperator(),t])));static UNARY_MAP=new Map([[ae.ADDITION,ae.UNARY_PLUS],[ae.SUBTRACTION,ae.UNARY_MINUS],[ae.NOT,ae.UNARY_LOGICAL_NOT],[ae.BITWISE_COMPLEMENT,ae.UNARY_BITWISE_COMPLEMENT],[ae.UNARY_PLUS,ae.UNARY_PLUS],[ae.UNARY_MINUS,ae.UNARY_MINUS],[ae.UNARY_LOGICAL_NOT,ae.UNARY_LOGICAL_NOT],[ae.UNARY_BITWISE_COMPLEMENT,ae.UNARY_BITWISE_COMPLEMENT]]);static BIGGEST_OPERATOR_SIZE=Array.from(ae.VALUE_OF.values()).map((e=>e.getOperator())).filter((e=>!e.startsWith("UN: "))).map((e=>e.length)).reduce(((e,t)=>e>t?e:t),0);constructor(e,t){this.operator=e,this.operatorName=t??e}getOperator(){return this.operator}getOperatorName(){return this.operatorName}valueOf(e){return ae.VALUE_OF.get(e)}toString(){return this.operator}}class oe extends ie{tokens=new te;ops=new te;constructor(e,t,r,s){super(e||""),t&&this.tokens.push(t),r&&this.tokens.push(r),s&&this.ops.push(s),this.evaluate()}getTokens(){return this.tokens}getOperations(){return this.ops}evaluate(){const e=this.expression.length;let t,r="",s=new se(""),n=0,i=!1;for(;n<e;){switch(r=this.expression[n],t=s.toString(),r){case" ":i=this.processTokenSepearator(s,t,i);break;case"(":n=this.processSubExpression(e,s,t,n,i),i=!1;break;case")":throw new ne(this.expression,"Extra closing parenthesis found");case"]":throw new ne(this.expression,"Extra closing square bracket found");default:let a=this.processOthers(r,e,s,t,n,i);n=a.getT1(),i=a.getT2(),i&&this.ops.peek()==ae.ARRAY_OPERATOR&&(a=this.process(e,s,n),n=a.getT1(),i=a.getT2())}++n}if(t=s.toString(),!y.isNullOrBlank(t)){if(ae.OPERATORS.has(t))throw new ne(this.expression,"Expression is ending with an operator");this.tokens.push(new ie(t))}}process(e,t,r){let n=1;for(++r;r<e&&0!=n;){let e=this.expression.charAt(r);"]"==e?--n:"["==e&&++n,0!=n&&(t.append(e),r++)}return this.tokens.push(new oe(t.toString())),t.setLength(0),new s(r,!1)}processOthers(e,t,r,n,i,a){let o=t-i;o=o<ae.BIGGEST_OPERATOR_SIZE?o:ae.BIGGEST_OPERATOR_SIZE;for(let e=o;e>0;e--){let t=this.expression.substring(i,i+e);if(ae.OPERATORS.has(t))return y.isNullOrBlank(n)||(this.tokens.push(new ie(n)),a=!1),this.checkUnaryOperator(this.tokens,this.ops,ae.OPERATION_VALUE_OF.get(t),a),a=!0,r.setLength(0),new s(i+e-1,a)}return r.append(e),new s(i,!1)}processSubExpression(e,t,r,s,n){if(ae.OPERATORS.has(r))this.checkUnaryOperator(this.tokens,this.ops,ae.OPERATION_VALUE_OF.get(r),n),t.setLength(0);else if(!y.isNullOrBlank(r))throw new ne(this.expression,w.format("Unkown token : $ found.",r));let i=1;const a=new se;let o=this.expression.charAt(s);for(s++;s<e&&i>0;)o=this.expression.charAt(s),"("==o?i++:")"==o&&i--,0!=i&&(a.append(o),s++);if(")"!=o)throw new ne(this.expression,"Missing a closed parenthesis");for(;a.length()>2&&"("==a.charAt(0)&&")"==a.charAt(a.length()-1);)a.deleteCharAt(0),a.setLength(a.length()-1);return this.tokens.push(new oe(a.toString().trim())),s}processTokenSepearator(e,t,r){return y.isNullOrBlank(t)||(ae.OPERATORS.has(t)?(this.checkUnaryOperator(this.tokens,this.ops,ae.OPERATION_VALUE_OF.get(t),r),r=!0):(this.tokens.push(new ie(t)),r=!1)),e.setLength(0),r}checkUnaryOperator(e,t,r,s){if(r)if(s||e.isEmpty()){if(!ae.UNARY_OPERATORS.has(r))throw new ne(this.expression,w.format("Extra operator $ found.",r));{const e=ae.UNARY_MAP.get(r);e&&t.push(e)}}else{for(;!t.isEmpty()&&this.hasPrecedence(r,t.peek());){let r=t.pop();if(ae.UNARY_OPERATORS.has(r)){let t=e.pop();e.push(new oe("",t,void 0,r))}else{let t=e.pop(),s=e.pop();e.push(new oe("",s,t,r))}}t.push(r)}}hasPrecedence(e,t){let r=ae.OPERATOR_PRIORITY.get(e),s=ae.OPERATOR_PRIORITY.get(t);if(!r||!s)throw new Error("Unknown operators provided");return s<r}toString(){if(this.ops.isEmpty())return 1==this.tokens.size()?this.tokens.get(0).toString():"Error: No tokens";let e=new se,t=0;const r=this.ops.toArray(),s=this.tokens.toArray();for(let n=0;n<r.length;n++)if(r[n].getOperator().startsWith("UN: "))e.append("(").append(r[n].getOperator().substring(4)).append(s[t]instanceof oe?s[t].toString():s[t]).append(")"),t++;else{if(0==t){const r=s[t++];e.insert(0,r.toString())}const i=s[t++];e.insert(0,r[n].getOperator()).insert(0,i.toString()).insert(0,"(").append(")")}return e.toString()}equals(e){return this.expression==e.expression}}class he extends ie{constructor(e,t){super(e),this.element=t}getTokenValue(){return this.element}getElement(){return this.element}toString(){return w.format("$: $",this.expression,this.element)}}class ue{nullCheck(e,t,r){if(p(e)||p(t))throw new $(w.format("$ cannot be applied to a null value",r.getOperatorName()))}}class le extends ue{apply(e,t){return this.nullCheck(e,t,ae.ADDITION),e+t}}class pe extends ue{apply(e,t){return this.nullCheck(e,t,ae.DIVISION),e/t}}class ce extends ue{apply(e,t){return this.nullCheck(e,t,ae.DIVISION),Math.floor(e/t)}}class me extends ue{apply(e,t){return this.nullCheck(e,t,ae.MOD),e%t}}class ge extends ue{apply(e,t){return this.nullCheck(e,t,ae.MULTIPLICATION),e*t}}class fe extends ue{apply(e,t){return this.nullCheck(e,t,ae.SUBTRACTION),e-t}}class Ee extends ue{apply(e,t){if(!e)throw new $("Cannot apply array operator on a null value");if(!t)throw new $("Cannot retrive null index value");if(!Array.isArray(e)&&"string"!=typeof e)throw new $(w.format("Cannot retrieve value from a primitive value $",e));if(t>=e.length)throw new $(w.format("Cannot retrieve index $ from the array of length $",t,e.length));return e[t]}}class Te extends ue{apply(e,t){return this.nullCheck(e,t,ae.BITWISE_AND),e&t}}class Ae extends ue{apply(e,t){return this.nullCheck(e,t,ae.BITWISE_LEFT_SHIFT),e<<t}}class de extends ue{apply(e,t){return this.nullCheck(e,t,ae.BITWISE_OR),e|t}}class Oe extends ue{apply(e,t){return this.nullCheck(e,t,ae.BITWISE_RIGHT_SHIFT),e>>t}}class Se extends ue{apply(e,t){return this.nullCheck(e,t,ae.BITWISE_UNSIGNED_RIGHT_SHIFT),e>>>t}}class Ne extends ue{apply(e,t){return this.nullCheck(e,t,ae.BITWISE_XOR),e^t}}class Ie{static findPrimitiveNullAsBoolean(e){if(!e)return new s(f.BOOLEAN,!1);let t=typeof e;if("object"===t)throw new $(w.format("$ is not a primitive type",e));let r=e;return"boolean"===t?new s(f.BOOLEAN,r):"string"===t?new s(f.STRING,r):Ie.findPrimitiveNumberType(r)}static findPrimitive(e){if(p(e))return new s(f.NULL,void 0);let t=typeof e;if("object"===t)throw new $(w.format("$ is not a primitive type",e));let r=e;return"boolean"===t?new s(f.BOOLEAN,r):"string"===t?new s(f.STRING,r):Ie.findPrimitiveNumberType(r)}static findPrimitiveNumberType(e){if(p(e)||Array.isArray(e)||"object"==typeof e)throw new $(w.format("Unable to convert $ to a number.",e));let t=e;try{let e=t;return Number.isInteger(e)?new s(f.LONG,e):new s(f.DOUBLE,e)}catch(e){throw new $(w.format("Unable to convert $ to a number.",t),e)}}static compare(e,t){if(e==t)return 0;if(p(e)||p(t))return p(e)?-1:1;if(Array.isArray(e)||Array.isArray(t)){if(Array.isArray(e)||Array.isArray(t)){if(e.length!=t.length)return e.length-t.length;for(let r=0;r<e.length;r++){let s=this.compare(e[r],t[r]);if(0!=s)return s}return 0}return Array.isArray(e)?-1:1}const r=typeof e,s=typeof t;return"object"!==r&&"object"!==s||"object"===r&&"object"===s&&Object.keys(e).forEach((r=>{let s=this.compare(e[r],t[r]);if(0!=s)return s})),this.comparePrimitive(e,t)}static comparePrimitive(e,t){return p(e)||p(t)?p(e)&&p(t)?0:p(e)?-1:1:e==t?0:"boolean"==typeof e||"boolean"==typeof t?e?-1:1:"string"==typeof e||"string"==typeof t?e+""<t+""?-1:1:"number"==typeof e||"number"==typeof t?e-t:0}static baseNumberType(e){return Number.isInteger(e)?f.LONG:f.DOUBLE}static toPrimitiveType(e){return e}constructor(){}}class Re extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);if(r.getT1()!=f.BOOLEAN)throw new $(w.format("Boolean value expected but found $",r.getT2()));if(s.getT1()!=f.BOOLEAN)throw new $(w.format("Boolean value expected but found $",s.getT2()));return r.getT2()&&s.getT2()}}class we extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);return r.getT2()==s.getT2()}}class ye extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);if(r.getT1()==f.BOOLEAN||s.getT1()==f.BOOLEAN)throw new $(w.format("Cannot compare >= with the values $ and $",r.getT2(),s.getT2()));return r.getT2()>=s.getT2()}}class xe extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);if(r.getT1()==f.BOOLEAN||s.getT1()==f.BOOLEAN)throw new $(w.format("Cannot compare > with the values $ and $",r.getT2(),s.getT2()));return r.getT2()>s.getT2()}}class _e extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);if(r.getT1()==f.BOOLEAN||s.getT1()==f.BOOLEAN)throw new $(w.format("Cannot compare <= with the values $ and $",r.getT2(),s.getT2()));return r.getT2()<=s.getT2()}}class ve extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);if(r.getT1()==f.BOOLEAN||s.getT1()==f.BOOLEAN)throw new $(w.format("Cannot compare < with the values $ and $",r.getT2(),s.getT2()));return r.getT2()<s.getT2()}}class Pe extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);return r.getT2()!=s.getT2()}}class Me extends ue{apply(e,t){const r=Ie.findPrimitiveNullAsBoolean(e),s=Ie.findPrimitiveNullAsBoolean(t);if(r.getT1()!=f.BOOLEAN)throw new $(w.format("Boolean value expected but found $",r.getT2()));if(s.getT1()!=f.BOOLEAN)throw new $(w.format("Boolean value expected but found $",s.getT2()));return r.getT2()||s.getT2()}}class Le extends ue{apply(e,t){if(!e)throw new $("Cannot apply array operator on a null value");if(!t)throw new $("Cannot retrive null property value");const r=typeof e;if(!Array.isArray(e)&&"string"!=r&&"object"!=r)throw new $(w.format("Cannot retrieve value from a primitive value $",e));return e[t]}}class Ue{nullCheck(e,t){if(p(e))throw new $(w.format("$ cannot be applied to a null value",t.getOperatorName()))}}class Ce extends Ue{apply(e){return this.nullCheck(e,ae.UNARY_MINUS),Ie.findPrimitiveNumberType(e),-e}}class Be extends Ue{apply(e){return this.nullCheck(e,ae.UNARY_PLUS),Ie.findPrimitiveNumberType(e),e}}class be extends Ue{apply(e){this.nullCheck(e,ae.UNARY_BITWISE_COMPLEMENT);let t=Ie.findPrimitiveNumberType(e);if(t.getT1()!=f.INTEGER&&t.getT1()!=f.LONG)throw new $(w.format("Unable to apply bitwise operator on $",e));return~e}}class Ve extends Ue{apply(e){if(this.nullCheck(e,ae.UNARY_LOGICAL_NOT),Ie.findPrimitiveNumberType(e).getT1()!=f.BOOLEAN)throw new $(w.format("Unable to apply bitwise operator on $",e));return!e}}class De{static REGEX_SQUARE_BRACKETS=/[\[\]]/;static REGEX_DOT=/\./;getValue(e){let t=this.getPrefix();if(!e.startsWith(t))throw new R(w.format("Token $ doesn't start with $",e,t));return this.getValueInternal(e)}retrieveElementFrom(e,t,r,s){if(p(s))return;if(t.length==r)return s;let n=t[r].split(De.REGEX_SQUARE_BRACKETS).map((e=>e.trim())).filter((e=>!y.isNullOrBlank(e))).reduce(((s,n,i)=>this.resolveForEachPartOfTokenWithBrackets(e,t,r,n,s,i)),s);return this.retrieveElementFrom(e,t,r+1,n)}resolveForEachPartOfTokenWithBrackets(e,t,r,s,n,i){if(!p(n)){if(0===i){if(Array.isArray(n)){if("length"===s)return n.length;try{let e=parseInt(s);if(isNaN(e))throw new Error(w.format("$ is not a number",e));if(e>=n.length)return;return n[e]}catch(t){throw new ne(e,w.format("$ couldn't be parsed into integer in $",s,e),t)}}return this.checkIfObject(e,t,r,n),n[s]}if(s?.startsWith('"')){if(!s.endsWith('"')||1==s.length||2==s.length)throw new ne(e,w.format("$ is missing a double quote or empty key found",e));return this.checkIfObject(e,t,r,n),n[s.substring(1,s.length-1)]}try{let t=parseInt(s);if(isNaN(t))throw new Error(w.format("$ is not a number",t));if(!Array.isArray(n))throw new ne(e,w.format("Expecting an array with index $ while processing the expression",t,e));if(t>=n.length)return;return n[t]}catch(t){throw new ne(e,w.format("$ couldn't be parsed into integer in $",s,e),t)}}}checkIfObject(e,t,r,s){if("object"!=typeof s||Array.isArray(s))throw new ne(e,w.format("Unable to retrive $ from $ in the path $",t[r],s.toString(),e))}}const ke=new Map([["true",!0],["false",!1],["null",void 0]]);class Ge extends De{static INSTANCE=new Ge;getValueInternal(e){if(!y.isNullOrBlank(e))return e=e.trim(),ke.has(e)?ke.get(e):e.startsWith('"')?this.processString(e):this.processNumbers(e)}processNumbers(e){try{let t;if(t=-1==e.indexOf(".")?parseInt(e):parseFloat(e),isNaN(t))throw new Error("Parse number error");return t}catch(t){throw new ne(e,w.format("Unable to parse the literal or expression $",e),t)}}processString(e){if(!e.endsWith('"'))throw new ne(e,w.format("String literal $ is not closed properly",e));return e.substring(1,e.length-1)}getPrefix(){return""}}class Fe{static UNARY_OPERATORS_MAP=new Map([[ae.UNARY_BITWISE_COMPLEMENT,new be],[ae.UNARY_LOGICAL_NOT,new Ve],[ae.UNARY_MINUS,new Ce],[ae.UNARY_PLUS,new Be]]);static BINARY_OPERATORS_MAP=new Map([[ae.ADDITION,new le],[ae.DIVISION,new pe],[ae.INTEGER_DIVISION,new ce],[ae.MOD,new me],[ae.MULTIPLICATION,new ge],[ae.SUBTRACTION,new fe],[ae.BITWISE_AND,new Te],[ae.BITWISE_LEFT_SHIFT,new Ae],[ae.BITWISE_OR,new de],[ae.BITWISE_RIGHT_SHIFT,new Oe],[ae.BITWISE_UNSIGNED_RIGHT_SHIFT,new Se],[ae.BITWISE_XOR,new Ne],[ae.AND,new Re],[ae.EQUAL,new we],[ae.GREATER_THAN,new xe],[ae.GREATER_THAN_EQUAL,new ye],[ae.LESS_THAN,new ve],[ae.LESS_THAN_EQUAL,new _e],[ae.OR,new Me],[ae.NOT_EQUAL,new Pe],[ae.ARRAY_OPERATOR,new Ee],[ae.OBJECT_OPERATOR,new Le]]);static UNARY_OPERATORS_MAP_KEY_SET=new Set(Fe.UNARY_OPERATORS_MAP.keys());constructor(e){e instanceof oe?(this.exp=e,this.expression=this.exp.getExpression()):this.expression=e}evaluate(e){return this.exp||(this.exp=new oe(this.expression)),this.evaluateExpression(this.exp,e)}getExpression(){return this.exp||(this.exp=new oe(this.expression)),this.exp}getExpressionString(){return this.expression}evaluateExpression(e,t){let r=e.getOperations(),s=e.getTokens();for(;!r.isEmpty();){let e=r.pop(),a=s.pop();if(Fe.UNARY_OPERATORS_MAP_KEY_SET.has(e))s.push(this.applyUnaryOperation(e,this.getValueFromToken(t,a)));else if(e==ae.OBJECT_OPERATOR||e==ae.ARRAY_OPERATOR)this.processObjectOrArrayOperator(t,r,s,e,a);else{const r=s.pop();var n=this.getValueFromToken(t,r),i=this.getValueFromToken(t,a);s.push(this.applyBinaryOperation(e,n,i))}}if(s.isEmpty())throw new $(w.format("Expression : $ evaluated to null",e));if(1!=s.size())throw new $(w.format("Expression : $ evaluated multiple values $",e,s));const a=s.get(0);if(a instanceof he)return a.getElement();if(!(a instanceof oe))return this.getValueFromToken(t,a);throw new $(w.format("Expression : $ evaluated to $",e,s.get(0)))}processObjectOrArrayOperator(e,t,r,s,n){const i=new te,a=new te;if(!s||!n)return;do{a.push(s),n instanceof oe?i.push(new he(n.toString(),this.evaluateExpression(n,e))):n&&i.push(n),n=r.isEmpty()?void 0:r.pop(),s=t.isEmpty()?void 0:t.pop()}while(s==ae.OBJECT_OPERATOR||s==ae.ARRAY_OPERATOR);n&&(n instanceof oe?i.push(new he(n.toString(),this.evaluateExpression(n,e))):i.push(n)),s&&t.push(s);let o=i.pop(),h=new se(o instanceof he?o.getTokenValue():o.toString());for(;!i.isEmpty();)o=i.pop(),s=a.pop(),h.append(s.getOperator()).append(o instanceof he?o.getTokenValue():o.toString()),s==ae.ARRAY_OPERATOR&&h.append("]");let u=h.toString(),l=u.substring(0,u.indexOf(".")+1);if(l.length>2&&e.has(l))r.push(new he(u,this.getValue(u,e)));else{let e;try{e=Ge.INSTANCE.getValue(u)}catch(t){e=u}r.push(new he(u,e))}}applyBinaryOperation(e,t,r){if("object"===typeof t||"object"===typeof r||Array.isArray(t)||Array.isArray(r))throw new ne(this.expression,w.format("Cannot evaluate expression $ $ $",t,e.getOperator(),r));let s=Fe.BINARY_OPERATORS_MAP.get(e);if(!s)throw new ne(this.expression,w.format("No operator found to evaluate $ $ $",t,e.getOperator(),r));return new he(e.toString(),s.apply(t,r))}applyUnaryOperation(e,t){if("object"===typeof t||Array.isArray(t))throw new ne(this.expression,w.format("The operator $ cannot be applied to $",e.getOperator(),t));let r=Fe.UNARY_OPERATORS_MAP.get(e);if(!r)throw new ne(this.expression,w.format("No Unary operator $ is found to apply on $",e.getOperator(),t));return new he(e.toString(),r.apply(t))}getValueFromToken(e,t){return t instanceof oe?this.evaluateExpression(t,e):t instanceof he?t.getElement():this.getValue(t.getExpression(),e)}getValue(e,t){if(e.length<=5)return Ge.INSTANCE.getValue(e);const r=e.substring(0,e.indexOf(".")+1);return(t.get(r)??Ge.INSTANCE).getValue(e)}}class $e extends De{static PREFIX="Arguments.";constructor(e){super(),this.args=e}getValueInternal(e){let t=e.split(De.REGEX_DOT);return this.retrieveElementFrom(e,t,2,this.args.get(t[1]))}getPrefix(){return $e.PREFIX}}class Ye extends De{static PREFIX="Context.";constructor(e){super(),this.context=e}getValueInternal(e){let t=e.split(De.REGEX_DOT),r=t[1],s=r.indexOf("["),n=2;return-1!=s&&(r=t[1].substring(0,s),t[1]=t[1].substring(s),n=1),this.retrieveElementFrom(e,t,n,this.context.get(r)?.getElement())}getPrefix(){return Ye.PREFIX}}class He extends De{static PREFIX="Steps.";constructor(e){super(),this.output=e}getValueInternal(e){let t=e.split(De.REGEX_DOT),r=1,s=this.output.get(t[r++]);if(!s||r>=t.length)return;let n=s.get(t[r++]);if(!n||r>=t.length)return;let i=n.get(t[r++]);return this.retrieveElementFrom(e,t,r,i)}getPrefix(){return He.PREFIX}}class We{count=0;valueExtractors=new Map;getContext(){return this.context}setContext(e){this.context=e;let t=new Ye(e);return this.valueExtractors.set(t.getPrefix(),t),this}getArguments(){return this.args}setArguments(e){this.args=e;let t=new $e(e);return this.valueExtractors.set(t.getPrefix(),t),this}getEvents(){return this.events}setEvents(e){return this.events=e,this}getStatementExecution(){return this.statementExecution}setStatementExecution(e){return this.statementExecution=e,this}getSteps(){return this.steps}setSteps(e){this.steps=e;let t=new He(e);return this.valueExtractors.set(t.getPrefix(),t),this}getCount(){return this.count}setCount(e){return this.count=e,this}getValuesMap(){return this.valueExtractors}}class je{outVertices=new Map;inVertices=new Set;constructor(e,t){this.data=t,this.graph=e}getData(){return this.data}setData(e){return this.data=e,this}getOutVertices(){return this.outVertices}setOutVertices(e){return this.outVertices=e,this}getInVertices(){return this.inVertices}setInVertices(e){return this.inVertices=e,this}getGraph(){return this.graph}setGraph(e){return this.graph=e,this}getKey(){return this.data.getUniqueKey()}addOutEdgeTo(e,t){return this.outVertices.has(e)||this.outVertices.set(e,new Set),this.outVertices.get(e).add(t),t.inVertices.add(new s(this,e)),t}addInEdgeTo(e,t){return this.inVertices.add(new s(e,t)),e.outVertices.has(t)||e.outVertices.set(t,new Set),e.outVertices.get(t).add(this),e}hasIncomingEdges(){return!!this.inVertices.size}hasOutgoingEdges(){return!!this.outVertices.size}getSubGraphOfType(e){let t=new qe(!0);var r=new te(Array.from(this.outVertices.get(e)??[]));for(r.map((e=>e.getData())).forEach((e=>t.addVertex(e)));!r.isEmpty();){var s=r.pop();Array.from(s.outVertices.values()).flatMap((e=>Array.from(e))).forEach((e=>{t.addVertex(e.getData()),r.add(e)}))}return t}toString(){var e=Array.from(this.getInVertices()).map((e=>e.getT1().getKey()+"("+e.getT2()+")")).join(", "),t=Array.from(this.outVertices.entries()).map((([e,t])=>e+": "+Array.from(t).map((e=>e.getKey())).join(","))).join("\n\t\t");return this.getKey()+":\n\tIn: "+e+"\n\tOut: \n\t\t"+t}}class qe{nodeMap=new Map;constructor(e=!1){this.isSubGrph=e}getVerticesData(){return Array.from(this.nodeMap.values()).map((e=>e.getData()))}addVertex(e){if(!this.nodeMap.has(e.getUniqueKey())){let t=new je(this,e);this.nodeMap.set(e.getUniqueKey(),t)}return this.nodeMap.get(e.getUniqueKey())}getVertex(e){return this.nodeMap.get(e)}getVertexData(e){if(this.nodeMap.has(e))return this.nodeMap.get(e).getData()}getVerticesWithNoIncomingEdges(){return Array.from(this.nodeMap.values()).filter((e=>!e.hasIncomingEdges()))}isCyclic(){let e,t=new te(this.getVerticesWithNoIncomingEdges()),r=new Set;for(;!t.isEmpty();){if(r.has(t.getFirst().getKey()))return!0;e=t.removeFirst(),r.add(e.getKey()),e.hasOutgoingEdges()&&t.addAll(Array.from(e.getOutVertices().values()).flatMap((e=>Array.from(e))))}return!1}addVertices(e){for(const t of e)this.addVertex(t)}getNodeMap(){return this.nodeMap}isSubGraph(){return this.isSubGrph}toString(){return"Execution Graph : \n"+Array.from(this.nodeMap.values()).map((e=>e.toString())).join("\n")}}class Xe{constructor(e,t){this.message=t,this.messageType=e}getMessageType(){return this.messageType}setMessageType(e){return this.messageType=e,this}getMessage(){return this.message}setMessage(e){return this.message=e,this}toString(){return`${this.messageType} : ${this.message}`}}class Qe{messages=new Array;dependencies=new Set;constructor(e){this.statement=e}getStatement(){return this.statement}setStatement(e){return this.statement=e,this}getMessages(){return this.messages}setMessages(e){return this.messages=e,this}getDependencies(){return this.dependencies}setDependencies(e){return this.dependencies=e,this}getUniqueKey(){return this.statement.getStatementName()}addMessage(e,t){this.messages.push(new Xe(e,t))}addDependency(e){this.dependencies.add(e)}getDepenedencies(){return this.dependencies}equals(e){if(!(e instanceof Qe))return!1;return e.statement.equals(this.statement)}}let Je;var Ke;(Ke=Je||(Je={})).ERROR="ERROR",Ke.WARNING="WARNING",Ke.MESSAGE="MESSAGE";class ze extends H{static PARAMETER_NEEDS_A_VALUE='Parameter "$" needs a value';static STEP_REGEX_PATTERN=new RegExp("Steps\\.([a-zA-Z0-9\\\\-]{1,})\\.([a-zA-Z0-9\\\\-]{1,})","g");static VERSION=1;static MAX_EXECUTION_ITERATIONS=1e7;constructor(e,t,r){if(super(),this.fd=e,this.fd.getVersion()>ze.VERSION)throw new R("Runtime is at a lower version "+ze.VERSION+" and trying to run code from version "+this.fd.getVersion()+".");this.fRepo=t,this.sRepo=r}getSignature(){return this.fd}getExecutionPlan(e){let t=new qe;for(let r of Array.from(this.fd.getSteps().values()))t.addVertex(this.prepareStatementExecution(e,r));let r=this.makeEdges(t);if(r.length)throw new R(w.format("Found these unresolved dependencies : $ ",r.map((e=>w.format("Steps.$.$",e.getT1(),e.getT2())))));return t}internalExecute(e){e.getContext()||e.setContext(new Map),e.getEvents()||e.setEvents(new Map),e.getSteps()||e.setSteps(new Map);let t=this.getExecutionPlan(e.getContext()),r=t.getVerticesData().filter((e=>e.getMessages().length)).map((e=>e.getStatement().getStatementName()+": \n"+e.getMessages().join(",")));if(r?.length)throw new R("Please fix the errors in the function definition before execution : \n"+r.join(",\n"));return this.executeGraph(t,e)}executeGraph(e,t){let r=new te;r.addAll(e.getVerticesWithNoIncomingEdges());let s=new te;for(;!(r.isEmpty()&&s.isEmpty()||t.getEvents()?.has(q.OUTPUT));)if(this.processBranchQue(t,r,s),this.processExecutionQue(t,r,s),t.setCount(t.getCount()+1),t.getCount()==ze.MAX_EXECUTION_ITERATIONS)throw new R("Execution locked in an infinite loop");if(!e.isSubGraph()&&!t.getEvents()?.size)throw new R("No events raised");return new Q(Array.from(t.getEvents()?.entries()??[]).flatMap((e=>e[1].map((t=>X.of(e[0],t))))))}processExecutionQue(e,t,r){if(!t.isEmpty()){let s=t.pop();this.allDependenciesResolvedVertex(s,e.getSteps())?this.executeVertex(s,e,r,t):t.add(s)}}processBranchQue(e,t,r){if(r.length){let s=r.pop();this.allDependenciesResolvedTuples(s.getT2(),e.getSteps())?this.executeBranch(e,t,s):r.add(s)}}executeBranch(e,t,r){let s,n=r.getT4();do{this.executeGraph(r.getT1(),e),s=r.getT3().next(),s&&(e.getSteps()?.has(n.getData().getStatement().getStatementName())||e.getSteps()?.set(n.getData().getStatement().getStatementName(),new Map),e.getSteps()?.get(n.getData().getStatement().getStatementName())?.set(s.getName(),this.resolveInternalExpressions(s.getResult(),e)))}while(s&&s.getName()!=q.OUTPUT);s?.getName()==q.OUTPUT&&n.getOutVertices().has(q.OUTPUT)&&(n?.getOutVertices()?.get(q.OUTPUT)??[]).forEach((e=>t.add(e)))}executeVertex(e,t,r,s){let n=e.getData().getStatement(),a=this.fRepo.find(n.getNamespace(),n.getName());if(!a)throw new R(w.format("$.$ function is not found.",n.getNamespace(),n.getName()));let o=a?.getSignature().getParameters(),h=this.getArgumentsFromParametersMap(t,n,o??new Map),u=t.getContext(),l=a.execute((new We).setContext(u).setArguments(h).setEvents(t.getEvents()).setSteps(t.getSteps()).setStatementExecution(e.getData()).setCount(t.getCount())),p=l.next();if(!p)throw new R(w.format("Executing $ returned no events",n.getStatementName()));let c=p.getName()==q.OUTPUT;if(t.getSteps()?.has(n.getStatementName())||t.getSteps().set(n.getStatementName(),new Map),t.getSteps().get(n.getStatementName()).set(p.getName(),this.resolveInternalExpressions(p.getResult(),t)),c){let t=e.getOutVertices().get(q.OUTPUT);t&&t.forEach((e=>s.add(e)))}else{let t=e.getSubGraphOfType(p.getName()),s=this.makeEdges(t);r.push(new i(t,s,l,e))}}resolveInternalExpressions(e,t){return e?Array.from(e.entries()).map((e=>new s(e[0],this.resolveInternalExpression(e[1],t)))).reduce(((e,t)=>(e.set(t.getT1(),t.getT2()),e)),new Map):e}resolveInternalExpression(e,t){if(p(e)||"object"!=typeof e)return e;if(e instanceof j){return new Fe(e.getExpression()).evaluate(t.getValuesMap())}if(Array.isArray(e)){let r=[];for(let s of e)r.push(this.resolveInternalExpression(s,t));return r}if("object"==typeof e){let r={};for(let s of Object.entries(e))r[s[0]]=this.resolveInternalExpression(s[1],t);return r}}allDependenciesResolvedTuples(e,t){for(let r of e){if(!t.has(r.getT1()))return!1;if(!t.get(r.getT1())?.get(r.getT2()))return!1}return!0}allDependenciesResolvedVertex(e,t){return!e.getInVertices().size||0==Array.from(e.getInVertices()).filter((e=>{let r=e.getT1().getData().getStatement().getStatementName(),s=e.getT2();return!(t.has(r)&&t.get(r)?.has(s))})).length}getArgumentsFromParametersMap(e,t,r){return Array.from(t.getParameterMap().entries()).map((t=>{let n,i=t[1];if(!i?.length)return new s(t[0],n);let a=r.get(t[0]);return a?(n=a.isVariableArgument()?i.map((t=>this.parameterReferenceEvaluation(e,t))).flatMap((e=>Array.isArray(e)?e:[e])):this.parameterReferenceEvaluation(e,i[0]),new s(t[0],n)):new s(t[0],void 0)})).filter((e=>!p(e.getT2()))).reduce(((e,t)=>(e.set(t.getT1(),t.getT2()),e)),new Map)}parameterReferenceEvaluation(e,t){let r;if(t.getType()==Z.VALUE)r=this.resolveInternalExpression(t.getValue(),e);else if(t.getType()==Z.EXPRESSION&&!y.isNullOrBlank(t.getExpression())){r=new Fe(t.getExpression()??"").evaluate(e.getValuesMap())}return r}prepareStatementExecution(e,t){let r=new Qe(t),s=this.fRepo.find(t.getNamespace(),t.getName());if(!s)throw new R(w.format("$.$ was not available",t.getNamespace(),t.getName()));let n=new Map(s.getSignature().getParameters());for(let s of Array.from(t.getParameterMap().entries())){let t=n.get(s[0]);if(!t)continue;let i=s[1];if(i.length){if(t.isVariableArgument())for(let s of i)this.parameterReferenceValidation(e,r,t,s);else{let s=i[0];this.parameterReferenceValidation(e,r,t,s)}n.delete(t.getParameterName())}else p(v.getDefaultValue(t.getSchema(),this.sRepo))&&r.addMessage(Je.ERROR,w.format(ze.PARAMETER_NEEDS_A_VALUE,t.getParameterName()))}if(!p(r.getStatement().getDependentStatements()))for(let e of r.getStatement().getDependentStatements())r.addDependency(e);if(n.size)for(let e of Array.from(n.values()))p(v.getDefaultValue(e.getSchema(),this.sRepo))&&r.addMessage(Je.ERROR,w.format(ze.PARAMETER_NEEDS_A_VALUE,e.getParameterName()));return r}parameterReferenceValidation(e,t,r,n){if(n){if(n.getType()==Z.VALUE){p(n.getValue())&&p(v.getDefaultValue(r.getSchema(),this.sRepo))&&t.addMessage(Je.ERROR,w.format(ze.PARAMETER_NEEDS_A_VALUE,r.getParameterName()));let e=new te;for(e.push(new s(r.getSchema(),n.getValue()));!e.isEmpty();){let r=e.pop();if(r.getT2()instanceof j)this.addDependencies(t,r.getT2().getExpression());else{if(p(r.getT1())||p(r.getT1().getType()))continue;if(r.getT1().getType()?.contains(f.ARRAY)&&Array.isArray(r.getT2())){let t=r.getT1().getItems();if(!t)continue;if(t.isSingleType())for(let n of r.getT2())e.push(new s(t.getSingleSchema(),n));else{let n=r.getT2();for(let r=0;r<n.length;r++)e.push(new s(t.getTupleSchema()[r],n[r]))}}else if(r.getT1().getType()?.contains(f.OBJECT)&&"object"==typeof r.getT2()){let n=r.getT1();if(n.getName()===z.EXPRESSION.getName()&&n.getNamespace()===z.EXPRESSION.getNamespace()){let e=r.getT2();e.isExpression&&this.addDependencies(t,e.value)}else if(n.getProperties())for(let t of Object.entries(r.getT2()))n.getProperties().has(t[0])&&e.push(new s(n.getProperties().get(t[0]),t[1]))}}}}else if(n.getType()==Z.EXPRESSION)if(y.isNullOrBlank(n.getExpression()))p(v.getDefaultValue(r.getSchema(),this.sRepo))&&t.addMessage(Je.ERROR,w.format(ze.PARAMETER_NEEDS_A_VALUE,r.getParameterName()));else try{this.addDependencies(t,n.getExpression())}catch(e){t.addMessage(Je.ERROR,w.format("Error evaluating $ : $",n.getExpression(),e))}}else p(v.getDefaultValue(r.getSchema(),this.sRepo))&&t.addMessage(Je.ERROR,w.format(ze.PARAMETER_NEEDS_A_VALUE,r.getParameterName()))}addDependencies(e,t){t&&Array.from(t.match(ze.STEP_REGEX_PATTERN)??[]).forEach((t=>e.addDependency(t)))}makeEdges(e){let t=e.getNodeMap().values(),r=[];for(let n of Array.from(t))for(let t of n.getData().getDependencies()){let i=t.indexOf(".",6),a=t.substring(6,i),o=t.indexOf(".",i+1),h=-1==o?t.substring(i+1):t.substring(i+1,o);e.getNodeMap().has(a)||r.push(new s(a,h));let u=e.getNodeMap().get(a);u&&n.addInEdgeTo(u,h)}return r}}e(module.exports,r),e(module.exports,{}),e(module.exports,a),e(module.exports,h),e(module.exports,g),e(module.exports,N),e(module.exports,k),e(module.exports,F),e(module.exports,I),e(module.exports,{}),e(module.exports,Y),e(module.exports,u),e(module.exports,W);
1
+ function e(e,t){return Object.keys(t).forEach((function(r){"default"===r||"__esModule"===r||e.hasOwnProperty(r)||Object.defineProperty(e,r,{enumerable:!0,get:function(){return t[r]}})})),e}function t(e,t,r,s){Object.defineProperty(e,t,{get:r,set:s,enumerable:!0,configurable:!0})}var r={};t(r,"Tuple2",(()=>s)),t(r,"Tuple3",(()=>n)),t(r,"Tuple4",(()=>i));class s{constructor(e,t){this.f=e,this.s=t}getT1(){return this.f}getT2(){return this.s}}class n extends s{constructor(e,t,r){super(e,t),this.t=r}getT3(){return this.t}}class i extends n{constructor(e,t,r,s){super(e,t,r),this.fr=s}getT4(){return this.fr}}var a={};t(a,"HybridRepository",(()=>o));class o{constructor(...e){this.repos=e}find(e,t){for(let r of this.repos){let s=r.find(e,t);if(s)return s}}}var u={};t(u,"Schema",(()=>N));var h={};t(h,"Namespaces",(()=>l));class l{static SYSTEM="System";static SYSTEM_CTX="System.Context";static SYSTEM_LOOP="System.Loop";static SYSTEM_ARRAY="System.Array";static MATH="System.Math";static STRING="System.String";constructor(){}}var p={};function c(e){return null==e}t(p,"isNullValue",(()=>c));class m{setSingleSchema(e){return this.singleSchema=e,this}setTupleSchema(e){return this.tupleSchema=e,this}getSingleSchema(){return this.singleSchema}getTupleSchema(){return this.tupleSchema}isSingleType(){return!c(this.singleSchema)}static of(...e){return 1==e.length?(new m).setSingleSchema(e[0]):(new m).setTupleSchema(e)}static from(e){if(!e)return;Array.isArray(e)&&m.of(...N.fromListOfSchemas(e));let t=N.from(e);return t?m.of(t):void 0}}class g{getBooleanValue(){return this.booleanValue}getSchemaValue(){return this.schemaValue}setBooleanValue(e){return this.booleanValue=e,this}setSchemaValue(e){return this.schemaValue=e,this}static from(e){if(!e)return;const t=new g;return t.booleanValue=e.booleanValue,t.schemaValue=e.schemaValue,t}}var f={};let E;var T;t(f,"SchemaType",(()=>E)),(T=E||(E={})).INTEGER="Integer",T.LONG="Long",T.FLOAT="Float",T.DOUBLE="Double",T.STRING="String",T.OBJECT="Object",T.ARRAY="Array",T.BOOLEAN="Boolean",T.NULL="Null";class A{}class d extends A{constructor(e){super(),this.type=e}getType(){return this.type}setType(e){return this.type=e,this}getAllowedSchemaTypes(){return this.type}contains(e){return this.type?.has(e)}}class O extends A{constructor(e){super(),this.type=e}getType(){return this.type}getAllowedSchemaTypes(){return new Set([this.type])}contains(e){return this.type==e}}class S{static of(...e){return 1==e.length?new O(e[0]):new d(new Set(e))}static from(e){return"string"==typeof e?S.of(e):Array.isArray(e)?S.of(...Array.of(e).map((e=>e)).map((e=>e))):void 0}}class N{static NULL=(new N).setNamespace(l.SYSTEM).setName("Null").setType(S.of(E.NULL)).setConstant(void 0);static TYPE_SCHEMA=(new N).setType(S.of(E.STRING)).setEnums(["INTEGER","LONG","FLOAT","DOUBLE","STRING","OBJECT","ARRAY","BOOLEAN","NULL"]);static SCHEMA=(new N).setNamespace(l.SYSTEM).setName("Schema").setType(S.of(E.OBJECT)).setProperties(new Map([["namespace",N.of("namespace",E.STRING).setDefaultValue("_")],["name",N.ofString("name")],["version",N.of("version",E.INTEGER).setDefaultValue(1)],["ref",N.ofString("ref")],["type",(new N).setAnyOf([N.TYPE_SCHEMA,N.ofArray("type",N.TYPE_SCHEMA)])],["anyOf",N.ofArray("anyOf",N.ofRef("#/"))],["allOf",N.ofArray("allOf",N.ofRef("#/"))],["oneOf",N.ofArray("oneOf",N.ofRef("#/"))],["not",N.ofRef("#/")],["title",N.ofString("title")],["description",N.ofString("description")],["id",N.ofString("id")],["examples",N.ofAny("examples")],["defaultValue",N.ofAny("defaultValue")],["comment",N.ofString("comment")],["enums",N.ofArray("enums",N.ofString("enums"))],["constant",N.ofAny("constant")],["pattern",N.ofString("pattern")],["format",N.of("format",E.STRING).setEnums(["DATETIME","TIME","DATE","EMAIL","REGEX"])],["minLength",N.ofInteger("minLength")],["maxLength",N.ofInteger("maxLength")],["multipleOf",N.ofLong("multipleOf")],["minimum",N.ofNumber("minimum")],["maximum",N.ofNumber("maximum")],["exclusiveMinimum",N.ofNumber("exclusiveMinimum")],["exclusiveMaximum",N.ofNumber("exclusiveMaximum")],["properties",N.of("properties",E.OBJECT).setAdditionalProperties((new g).setSchemaValue(N.ofRef("#/")))],["additionalProperties",(new N).setName("additionalProperty").setNamespace(l.SYSTEM).setAnyOf([N.ofBoolean("additionalProperty"),N.ofObject("additionalProperty").setRef("#/")]).setDefaultValue(!0)],["required",N.ofArray("required",N.ofString("required")).setDefaultValue([])],["propertyNames",N.ofRef("#/")],["minProperties",N.ofInteger("minProperties")],["maxProperties",N.ofInteger("maxProperties")],["patternProperties",N.of("patternProperties",E.OBJECT).setAdditionalProperties((new g).setSchemaValue(N.ofRef("#/")))],["items",(new N).setName("items").setAnyOf([N.ofRef("#/").setName("item"),N.ofArray("tuple",N.ofRef("#/"))])],["contains",N.ofRef("#/")],["minItems",N.ofInteger("minItems")],["maxItems",N.ofInteger("maxItems")],["uniqueItems",N.ofBoolean("uniqueItems")],["$defs",N.of("$defs",E.OBJECT).setAdditionalProperties((new g).setSchemaValue(N.ofRef("#/")))],["permission",N.ofString("permission")]])).setRequired([]);static ofString(e){return(new N).setType(S.of(E.STRING)).setName(e)}static ofInteger(e){return(new N).setType(S.of(E.INTEGER)).setName(e)}static ofFloat(e){return(new N).setType(S.of(E.FLOAT)).setName(e)}static ofLong(e){return(new N).setType(S.of(E.LONG)).setName(e)}static ofDouble(e){return(new N).setType(S.of(E.DOUBLE)).setName(e)}static ofAny(e){return(new N).setType(S.of(E.INTEGER,E.LONG,E.FLOAT,E.DOUBLE,E.STRING,E.BOOLEAN,E.ARRAY,E.NULL,E.OBJECT)).setName(e)}static ofAnyNotNull(e){return(new N).setType(S.of(E.INTEGER,E.LONG,E.FLOAT,E.DOUBLE,E.STRING,E.BOOLEAN,E.ARRAY,E.OBJECT)).setName(e)}static ofNumber(e){return(new N).setType(S.of(E.INTEGER,E.LONG,E.FLOAT,E.DOUBLE)).setName(e)}static ofBoolean(e){return(new N).setType(S.of(E.BOOLEAN)).setName(e)}static of(e,...t){return(new N).setType(S.of(...t)).setName(e)}static ofObject(e){return(new N).setType(S.of(E.OBJECT)).setName(e)}static ofRef(e){return(new N).setRef(e)}static ofArray(e,...t){return(new N).setType(S.of(E.ARRAY)).setName(e).setItems(m.of(...t))}static fromListOfSchemas(e){if(c(e)&&!Array.isArray(e))return[];let t=[];for(let r of Array.from(e)){let e=N.from(r);e&&t.push(e)}return t}static fromMapOfSchemas(e){if(c(e))return;const t=new Map;return Object.entries(e).forEach((([e,r])=>{let s=N.from(r);s&&t.set(e,s)})),t}static from(e,t=!1){if(c(e))return;let r=new N;return r.namespace=e.namespace,r.name=e.name,r.version=e.version,r.ref=e.ref,r.type=t?new O(E.STRING):S.from(r.type),r.anyOf=N.fromListOfSchemas(e.anyOf),r.allOf=N.fromListOfSchemas(e.allOf),r.oneOf=N.fromListOfSchemas(e.oneOf),r.not=N.from(e.not),r.description=e.description,r.examples=e.examples?[...e.examples]:void 0,r.defaultValue=e.defaultValue,r.comment=e.comment,r.enums=e.enums?[...e.enums]:void 0,r.constant=e.constant,r.pattern=e.pattern,r.format=e.format,r.minLength=e.minLength,r.maxLength=e.maxLength,r.multipleOf=e.multipleOf,r.minimum=e.minimum,r.maximum=e.maximum,r.exclusiveMinimum=e.exclusiveMinimum,r.exclusiveMaximum=e.exclusiveMaximum,r.properties=N.fromMapOfSchemas(e.properties),r.additionalProperties=g.from(e.additionalProperties),r.required=e.required,r.propertyNames=N.from(e.propertyNames,!0),r.minProperties=e.minProperties,r.maxProperties=e.maxProperties,r.patternProperties=N.fromMapOfSchemas(e.patternProperties),r.items=m.from(e.items),r.contains=N.from(e.contains),r.minItems=e.minItems,r.maxItems=e.maxItems,r.uniqueItems=e.uniqueItems,r.$defs=N.fromMapOfSchemas(e.$defs),r.permission=e.permission,r}namespace="_";version=1;getTitle(){return this.getFullName()}getFullName(){return this.namespace&&"_"!=this.namespace?this.namespace+"."+this.name:this.name}get$defs(){return this.$defs}set$defs(e){return this.$defs=e,this}getNamespace(){return this.namespace}setNamespace(e){return this.namespace=e,this}getName(){return this.name}setName(e){return this.name=e,this}getVersion(){return this.version}setVersion(e){return this.version=e,this}getRef(){return this.ref}setRef(e){return this.ref=e,this}getType(){return this.type}setType(e){return this.type=e,this}getAnyOf(){return this.anyOf}setAnyOf(e){return this.anyOf=e,this}getAllOf(){return this.allOf}setAllOf(e){return this.allOf=e,this}getOneOf(){return this.oneOf}setOneOf(e){return this.oneOf=e,this}getNot(){return this.not}setNot(e){return this.not=e,this}getDescription(){return this.description}setDescription(e){return this.description=e,this}getExamples(){return this.examples}setExamples(e){return this.examples=e,this}getDefaultValue(){return this.defaultValue}setDefaultValue(e){return this.defaultValue=e,this}getComment(){return this.comment}setComment(e){return this.comment=e,this}getEnums(){return this.enums}setEnums(e){return this.enums=e,this}getConstant(){return this.constant}setConstant(e){return this.constant=e,this}getPattern(){return this.pattern}setPattern(e){return this.pattern=e,this}getFormat(){return this.format}setFormat(e){return this.format=e,this}getMinLength(){return this.minLength}setMinLength(e){return this.minLength=e,this}getMaxLength(){return this.maxLength}setMaxLength(e){return this.maxLength=e,this}getMultipleOf(){return this.multipleOf}setMultipleOf(e){return this.multipleOf=e,this}getMinimum(){return this.minimum}setMinimum(e){return this.minimum=e,this}getMaximum(){return this.maximum}setMaximum(e){return this.maximum=e,this}getExclusiveMinimum(){return this.exclusiveMinimum}setExclusiveMinimum(e){return this.exclusiveMinimum=e,this}getExclusiveMaximum(){return this.exclusiveMaximum}setExclusiveMaximum(e){return this.exclusiveMaximum=e,this}getProperties(){return this.properties}setProperties(e){return this.properties=e,this}getAdditionalProperties(){return this.additionalProperties}setAdditionalProperties(e){return this.additionalProperties=e,this}getRequired(){return this.required}setRequired(e){return this.required=e,this}getPropertyNames(){return this.propertyNames}setPropertyNames(e){return this.propertyNames=e,this.propertyNames.type=new O(E.STRING),this}getMinProperties(){return this.minProperties}setMinProperties(e){return this.minProperties=e,this}getMaxProperties(){return this.maxProperties}setMaxProperties(e){return this.maxProperties=e,this}getPatternProperties(){return this.patternProperties}setPatternProperties(e){return this.patternProperties=e,this}getItems(){return this.items}setItems(e){return this.items=e,this}getContains(){return this.contains}setContains(e){return this.contains=e,this}getMinItems(){return this.minItems}setMinItems(e){return this.minItems=e,this}getMaxItems(){return this.maxItems}setMaxItems(e){return this.maxItems=e,this}getUniqueItems(){return this.uniqueItems}setUniqueItems(e){return this.uniqueItems=e,this}getPermission(){return this.permission}setPermission(e){return this.permission=e,this}}var I={};t(I,"SchemaValidator",(()=>F));var R={};t(R,"StringUtil",(()=>v));var w={};t(w,"KIRuntimeException",(()=>y));class y extends Error{constructor(e,t){super(e),this.cause=t}getCause(){return this.cause}}var x={};t(x,"StringFormatter",(()=>_));class _{static format(e,...t){if(!t||0==t.length)return e;let r="",s=0,n="",i=n,a=e.length;for(let o=0;o<a;o++)n=e.charAt(o),"$"==n&&"\\"==i?r=r.substring(0,o-1)+n:"$"==n&&s<t.length?r+=t[s++]:r+=n,i=n;return r.toString()}constructor(){}}class v{constructor(){}static nthIndex(e,t,r=0,s){if(!e)throw new y("String cannot be null");if(r<0||r>=e.length)throw new y(_.format("Cannot search from index : $",r));if(s<=0||s>e.length)throw new y(_.format("Cannot search for occurance : $",s));for(;r<e.length;){if(e.charAt(r)==t&&0==--s)return r;++r}return-1}static splitAtFirstOccurance(e,t){if(!e)return[void 0,void 0];let r=e.indexOf(t);return-1==r?[e,void 0]:[e.substring(0,r),e.substring(r+1)]}static isNullOrBlank(e){return!e||""==e.trim()}}class P extends Error{constructor(e,t,r){super(e.trim()?e+"-"+t:t),this.schemaPath=e,this.cause=r}getSchemaPath(){return this.schemaPath}getCause(){return this.cause}}class M extends Error{constructor(e,t,r=[],s){super(t+(r?r.map((e=>e.message)).reduce(((e,t)=>e+"\n"+t),""):"")),this.schemaPath=e,this.cause=s}getSchemaPath(){return this.schemaPath}getCause(){return this.cause}}class L{static UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH="Unable to retrive schema from referenced path";static CYCLIC_REFERENCE_LIMIT_COUNTER=20;static getDefaultValue(e,t){if(e)return e.getConstant()?e.getConstant():e.getDefaultValue()?e.getDefaultValue():L.getDefaultValue(L.getSchemaFromRef(e,t,e.getRef()),t)}static getSchemaFromRef(e,t,r,s=0){if(++s==L.CYCLIC_REFERENCE_LIMIT_COUNTER)throw new M(r??"","Schema has a cyclic reference");if(!e||!r||v.isNullOrBlank(r))return;if(!r.startsWith("#")){var n=L.resolveExternalSchema(e,t,r);n&&(e=n.getT1(),r=n.getT2())}let i=r.split("/");return e=L.resolveInternalSchema(e,t,r,s,i,1)}static resolveInternalSchema(e,t,r,s,n,i){let a=e;for(;i<n.length;){if("$defs"===n[i]){if(++i>=n.length||!a.get$defs())throw new P(r,L.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH);a=a.get$defs()?.get(n[i])}else{if(a&&(!a.getType()?.contains(E.OBJECT)||!a.getProperties()))throw new P(r,"Cannot retrievie schema from non Object type schemas");a=a.getProperties()?.get(n[i])}if(i++,!a)throw new P(r,L.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH);if(!v.isNullOrBlank(a.getRef())&&(a=L.getSchemaFromRef(a,t,a.getRef(),s),!a))throw new P(r,L.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH)}return a}static resolveExternalSchema(e,t,r){if(!t)return;let n=v.splitAtFirstOccurance(e?.getRef()??"","/");if(!n[0])return;let i=v.splitAtFirstOccurance(n[0],".");if(!i[0]||!i[1])return;let a=t.find(i[0],i[1]);if(a){if(!n[1]||""===n[1])return new s(a,r);if(r="#/"+n[1],!a)throw new P(r,L.UNABLE_TO_RETRIVE_SCHEMA_FROM_REFERENCED_PATH);return new s(a,r)}}constructor(){}}class U{static validate(e,t,r,s){let n=[];return t.getOneOf()&&!t.getOneOf()?U.oneOf(e,t,r,s,n):t.getAllOf()&&!t.getAllOf()?U.allOf(e,t,r,s,n):t.getAnyOf()&&!t.getAnyOf()&&U.anyOf(e,t,r,s,n),s}static anyOf(e,t,r,s,n){let i=!1;for(let a of t.getAnyOf()??[])try{U.validate(e,a,r,s),i=!0;break}catch(e){i=!1,n.push(e)}if(!i)throw new M(F.path(e),"The value don't satisfy any of the schemas.",n)}static allOf(e,t,r,s,n){let i=0;for(let a of t.getAllOf()??[])try{U.validate(e,a,r,s),i++}catch(e){n.push(e)}if(i!==t.getAllOf()?.length)throw new M(F.path(e),"The value doesn't satisfy some of the schemas.",n)}static oneOf(e,t,r,s,n){let i=0;for(let a of t.getOneOf()??[])try{U.validate(e,a,r,s),i++}catch(e){n.push(e)}if(1!=i)throw new M(F.path(e),0==i?"The value does not satisfy any schema":"The value satisfy more than one schema",n)}constructor(){}}class C{static validate(e,t,r,s){if(c(s))throw new M(F.path(e),"Expected an array but found null");if(!Array.isArray(s))throw new M(F.path(e),s.toString()+" is not an Array");let n=s;return C.checkMinMaxItems(e,t,n),C.checkItems(e,t,r,n),C.checkUniqueItems(e,t,n),C.checkContains(e,t,r,n),s}static checkContains(e,t,r,s){if(!t.getContains())return;let n=!1;for(let i=0;i<s.length;i++){let a=e?[...e]:[];try{F.validate(a,t.getContains(),r,s[i]),n=!0;break}catch(e){n=!1}}if(!n)throw new M(F.path(e),"None of the items are of type contains schema")}static checkUniqueItems(e,t,r){if(t.getUniqueItems()&&t.getUniqueItems()){if(new Set(r).size!==r.length)throw new M(F.path(e),"Items on the array are not unique")}}static checkMinMaxItems(e,t,r){if(t.getMinItems()&&t.getMinItems()>r.length)throw new M(F.path(e),"Array should have minimum of "+t.getMinItems()+" elements");if(t.getMaxItems()&&t.getMaxItems()<r.length)throw new M(F.path(e),"Array can have maximum of "+t.getMaxItems()+" elements")}static checkItems(e,t,r,s){if(!t.getItems())return;let n=t.getItems();if(n.getSingleSchema())for(let t=0;t<s.length;t++){let i=e?[...e]:[],a=F.validate(i,n.getSingleSchema(),r,s[t]);s[t]=a}if(n.getTupleSchema()){if(n.getTupleSchema().length!==s.length)throw new M(F.path(e),"Expected an array with only "+n.getTupleSchema().length+" but found "+s.length);for(let t=0;t<s.length;t++){let i=e?[...e]:[],a=F.validate(i,n.getTupleSchema()[t],r,s[t]);s[t]=a}}}constructor(){}}class B{static validate(e,t,r,s){if(c(s))throw new M(F.path(t),"Expected a number but found null");if("number"!=typeof s)throw new M(F.path(t),s.toString()+" is not a "+e);let n=B.extractNumber(e,t,r,s);return B.checkRange(t,r,s,n),B.checkMultipleOf(t,r,s,n),s}static extractNumber(e,t,r,s){let n=s;try{e!=E.LONG&&e!=E.INTEGER||(n=Math.round(n))}catch(r){throw new M(F.path(t),s+" is not a number of type "+e,r)}if(c(n)||(e==E.LONG||e==E.INTEGER)&&n!=s)throw new M(F.path(t),s.toString()+" is not a number of type "+e);return n}static checkMultipleOf(e,t,r,s){if(t.getMultipleOf()){if(s%t.getMultipleOf()!=0)throw new M(F.path(e),r.toString()+" is not multiple of "+t.getMultipleOf())}}static checkRange(e,t,r,s){if(t.getMinimum()&&B.numberCompare(s,t.getMinimum())<0)throw new M(F.path(e),r.toString()+" should be greater than or equal to "+t.getMinimum());if(t.getMaximum()&&B.numberCompare(s,t.getMaximum())>0)throw new M(F.path(e),r.toString()+" should be less than or equal to "+t.getMaximum());if(t.getExclusiveMinimum()&&B.numberCompare(s,t.getExclusiveMinimum())<=0)throw new M(F.path(e),r.toString()+" should be greater than "+t.getExclusiveMinimum());if(t.getExclusiveMaximum()&&B.numberCompare(s,t.getExclusiveMaximum())>0)throw new M(F.path(e),r.toString()+" should be less than "+t.getExclusiveMaximum())}static numberCompare(e,t){return e-t}constructor(){}}class V{static validate(e,t,r,s){if(c(s))throw new M(F.path(e),"Expected an object but found null");if("object"!=typeof s||Array.isArray(s))throw new M(F.path(e),s.toString()+" is not an Object");let n=s,i=new Set(Object.keys(n));V.checkMinMaxProperties(e,t,i),t.getPropertyNames()&&V.checkPropertyNameSchema(e,t,r,i),t.getRequired()&&V.checkRequired(e,t,n),t.getProperties()&&V.checkProperties(e,t,r,n,i),t.getPatternProperties()&&V.checkPatternProperties(e,t,r,n,i),t.getAdditionalProperties()&&V.checkAddtionalProperties(e,t,r,n,i)}static checkPropertyNameSchema(e,t,r,s){for(let n of Array.from(s.values()))try{F.validate(e,t.getPropertyNames(),r,n)}catch(t){throw new M(F.path(e),"Property name '"+n+"' does not fit the property schema")}}static checkRequired(e,t,r){for(const s of t.getRequired()??[])if(c(r[s]))throw new M(F.path(e),s+" is mandatory")}static checkAddtionalProperties(e,t,r,s,n){let i=t.getAdditionalProperties();if(i.getSchemaValue())for(let t of Array.from(n.values())){let n=e?[...e]:[],a=F.validate(n,i.getSchemaValue(),r,s.get(t));s[t]=a}else if(!1===i.getBooleanValue()&&n.size)throw new M(F.path(e),n.toString()+" are additional properties which are not allowed.")}static checkPatternProperties(e,t,r,s,n){const i=new Map;for(const e of Array.from(t.getPatternProperties().keys()))i.set(e,new RegExp(e));for(const a of Array.from(n.values())){const o=e?[...e]:[];for(const e of Array.from(i.entries()))if(e[1].test(a)){const i=F.validate(o,t.getPatternProperties().get(e[0]),r,s[a]);s[a]=i,n.delete(a);break}}}static checkProperties(e,t,r,s,n){for(const i of Array.from(t.getProperties())){let t=s[i[0]];if(c(t))continue;let a=e?[...e]:[],o=F.validate(a,i[1],r,t);s[i[0]]=o,n.delete(i[0])}}static checkMinMaxProperties(e,t,r){if(t.getMinProperties()&&r.size<t.getMinProperties())throw new M(F.path(e),"Object should have minimum of "+t.getMinProperties()+" properties");if(t.getMaxProperties()&&r.size>t.getMaxProperties())throw new M(F.path(e),"Object can have maximum of "+t.getMaxProperties()+" properties")}constructor(){}}let b;var D;(D=b||(b={})).DATETIME="DATETIME",D.TIME="TIME",D.DATE="DATE",D.EMAIL="EMAIL",D.REGEX="REGEX";class k{static TIME=/^([01]?[0-9]|2[0-3]):[0-5][0-9](:[0-5][0-9])?([+-][01][0-9]:[0-5][0-9])?$/;static DATE=/^[0-9]{4,4}-([0][0-9]|[1][0-2])-(0[1-9]|[1-2][1-9]|3[01])$/;static DATETIME=/^[0-9]{4,4}-([0][0-9]|[1][0-2])-(0[1-9]|[1-2][1-9]|3[01])T([01]?[0-9]|2[0-3]):[0-5][0-9](:[0-5][0-9])?([+-][01][0-9]:[0-5][0-9])?$/;static validate(e,t,r){if(c(r))throw new M(F.path(e),"Expected a string but found "+r);if("string"!=typeof r)throw new M(F.path(e),r.toString()+" is not String");t.getFormat()==b.TIME?k.patternMatcher(e,t,r,k.TIME,"time pattern"):t.getFormat()==b.DATE?k.patternMatcher(e,t,r,k.DATE,"date pattern"):t.getFormat()==b.DATETIME?k.patternMatcher(e,t,r,k.DATETIME,"date time pattern"):t.getPattern()&&k.patternMatcher(e,t,r,new RegExp(t.getPattern()),"pattern "+t.getPattern());let s=r.length;if(t.getMinLength()&&s<t.getMinLength())throw new M(F.path(e),"Expected a minimum of "+t.getMinLength()+" characters");if(t.getMaxLength()&&s>t.getMinLength())throw new M(F.path(e),"Expected a maximum of "+t.getMaxLength()+" characters");return r}static patternMatcher(e,t,r,s,n){if(!s.test(r))throw new M(F.path(e),r.toString()+" is not matched with the "+n)}constructor(){}}class G{static validate(e,t,r,s,n){if(t==E.STRING)k.validate(e,r,n);else if(t==E.LONG||t==E.INTEGER||t==E.DOUBLE||t==E.FLOAT)B.validate(t,e,r,n);else if(t==E.BOOLEAN)(class{static validate(e,t,r){if(c(r))throw new M(F.path(e),"Expected a boolean but found null");if("boolean"!=typeof r)throw new M(F.path(e),r.toString()+" is not a boolean");return r}constructor(){}}).validate(e,r,n);else if(t==E.OBJECT)V.validate(e,r,s,n);else if(t==E.ARRAY)C.validate(e,r,s,n);else{if(t!=E.NULL)throw new M(F.path(e),t+" is not a valid type.");(class{static validate(e,t,r){if(r)throw new M(F.path(e),"Expected a null but found "+r);return r}constructor(){}}).validate(e,r,n)}return n}constructor(){}}class F{static path(e){return e?e.map((e=>e.getTitle()??"")).filter((e=>!!e)).reduce(((e,t,r)=>e+(0===r?"":".")+t),""):""}static validate(e,t,r,s){if(!t)return s;if(e||(e=new Array),e.push(t),c(s)&&!c(t.getDefaultValue()))return JSON.parse(JSON.stringify(t.getDefaultValue()));if(t.getConstant())return F.constantValidation(e,t,s);if(t.getEnums()&&!t.getEnums()?.length)return F.enumCheck(e,t,s);if(t.getType()&&F.typeValidation(e,t,r,s),!v.isNullOrBlank(t.getRef()))return F.validate(e,L.getSchemaFromRef(e[0],r,t.getRef()),r,s);if((t.getOneOf()||t.getAllOf()||t.getAnyOf())&&U.validate(e,t,r,s),t.getNot()){let n=!1;try{F.validate(e,t.getNot(),r,s),n=!0}catch(e){n=!1}if(n)throw new M(F.path(e),"Schema validated value in not condition.")}return s}static constantValidation(e,t,r){if(!t.getConstant().equals(r))throw new M(F.path(e),"Expecting a constant value : "+r);return r}static enumCheck(e,t,r){let s=!1;for(let e of t.getEnums()??[])if(e===r){s=!0;break}if(s)return r;throw new M(F.path(e),"Value is not one of "+t.getEnums())}static typeValidation(e,t,r,s){let n=!1,i=[];for(const a of Array.from(t.getType()?.getAllowedSchemaTypes()?.values()??[]))try{G.validate(e,a,t,r,s),n=!0;break}catch(e){n=!1,i.push(e)}if(!n)throw new M(F.path(e),"Value "+JSON.stringify(s)+" is not of valid type(s)",i)}constructor(){}}var $={};t($,"KIRunConstants",(()=>Y));class Y{static NAMESPACE="namespace";static NAME="name";static ID="id";constructor(){}}var H={};t(H,"ExecutionException",(()=>W));class W extends Error{constructor(e,t){super(e),this.cause=t}getCause(){return this.cause}}var j={};t(j,"AbstractFunction",(()=>q));class q{validateArguments(e){return Array.from(this.getSignature().getParameters().entries()).map((t=>{let r,n=t[0],i=t[1],a=e.get(t[0]);if(c(a))return new s(n,F.validate(void 0,i.getSchema(),void 0,void 0));if(!i?.isVariableArgument())return new s(n,F.validate(void 0,i.getSchema(),void 0,a));Array.isArray(a)?r=a:(r=[],r.push(a));for(const e of r)F.validate(void 0,i.getSchema(),void 0,e);return new s(n,a)})).reduce(((e,t)=>(e.set(t.getT1(),t.getT2()),e)),new Map)}execute(e){return e.setArguments(this.validateArguments(e.getArguments()??new Map)),this.internalExecute(e)}getProbableEventSignature(e){return this.getSignature().getEvents()}}var X={};t(X,"KIRuntime",(()=>ht));class Q{constructor(e){this.expression=e}getExpression(){return this.expression}}class J{static OUTPUT="output";static ERROR="error";static ITERATION="iteration";static TRUE="true";static FALSE="false";static SCHEMA_NAME="Event";static SCHEMA=(new N).setNamespace(l.SYSTEM).setName(J.SCHEMA_NAME).setType(S.of(E.OBJECT)).setProperties(new Map([["name",N.ofString("name")],["parameters",N.ofObject("parameter").setAdditionalProperties((new g).setSchemaValue(N.SCHEMA))]]));constructor(e,t){this.name=e,this.parameters=t}getName(){return this.name}setName(e){return this.name=e,this}getParameters(){return this.parameters}setParameters(e){return this.parameters=e,this}static outputEventMapEntry(e){return J.eventMapEntry(J.OUTPUT,e)}static eventMapEntry(e,t){return[e,new J(e,t)]}}class K{constructor(e,t){this.name=e,this.result=t}getName(){return this.name}setName(e){return this.name=e,this}getResult(){return this.result}setResult(e){return this.result=e,this}static outputOf(e){return K.of(J.OUTPUT,e)}static of(e,t){return new K(e,t)}}class z{index=0;constructor(e){if(c(e))throw new y("Function output is generating null");Array.isArray(e)&&e.length&&e[0]instanceof K?this.fo=e:(this.fo=[],this.generator=e)}next(){if(!this.generator)return this.index<this.fo.length?this.fo[this.index++]:void 0;const e=this.generator.next();return e&&this.fo.push(e),e}allResults(){return this.fo}}let Z;var ee;(ee=Z||(Z={})).CONSTANT="CONSTANT",ee.EXPRESSION="EXPRESSION";class te{static SCHEMA_NAME="Parameter";static SCHEMA=(new N).setNamespace(l.SYSTEM).setName(te.SCHEMA_NAME).setProperties(new Map([["schema",N.SCHEMA],["parameterName",N.ofString("parameterName")],["variableArgument",N.of("variableArgument",E.BOOLEAN).setDefaultValue(!1)]]));static EXPRESSION=(new N).setNamespace(l.SYSTEM).setName("ParameterExpression").setType(S.of(E.OBJECT)).setProperties(new Map([["isExpression",N.ofBoolean("isExpression").setDefaultValue(!0)],["value",N.ofAny("value")]]));variableArgument=!1;type=Z.EXPRESSION;constructor(e,t){this.schema=t,this.parameterName=e}getSchema(){return this.schema}setSchema(e){return this.schema=e,this}getParameterName(){return this.parameterName}setParameterName(e){return this.parameterName=e,this}isVariableArgument(){return this.variableArgument}setVariableArgument(e){return this.variableArgument=e,this}getType(){return this.type}setType(e){return this.type=e,this}static ofEntry(e,t,r=!1,s=Z.EXPRESSION){return[e,new te(e,t).setType(s).setVariableArgument(r)]}static of(e,t,r=!1,s=Z.EXPRESSION){return new te(e,t).setType(s).setVariableArgument(r)}}let re;var se;(se=re||(re={})).VALUE="VALUE",se.EXPRESSION="EXPRESSION";var ne={};t(ne,"LinkedList",(()=>ie));class ie{head=void 0;tail=void 0;length=0;constructor(e){if(e?.length){for(const t of e)if(this.head){const e=new ae(t,this.tail);this.tail.next=e,this.tail=e}else this.tail=this.head=new ae(t);this.length=e.length}}push(e){const t=new ae(e,void 0,this.head);this.head?(this.head.previous=t,this.head=t):this.tail=this.head=t,this.length++}pop(){if(!this.head)throw Error("List is empty and cannot pop further.");const e=this.head.value;if(this.length--,this.head==this.tail)return this.head=this.tail=void 0,e;const t=this.head;return this.head=t.next,t.next=void 0,t.previous=void 0,this.head.previous=void 0,e}isEmpty(){return!this.length}size(){return this.length}get(e){if(e<0||e>=this.length)throw new Error(`${e} is out of bounds [0,${this.length}]`);let t=this.head;for(;e>0;)t=this.head.next,--e;return t.value}set(e,t){if(e<0||e>=this.length)throw new y(_.format("Index $ out of bound to set the value in linked list.",e));let r=this.head;for(;e>0;)r=this.head.next,--e;return r.value=t,this}toString(){let e=this.head,t="";for(;e;)t+=e.value,e=e.next,e&&(t+=", ");return`[${t}]`}toArray(){let e=[],t=this.head;for(;t;)e.push(t.value),t=t.next;return e}peek(){if(!this.head)throw new Error("List is empty so cannot peak");return this.head.value}peekLast(){if(!this.tail)throw new Error("List is empty so cannot peak");return this.tail.value}getFirst(){if(!this.head)throw new Error("List is empty so cannot get first");return this.head.value}removeFirst(){return this.pop()}removeLast(){if(!this.tail)throw new Error("List is empty so cannot remove");--this.length;const e=this.tail.value;if(0==this.length)this.head=this.tail=void 0;else{const e=this.tail.previous;e.next=void 0,this.tail.previous=void 0,this.tail=e}return e}addAll(e){return e&&e.length?(e.forEach(this.add.bind(this)),this):this}add(e){return++this.length,this.tail||this.head?this.head===this.tail?(this.tail=new ae(e,this.head),this.head.next=this.tail):(this.tail=new ae(e,this.tail),this.tail.previous.next=this.tail):this.head=this.tail=new ae(e),this}map(e,t){let r=new ie,s=this.head,n=0;for(;s;)r.add(e(s.value,n)),s=s.next,++n;return r}forEach(e,t){let r=this.head,s=0;for(;r;)e(r.value,s),r=r.next,++s}}class ae{constructor(e,t,r){this.value=e,this.next=r,this.previous=t}toString(){return""+this.value}}var oe={};t(oe,"ExpressionEvaluator",(()=>ze));class ue{constructor(e){this.str=e??""}append(e){return this.str+=e,this}toString(){return""+this.str}trim(){return this.str=this.str.trim(),this}setLength(e){return this.str=this.str.substring(0,e),this}length(){return this.str.length}charAt(e){return this.str.charAt(e)}deleteCharAt(e){return this.checkIndex(e),this.str=this.str.substring(0,e)+this.str.substring(e+1),this}insert(e,t){return this.str=this.str.substring(0,e)+t+this.str.substring(e),this}checkIndex(e){if(e>=this.str.length)throw new y(`Index ${e} is greater than or equal to ${this.str.length}`)}substring(e,t){return this.str.substring(e,t)}}var he={};t(he,"ExpressionEvaluationException",(()=>le));class le extends Error{constructor(e,t,r){super(_.format("$ : $",e,t)),this.cause=r}getCause(){return this.cause}}var pe={};t(pe,"Expression",(()=>Ee));var ce={};t(ce,"ExpressionToken",(()=>me));class me{constructor(e){this.expression=e}getExpression(){return this.expression}toString(){return this.expression}}var ge={};t(ge,"Operation",(()=>fe));class fe{static MULTIPLICATION=new fe("*");static DIVISION=new fe("/");static INTEGER_DIVISION=new fe("//");static MOD=new fe("%");static ADDITION=new fe("+");static SUBTRACTION=new fe("-");static NOT=new fe("not",void 0,!0);static AND=new fe("and",void 0,!0);static OR=new fe("or",void 0,!0);static LESS_THAN=new fe("<");static LESS_THAN_EQUAL=new fe("<=");static GREATER_THAN=new fe(">");static GREATER_THAN_EQUAL=new fe(">=");static EQUAL=new fe("=");static NOT_EQUAL=new fe("!=");static BITWISE_AND=new fe("&");static BITWISE_OR=new fe("|");static BITWISE_XOR=new fe("^");static BITWISE_COMPLEMENT=new fe("~");static BITWISE_LEFT_SHIFT=new fe("<<");static BITWISE_RIGHT_SHIFT=new fe(">>");static BITWISE_UNSIGNED_RIGHT_SHIFT=new fe(">>>");static UNARY_PLUS=new fe("UN: +","+");static UNARY_MINUS=new fe("UN: -","-");static UNARY_LOGICAL_NOT=new fe("UN: not","not");static UNARY_BITWISE_COMPLEMENT=new fe("UN: ~","~");static ARRAY_OPERATOR=new fe("[");static OBJECT_OPERATOR=new fe(".");static VALUE_OF=new Map([["MULTIPLICATION",fe.MULTIPLICATION],["DIVISION",fe.DIVISION],["INTEGER_DIVISON",fe.INTEGER_DIVISION],["MOD",fe.MOD],["ADDITION",fe.ADDITION],["SUBTRACTION",fe.SUBTRACTION],["NOT",fe.NOT],["AND",fe.AND],["OR",fe.OR],["LESS_THAN",fe.LESS_THAN],["LESS_THAN_EQUAL",fe.LESS_THAN_EQUAL],["GREATER_THAN",fe.GREATER_THAN],["GREATER_THAN_EQUAL",fe.GREATER_THAN_EQUAL],["EQUAL",fe.EQUAL],["NOT_EQUAL",fe.NOT_EQUAL],["BITWISE_AND",fe.BITWISE_AND],["BITWISE_OR",fe.BITWISE_OR],["BITWISE_XOR",fe.BITWISE_XOR],["BITWISE_COMPLEMENT",fe.BITWISE_COMPLEMENT],["BITWISE_LEFT_SHIFT",fe.BITWISE_LEFT_SHIFT],["BITWISE_RIGHT_SHIFT",fe.BITWISE_RIGHT_SHIFT],["BITWISE_UNSIGNED_RIGHT_SHIFT",fe.BITWISE_UNSIGNED_RIGHT_SHIFT],["UNARY_PLUS",fe.UNARY_PLUS],["UNARY_MINUS",fe.UNARY_MINUS],["UNARY_LOGICAL_NOT",fe.UNARY_LOGICAL_NOT],["UNARY_BITWISE_COMPLEMENT",fe.UNARY_BITWISE_COMPLEMENT],["ARRAY_OPERATOR",fe.ARRAY_OPERATOR],["OBJECT_OPERATOR",fe.OBJECT_OPERATOR]]);static UNARY_OPERATORS=new Set([fe.ADDITION,fe.SUBTRACTION,fe.NOT,fe.BITWISE_COMPLEMENT,fe.UNARY_PLUS,fe.UNARY_MINUS,fe.UNARY_LOGICAL_NOT,fe.UNARY_BITWISE_COMPLEMENT]);static ARITHMETIC_OPERATORS=new Set([fe.MULTIPLICATION,fe.DIVISION,fe.INTEGER_DIVISION,fe.MOD,fe.ADDITION,fe.SUBTRACTION]);static LOGICAL_OPERATORS=new Set([fe.NOT,fe.AND,fe.OR,fe.LESS_THAN,fe.LESS_THAN_EQUAL,fe.GREATER_THAN,fe.GREATER_THAN_EQUAL,fe.EQUAL,fe.NOT_EQUAL]);static BITWISE_OPERATORS=new Set([fe.BITWISE_AND,fe.BITWISE_COMPLEMENT,fe.BITWISE_LEFT_SHIFT,fe.BITWISE_OR,fe.BITWISE_RIGHT_SHIFT,fe.BITWISE_UNSIGNED_RIGHT_SHIFT,fe.BITWISE_XOR]);static OPERATOR_PRIORITY=new Map([[fe.UNARY_PLUS,1],[fe.UNARY_MINUS,1],[fe.UNARY_LOGICAL_NOT,1],[fe.UNARY_BITWISE_COMPLEMENT,1],[fe.ARRAY_OPERATOR,1],[fe.OBJECT_OPERATOR,1],[fe.MULTIPLICATION,2],[fe.DIVISION,2],[fe.INTEGER_DIVISION,2],[fe.MOD,2],[fe.ADDITION,3],[fe.SUBTRACTION,3],[fe.BITWISE_LEFT_SHIFT,4],[fe.BITWISE_RIGHT_SHIFT,4],[fe.BITWISE_UNSIGNED_RIGHT_SHIFT,4],[fe.LESS_THAN,5],[fe.LESS_THAN_EQUAL,5],[fe.GREATER_THAN,5],[fe.GREATER_THAN_EQUAL,5],[fe.EQUAL,6],[fe.NOT_EQUAL,6],[fe.BITWISE_AND,7],[fe.BITWISE_XOR,8],[fe.BITWISE_OR,9],[fe.AND,10],[fe.OR,11]]);static OPERATORS=new Set([...Array.from(fe.ARITHMETIC_OPERATORS),...Array.from(fe.LOGICAL_OPERATORS),...Array.from(fe.BITWISE_OPERATORS),fe.ARRAY_OPERATOR,fe.OBJECT_OPERATOR].map((e=>e.getOperator())));static OPERATORS_WITHOUT_SPACE_WRAP=new Set([...Array.from(fe.ARITHMETIC_OPERATORS),...Array.from(fe.LOGICAL_OPERATORS),...Array.from(fe.BITWISE_OPERATORS),fe.ARRAY_OPERATOR,fe.OBJECT_OPERATOR].filter((e=>!e.shouldBeWrappedInSpace())).map((e=>e.getOperator())));static OPERATION_VALUE_OF=new Map(Array.from(fe.VALUE_OF.entries()).map((([e,t])=>[t.getOperator(),t])));static UNARY_MAP=new Map([[fe.ADDITION,fe.UNARY_PLUS],[fe.SUBTRACTION,fe.UNARY_MINUS],[fe.NOT,fe.UNARY_LOGICAL_NOT],[fe.BITWISE_COMPLEMENT,fe.UNARY_BITWISE_COMPLEMENT],[fe.UNARY_PLUS,fe.UNARY_PLUS],[fe.UNARY_MINUS,fe.UNARY_MINUS],[fe.UNARY_LOGICAL_NOT,fe.UNARY_LOGICAL_NOT],[fe.UNARY_BITWISE_COMPLEMENT,fe.UNARY_BITWISE_COMPLEMENT]]);static BIGGEST_OPERATOR_SIZE=Array.from(fe.VALUE_OF.values()).map((e=>e.getOperator())).filter((e=>!e.startsWith("UN: "))).map((e=>e.length)).reduce(((e,t)=>e>t?e:t),0);constructor(e,t,r=!1){this.operator=e,this.operatorName=t??e,this._shouldBeWrappedInSpace=r}getOperator(){return this.operator}getOperatorName(){return this.operatorName}shouldBeWrappedInSpace(){return this._shouldBeWrappedInSpace}valueOf(e){return fe.VALUE_OF.get(e)}toString(){return this.operator}}class Ee extends me{tokens=new ie;ops=new ie;constructor(e,t,r,s){super(e||""),t&&this.tokens.push(t),r&&this.tokens.push(r),s&&this.ops.push(s),this.evaluate()}getTokens(){return this.tokens}getOperations(){return this.ops}evaluate(){const e=this.expression.length;let t,r="",s=new ue(""),n=0,i=!1;for(;n<e;){switch(r=this.expression[n],t=s.toString(),r){case" ":i=this.processTokenSepearator(s,t,i);break;case"(":n=this.processSubExpression(e,s,t,n,i),i=!1;break;case")":throw new le(this.expression,"Extra closing parenthesis found");case"]":throw new le(this.expression,"Extra closing square bracket found");default:let a=this.processOthers(r,e,s,t,n,i);n=a.getT1(),i=a.getT2(),i&&this.ops.peek()==fe.ARRAY_OPERATOR&&(a=this.process(e,s,n),n=a.getT1(),i=a.getT2())}++n}if(t=s.toString(),!v.isNullOrBlank(t)){if(fe.OPERATORS.has(t))throw new le(this.expression,"Expression is ending with an operator");this.tokens.push(new me(t))}}process(e,t,r){let n=1;for(++r;r<e&&0!=n;){let e=this.expression.charAt(r);"]"==e?--n:"["==e&&++n,0!=n&&(t.append(e),r++)}return this.tokens.push(new Ee(t.toString())),t.setLength(0),new s(r,!1)}processOthers(e,t,r,n,i,a){let o=t-i;o=o<fe.BIGGEST_OPERATOR_SIZE?o:fe.BIGGEST_OPERATOR_SIZE;for(let e=o;e>0;e--){let t=this.expression.substring(i,i+e);if(fe.OPERATORS_WITHOUT_SPACE_WRAP.has(t))return v.isNullOrBlank(n)||(this.tokens.push(new me(n)),a=!1),this.checkUnaryOperator(this.tokens,this.ops,fe.OPERATION_VALUE_OF.get(t),a),a=!0,r.setLength(0),new s(i+e-1,a)}return r.append(e),new s(i,!1)}processSubExpression(e,t,r,s,n){if(fe.OPERATORS.has(r))this.checkUnaryOperator(this.tokens,this.ops,fe.OPERATION_VALUE_OF.get(r),n),t.setLength(0);else if(!v.isNullOrBlank(r))throw new le(this.expression,_.format("Unkown token : $ found.",r));let i=1;const a=new ue;let o=this.expression.charAt(s);for(s++;s<e&&i>0;)o=this.expression.charAt(s),"("==o?i++:")"==o&&i--,0!=i&&(a.append(o),s++);if(")"!=o)throw new le(this.expression,"Missing a closed parenthesis");for(;a.length()>2&&"("==a.charAt(0)&&")"==a.charAt(a.length()-1);)a.deleteCharAt(0),a.setLength(a.length()-1);return this.tokens.push(new Ee(a.toString().trim())),s}processTokenSepearator(e,t,r){return v.isNullOrBlank(t)||(fe.OPERATORS.has(t)?(this.checkUnaryOperator(this.tokens,this.ops,fe.OPERATION_VALUE_OF.get(t),r),r=!0):(this.tokens.push(new me(t)),r=!1)),e.setLength(0),r}checkUnaryOperator(e,t,r,s){if(r)if(s||e.isEmpty()){if(!fe.UNARY_OPERATORS.has(r))throw new le(this.expression,_.format("Extra operator $ found.",r));{const e=fe.UNARY_MAP.get(r);e&&t.push(e)}}else{for(;!t.isEmpty()&&this.hasPrecedence(r,t.peek());){let r=t.pop();if(fe.UNARY_OPERATORS.has(r)){let t=e.pop();e.push(new Ee("",t,void 0,r))}else{let t=e.pop(),s=e.pop();e.push(new Ee("",s,t,r))}}t.push(r)}}hasPrecedence(e,t){let r=fe.OPERATOR_PRIORITY.get(e),s=fe.OPERATOR_PRIORITY.get(t);if(!r||!s)throw new Error("Unknown operators provided");return s<r}toString(){if(this.ops.isEmpty())return 1==this.tokens.size()?this.tokens.get(0).toString():"Error: No tokens";let e=new ue,t=0;const r=this.ops.toArray(),s=this.tokens.toArray();for(let n=0;n<r.length;n++)if(r[n].getOperator().startsWith("UN: "))e.append("(").append(r[n].getOperator().substring(4)).append(s[t]instanceof Ee?s[t].toString():s[t]).append(")"),t++;else{if(0==t){const r=s[t++];e.insert(0,r.toString())}const i=s[t++];e.insert(0,r[n].getOperator()).insert(0,i.toString()).insert(0,"(").append(")")}return e.toString()}equals(e){return this.expression==e.expression}}var Te={};t(Te,"ExpressionTokenValue",(()=>Ae));class Ae extends me{constructor(e,t){super(e),this.element=t}getTokenValue(){return this.element}getElement(){return this.element}toString(){return _.format("$: $",this.expression,this.element)}}class de{nullCheck(e,t,r){if(c(e)||c(t))throw new W(_.format("$ cannot be applied to a null value",r.getOperatorName()))}}class Oe extends de{apply(e,t){return this.nullCheck(e,t,fe.ADDITION),e+t}}class Se extends de{apply(e,t){return this.nullCheck(e,t,fe.DIVISION),e/t}}class Ne extends de{apply(e,t){return this.nullCheck(e,t,fe.DIVISION),Math.floor(e/t)}}class Ie extends de{apply(e,t){return this.nullCheck(e,t,fe.MOD),e%t}}class Re extends de{apply(e,t){return this.nullCheck(e,t,fe.MULTIPLICATION),e*t}}class we extends de{apply(e,t){return this.nullCheck(e,t,fe.SUBTRACTION),e-t}}class ye extends de{apply(e,t){if(!e)throw new W("Cannot apply array operator on a null value");if(!t)throw new W("Cannot retrive null index value");if(!Array.isArray(e)&&"string"!=typeof e)throw new W(_.format("Cannot retrieve value from a primitive value $",e));if(t>=e.length)throw new W(_.format("Cannot retrieve index $ from the array of length $",t,e.length));return e[t]}}class xe extends de{apply(e,t){return this.nullCheck(e,t,fe.BITWISE_AND),e&t}}class _e extends de{apply(e,t){return this.nullCheck(e,t,fe.BITWISE_LEFT_SHIFT),e<<t}}class ve extends de{apply(e,t){return this.nullCheck(e,t,fe.BITWISE_OR),e|t}}class Pe extends de{apply(e,t){return this.nullCheck(e,t,fe.BITWISE_RIGHT_SHIFT),e>>t}}class Me extends de{apply(e,t){return this.nullCheck(e,t,fe.BITWISE_UNSIGNED_RIGHT_SHIFT),e>>>t}}class Le extends de{apply(e,t){return this.nullCheck(e,t,fe.BITWISE_XOR),e^t}}class Ue{static findPrimitiveNullAsBoolean(e){if(!e)return new s(E.BOOLEAN,!1);let t=typeof e;if("object"===t)throw new W(_.format("$ is not a primitive type",e));let r=e;return"boolean"===t?new s(E.BOOLEAN,r):"string"===t?new s(E.STRING,r):Ue.findPrimitiveNumberType(r)}static findPrimitive(e){if(c(e))return new s(E.NULL,void 0);let t=typeof e;if("object"===t)throw new W(_.format("$ is not a primitive type",e));let r=e;return"boolean"===t?new s(E.BOOLEAN,r):"string"===t?new s(E.STRING,r):Ue.findPrimitiveNumberType(r)}static findPrimitiveNumberType(e){if(c(e)||Array.isArray(e)||"object"==typeof e)throw new W(_.format("Unable to convert $ to a number.",e));let t=e;try{let e=t;return Number.isInteger(e)?new s(E.LONG,e):new s(E.DOUBLE,e)}catch(e){throw new W(_.format("Unable to convert $ to a number.",t),e)}}static compare(e,t){if(e==t)return 0;if(c(e)||c(t))return c(e)?-1:1;if(Array.isArray(e)||Array.isArray(t)){if(Array.isArray(e)&&Array.isArray(t)){if(e.length!=t.length)return e.length-t.length;for(let r=0;r<e.length;r++){let s=this.compare(e[r],t[r]);if(0!=s)return s}return 0}return Array.isArray(e)?-1:1}const r=typeof e,s=typeof t;return"object"===r||"object"===s?("object"===r&&"object"===s&&Object.keys(e).forEach((r=>{let s=this.compare(e[r],t[r]);if(0!=s)return s})),"object"===r?-1:1):this.comparePrimitive(e,t)}static comparePrimitive(e,t){return c(e)||c(t)?c(e)&&c(t)?0:c(e)?-1:1:e==t?0:"boolean"==typeof e||"boolean"==typeof t?e?-1:1:"string"==typeof e||"string"==typeof t?e+""<t+""?-1:1:"number"==typeof e||"number"==typeof t?e-t:0}static baseNumberType(e){return Number.isInteger(e)?E.LONG:E.DOUBLE}static toPrimitiveType(e){return e}constructor(){}}class Ce extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);if(r.getT1()!=E.BOOLEAN)throw new W(_.format("Boolean value expected but found $",r.getT2()));if(s.getT1()!=E.BOOLEAN)throw new W(_.format("Boolean value expected but found $",s.getT2()));return r.getT2()&&s.getT2()}}class Be extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);return r.getT2()==s.getT2()}}class Ve extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);if(r.getT1()==E.BOOLEAN||s.getT1()==E.BOOLEAN)throw new W(_.format("Cannot compare >= with the values $ and $",r.getT2(),s.getT2()));return r.getT2()>=s.getT2()}}class be extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);if(r.getT1()==E.BOOLEAN||s.getT1()==E.BOOLEAN)throw new W(_.format("Cannot compare > with the values $ and $",r.getT2(),s.getT2()));return r.getT2()>s.getT2()}}class De extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);if(r.getT1()==E.BOOLEAN||s.getT1()==E.BOOLEAN)throw new W(_.format("Cannot compare <= with the values $ and $",r.getT2(),s.getT2()));return r.getT2()<=s.getT2()}}class ke extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);if(r.getT1()==E.BOOLEAN||s.getT1()==E.BOOLEAN)throw new W(_.format("Cannot compare < with the values $ and $",r.getT2(),s.getT2()));return r.getT2()<s.getT2()}}class Ge extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);return r.getT2()!=s.getT2()}}class Fe extends de{apply(e,t){const r=Ue.findPrimitiveNullAsBoolean(e),s=Ue.findPrimitiveNullAsBoolean(t);if(r.getT1()!=E.BOOLEAN)throw new W(_.format("Boolean value expected but found $",r.getT2()));if(s.getT1()!=E.BOOLEAN)throw new W(_.format("Boolean value expected but found $",s.getT2()));return r.getT2()||s.getT2()}}class $e extends de{apply(e,t){if(!e)throw new W("Cannot apply array operator on a null value");if(!t)throw new W("Cannot retrive null property value");const r=typeof e;if(!Array.isArray(e)&&"string"!=r&&"object"!=r)throw new W(_.format("Cannot retrieve value from a primitive value $",e));return e[t]}}class Ye{nullCheck(e,t){if(c(e))throw new W(_.format("$ cannot be applied to a null value",t.getOperatorName()))}}class He extends Ye{apply(e){return this.nullCheck(e,fe.UNARY_MINUS),Ue.findPrimitiveNumberType(e),-e}}class We extends Ye{apply(e){return this.nullCheck(e,fe.UNARY_PLUS),Ue.findPrimitiveNumberType(e),e}}class je extends Ye{apply(e){this.nullCheck(e,fe.UNARY_BITWISE_COMPLEMENT);let t=Ue.findPrimitiveNumberType(e);if(t.getT1()!=E.INTEGER&&t.getT1()!=E.LONG)throw new W(_.format("Unable to apply bitwise operator on $",e));return~e}}class qe extends Ye{apply(e){if(this.nullCheck(e,fe.UNARY_LOGICAL_NOT),Ue.findPrimitiveNumberType(e).getT1()!=E.BOOLEAN)throw new W(_.format("Unable to apply bitwise operator on $",e));return!e}}var Xe={};t(Xe,"TokenValueExtractor",(()=>Qe));class Qe{static REGEX_SQUARE_BRACKETS=/[\[\]]/;static REGEX_DOT=/\./;getValue(e){let t=this.getPrefix();if(!e.startsWith(t))throw new y(_.format("Token $ doesn't start with $",e,t));return this.getValueInternal(e)}retrieveElementFrom(e,t,r,s){if(c(s))return;if(t.length==r)return s;let n=t[r].split(Qe.REGEX_SQUARE_BRACKETS).map((e=>e.trim())).filter((e=>!v.isNullOrBlank(e))).reduce(((s,n,i)=>this.resolveForEachPartOfTokenWithBrackets(e,t,r,n,s,i)),s);return this.retrieveElementFrom(e,t,r+1,n)}resolveForEachPartOfTokenWithBrackets(e,t,r,s,n,i){if(!c(n)){if(0===i){if(Array.isArray(n)){if("length"===s)return n.length;try{let e=parseInt(s);if(isNaN(e))throw new Error(_.format("$ is not a number",e));if(e>=n.length)return;return n[e]}catch(t){throw new le(e,_.format("$ couldn't be parsed into integer in $",s,e),t)}}return this.checkIfObject(e,t,r,n),n[s]}if(s?.startsWith('"')){if(!s.endsWith('"')||1==s.length||2==s.length)throw new le(e,_.format("$ is missing a double quote or empty key found",e));return this.checkIfObject(e,t,r,n),n[s.substring(1,s.length-1)]}try{let t=parseInt(s);if(isNaN(t))throw new Error(_.format("$ is not a number",t));if(!Array.isArray(n))throw new le(e,_.format("Expecting an array with index $ while processing the expression",t,e));if(t>=n.length)return;return n[t]}catch(t){throw new le(e,_.format("$ couldn't be parsed into integer in $",s,e),t)}}}checkIfObject(e,t,r,s){if("object"!=typeof s||Array.isArray(s))throw new le(e,_.format("Unable to retrive $ from $ in the path $",t[r],s.toString(),e))}}const Je=new Map([["true",!0],["false",!1],["null",void 0]]);class Ke extends Qe{static INSTANCE=new Ke;getValueInternal(e){if(!v.isNullOrBlank(e))return e=e.trim(),Je.has(e)?Je.get(e):e.startsWith('"')?this.processString(e):this.processNumbers(e)}processNumbers(e){try{let t;if(t=-1==e.indexOf(".")?parseInt(e):parseFloat(e),isNaN(t))throw new Error("Parse number error");return t}catch(t){throw new le(e,_.format("Unable to parse the literal or expression $",e),t)}}processString(e){if(!e.endsWith('"'))throw new le(e,_.format("String literal $ is not closed properly",e));return e.substring(1,e.length-1)}getPrefix(){return""}}class ze{static UNARY_OPERATORS_MAP=new Map([[fe.UNARY_BITWISE_COMPLEMENT,new je],[fe.UNARY_LOGICAL_NOT,new qe],[fe.UNARY_MINUS,new He],[fe.UNARY_PLUS,new We]]);static BINARY_OPERATORS_MAP=new Map([[fe.ADDITION,new Oe],[fe.DIVISION,new Se],[fe.INTEGER_DIVISION,new Ne],[fe.MOD,new Ie],[fe.MULTIPLICATION,new Re],[fe.SUBTRACTION,new we],[fe.BITWISE_AND,new xe],[fe.BITWISE_LEFT_SHIFT,new _e],[fe.BITWISE_OR,new ve],[fe.BITWISE_RIGHT_SHIFT,new Pe],[fe.BITWISE_UNSIGNED_RIGHT_SHIFT,new Me],[fe.BITWISE_XOR,new Le],[fe.AND,new Ce],[fe.EQUAL,new Be],[fe.GREATER_THAN,new be],[fe.GREATER_THAN_EQUAL,new Ve],[fe.LESS_THAN,new ke],[fe.LESS_THAN_EQUAL,new De],[fe.OR,new Fe],[fe.NOT_EQUAL,new Ge],[fe.ARRAY_OPERATOR,new ye],[fe.OBJECT_OPERATOR,new $e]]);static UNARY_OPERATORS_MAP_KEY_SET=new Set(ze.UNARY_OPERATORS_MAP.keys());constructor(e){e instanceof Ee?(this.exp=e,this.expression=this.exp.getExpression()):this.expression=e}evaluate(e){return this.exp||(this.exp=new Ee(this.expression)),this.evaluateExpression(this.exp,e)}getExpression(){return this.exp||(this.exp=new Ee(this.expression)),this.exp}getExpressionString(){return this.expression}evaluateExpression(e,t){let r=e.getOperations(),s=e.getTokens();for(;!r.isEmpty();){let e=r.pop(),a=s.pop();if(ze.UNARY_OPERATORS_MAP_KEY_SET.has(e))s.push(this.applyUnaryOperation(e,this.getValueFromToken(t,a)));else if(e==fe.OBJECT_OPERATOR||e==fe.ARRAY_OPERATOR)this.processObjectOrArrayOperator(t,r,s,e,a);else{const r=s.pop();var n=this.getValueFromToken(t,r),i=this.getValueFromToken(t,a);s.push(this.applyBinaryOperation(e,n,i))}}if(s.isEmpty())throw new W(_.format("Expression : $ evaluated to null",e));if(1!=s.size())throw new W(_.format("Expression : $ evaluated multiple values $",e,s));const a=s.get(0);if(a instanceof Ae)return a.getElement();if(!(a instanceof Ee))return this.getValueFromToken(t,a);throw new W(_.format("Expression : $ evaluated to $",e,s.get(0)))}processObjectOrArrayOperator(e,t,r,s,n){const i=new ie,a=new ie;if(!s||!n)return;do{a.push(s),n instanceof Ee?i.push(new Ae(n.toString(),this.evaluateExpression(n,e))):n&&i.push(n),n=r.isEmpty()?void 0:r.pop(),s=t.isEmpty()?void 0:t.pop()}while(s==fe.OBJECT_OPERATOR||s==fe.ARRAY_OPERATOR);n&&(n instanceof Ee?i.push(new Ae(n.toString(),this.evaluateExpression(n,e))):i.push(n)),s&&t.push(s);let o=i.pop(),u=new ue(o instanceof Ae?o.getTokenValue():o.toString());for(;!i.isEmpty();)o=i.pop(),s=a.pop(),u.append(s.getOperator()).append(o instanceof Ae?o.getTokenValue():o.toString()),s==fe.ARRAY_OPERATOR&&u.append("]");let h=u.toString(),l=h.substring(0,h.indexOf(".")+1);if(l.length>2&&e.has(l))r.push(new Ae(h,this.getValue(h,e)));else{let e;try{e=Ke.INSTANCE.getValue(h)}catch(t){e=h}r.push(new Ae(h,e))}}applyBinaryOperation(e,t,r){if("object"===typeof t||"object"===typeof r||Array.isArray(t)||Array.isArray(r))throw new le(this.expression,_.format("Cannot evaluate expression $ $ $",t,e.getOperator(),r));let s=ze.BINARY_OPERATORS_MAP.get(e);if(!s)throw new le(this.expression,_.format("No operator found to evaluate $ $ $",t,e.getOperator(),r));return new Ae(e.toString(),s.apply(t,r))}applyUnaryOperation(e,t){if("object"===typeof t||Array.isArray(t))throw new le(this.expression,_.format("The operator $ cannot be applied to $",e.getOperator(),t));let r=ze.UNARY_OPERATORS_MAP.get(e);if(!r)throw new le(this.expression,_.format("No Unary operator $ is found to apply on $",e.getOperator(),t));return new Ae(e.toString(),r.apply(t))}getValueFromToken(e,t){return t instanceof Ee?this.evaluateExpression(t,e):t instanceof Ae?t.getElement():this.getValue(t.getExpression(),e)}getValue(e,t){if(e.length<=5)return Ke.INSTANCE.getValue(e);const r=e.substring(0,e.indexOf(".")+1);return(t.get(r)??Ke.INSTANCE).getValue(e)}}class Ze extends Qe{static PREFIX="Arguments.";constructor(e){super(),this.args=e}getValueInternal(e){let t=e.split(Qe.REGEX_DOT);return this.retrieveElementFrom(e,t,2,this.args.get(t[1]))}getPrefix(){return Ze.PREFIX}}class et extends Qe{static PREFIX="Context.";constructor(e){super(),this.context=e}getValueInternal(e){let t=e.split(Qe.REGEX_DOT),r=t[1],s=r.indexOf("["),n=2;return-1!=s&&(r=t[1].substring(0,s),t[1]=t[1].substring(s),n=1),this.retrieveElementFrom(e,t,n,this.context.get(r)?.getElement())}getPrefix(){return et.PREFIX}}class tt extends Qe{static PREFIX="Steps.";constructor(e){super(),this.output=e}getValueInternal(e){let t=e.split(Qe.REGEX_DOT),r=1,s=this.output.get(t[r++]);if(!s||r>=t.length)return;let n=s.get(t[r++]);if(!n||r>=t.length)return;let i=n.get(t[r++]);return this.retrieveElementFrom(e,t,r,i)}getPrefix(){return tt.PREFIX}}class rt{count=0;valueExtractors=new Map;getContext(){return this.context}setContext(e){this.context=e;let t=new et(e);return this.valueExtractors.set(t.getPrefix(),t),this}getArguments(){return this.args}setArguments(e){this.args=e;let t=new Ze(e);return this.valueExtractors.set(t.getPrefix(),t),this}getEvents(){return this.events}setEvents(e){return this.events=e,this}getStatementExecution(){return this.statementExecution}setStatementExecution(e){return this.statementExecution=e,this}getSteps(){return this.steps}setSteps(e){this.steps=e;let t=new tt(e);return this.valueExtractors.set(t.getPrefix(),t),this}getCount(){return this.count}setCount(e){return this.count=e,this}getValuesMap(){return this.valueExtractors}}class st{outVertices=new Map;inVertices=new Set;constructor(e,t){this.data=t,this.graph=e}getData(){return this.data}setData(e){return this.data=e,this}getOutVertices(){return this.outVertices}setOutVertices(e){return this.outVertices=e,this}getInVertices(){return this.inVertices}setInVertices(e){return this.inVertices=e,this}getGraph(){return this.graph}setGraph(e){return this.graph=e,this}getKey(){return this.data.getUniqueKey()}addOutEdgeTo(e,t){return this.outVertices.has(e)||this.outVertices.set(e,new Set),this.outVertices.get(e).add(t),t.inVertices.add(new s(this,e)),t}addInEdgeTo(e,t){return this.inVertices.add(new s(e,t)),e.outVertices.has(t)||e.outVertices.set(t,new Set),e.outVertices.get(t).add(this),e}hasIncomingEdges(){return!!this.inVertices.size}hasOutgoingEdges(){return!!this.outVertices.size}getSubGraphOfType(e){let t=new nt(!0);var r=new ie(Array.from(this.outVertices.get(e)??[]));for(r.map((e=>e.getData())).forEach((e=>t.addVertex(e)));!r.isEmpty();){var s=r.pop();Array.from(s.outVertices.values()).flatMap((e=>Array.from(e))).forEach((e=>{t.addVertex(e.getData()),r.add(e)}))}return t}toString(){var e=Array.from(this.getInVertices()).map((e=>e.getT1().getKey()+"("+e.getT2()+")")).join(", "),t=Array.from(this.outVertices.entries()).map((([e,t])=>e+": "+Array.from(t).map((e=>e.getKey())).join(","))).join("\n\t\t");return this.getKey()+":\n\tIn: "+e+"\n\tOut: \n\t\t"+t}}class nt{nodeMap=new Map;constructor(e=!1){this.isSubGrph=e}getVerticesData(){return Array.from(this.nodeMap.values()).map((e=>e.getData()))}addVertex(e){if(!this.nodeMap.has(e.getUniqueKey())){let t=new st(this,e);this.nodeMap.set(e.getUniqueKey(),t)}return this.nodeMap.get(e.getUniqueKey())}getVertex(e){return this.nodeMap.get(e)}getVertexData(e){if(this.nodeMap.has(e))return this.nodeMap.get(e).getData()}getVerticesWithNoIncomingEdges(){return Array.from(this.nodeMap.values()).filter((e=>!e.hasIncomingEdges()))}isCyclic(){let e,t=new ie(this.getVerticesWithNoIncomingEdges()),r=new Set;for(;!t.isEmpty();){if(r.has(t.getFirst().getKey()))return!0;e=t.removeFirst(),r.add(e.getKey()),e.hasOutgoingEdges()&&t.addAll(Array.from(e.getOutVertices().values()).flatMap((e=>Array.from(e))))}return!1}addVertices(e){for(const t of e)this.addVertex(t)}getNodeMap(){return this.nodeMap}isSubGraph(){return this.isSubGrph}toString(){return"Execution Graph : \n"+Array.from(this.nodeMap.values()).map((e=>e.toString())).join("\n")}}class it{constructor(e,t){this.message=t,this.messageType=e}getMessageType(){return this.messageType}setMessageType(e){return this.messageType=e,this}getMessage(){return this.message}setMessage(e){return this.message=e,this}toString(){return`${this.messageType} : ${this.message}`}}class at{messages=new Array;dependencies=new Set;constructor(e){this.statement=e}getStatement(){return this.statement}setStatement(e){return this.statement=e,this}getMessages(){return this.messages}setMessages(e){return this.messages=e,this}getDependencies(){return this.dependencies}setDependencies(e){return this.dependencies=e,this}getUniqueKey(){return this.statement.getStatementName()}addMessage(e,t){this.messages.push(new it(e,t))}addDependency(e){this.dependencies.add(e)}getDepenedencies(){return this.dependencies}equals(e){if(!(e instanceof at))return!1;return e.statement.equals(this.statement)}}let ot;var ut;(ut=ot||(ot={})).ERROR="ERROR",ut.WARNING="WARNING",ut.MESSAGE="MESSAGE";class ht extends q{static PARAMETER_NEEDS_A_VALUE='Parameter "$" needs a value';static STEP_REGEX_PATTERN=new RegExp("Steps\\.([a-zA-Z0-9\\\\-]{1,})\\.([a-zA-Z0-9\\\\-]{1,})","g");static VERSION=1;static MAX_EXECUTION_ITERATIONS=1e7;constructor(e,t,r){if(super(),this.fd=e,this.fd.getVersion()>ht.VERSION)throw new y("Runtime is at a lower version "+ht.VERSION+" and trying to run code from version "+this.fd.getVersion()+".");this.fRepo=t,this.sRepo=r}getSignature(){return this.fd}getExecutionPlan(e){let t=new nt;for(let r of Array.from(this.fd.getSteps().values()))t.addVertex(this.prepareStatementExecution(e,r));let r=this.makeEdges(t);if(r.length)throw new y(_.format("Found these unresolved dependencies : $ ",r.map((e=>_.format("Steps.$.$",e.getT1(),e.getT2())))));return t}internalExecute(e){e.getContext()||e.setContext(new Map),e.getEvents()||e.setEvents(new Map),e.getSteps()||e.setSteps(new Map);let t=this.getExecutionPlan(e.getContext()),r=t.getVerticesData().filter((e=>e.getMessages().length)).map((e=>e.getStatement().getStatementName()+": \n"+e.getMessages().join(",")));if(r?.length)throw new y("Please fix the errors in the function definition before execution : \n"+r.join(",\n"));return this.executeGraph(t,e)}executeGraph(e,t){let r=new ie;r.addAll(e.getVerticesWithNoIncomingEdges());let s=new ie;for(;!(r.isEmpty()&&s.isEmpty()||t.getEvents()?.has(J.OUTPUT));)if(this.processBranchQue(t,r,s),this.processExecutionQue(t,r,s),t.setCount(t.getCount()+1),t.getCount()==ht.MAX_EXECUTION_ITERATIONS)throw new y("Execution locked in an infinite loop");if(!e.isSubGraph()&&!t.getEvents()?.size)throw new y("No events raised");return new z(Array.from(t.getEvents()?.entries()??[]).flatMap((e=>e[1].map((t=>K.of(e[0],t))))))}processExecutionQue(e,t,r){if(!t.isEmpty()){let s=t.pop();this.allDependenciesResolvedVertex(s,e.getSteps())?this.executeVertex(s,e,r,t):t.add(s)}}processBranchQue(e,t,r){if(r.length){let s=r.pop();this.allDependenciesResolvedTuples(s.getT2(),e.getSteps())?this.executeBranch(e,t,s):r.add(s)}}executeBranch(e,t,r){let s,n=r.getT4();do{this.executeGraph(r.getT1(),e),s=r.getT3().next(),s&&(e.getSteps()?.has(n.getData().getStatement().getStatementName())||e.getSteps()?.set(n.getData().getStatement().getStatementName(),new Map),e.getSteps()?.get(n.getData().getStatement().getStatementName())?.set(s.getName(),this.resolveInternalExpressions(s.getResult(),e)))}while(s&&s.getName()!=J.OUTPUT);s?.getName()==J.OUTPUT&&n.getOutVertices().has(J.OUTPUT)&&(n?.getOutVertices()?.get(J.OUTPUT)??[]).forEach((e=>t.add(e)))}executeVertex(e,t,r,s){let n=e.getData().getStatement(),a=this.fRepo.find(n.getNamespace(),n.getName());if(!a)throw new y(_.format("$.$ function is not found.",n.getNamespace(),n.getName()));let o=a?.getSignature().getParameters(),u=this.getArgumentsFromParametersMap(t,n,o??new Map),h=t.getContext(),l=a.execute((new rt).setContext(h).setArguments(u).setEvents(t.getEvents()).setSteps(t.getSteps()).setStatementExecution(e.getData()).setCount(t.getCount())),p=l.next();if(!p)throw new y(_.format("Executing $ returned no events",n.getStatementName()));let c=p.getName()==J.OUTPUT;if(t.getSteps()?.has(n.getStatementName())||t.getSteps().set(n.getStatementName(),new Map),t.getSteps().get(n.getStatementName()).set(p.getName(),this.resolveInternalExpressions(p.getResult(),t)),c){let t=e.getOutVertices().get(J.OUTPUT);t&&t.forEach((e=>s.add(e)))}else{let t=e.getSubGraphOfType(p.getName()),s=this.makeEdges(t);r.push(new i(t,s,l,e))}}resolveInternalExpressions(e,t){return e?Array.from(e.entries()).map((e=>new s(e[0],this.resolveInternalExpression(e[1],t)))).reduce(((e,t)=>(e.set(t.getT1(),t.getT2()),e)),new Map):e}resolveInternalExpression(e,t){if(c(e)||"object"!=typeof e)return e;if(e instanceof Q){return new ze(e.getExpression()).evaluate(t.getValuesMap())}if(Array.isArray(e)){let r=[];for(let s of e)r.push(this.resolveInternalExpression(s,t));return r}if("object"==typeof e){let r={};for(let s of Object.entries(e))r[s[0]]=this.resolveInternalExpression(s[1],t);return r}}allDependenciesResolvedTuples(e,t){for(let r of e){if(!t.has(r.getT1()))return!1;if(!t.get(r.getT1())?.get(r.getT2()))return!1}return!0}allDependenciesResolvedVertex(e,t){return!e.getInVertices().size||0==Array.from(e.getInVertices()).filter((e=>{let r=e.getT1().getData().getStatement().getStatementName(),s=e.getT2();return!(t.has(r)&&t.get(r)?.has(s))})).length}getArgumentsFromParametersMap(e,t,r){return Array.from(t.getParameterMap().entries()).map((t=>{let n,i=t[1];if(!i?.length)return new s(t[0],n);let a=r.get(t[0]);return a?(n=a.isVariableArgument()?i.map((t=>this.parameterReferenceEvaluation(e,t))).flatMap((e=>Array.isArray(e)?e:[e])):this.parameterReferenceEvaluation(e,i[0]),new s(t[0],n)):new s(t[0],void 0)})).filter((e=>!c(e.getT2()))).reduce(((e,t)=>(e.set(t.getT1(),t.getT2()),e)),new Map)}parameterReferenceEvaluation(e,t){let r;if(t.getType()==re.VALUE)r=this.resolveInternalExpression(t.getValue(),e);else if(t.getType()==re.EXPRESSION&&!v.isNullOrBlank(t.getExpression())){r=new ze(t.getExpression()??"").evaluate(e.getValuesMap())}return r}prepareStatementExecution(e,t){let r=new at(t),s=this.fRepo.find(t.getNamespace(),t.getName());if(!s)throw new y(_.format("$.$ was not available",t.getNamespace(),t.getName()));let n=new Map(s.getSignature().getParameters());for(let s of Array.from(t.getParameterMap().entries())){let t=n.get(s[0]);if(!t)continue;let i=s[1];if(i.length){if(t.isVariableArgument())for(let s of i)this.parameterReferenceValidation(e,r,t,s);else{let s=i[0];this.parameterReferenceValidation(e,r,t,s)}n.delete(t.getParameterName())}else c(L.getDefaultValue(t.getSchema(),this.sRepo))&&r.addMessage(ot.ERROR,_.format(ht.PARAMETER_NEEDS_A_VALUE,t.getParameterName()))}if(!c(r.getStatement().getDependentStatements()))for(let e of r.getStatement().getDependentStatements())r.addDependency(e);if(n.size)for(let e of Array.from(n.values()))c(L.getDefaultValue(e.getSchema(),this.sRepo))&&r.addMessage(ot.ERROR,_.format(ht.PARAMETER_NEEDS_A_VALUE,e.getParameterName()));return r}parameterReferenceValidation(e,t,r,n){if(n){if(n.getType()==re.VALUE){c(n.getValue())&&c(L.getDefaultValue(r.getSchema(),this.sRepo))&&t.addMessage(ot.ERROR,_.format(ht.PARAMETER_NEEDS_A_VALUE,r.getParameterName()));let e=new ie;for(e.push(new s(r.getSchema(),n.getValue()));!e.isEmpty();){let r=e.pop();if(r.getT2()instanceof Q)this.addDependencies(t,r.getT2().getExpression());else{if(c(r.getT1())||c(r.getT1().getType()))continue;if(r.getT1().getType()?.contains(E.ARRAY)&&Array.isArray(r.getT2())){let t=r.getT1().getItems();if(!t)continue;if(t.isSingleType())for(let n of r.getT2())e.push(new s(t.getSingleSchema(),n));else{let n=r.getT2();for(let r=0;r<n.length;r++)e.push(new s(t.getTupleSchema()[r],n[r]))}}else if(r.getT1().getType()?.contains(E.OBJECT)&&"object"==typeof r.getT2()){let n=r.getT1();if(n.getName()===te.EXPRESSION.getName()&&n.getNamespace()===te.EXPRESSION.getNamespace()){let e=r.getT2();e.isExpression&&this.addDependencies(t,e.value)}else if(n.getProperties())for(let t of Object.entries(r.getT2()))n.getProperties().has(t[0])&&e.push(new s(n.getProperties().get(t[0]),t[1]))}}}}else if(n.getType()==re.EXPRESSION)if(v.isNullOrBlank(n.getExpression()))c(L.getDefaultValue(r.getSchema(),this.sRepo))&&t.addMessage(ot.ERROR,_.format(ht.PARAMETER_NEEDS_A_VALUE,r.getParameterName()));else try{this.addDependencies(t,n.getExpression())}catch(e){t.addMessage(ot.ERROR,_.format("Error evaluating $ : $",n.getExpression(),e))}}else c(L.getDefaultValue(r.getSchema(),this.sRepo))&&t.addMessage(ot.ERROR,_.format(ht.PARAMETER_NEEDS_A_VALUE,r.getParameterName()))}addDependencies(e,t){t&&Array.from(t.match(ht.STEP_REGEX_PATTERN)??[]).forEach((t=>e.addDependency(t)))}makeEdges(e){let t=e.getNodeMap().values(),r=[];for(let n of Array.from(t))for(let t of n.getData().getDependencies()){let i=t.indexOf(".",6),a=t.substring(6,i),o=t.indexOf(".",i+1),u=-1==o?t.substring(i+1):t.substring(i+1,o);e.getNodeMap().has(a)||r.push(new s(a,u));let h=e.getNodeMap().get(a);h&&n.addInEdgeTo(h,u)}return r}}e(module.exports,r),e(module.exports,{}),e(module.exports,a),e(module.exports,u),e(module.exports,f),e(module.exports,I),e(module.exports,$),e(module.exports,H),e(module.exports,w),e(module.exports,{}),e(module.exports,j),e(module.exports,h),e(module.exports,X),e(module.exports,pe),e(module.exports,oe),e(module.exports,Xe),e(module.exports,he),e(module.exports,ce),e(module.exports,Te),e(module.exports,ge),e(module.exports,ne),e(module.exports,p),e(module.exports,x),e(module.exports,R);
2
2
  //# sourceMappingURL=index.js.map