@hpcc-js/comms 3.15.4 → 3.15.5

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 (108) hide show
  1. package/LICENSE +43 -43
  2. package/README.md +50 -50
  3. package/dist/browser/index.js +1 -1
  4. package/dist/browser/index.js.map +1 -1
  5. package/dist/browser/index.umd.cjs +1 -1
  6. package/dist/browser/index.umd.cjs.map +1 -1
  7. package/dist/node/index.cjs +1 -1
  8. package/dist/node/index.cjs.map +2 -2
  9. package/dist/node/index.js +1 -1
  10. package/dist/node/index.js.map +2 -2
  11. package/package.json +5 -5
  12. package/src/__package__.ts +3 -3
  13. package/src/clienttools/eclMeta.ts +506 -506
  14. package/src/clienttools/eclcc.ts +628 -628
  15. package/src/connection.ts +288 -288
  16. package/src/ecl/activity.ts +82 -82
  17. package/src/ecl/dfuWorkunit.ts +363 -363
  18. package/src/ecl/graph.ts +196 -196
  19. package/src/ecl/logicalFile.ts +196 -196
  20. package/src/ecl/machine.ts +63 -63
  21. package/src/ecl/query.ts +265 -265
  22. package/src/ecl/queryGraph.ts +813 -813
  23. package/src/ecl/resource.ts +39 -39
  24. package/src/ecl/result.ts +245 -245
  25. package/src/ecl/scope.ts +188 -188
  26. package/src/ecl/sourceFile.ts +34 -34
  27. package/src/ecl/store.ts +154 -154
  28. package/src/ecl/targetCluster.ts +149 -149
  29. package/src/ecl/timer.ts +42 -42
  30. package/src/ecl/topology.ts +131 -131
  31. package/src/ecl/workunit.ts +1340 -1340
  32. package/src/ecl/xsdParser.ts +267 -267
  33. package/src/espConnection.ts +164 -164
  34. package/src/index.browser.ts +1 -1
  35. package/src/index.common.ts +40 -40
  36. package/src/index.node.ts +48 -48
  37. package/src/pem/trustwave.ts +909 -909
  38. package/src/services/fileSpray.ts +73 -73
  39. package/src/services/wsAccess.ts +8 -8
  40. package/src/services/wsAccount.ts +27 -27
  41. package/src/services/wsCloud.ts +73 -73
  42. package/src/services/wsCodesign.ts +18 -18
  43. package/src/services/wsDFU.ts +34 -34
  44. package/src/services/wsDFUXRef.ts +121 -121
  45. package/src/services/wsDali.ts +8 -8
  46. package/src/services/wsEcl.ts +123 -123
  47. package/src/services/wsElk.ts +8 -8
  48. package/src/services/wsLogaccess.ts +270 -270
  49. package/src/services/wsMachine.ts +89 -89
  50. package/src/services/wsPackageProcess.ts +8 -8
  51. package/src/services/wsResources.ts +8 -8
  52. package/src/services/wsSMC.ts +80 -80
  53. package/src/services/wsSasha.ts +7 -7
  54. package/src/services/wsStore.ts +32 -32
  55. package/src/services/wsTopology.ts +45 -45
  56. package/src/services/wsWorkunits.ts +151 -151
  57. package/src/services/wsdl/FileSpray/v1.23/FileSpray.ts +1008 -1008
  58. package/src/services/wsdl/FileSpray/v1.25/FileSpray.ts +1040 -1040
  59. package/src/services/wsdl/FileSpray/v1.26/FileSpray.ts +929 -929
  60. package/src/services/wsdl/FileSpray/v1.27/FileSpray.ts +930 -930
  61. package/src/services/wsdl/WsCloud/v1/WsCloud.ts +38 -38
  62. package/src/services/wsdl/WsCloud/v1.02/WsCloud.ts +77 -77
  63. package/src/services/wsdl/WsDFUXRef/v1.02/WsDFUXRef.ts +224 -224
  64. package/src/services/wsdl/WsDFUXRef/v1.04/WsDFUXRef.ts +227 -227
  65. package/src/services/wsdl/WsDali/v1.04/WsDali.ts +216 -216
  66. package/src/services/wsdl/WsDfu/v1.62/WsDfu.ts +1455 -1455
  67. package/src/services/wsdl/WsDfu/v1.63/WsDfu.ts +1465 -1465
  68. package/src/services/wsdl/WsDfu/v1.65/WsDfu.ts +1244 -1244
  69. package/src/services/wsdl/WsDfu/v1.66/WsDfu.ts +1267 -1267
  70. package/src/services/wsdl/WsDfu/v1.67/WsDfu.ts +1268 -1268
  71. package/src/services/wsdl/WsFileIO/v1.01/WsFileIO.ts +104 -104
  72. package/src/services/wsdl/WsPackageProcess/v1.04/WsPackageProcess.ts +519 -519
  73. package/src/services/wsdl/WsPackageProcess/v1.07/WsPackageProcess.ts +500 -500
  74. package/src/services/wsdl/WsResources/v1.01/WsResources.ts +119 -119
  75. package/src/services/wsdl/WsSMC/v1.24/WsSMC.ts +665 -665
  76. package/src/services/wsdl/WsSMC/v1.27/WsSMC.ts +591 -591
  77. package/src/services/wsdl/WsSMC/v1.28/WsSMC.ts +645 -645
  78. package/src/services/wsdl/WsSMC/v1.29/WsSMC.ts +660 -660
  79. package/src/services/wsdl/WsTopology/v1.31/WsTopology.ts +856 -856
  80. package/src/services/wsdl/WsTopology/v1.32/WsTopology.ts +786 -786
  81. package/src/services/wsdl/WsTopology/v1.33/WsTopology.ts +835 -835
  82. package/src/services/wsdl/WsWorkunits/v1.88/WsWorkunits.ts +2944 -2944
  83. package/src/services/wsdl/WsWorkunits/v1.94/WsWorkunits.ts +3072 -3072
  84. package/src/services/wsdl/WsWorkunits/v1.95/WsWorkunits.ts +3073 -3073
  85. package/src/services/wsdl/WsWorkunits/v1.97/WsWorkunits.ts +3134 -3134
  86. package/src/services/wsdl/WsWorkunits/v1.98/WsWorkunits.ts +3182 -3182
  87. package/src/services/wsdl/WsWorkunits/v1.99/WsWorkunits.ts +3162 -3162
  88. package/src/services/wsdl/WsWorkunits/v2/WsWorkunits.ts +3153 -3153
  89. package/src/services/wsdl/WsWorkunits/v2.02/WsWorkunits.ts +3162 -3162
  90. package/src/services/wsdl/WsWorkunits/v2.03/WsWorkunits.ts +3164 -3164
  91. package/src/services/wsdl/WsWorkunits/v2.04/WsWorkunits.ts +3171 -3171
  92. package/src/services/wsdl/ws_access/v1.16/ws_access.ts +1086 -1086
  93. package/src/services/wsdl/ws_access/v1.17/ws_access.ts +1023 -1023
  94. package/src/services/wsdl/ws_account/v1.05/ws_account.ts +111 -111
  95. package/src/services/wsdl/ws_account/v1.06/ws_account.ts +109 -109
  96. package/src/services/wsdl/ws_account/v1.07/ws_account.ts +114 -114
  97. package/src/services/wsdl/ws_codesign/v1.1/ws_codesign.ts +95 -95
  98. package/src/services/wsdl/ws_elk/v1/ws_elk.ts +47 -47
  99. package/src/services/wsdl/ws_logaccess/v1/ws_logaccess.ts +83 -83
  100. package/src/services/wsdl/ws_logaccess/v1.02/ws_logaccess.ts +161 -161
  101. package/src/services/wsdl/ws_logaccess/v1.03/ws_logaccess.ts +190 -190
  102. package/src/services/wsdl/ws_logaccess/v1.04/ws_logaccess.ts +215 -215
  103. package/src/services/wsdl/ws_logaccess/v1.05/ws_logaccess.ts +219 -219
  104. package/src/services/wsdl/ws_logaccess/v1.08/ws_logaccess.ts +267 -267
  105. package/src/services/wsdl/ws_machine/v1.17/ws_machine.ts +567 -567
  106. package/src/services/wsdl/ws_machine/v1.18/ws_machine.ts +497 -497
  107. package/src/services/wsdl/ws_machine/v1.19/ws_machine.ts +497 -497
  108. package/src/services/wsdl/wsstore/v1.02/wsstore.ts +239 -239
@@ -912,7 +912,7 @@ Sw==
912
912
  <table>
913
913
  ${s.join("")}
914
914
  </table>
915
- </div>`}},yt=class extends Js{wu;constructor(e,t){super(t),this.wu=e}};var ti=require("@hpcc-js/util");var Kt=class extends ti.StateObject{connection;get properties(){return this.get()}get Wuid(){return this.get("Wuid")}get FileCluster(){return this.get("FileCluster")}get Name(){return this.get("Name")}get IsSuperFile(){return this.get("IsSuperFile")}get Subs(){return this.get("Subs")}get Count(){return this.get("Count")}get ECLSourceFiles(){return this.get("ECLSourceFiles")}constructor(e,t,s){super(),e instanceof re?this.connection=e:this.connection=new re(e),this.set({Wuid:t,...s})}};var Ks=require("@hpcc-js/util");var Zt=class extends Ks.StateObject{connection;get properties(){return this.get()}get Wuid(){return this.get("Wuid")}get Name(){return this.get("Name")}get Value(){return this.get("Value")}get Seconds(){return this.get("Seconds")}get GraphName(){return this.get("GraphName")}get SubGraphId(){return this.get("SubGraphId")}get HasSubGraphId(){return this.get("HasSubGraphId")}get count(){return this.get("count")}get Timestamp(){return this.get("Timestamp")}get When(){return this.get("When")}constructor(e,t,s){super(),e instanceof re?this.connection=e:this.connection=new re(e);let r=(0,Ks.espTime2Seconds)(s.Value);this.set({Wuid:t,Seconds:Math.round(r*1e3)/1e3,HasSubGraphId:s.SubGraphId!==void 0,...s})}};var jo=(0,sn.utcFormat)("%Y-%m-%dT%H:%M:%S.%LZ"),Oo=(0,sn.utcParse)("%Y-%m-%dT%H:%M:%S.%LZ"),_o=(0,ri.format)(",");function Yo(n){return n&&!isNaN(+n)?_o(+n):n}var si="DefinitionList",Xo=/([a-zA-Z]:)?(.*[\\\/])(.*)(\((\d+),(\d+)\))/,ii=["Avg","Min","Max","Delta","StdDev"],oi=["SkewMin","SkewMax","NodeMin","NodeMax"],qo=/[A-Z][a-z]*/g;function zo(n){for(let t of oi){let s=n.indexOf(t);if(s===0){let i=n.slice(s+t.length);return{measure:"",ext:t,label:i}}}let e=n.match(qo);if(e?.length){let t=e.shift(),s=e.join("");for(let r of ii){let i=s.indexOf(r);if(i===0)return s=s.slice(i+r.length),{measure:t,ext:r,label:s}}return{measure:t,ext:"",label:s}}return{measure:"",ext:"",label:n}}var ni={};function ai(n){let e=ni[n];return e||(e=zo(n),ni[n]=e),e}function Le(n,e){return n.__formattedProps?.[e]??n[e]}function Zs(n){if(n===void 0)return;let e=parseFloat(n);return isNaN(e)?void 0:e}function Jo(n,e,t){let s=ai(e);if(!t[s.measure]){t[s.label]=!0;let r=Zs(n[`${s.measure}Avg${s.label}`]),i=Zs(n[`${s.measure}Min${s.label}`]),o=Zs(n[`${s.measure}Max${s.label}`]),u=Zs(n[`${s.measure}StdDev${s.label}`]),p=Math.max((r-i)/u,(o-r)/u);return{Key:`${s.measure}${s.label}`,Value:Le(n,`${s.measure}${s.label}`),Avg:Le(n,`${s.measure}Avg${s.label}`),Min:Le(n,`${s.measure}Min${s.label}`),Max:Le(n,`${s.measure}Max${s.label}`),Delta:Le(n,`${s.measure}Delta${s.label}`),StdDev:Le(n,`${s.measure}StdDev${s.label}`),StdDevs:isNaN(p)?void 0:p,SkewMin:Le(n,`SkewMin${s.label}`),SkewMax:Le(n,`SkewMax${s.label}`),NodeMin:Le(n,`NodeMin${s.label}`),NodeMax:Le(n,`NodeMax${s.label}`)}}return null}var $s=(0,We.scopedLogger)("workunit.ts"),tn=class extends We.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Wuid}`)}},en=new tn,ut=class n extends We.StateObject{connection;topologyConnection;get BaseUrl(){return this.connection.baseUrl}_debugMode=!1;_debugAllGraph;_submitAction;get properties(){return this.get()}get Wuid(){return this.get("Wuid")}get Owner(){return this.get("Owner","")}get Cluster(){return this.get("Cluster","")}get Jobname(){return this.get("Jobname","")}get Description(){return this.get("Description","")}get ActionEx(){return this.get("ActionEx","")}get StateID(){return this.get("StateID",0)}get State(){return this.get("State")||js[this.StateID]}get Protected(){return this.get("Protected",!1)}get Exceptions(){return this.get("Exceptions",{ECLException:[]})}get ResultViews(){return this.get("ResultViews",{View:[]})}_resultCache=new Jt;get ResultCount(){return this.get("ResultCount",0)}get Results(){return this.get("Results",{ECLResult:[]})}get CResults(){return this.Results.ECLResult.map(e=>this._resultCache.get(e,()=>zt.attach(this.connection,this.Wuid,e,this.ResultViews.View)))}get SequenceResults(){let e={};return this.CResults.forEach(t=>{e[t.Sequence]=t}),e}get Timers(){return this.get("Timers",{ECLTimer:[]})}get CTimers(){return this.Timers.ECLTimer.map(e=>new Zt(this.connection,this.Wuid,e))}_graphCache=new vt;get GraphCount(){return this.get("GraphCount",0)}get Graphs(){return this.get("Graphs",{ECLGraph:[]})}get CGraphs(){return this.Graphs.ECLGraph.map(e=>this._graphCache.get(e,()=>new kt(this,e,this.CTimers)))}get ThorLogList(){return this.get("ThorLogList")}get ResourceURLCount(){return this.get("ResourceURLCount",0)}get ResourceURLs(){return this.get("ResourceURLs",{URL:[]})}get CResourceURLs(){return this.ResourceURLs.URL.map(e=>new jt(this,e))}get TotalClusterTime(){return this.get("TotalClusterTime","")}get DateTimeScheduled(){return this.get("DateTimeScheduled")}get IsPausing(){return this.get("IsPausing")}get ThorLCR(){return this.get("ThorLCR")}get ApplicationValues(){return this.get("ApplicationValues",{ApplicationValue:[]})}get HasArchiveQuery(){return this.get("HasArchiveQuery")}get StateEx(){return this.get("StateEx")}get PriorityClass(){return this.get("PriorityClass")}get PriorityLevel(){return this.get("PriorityLevel")}get Snapshot(){return this.get("Snapshot")}get ResultLimit(){return this.get("ResultLimit")}get EventSchedule(){return this.get("EventSchedule")}get Query(){return this.get("Query")}get HelpersCount(){return this.get("HelpersCount",0)}get Helpers(){return this.get("Helpers",{ECLHelpFile:[]})}get DebugValues(){return this.get("DebugValues")}get AllowedClusters(){return this.get("AllowedClusters")}get ErrorCount(){return this.get("ErrorCount",0)}get WarningCount(){return this.get("WarningCount",0)}get InfoCount(){return this.get("InfoCount",0)}get AlertCount(){return this.get("AlertCount",0)}get SourceFileCount(){return this.get("SourceFileCount",0)}get SourceFiles(){return this.get("SourceFiles",{ECLSourceFile:[]})}get CSourceFiles(){return this.SourceFiles.ECLSourceFile.map(e=>new Kt(this.connection,this.Wuid,e))}get VariableCount(){return this.get("VariableCount",0)}get Variables(){return this.get("Variables",{ECLResult:[]})}get TimerCount(){return this.get("TimerCount",0)}get HasDebugValue(){return this.get("HasDebugValue")}get ApplicationValueCount(){return this.get("ApplicationValueCount",0)}get XmlParams(){return this.get("XmlParams")}get AccessFlag(){return this.get("AccessFlag")}get ClusterFlag(){return this.get("ClusterFlag")}get ResultViewCount(){return this.get("ResultViewCount",0)}get DebugValueCount(){return this.get("DebugValueCount",0)}get WorkflowCount(){return this.get("WorkflowCount",0)}get Archived(){return this.get("Archived")}get RoxieCluster(){return this.get("RoxieCluster")}get DebugState(){return this.get("DebugState",{})}get Queue(){return this.get("Queue")}get Active(){return this.get("Active")}get Action(){return this.get("Action")}get Scope(){return this.get("Scope")}get AbortBy(){return this.get("AbortBy")}get AbortTime(){return this.get("AbortTime")}get Workflows(){return this.get("Workflows")}get TimingData(){return this.get("TimingData")}get HelpersDesc(){return this.get("HelpersDesc")}get GraphsDesc(){return this.get("GraphsDesc")}get SourceFilesDesc(){return this.get("SourceFilesDesc")}get ResultsDesc(){return this.get("ResultsDesc")}get VariablesDesc(){return this.get("VariablesDesc")}get TimersDesc(){return this.get("TimersDesc")}get DebugValuesDesc(){return this.get("DebugValuesDesc")}get ApplicationValuesDesc(){return this.get("ApplicationValuesDesc")}get WorkflowsDesc(){return this.get("WorkflowsDesc")}get ServiceNames(){return this.get("ServiceNames")}get CompileCost(){return this.get("CompileCost")}get ExecuteCost(){return this.get("ExecuteCost")}get FileAccessCost(){return this.get("FileAccessCost")}get NoAccess(){return this.get("NoAccess")}get ECLWUProcessList(){return this.get("ECLWUProcessList")}get CostSavingPotential(){return this.get("CostSavingPotential")}static create(e){let t=new n(e);return t.connection.WUCreate().then(s=>(en.set(t),t.set(s.Workunit),t))}static attach(e,t,s){let r=en.get({BaseUrl:e.baseUrl,Wuid:t},()=>new n(e,t));return s&&r.set(s),r}static existsLocal(e,t){return en.has({BaseUrl:e,Wuid:t})}static submit(e,t,s,r=!1){return n.create(e).then(i=>i.update({QueryText:s})).then(i=>r?i.submit(t,ze.Action.Compile):i.submit(t))}static compile(e,t,s){return n.submit(e,t,s,!0)}static query(e,t){return new re(e).WUQuery(t).then(r=>r.Workunits.ECLWorkunit.map(function(i){return n.attach(e,i.Wuid,i)}))}constructor(e,t){super(),this.connection=new re(e),this.topologyConnection=new oe(e),this.clearState(t)}clearState(e){this.clear({Wuid:e,StateID:0})}update(e){return this.connection.WUUpdate({...e,Wuid:this.Wuid,StateOrig:this.StateID,JobnameOrig:this.Jobname,DescriptionOrig:this.Description,ProtectedOrig:this.Protected,ClusterOrig:this.Cluster}).then(t=>(this.set(t.Workunit),this))}submit(e,t=ze.Action.Run,s){let r;return e!==void 0?r=Promise.resolve(e):r=this.topologyConnection.DefaultTpLogicalClusterQuery().then(i=>i.Name),this._debugMode=!1,t===ze.Action.Debug&&(t=ze.Action.Run,this._debugMode=!0),r.then(i=>this.connection.WUUpdate({Wuid:this.Wuid,Action:t,ResultLimit:s,DebugValues:{DebugValue:[{Name:"Debug",Value:this._debugMode?"1":""}]}}).then(o=>(this.set(o.Workunit),this._submitAction=t,this.connection.WUSubmit({Wuid:this.Wuid,Cluster:i})))).then(()=>this)}isComplete(){switch(this.StateID){case 1:return this.ActionEx==="compile"||this._submitAction===ze.Action.Compile;case 3:case 4:case 7:case 999:return!0;default:}return!1}isFailed(){switch(this.StateID){case 7:case 4:return!0;default:}return!1}isDeleted(){return this.StateID===999}isDebugging(){switch(this.StateID){case 14:case 15:return!0;default:}return this._debugMode}isRunning(){switch(this.StateID){case 1:case 2:case 6:case 8:case 14:case 15:return!0;default:}return!1}setToFailed(){return this.WUAction(de.ECLWUActions.SetToFailed)}pause(){return this.WUAction(de.ECLWUActions.Pause)}pauseNow(){return this.WUAction(de.ECLWUActions.PauseNow)}resume(){return this.WUAction(de.ECLWUActions.Resume)}abort(){return this.WUAction(de.ECLWUActions.Abort)}protect(){return this.WUAction(de.ECLWUActions.Protect)}unprotect(){return this.WUAction(de.ECLWUActions.Unprotect)}delete(){return this.WUAction(de.ECLWUActions.Delete)}restore(){return this.WUAction(de.ECLWUActions.Restore)}deschedule(){return this.WUAction(de.ECLWUActions.Deschedule)}reschedule(){return this.WUAction(de.ECLWUActions.Reschedule)}resubmit(){return this.WUResubmit({CloneWorkunit:!1,ResetWorkflow:!1}).then(()=>(this.clearState(this.Wuid),this.refresh().then(()=>(this._monitor(),this))))}clone(){return this.WUResubmit({CloneWorkunit:!0,ResetWorkflow:!1}).then(e=>n.attach(this.connection.opts(),e.WUs.WU[0].WUID).refresh())}async refreshState(){return await this.WUQuery(),this.StateID===1&&!this.ActionEx&&!this._submitAction&&await this.refreshInfo(),this}async refreshInfo(e){return await this.WUInfo(e),this}async refreshDebug(){return await this.debugStatus(),this}async refresh(e=!1,t){return e?await Promise.all([this.refreshInfo(t),this.refreshDebug()]):await this.refreshState(),this}eclExceptions(){return this.Exceptions.ECLException}fetchArchive(){return this.connection.WUFileEx({Wuid:this.Wuid,Type:"ArchiveQuery"})}fetchECLExceptions(){return this.WUInfo({IncludeExceptions:!0}).then(()=>this.eclExceptions())}fetchResults(){return this.WUInfo({IncludeResults:!0}).then(()=>this.CResults)}fetchGraphs(){return this.WUInfo({IncludeGraphs:!0}).then(()=>this.CGraphs)}fetchQuery(){return this.WUInfo({IncludeECL:!0,TruncateEclTo64k:!1}).then(()=>this.Query)}fetchHelpers(){return this.WUInfo({IncludeHelpers:!0}).then(()=>this.Helpers?.ECLHelpFile||[])}fetchAllowedClusters(){return this.WUInfo({IncludeAllowedClusters:!0}).then(()=>this.AllowedClusters?.AllowedCluster||[])}fetchTotalClusterTime(){return this.WUInfo({IncludeTotalClusterTime:!0}).then(()=>this.TotalClusterTime)}fetchServiceNames(){return this.WUInfo({IncludeServiceNames:!0}).then(()=>this.ServiceNames?.Item)}fetchDetailsMeta(e={}){return this.WUDetailsMeta(e)}fetchDetailsRaw(e={}){return this.WUDetails(e).then(t=>t.Scopes.Scope)}normalizeDetails(e,t){let s={id:{Measure:"label"},name:{Measure:"label"},type:{Measure:"label"}},r=new Map;for(let o of e.Activities?.Activity??[])r.set(o.Kind,o.Name);let i=new Array(t.length);for(let o=0;o<t.length;o++){let u=t[o],p={},A={};if(u.Id&&u.Properties?.Property)for(let V of u.Properties.Property){let N=V.Measure,q=V.Name,k=V.RawValue;if(N==="ns"&&(V.Measure="s"),q==="Kind"){let I=parseInt(k,10);V.Formatted=r.get(I)??k}switch(s[q]={Name:V.Name,Measure:V.Measure,Creator:V.Creator,CreatorType:V.CreatorType},V.Measure){case"bool":p[q]=!!+k;break;case"sz":p[q]=+k;break;case"s":p[q]=+k/1e9;break;case"ns":p[q]=+k;break;case"ts":p[q]=new Date(+k/1e3).toISOString();break;case"cnt":p[q]=+k;break;case"cost":p[q]=+k/1e6;break;case"node":p[q]=+k;break;case"skw":p[q]=+k;break;default:p[q]=k}A[q]=Yo(V.Formatted??p[q])}let l={id:u.Id,name:u.ScopeName,type:u.ScopeType,Kind:u.Kind,Label:u.Label,__formattedProps:A,__groupedProps:{},__groupedRawProps:{},__StdDevs:0,__StdDevsSource:"",...p},x=l[si];if(x)try{let V=JSON.parse(x.split("\\").join("\\\\")),N=[];for(let q=0;q<V.length;q++){let k=V[q].match(Xo);k&&N.push({filePath:(k[1]??"")+k[2]+k[3],line:parseInt(k[5],10),col:parseInt(k[6],10)})}l[si]=N}catch{$s.error(`Unexpected "DefinitionList": ${x}`)}let S={},M=0,Q="";for(let V in l)if(!V.startsWith("__")){let N=Jo(l,V,S);N&&(l.__groupedProps[N.Key]=N,!isNaN(N.StdDevs)&&N.StdDevs>M&&(M=N.StdDevs,Q=N.Key))}l.__StdDevs=M,l.__StdDevsSource=Q,i[o]=l}return{meta:e,columns:s,data:i}}fetchDetailsNormalized(e={}){return Promise.all([this.fetchDetailsMeta(),this.fetchDetailsRaw(e)]).then(t=>this.normalizeDetails(t[0],t[1]))}fetchInfo(e={}){return this.WUInfo(e)}fetchDetails(e={}){return this.WUDetails(e).then(t=>t.Scopes.Scope.map(s=>new yt(this,s)))}fetchDetailsHierarchy(e={}){return this.WUDetails(e).then(t=>{let s=[],r={};t.Scopes.Scope.forEach(i=>{if(r[i.ScopeName])return r[i.ScopeName].update(i),null;{let o=new yt(this,i);return r[o.ScopeName]=o,o}});for(let i in r)if(r.hasOwnProperty(i)){let o=r[i],u=o.parentScope();u&&r[u]?r[u].children().push(o):s.push(o)}return s})}fetchGraphDetails(e=[],t){return this.fetchDetails({ScopeFilter:{MaxDepth:999999,Ids:e,ScopeTypes:t},NestedFilter:{Depth:999999,ScopeTypes:["graph","subgraph","activity","edge","function"]},PropertiesToReturn:{AllStatistics:!0,AllAttributes:!0,AllHints:!0,AllProperties:!0,AllScopes:!0},ScopeOptions:{IncludeId:!0,IncludeScope:!0,IncludeScopeType:!0},PropertyOptions:{IncludeName:!0,IncludeRawValue:!0,IncludeFormatted:!0,IncludeMeasure:!0,IncludeCreator:!1,IncludeCreatorType:!1}})}fetchScopeGraphs(e=[]){return this.fetchGraphDetails(e,["graph"]).then(t=>Ht(t))}fetchTimeElapsed(){return this.fetchDetails({ScopeFilter:{PropertyFilters:{PropertyFilter:[{Name:"TimeElapsed"}]}}}).then(e=>{let t={};e.forEach(r=>{t[r.ScopeName]=t[r.ScopeName]||{scope:r.ScopeName,start:null,elapsed:null,finish:null},r.CAttributes.forEach(i=>{i.Name==="TimeElapsed"?t[r.ScopeName].elapsed=+i.RawValue:i.Measure==="ts"&&i.Name.indexOf("Started")>=0&&(t[r.ScopeName].start=i.Formatted)})});let s=[];for(let r in t){let i=t[r];if(i.start&&i.elapsed){let o=Oo(i.start);o.setMilliseconds(o.getMilliseconds()+i.elapsed/1e6),i.finish=jo(o),s.push(i)}}return s.sort((r,i)=>r.start<i.start?-1:r.start>i.start?1:0),s})}_monitor(){if(this.isComplete()){this._monitorTickCount=0;return}super._monitor()}_monitorTimeoutDuration(){let e=super._monitorTimeoutDuration();return this._monitorTickCount<=1?1e3:this._monitorTickCount<=3?3e3:this._monitorTickCount<=5?5e3:this._monitorTickCount<=7?1e4:e}on(e,t,s){if(this.isCallback(t))switch(e){case"completed":super.on("propChanged","StateID",r=>{this.isComplete()&&t([r])});break;case"changed":super.on(e,t);break;default:}else e==="changed"&&super.on(e,t,s);return this._monitor(),this}watchUntilComplete(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),this.isComplete()&&(r.release(),t(this))})})}watchUntilRunning(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),(this.isComplete()||this.isRunning())&&(r.release(),t(this))})})}WUQuery(e={}){return this.connection.WUQuery({...e,Wuid:this.Wuid}).then(t=>(t.Workunits.ECLWorkunit.length===0?(this.clearState(this.Wuid),this.set("StateID",999)):this.set(t.Workunits.ECLWorkunit[0]),t)).catch(t=>{if(!t.Exception.some(r=>r.Code===20081?(this.clearState(this.Wuid),this.set("StateID",999),!0):!1))throw $s.warning(`Unexpected ESP exception: ${t.message}`),t;return{}})}WUCreate(){return this.connection.WUCreate().then(e=>(this.set(e.Workunit),en.set(this),e))}WUInfo(e={}){let t=e.IncludeResults||e.IncludeResultsViewNames;return this.connection.WUInfo({...e,Wuid:this.Wuid,IncludeResults:t,IncludeResultsViewNames:t,SuppressResultSchemas:!1}).then(s=>(this.set(s.Workunit),t&&this.set({ResultViews:s.ResultViews}),s)).catch(s=>{if(!s.Exception.some(i=>i.Code===20080?(this.clearState(this.Wuid),this.set("StateID",999),!0):!1))throw $s.warning(`Unexpected ESP exception: ${s.message}`),s;return{}})}WUResubmit(e){return this.connection.WUResubmit((0,We.deepMixinT)({},e,{Wuids:{Item:[this.Wuid]}}))}WUDetailsMeta(e){return this.connection.WUDetailsMeta(e)}WUDetails(e){return this.connection.WUDetails((0,We.deepMixinT)({ScopeFilter:{MaxDepth:9999},ScopeOptions:{IncludeMatchedScopesInResults:!0,IncludeScope:!0,IncludeId:!1,IncludeScopeType:!1},PropertyOptions:{IncludeName:!0,IncludeRawValue:!1,IncludeFormatted:!0,IncludeMeasure:!0,IncludeCreator:!1,IncludeCreatorType:!1}},e,{WUID:this.Wuid})).then(t=>(0,We.deepMixinT)({Scopes:{Scope:[]}},t))}WUAction(e){return this.connection.WUAction({Wuids:{Item:[this.Wuid]},WUActionType:e}).then(t=>this.refresh().then(()=>(this._monitor(),t)))}publish(e){return this.connection.WUPublishWorkunit({Wuid:this.Wuid,Cluster:this.Cluster,JobName:e||this.Jobname,AllowForeignFiles:!0,Activate:de.WUQueryActivationMode.ActivateQuery,Wait:5e3})}publishEx(e){let t=new Gt({baseUrl:""}),s={Wuid:this.Wuid,Cluster:this.Cluster,JobName:this.Jobname,AllowForeignFiles:!0,Activate:1,Wait:5e3,...e};return t.WUPublishWorkunitEx(s)}WUCDebug(e,t={}){let s="";for(let r in t)t.hasOwnProperty(r)&&(s+=` ${r}='${t[r]}'`);return this.connection.WUCDebugEx({Wuid:this.Wuid,Command:`<debug:${e} uid='${this.Wuid}'${s}/>`}).then(r=>r)}debug(e,t){return this.isDebugging()?this.WUCDebug(e,t).then(s=>{let r=s.children(e);return r.length?r[0]:new We.XMLNode(e)}).catch(s=>($s.error(s),Promise.resolve(new We.XMLNode(e)))):Promise.resolve(new We.XMLNode(e))}debugStatus(){return this.isDebugging()?this.debug("status").then(e=>{let t={...this.DebugState,...e.$};return this.set({DebugState:t}),e}):Promise.resolve({DebugState:{state:"unknown"}})}debugContinue(e=""){return this.debug("continue",{mode:e})}debugStep(e){return this.debug("step",{mode:e})}debugPause(){return this.debug("interrupt")}debugQuit(){return this.debug("quit")}debugDeleteAllBreakpoints(){return this.debug("delete",{idx:0})}debugBreakpointResponseParser(e){return e.children().map(t=>{if(t.name==="break")return t.$})}debugBreakpointAdd(e,t,s){return this.debug("breakpoint",{id:e,mode:t,action:s}).then(r=>this.debugBreakpointResponseParser(r))}debugBreakpointList(){return this.debug("list").then(e=>this.debugBreakpointResponseParser(e))}debugGraph(){return this._debugAllGraph&&this.DebugState._prevGraphSequenceNum===this.DebugState.graphSequenceNum?Promise.resolve(this._debugAllGraph):this.debug("graph",{name:"all"}).then(e=>(this.DebugState._prevGraphSequenceNum=this.DebugState.graphSequenceNum,this._debugAllGraph=tr(this.Wuid,e),this._debugAllGraph))}debugBreakpointValid(e){return this.debugGraph().then(t=>$o(t,e))}debugPrint(e,t=0,s=10){return this.debug("print",{edgeID:e,startRow:t,numRows:s}).then(r=>r.children().map(i=>{let o={};return i.children().forEach(u=>{o[u.name]=u.content}),o}))}},rr="definition";function Ko(n){return n._[rr]!==void 0}function Zo(n){let e=/([a-z]:\\(?:[-\w\.\d]+\\)*(?:[-\w\.\d]+)?|(?:\/[\w\.\-]+)+)\((\d*),(\d*)\)/.exec(n._[rr]);if(e){let[,t,s,r]=e;return t.replace(/\/\.\//g,"/"),{id:n._.id,file:t,line:+s,column:+r}}throw new Error(`Bad definition: ${n._[rr]}`)}function $o(n,e){let t=[];for(let s of n.vertices)if(Ko(s)){let r=Zo(s);(r&&!e||e===r.file)&&t.push(r)}return t.sort((s,r)=>s.line-r.line)}var nn,ir=class n extends rn.StateObject{connection;get properties(){return this.get()}get Exceptions(){return this.get("Exceptions")}get Build(){return this.get("Build")}get ThorClusterList(){return this.get("ThorClusterList")}get RoxieClusterList(){return this.get("RoxieClusterList")}get HThorClusterList(){return this.get("HThorClusterList")}get DFUJobs(){return this.get("DFUJobs")}get Running(){return this.get("Running",{ActiveWorkunit:[]})}get BannerContent(){return this.get("BannerContent")}get BannerColor(){return this.get("BannerColor")}get BannerSize(){return this.get("BannerSize")}get BannerScroll(){return this.get("BannerScroll")}get ChatURL(){return this.get("ChatURL")}get ShowBanner(){return this.get("ShowBanner")}get ShowChatURL(){return this.get("ShowChatURL")}get SortBy(){return this.get("SortBy")}get Descending(){return this.get("Descending")}get SuperUser(){return this.get("SuperUser")}get AccessRight(){return this.get("AccessRight")}get ServerJobQueues(){return this.get("ServerJobQueues")}get ActivityTime(){return this.get("ActivityTime")}get DaliDetached(){return this.get("DaliDetached")}static attach(e,t){return nn||(nn=new n(e)),t&&nn.set(t),nn}constructor(e){super(),e instanceof Rt?this.connection=e:this.connection=new Rt(e),this.clear({})}runningWorkunits(e=""){return this.Running.ActiveWorkunit.filter(t=>e===""||t.ClusterName===e).map(t=>ut.attach(this.connection.connectionOptions(),t.Wuid,t))}setBanner(e){return this.connection.SetBanner({...e}).then(t=>(this.set(t),this))}lazyRefresh=(0,rn.debounce)(async()=>{let e=await this.connection.Activity({});return this.set(e),this});async refresh(){return this.lazyRefresh()}};var xt=require("@hpcc-js/util");var ea=(0,xt.scopedLogger)("logicalFile.ts"),on=class extends xt.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Cluster}-${e.Name}`)}},ta=new on,or=class n extends xt.StateObject{connection;get BaseUrl(){return this.connection.baseUrl}get Cluster(){return this.get("Cluster")}get Name(){return this.get("Name")}get Filename(){return this.get("Filename")}get Prefix(){return this.get("Prefix")}get NodeGroup(){return this.get("NodeGroup")}get NumParts(){return this.get("NumParts")}get Description(){return this.get("Description")}get Dir(){return this.get("Dir")}get PathMask(){return this.get("PathMask")}get Filesize(){return this.get("Filesize")}get FileSizeInt64(){return this.get("FileSizeInt64")}get RecordSize(){return this.get("RecordSize")}get RecordCount(){return this.get("RecordCount")}get RecordSizeInt64(){return this.get("RecordSizeInt64")}get RecordCountInt64(){return this.get("RecordCountInt64")}get Wuid(){return this.get("Wuid")}get Owner(){return this.get("Owner")}get JobName(){return this.get("JobName")}get Persistent(){return this.get("Persistent")}get Format(){return this.get("Format")}get MaxRecordSize(){return this.get("MaxRecordSize")}get CsvSeparate(){return this.get("CsvSeparate")}get CsvQuote(){return this.get("CsvQuote")}get CsvTerminate(){return this.get("CsvTerminate")}get CsvEscape(){return this.get("CsvEscape")}get Modified(){return this.get("Modified")}get Ecl(){return this.get("Ecl")}get Stat(){return this.get("Stat")}get DFUFilePartsOnClusters(){return this.get("DFUFilePartsOnClusters")}get isSuperfile(){return this.get("isSuperfile")}get ShowFileContent(){return this.get("ShowFileContent")}get subfiles(){return this.get("subfiles")}get Superfiles(){return this.get("Superfiles")}get ProtectList(){return this.get("ProtectList")}get FromRoxieCluster(){return this.get("FromRoxieCluster")}get Graphs(){return this.get("Graphs")}get UserPermission(){return this.get("UserPermission")}get ContentType(){return this.get("ContentType")}get CompressedFileSize(){return this.get("CompressedFileSize")}get PercentCompressed(){return this.get("PercentCompressed")}get IsCompressed(){return this.get("IsCompressed")}get BrowseData(){return this.get("BrowseData")}get jsonInfo(){return this.get("jsonInfo")}get binInfo(){return this.get("binInfo")}get PackageID(){return this.get("PackageID")}get Partition(){return this.get("Partition")}get Blooms(){return this.get("Blooms")}get ExpireDays(){return this.get("ExpireDays")}get KeyType(){return this.get("KeyType")}get IsRestricted(){return this.get("IsRestricted")}get AtRestCost(){return this.get("AtRestCost")}get AccessCost(){return this.get("AccessCost")}get StateID(){return this.get("StateID")}get ExpirationDate(){return this.get("ExpirationDate")}get ExtendedIndexInfo(){return this.get("ExtendedIndexInfo")}get CompressionType(){return this.get("CompressionType")}get properties(){return this.get()}static attach(e,t,s,r){let i=ta.get({BaseUrl:e.baseUrl,Cluster:t,Name:s},()=>new n(e,t,s));return r&&i.set(r),i}constructor(e,t,s){super(),e instanceof Ct?this.connection=e:this.connection=new Ct(e),this.clear({Cluster:t,Name:s})}filePartsOnCluster(){return[...this.DFUFilePartsOnClusters?.DFUFilePartsOnCluster||[]]}fileParts(){let e=[];for(let t of this.DFUFilePartsOnClusters?.DFUFilePartsOnCluster||[])for(let s of t?.DFUFileParts?.DFUPart||[]){let r={...t,...s};delete r.DFUFileParts,e.push(r)}return e}update(e){return this.connection.DFUInfo({...e,Cluster:this.Cluster,Name:this.Name}).then(t=>(this.set({Cluster:this.Cluster,...t.FileDetail}),t))}fetchInfo(){return this.connection.DFUInfo({Cluster:this.Cluster,Name:this.Name}).then(e=>(this.set({Cluster:this.Cluster,...e.FileDetail,ProtectList:e?.FileDetail?.ProtectList??{DFUFileProtect:[]}}),e.FileDetail)).catch(e=>{if(!e.Exception.some(s=>s.Code===20038?(this.set("Name",this.Name+" (Deleted)"),this.set("StateID",999),!0):!1))throw ea.warning(`Unexpected ESP exception: ${e.message}`),e;return{}})}fetchDefFile(e){return this.connection.DFUFile({Name:this.Name,Format:e})}fetchAllLogicalFiles(){return this.connection.recursiveFetchLogicalFiles([this])}fetchListHistory(){return this.connection.ListHistory({Name:this.Name}).then(e=>e?.History?.Origin||[])}eraseHistory(){return this.connection.EraseHistory({Name:this.Name}).then(e=>e?.History?.Origin||[])}};var un=require("@hpcc-js/util");var an=class extends un.Cache{constructor(){super(e=>e.Address)}},sa=new an,$t=class n extends un.StateObject{connection;get Address(){return this.get("Address")}get ConfigAddress(){return this.get("ConfigAddress")}get Name(){return this.get("Name")}get ProcessType(){return this.get("ProcessType")}get DisplayType(){return this.get("DisplayType")}get Description(){return this.get("Description")}get AgentVersion(){return this.get("AgentVersion")}get Contact(){return this.get("Contact")}get Location(){return this.get("Location")}get UpTime(){return this.get("UpTime")}get ComponentName(){return this.get("ComponentName")}get ComponentPath(){return this.get("ComponentPath")}get RoxieState(){return this.get("RoxieState")}get RoxieStateDetails(){return this.get("RoxieStateDetails")}get OS(){return this.get("OS")}get ProcessNumber(){return this.get("ProcessNumber")}get Channels(){return this.get("Channels")}get Processors(){return this.get("Processors")}get Storage(){return this.get("Storage")}get Running(){return this.get("Running")}get PhysicalMemory(){return this.get("PhysicalMemory")}get VirtualMemory(){return this.get("VirtualMemory")}get ComponentInfo(){return this.get("ComponentInfo")}get Exception(){return this.get("Exception")}static attach(e,t,s){let r=sa.get({Address:t},()=>new n(e));return s&&r.set(s),r}constructor(e){super(),e instanceof Ge?this.connection=e:this.connection=new Ge(e)}};var dt=require("@hpcc-js/util"),ui=Pe(Xn(),1);var lt=require("@hpcc-js/util");var ln=require("@hpcc-js/util");var cn=class extends ln.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Name}`)}},na=new cn,ct=class n extends ln.StateObject{connection;machineConnection;get BaseUrl(){return this.connection.baseUrl}get Name(){return this.get("Name")}get Prefix(){return this.get("Prefix")}get Type(){return this.get("Type")}get IsDefault(){return this.get("IsDefault")}get TpClusters(){return this.get("TpClusters")}get TpEclCCServers(){return this.get("TpEclCCServers")}get TpEclServers(){return this.get("TpEclServers")}get TpEclAgents(){return this.get("TpEclAgents")}get TpEclSchedulers(){return this.get("TpEclSchedulers")}get MachineInfoEx(){return this.get("MachineInfoEx",[])}get CMachineInfoEx(){return this.MachineInfoEx.map(e=>$t.attach(this.machineConnection,e.Address,e))}static attach(e,t,s){let r=na.get({BaseUrl:e.baseUrl,Name:t},()=>new n(e,t));return s&&r.set(s),r}constructor(e,t){super(),e instanceof oe?(this.connection=e,this.machineConnection=new Ge(e.connectionOptions())):(this.connection=new oe(e),this.machineConnection=new Ge(e)),this.clear({Name:t})}fetchMachines(e={}){return this.machineConnection.GetTargetClusterInfo({TargetClusters:{Item:[`${this.Type}:${this.Name}`]},...e}).then(t=>{let s=[];for(let r of t.TargetClusterInfoList.TargetClusterInfo)for(let i of r.Processes.MachineInfoEx)s.push(i);return this.set("MachineInfoEx",s),this.CMachineInfoEx})}machineStats(){let e=0,t=0,s=0;for(let r of this.CMachineInfoEx)for(let i of r.Storage.StorageInfo){t+=i.Available,s+=i.Total;let o=1-i.Available/i.Total;o>e&&(e=o)}return{maxDisk:e,meanDisk:1-(s?t/s:1)}}fetchUsage(){return this.machineConnection.GetTargetClusterUsageEx([this.Name])}};function ra(n){let e;return n instanceof oe?e=n:e=new oe(n),e.TpListTargetClusters({}).then(t=>t.TargetClusters.TpClusterNameType.map(s=>ct.attach(n,s.Name,s)))}var ar={};function ia(n){if(!ar[n.baseUrl]){let e;n instanceof oe?e=n:e=new oe(n),ar[n.baseUrl]=e.TpListTargetClusters({}).then(t=>{let s,r,i;t.TargetClusters.TpClusterNameType.forEach(u=>{s||(s=u),!r&&u.IsDefault===!0&&(r=u),!i&&u.Type==="hthor"&&(i=u)});let o=r||i||s;return ct.attach(n,o.Name,o)})}return ar[n.baseUrl]}var pn=class extends lt.Cache{constructor(){super(e=>e.BaseUrl)}},oa=new pn,es=class n extends lt.StateObject{connection;get BaseUrl(){return this.connection.baseUrl}get properties(){return this.get()}get TargetClusters(){return this.get("TargetClusters")}get CTargetClusters(){return this.TargetClusters.map(e=>ct.attach(this.connection,e.Name,e))}get LogicalClusters(){return this.get("LogicalClusters")}get Services(){return this.get("Services")}static attach(e,t){let s=oa.get({BaseUrl:e.baseUrl},()=>new n(e));return t&&s.set(t),s}constructor(e){super(),e instanceof oe?this.connection=e:this.connection=new oe(e)}GetESPServiceBaseURL(e=""){return this.connection.TpServiceQuery({}).then(t=>{let s=this.connection.protocol(),r=this.connection.ip(),i=s==="https:"?"18002":"8002";if((0,lt.exists)("ServiceList.TpEspServers.TpEspServer",t)){for(let o of t.ServiceList.TpEspServers.TpEspServer)if((0,lt.exists)("TpBindings.TpBinding",o))for(let u of o.TpBindings.TpBinding)u.Service===e&&u.Protocol+":"===s&&(i=u.Port)}return`${s}//${r}:${i}/`})}fetchTargetClusters(){return this.connection.TpTargetClusterQuery({Type:"ROOT"}).then(e=>(this.set({TargetClusters:e.TpTargetClusters?.TpTargetCluster??[]}),this.CTargetClusters))}fetchLogicalClusters(e={}){return this.connection.TpLogicalClusterQuery(e).then(t=>(this.set({LogicalClusters:t.TpLogicalClusters.TpLogicalCluster}),this.LogicalClusters))}fetchServices(e={}){return this.connection.TpServiceQuery(e).then(t=>(this.set({Services:t.ServiceList}),this.Services))}_prevRefresh;refresh(e=!1){return(!this._prevRefresh||e)&&(this._prevRefresh=Promise.all([this.fetchTargetClusters(),this.fetchLogicalClusters(),this.fetchServices()]).then(()=>this)),this._prevRefresh}on(e,t,s){return this.isCallback(t)?e==="changed"&&super.on(e,t):e==="changed"&&super.on(e,t,s),this._monitor(),this}};function Ke(n,e,t){e==="__proto__"||e==="constructor"||e==="prototype"||(n[e]=t)}function ts(n){return n=""+n,n.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&apos;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/\n/g,"&#10;").replace(/\r/g,"&#13;")}function aa(n){if(n){if(!isNaN(+n))return parseFloat(n)}else return 0;let t=/(?:(?:(\d+).days.)?(?:(\d+)h)?(?:(\d+)m)?(?:(\d+\.\d+|\d+)s))|(?:(\d+\.\d+|\d+)ms|(\d+\.\d+|\d+)us|(\d+\.\d+|\d+)ns)/.exec(n);if(!t)return 0;let s=+t[1]||0,r=+t[2]||0,i=+t[3]||0,o=+t[4]||0,u=+t[5]||0,p=+t[6]||0,A=+t[7]||0;return s*24*60*60+r*60*60+i*60+o+u/1e3+p/1e6+A/1e9}function Ze(n,e){let t=n.indexOf(e);return t!==-1?parseFloat(n.substring(0,t)):-1}function ua(n){if(n){if(!isNaN(+n))return parseFloat(n)}else return 0;let e=Ze(n,"Kb");return e>=0?e*1024:(e=Ze(n,"Mb"),e>=0?e*Math.pow(1024,2):(e=Ze(n,"Gb"),e>=0?e*Math.pow(1024,3):(e=Ze(n,"Tb"),e>=0?e*Math.pow(1024,4):(e=Ze(n,"Pb"),e>=0?e*Math.pow(1024,5):(e=Ze(n,"Eb"),e>=0?e*Math.pow(1024,6):(e=Ze(n,"Zb"),e>=0?e*Math.pow(1024,7):(e=Ze(n,"b"),e>=0?e:0)))))))}function ca(n){return n?parseFloat(n):0}var ur=class{graph;m_xgmml;m_visibleSubgraphs;m_visibleVertices;m_semiVisibleVertices;m_visibleEdges;noSpills;constructor(e){this.graph=e,this.m_xgmml="",this.m_visibleSubgraphs={},this.m_visibleVertices={},this.m_semiVisibleVertices={},this.m_visibleEdges={}}calcVisibility(e,t,s,r){this.noSpills=r,e.forEach(i=>{this.graph.isVertex(i)?(this.calcInVertexVisibility(i,s),this.calcOutVertexVisibility(i,s)):this.graph.isEdge(i)?(this.calcInVertexVisibility(i.getSource(),s-1),this.calcOutVertexVisibility(i.getTarget(),s-1)):this.graph.isSubgraph(i)&&(this.m_visibleSubgraphs[i.__hpcc_id]=i,this.calcSubgraphVisibility(i,t-1))}),this.calcVisibility2()}calcInVertexVisibility(e,t){this.noSpills&&e.isSpill()&&t++,this.m_visibleVertices[e.__hpcc_id]=e,t>0&&e.getInEdges().forEach(s=>{this.calcInVertexVisibility(s.getSource(),t-1)})}calcOutVertexVisibility(e,t){this.noSpills&&e.isSpill()&&t++,this.m_visibleVertices[e.__hpcc_id]=e,t>0&&e.getOutEdges().forEach(s=>{this.calcOutVertexVisibility(s.getTarget(),t-1)})}calcSubgraphVisibility(e,t){if(t<0)return;t>0&&e.__hpcc_subgraphs.forEach((r,i)=>{this.calcSubgraphVisibility(r,t-1)}),e.__hpcc_subgraphs.forEach((r,i)=>{this.m_visibleSubgraphs[r.__hpcc_id]=r}),e.__hpcc_vertices.forEach((r,i)=>{this.m_visibleVertices[r.__hpcc_id]=r});let s={};this.graph.edges.forEach((r,i)=>{r.getSource().__hpcc_parent!==r.getTarget().__hpcc_parent&&e===this.getCommonAncestor(r)&&(s[r.getSource().__hpcc_parent.__hpcc_id+"::"+r.getTarget().__hpcc_parent.__hpcc_id]||(s[r.getSource().__hpcc_parent.__hpcc_id+"::"+r.getTarget().__hpcc_parent.__hpcc_id]=!0,this.m_visibleEdges[r.__hpcc_id]=r))})}buildVertexString(e,t){let s="",r="",i=e.getProperties();for(let o in i)t&&o.indexOf("_kind")>=0?r+='<att name="_kind" value="point"/>':o==="id"||o==="label"?s+=" "+o+'="'+ts(i[o])+'"':r+='<att name="'+o+'" value="'+ts(i[o])+'"/>';return"<node"+s+">"+r+"</node>"}buildEdgeString(e){let t="",s="",r=e.getProperties();for(let i in r)i.toLowerCase()==="id"||i.toLowerCase()==="label"||i.toLowerCase()==="source"||i.toLowerCase()==="target"?t+=" "+i+'="'+ts(r[i])+'"':s+='<att name="'+i+'" value="'+ts(r[i])+'"/>';return"<edge"+t+">"+s+"</edge>"}getAncestors(e,t){let s=e.__hpcc_parent;for(;s;)t.push(s),s=s.__hpcc_parent}getCommonAncestorV(e,t){let s=[],r=[];this.getAncestors(e,s),this.getAncestors(t,r);let i=s.length-1,o=r.length-1,u=null;for(;i>=0&&o>=0&&s[i]===r[o];)u=s[i],--i,--o;return u}getCommonAncestor(e){return this.getCommonAncestorV(e.getSource(),e.getTarget())}calcAncestorVisibility(e){let t=[];this.getAncestors(e,t),t.forEach((s,r)=>{this.m_visibleSubgraphs[s.__hpcc_id]=s})}calcVisibility2(){for(let e in this.m_visibleVertices){let t=this.m_visibleVertices[e];t.getInEdges().forEach((s,r)=>{this.m_visibleEdges[s.__hpcc_id]=s}),t.getOutEdges().forEach((s,r)=>{this.m_visibleEdges[s.__hpcc_id]=s}),this.calcAncestorVisibility(t)}this.calcSemiVisibleVertices()}addSemiVisibleEdge(e){e&&!this.m_visibleEdges[e.__hpcc_id]&&(this.m_visibleEdges[e.__hpcc_id]=e)}addSemiVisibleVertex(e){this.m_visibleVertices[e.__hpcc_id]||(this.m_semiVisibleVertices[e.__hpcc_id]=e,this.calcAncestorVisibility(e))}calcSemiVisibleVertices(){for(let e in this.m_visibleEdges){let t=this.m_visibleEdges[e],s=t.getSource();for(this.addSemiVisibleVertex(s);this.noSpills&&s.isSpill();){let i=s.getInEdges();if(i.length)this.addSemiVisibleEdge(i[0]),s=i[0].getSource(),this.addSemiVisibleVertex(s);else break}let r=t.getTarget();for(this.addSemiVisibleVertex(r);this.noSpills&&r.isSpill();){let i=r.getOutEdges();if(i.length)this.addSemiVisibleEdge(i[0]),r=i[0].getTarget(),this.addSemiVisibleVertex(r);else break}}}writeXgmml(){this.subgraphVisited(this.graph.subgraphs[0],!0),this.graph.edges.forEach((e,t)=>{this.edgeVisited(e)})}subgraphVisited(e,t=!1){if(this.m_visibleSubgraphs[e.__hpcc_id]){let s="";this.m_xgmml+=t?"":'<node id="'+e.__hpcc_id+'"><att><graph>';let r=this.m_xgmml.length;if(e.walkSubgraphs(this),e.walkVertices(this),r===this.m_xgmml.length){let o=e.__hpcc_vertices[0];o&&(this.m_xgmml+=this.buildVertexString(o,!0))}let i=e.getProperties();for(let o in i)s+='<att name="'+o+'" value="'+ts(i[o])+'"/>';this.m_xgmml+=t?"":"</graph></att>"+s+"</node>"}return!1}vertexVisited(e){this.m_visibleVertices[e.__hpcc_id]?this.m_xgmml+=this.buildVertexString(e,!1):this.m_semiVisibleVertices[e.__hpcc_id]&&(this.m_xgmml+=this.buildVertexString(e,!0))}edgeVisited(e){this.m_visibleEdges[e.__hpcc_id]&&(this.m_xgmml+=this.buildEdgeString(e))}},ss=class{__hpcc_graph;__hpcc_parent;__widget;__hpcc_id;_globalID;constructor(e,t){this.__hpcc_graph=e,this.__hpcc_id=t,this._globalID=t}getProperties(){let e={};for(let t in this)t.indexOf("__")!==0&&this.hasOwnProperty(t)&&(e[t]=this[t]);return e}},$e=class extends ss{_globalType;__hpcc_subgraphs;__hpcc_vertices;__hpcc_edges;id;constructor(e,t){super(e,t),this._globalType=t==="0"?"Graph":"Cluster",this.__hpcc_subgraphs=[],this.__hpcc_vertices=[],this.__hpcc_edges=[],this.id=t}addSubgraph(e){e.__hpcc_parent=this,this.__hpcc_subgraphs.some(t=>e===t)||this.__hpcc_subgraphs.push(e)}addVertex(e){e.__hpcc_parent=this,this.__hpcc_vertices.some(t=>e===t)||this.__hpcc_vertices.push(e)}removeVertex(e){this.__hpcc_vertices=this.__hpcc_vertices.filter(t=>e!==t)}addEdge(e){e.__hpcc_parent=this,this.__hpcc_edges.some(t=>e===t)||this.__hpcc_edges.push(e)}removeEdge(e){this.__hpcc_edges=this.__hpcc_edges.filter(t=>e!==t)}remove(){this.__hpcc_subgraphs.forEach(e=>e.__hpcc_parent=this.__hpcc_parent),this.__hpcc_vertices.forEach(e=>e.__hpcc_parent=this.__hpcc_parent),this.__hpcc_edges.forEach(e=>e.__hpcc_parent=this.__hpcc_parent),delete this.__hpcc_parent,this.__hpcc_graph.removeItem(this)}walkSubgraphs(e){this.__hpcc_subgraphs.forEach((t,s)=>{e.subgraphVisited(t)&&t.walkSubgraphs(e)})}walkVertices(e){this.__hpcc_vertices.forEach((t,s)=>{e.vertexVisited(t)})}},pt=class extends ss{_globalType="Vertex";_isSpill;constructor(e,t){super(e,t)}isSpill(){return this._isSpill}remove(){let e=this.getInVertices();e.length<=1&&console.warn(this.__hpcc_id+": remove only supports single or zero inputs activities..."),this.getInEdges().forEach(t=>{t.remove()}),this.getOutEdges().forEach(t=>{t.setSource(e[0])}),this.__hpcc_parent?.removeVertex(this),this.__hpcc_graph.removeItem(this)}getInVertices(){return this.getInEdges().map(e=>e.getSource())}getInEdges(){return this.__hpcc_graph.edges.filter(e=>e.getTarget()===this)}getOutVertices(){return this.getOutEdges().map(e=>e.getTarget())}getOutEdges(){return this.__hpcc_graph.edges.filter(e=>e.getSource()===this)}},gt=class extends ss{_globalType="Edge";_sourceActivity;source;_targetActivity;target;constructor(e,t){super(e,t),this._globalType="Edge"}remove(){this.__hpcc_graph.subgraphs.forEach(e=>{e.removeEdge(this)}),this.__hpcc_graph.removeItem(this)}getSource(){return this.__hpcc_graph.idx[this._sourceActivity||this.source]}setSource(e){this._sourceActivity?this._sourceActivity=e.__hpcc_id:this.source&&(this.source=e.__hpcc_id),this.__widget&&this.__widget.setSource(this.getSource().__widget)}getTarget(){return this.__hpcc_graph.idx[this._targetActivity||this.target]}},ns=class n{idx={};subgraphs=[];vertices=[];edges=[];xgmml="";constructor(){this.clear()}clear(){this.xgmml="",this.idx={},this.subgraphs=[],this.vertices=[],this.edges=[]}load(e){this.clear(),this.merge(e)}merge(e){this.xgmml=e;let s=new DOMParser().parseFromString(e,"text/xml");this.walkDocument(s.documentElement,"0")}isSubgraph(e){return e instanceof $e}isVertex(e){return e instanceof pt}isEdge(e){return e instanceof gt}getGlobalType(e){return e instanceof pt?3:e instanceof gt?4:e instanceof $e?2:e instanceof n?1:0}getGlobalTypeString(e){return e instanceof pt?"Vertex":e instanceof gt?"Edge":e instanceof $e?"Cluster":e instanceof n?"Graph":"Unknown"}getItem(e,t){if(!this.idx[t])switch(e.tagName){case"graph":let r=new $e(this,t);this.subgraphs.push(r),this.idx[t]=r;break;case"node":let i=new pt(this,t);this.vertices.push(i),this.idx[t]=i;break;case"edge":let o=new gt(this,t);this.edges.push(o),this.idx[t]=o;break;default:console.warn("Graph.getItem - Unknown Node Type!");break}let s=this.idx[t];return Array.from(e.attributes).forEach(r=>{Ke(s,r.name,r.value)}),s}removeItem(e){delete this.idx[e.__hpcc_id],e instanceof $e?this.subgraphs=this.subgraphs.filter(t=>e!==t):e instanceof pt?this.vertices=this.vertices.filter(t=>e!==t):e instanceof gt&&(this.edges=this.edges.filter(t=>e!==t))}getChildByTagName(e,t){let s=null;return Array.from(e.childNodes).some(r=>{if(r.tagName===t)return s=r,!0}),s}walkDocument(e,t){let s=this.getItem(e,t);return e.childNodes.forEach(r=>{switch(r.nodeType){case 1:switch(r.tagName){case"graph":break;case"node":let i=!1,o=this.getChildByTagName(r,"att");if(o){let x=this.getChildByTagName(o,"graph");if(x){i=!0;let S=this.walkDocument(x,r.getAttribute("id"));s.addSubgraph(S)}}if(!i){let x=this.walkDocument(r,r.getAttribute("id"));s.addVertex(x)}break;case"att":let u=r.getAttribute("name"),p="_"+u,A=r.getAttribute("value");u.indexOf("Time")===0?(Ke(s,p,A),Ke(s,u,""+aa(A))):u.indexOf("Size")===0?(Ke(s,p,A),Ke(s,u,""+ua(A))):u.indexOf("Skew")===0?(Ke(s,p,A),Ke(s,u,""+ca(A))):Ke(s,u,A);break;case"edge":let l=this.walkDocument(r,r.getAttribute("id"));if(l.NumRowsProcessed!==void 0?l._eclwatchCount=l.NumRowsProcessed.replace(/\B(?=(\d{3})+(?!\d))/g,","):l.Count!==void 0?l._eclwatchCount=l.Count.replace(/\B(?=(\d{3})+(?!\d))/g,","):l.count!==void 0&&(l._eclwatchCount=l.count.replace(/\B(?=(\d{3})+(?!\d))/g,",")),l.inputProgress&&(l._eclwatchInputProgress="["+l.inputProgress.replace(/\B(?=(\d{3})+(?!\d))/g,",")+"]"),l.SkewMaxRowsProcessed&&l.SkewMinRowsProcessed&&(l._eclwatchSkew="+"+l.SkewMaxRowsProcessed+", "+l.SkewMinRowsProcessed),!l._dependsOn){if(!l._childGraph){if(l._sourceActivity||l._targetActivity){l._isSpill=!0;let x=l.getSource();x&&(x._isSpill=!0);let S=l.getTarget();S&&(S._isSpill=!0)}}}s.addEdge(l);break;default:break}break;case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:case 11:case 12:break;default:break}}),s}removeSubgraphs(){[...this.subgraphs].forEach(t=>{t.__hpcc_parent instanceof $e&&t.remove()})}removeSpillVertices(){[...this.vertices].forEach(t=>{t.isSpill()&&t.remove()})}getLocalisedXGMML(e,t,s,r){let i=new ur(this);return i.calcVisibility(e,t,s,r),i.writeXgmml(),"<graph>"+i.m_xgmml+"</graph>"}};var gn=(0,dt.scopedLogger)("@hpcc-js/comms/ecl/query.ts"),la=(0,ui.format)("~s");function pa(n){return!isNaN(parseFloat(n))&&!isNaN(n-0)}var cr=class extends dt.Cache{constructor(){super(e=>dt.Cache.hash([e.QueryId,e.QuerySet]))}},ga=new cr,lr=class n extends dt.StateObject{wsWorkunitsService;get BaseUrl(){return this.wsWorkunitsService.baseUrl}topology;_requestSchema;_responseSchema;get properties(){return this.get()}get Exceptions(){return this.get("Exceptions")}get QueryId(){return this.get("QueryId")}get QuerySet(){return this.get("QuerySet")}get QueryName(){return this.get("QueryName")}get Wuid(){return this.get("Wuid")}get Dll(){return this.get("Dll")}get Suspended(){return this.get("Suspended")}get Activated(){return this.get("Activated")}get SuspendedBy(){return this.get("SuspendedBy")}get Clusters(){return this.get("Clusters")}get PublishedBy(){return this.get("PublishedBy")}get Comment(){return this.get("Comment")}get LogicalFiles(){return this.get("LogicalFiles")}get SuperFiles(){return this.get("SuperFiles")}get IsLibrary(){return this.get("IsLibrary")}get Priority(){return this.get("Priority")}get WUSnapShot(){return this.get("WUSnapShot")}get CompileTime(){return this.get("CompileTime")}get LibrariesUsed(){return this.get("LibrariesUsed")}get CountGraphs(){return this.get("CountGraphs")}get ResourceURLCount(){return this.get("ResourceURLCount")}get WsEclAddresses(){return this.get("WsEclAddresses")}get WUGraphs(){return this.get("WUGraphs")}get WUTimers(){return this.get("WUTimers")}get PriorityID(){return this.get("PriorityID")}constructor(e,t,s,r){super(),e instanceof re?this.wsWorkunitsService=e:this.wsWorkunitsService=new re(e),this.topology=es.attach(this.wsWorkunitsService.opts()),this.set({QuerySet:t,QueryId:s,...r})}static attach(e,t,s,r){let i=ga.get({BaseUrl:e.baseUrl,QuerySet:t,QueryId:s},()=>new n(e,t,s));return r&&i.set(r),i}_eclService;async wsEclService(){return this._eclService||(this._eclService=this.topology.fetchServices({}).then(e=>{for(let t of e?.TpEspServers?.TpEspServer??[])for(let s of t?.TpBindings?.TpBinding??[])if(s?.Service==="ws_ecl"){let r=`${s.Protocol}://${globalThis.location.hostname}:${s.Port}`;return new Qt({baseUrl:r})}})),this._eclService}async fetchDetails(){let e=await this.wsWorkunitsService.WUQueryDetails({QuerySet:this.QuerySet,QueryId:this.QueryId,IncludeStateOnClusters:!0,IncludeSuperFiles:!0,IncludeWsEclAddresses:!0,CheckAllNodes:!1});this.set({...e})}async fetchRequestSchema(){let e=await this.wsEclService();try{this._requestSchema=await e?.requestJson(this.QuerySet,this.QueryId)??[]}catch(t){gn.debug(t.message??t),this._requestSchema=[]}}async fetchResponseSchema(){let e=await this.wsEclService();try{this._responseSchema=await e?.responseJson(this.QuerySet,this.QueryId)??{}}catch(t){gn.debug(t.message??t),this._responseSchema={}}}async fetchSchema(){await Promise.all([this.fetchRequestSchema(),this.fetchResponseSchema()])}fetchSummaryStats(){return this.wsWorkunitsService.WUQueryGetSummaryStats({Target:this.QuerySet,QueryId:this.QueryId})}fetchGraph(e="",t=""){return this.wsWorkunitsService.WUQueryGetGraph({Target:this.QuerySet,QueryId:this.QueryId,GraphName:e,SubGraphId:t}).then(s=>{let r=new ns,i=!0;for(let o of s?.Graphs?.ECLGraphEx||[])i?(r.load(o.Graph),i=!1):r.merge(o.Graph);return r})}fetchDetailsNormalized(e={}){let t=ut.attach(this.wsWorkunitsService,this.Wuid);return t?Promise.all([this.fetchGraph(),t.fetchDetailsMeta(),t.fetchDetailsRaw(e)]).then(s=>{let r=s[0],i=s[1],u=s[2].map(p=>{let A=p.Id[0];if(A==="a"||A==="e"){let l=r.idx[p.Id.substring(1)];if(!l)return gn.debug(`Missing graph data for metric ID: ${p.Id}`),p;let x=new Set(p.Properties.Property.map(M=>M.Name)),S=[];for(let M in l){let Q=M.charAt(0);if(Q!=="_"&&Q===Q.toUpperCase()&&!x.has(M)){let V=l[M],N=typeof V;if(N==="string"||N==="number"||N==="boolean"){let k=pa(V)?parseFloat(V):V,I=V;M.indexOf("Time")>=0&&(k=k/1e9,I=la(k)+"s"),S.push({Name:M,RawValue:k,Formatted:I})}}}S.length>0&&p.Properties.Property.push(...S)}return p});return t.normalizeDetails(i,u)}):Promise.resolve({meta:void 0,columns:void 0,data:void 0})}async submit(e){let t=await this.wsEclService();try{return t?.submit(this.QuerySet,this.QueryId,e).then(s=>{for(let r in s)s[r]=s[r].Row;return s})??[]}catch(s){return gn.debug(s.message??s),[]}}async refresh(){return await Promise.all([this.fetchDetails(),this.fetchSchema()]),this}requestFields(){return this._requestSchema?this._requestSchema:[]}responseFields(){return this._responseSchema?this._responseSchema:{}}resultNames(){let e=[];for(let t in this.responseFields())e.push(t);return e}resultFields(e){return this._responseSchema[e]?this._responseSchema[e]:[]}};var Wt=require("@hpcc-js/util");var dn=class extends Wt.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Name}:${e.UserSpecific}-${e.Namespace}`)}},da=new dn,et=class extends Wt.Message{constructor(t,s,r){super();this.key=t;this.value=s;this.oldValue=r}key;value;oldValue;get canConflate(){return!0}conflate(t){return this.key===t.key?(this.value=t.value,!0):!1}void(){return this.value===this.oldValue}},pr=class n{connection;get BaseUrl(){return this.connection.baseUrl}Name;UserSpecific;Namespace;_dispatch=new Wt.Dispatch;static attach(e,t="HPCCApps",s,r=!0){return da.get({BaseUrl:e.baseUrl,Name:t,UserSpecific:r,Namespace:s},()=>new n(e,t,s,r))}constructor(e,t,s,r){e instanceof St?this.connection=e:this.connection=new St(e),this.Name=t,this.UserSpecific=r,this.Namespace=s}_knownValues={};create(){this.connection.CreateStore({Name:this.Name,Type:"",Description:""})}set(e,t,s=!0){return this.connection.Set({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace,Key:e,Value:t}).then(r=>{let i=this._knownValues[e];this._knownValues[e]=t,s&&this._dispatch.post(new et(e,t,i))}).catch(r=>{console.error(`Store.set("${e}", "${t}") failed:`,r)})}get(e,t=!0){return this.connection.Fetch({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace,Key:e}).then(s=>{let r=this._knownValues[e];return this._knownValues[e]=s.Value,t&&this._dispatch.post(new et(e,s.Value,r)),s.Value}).catch(s=>{console.error(`Store.get(${e}) failed:`,s)})}getAll(e=!0){return this.connection.FetchAll({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace}).then(t=>{let s={},r=this._knownValues;if(this._knownValues={},t.Pairs.Pair.forEach(i=>{let o=this._knownValues[i.Key];this._knownValues[i.Key]=i.Value,delete r[i.Key],s[i.Key]=i.Value,e&&this._dispatch.post(new et(i.Key,i.Value,o))}),e)for(let i in r)this._dispatch.post(new et(i,void 0,r[i]));return s}).catch(t=>(console.error("Store.getAll failed:",t),{}))}delete(e,t=!0){return this.connection.Delete({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace,Key:e}).then(s=>{let r=this._knownValues[e];delete this._knownValues[e],t&&this._dispatch.post(new et(e,void 0,r))}).catch(s=>{console.error(`Store.delete(${e}) failed:`,s)})}monitor(e){return this._dispatch.attach(e)}};var At=require("@hpcc-js/util");var ma=(0,At.scopedLogger)("@hpcc-js/comms/dfuWorkunit.ts");var mn=class extends At.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.ID}`)}},ci=new mn,gr=class n extends At.StateObject{connection;topologyConnection;get BaseUrl(){return this.connection.baseUrl}get properties(){return this.get()}get ID(){return this.get("ID")}get DFUServerName(){return this.get("DFUServerName")}get ClusterName(){return this.get("ClusterName")}get JobName(){return this.get("JobName")}get Queue(){return this.get("Queue")}get User(){return this.get("User")}get isProtected(){return this.get("isProtected")}get Command(){return this.get("Command")}get CommandMessage(){return this.get("CommandMessage")}get PercentDone(){return this.get("PercentDone")}get SecsLeft(){return this.get("SecsLeft")}get ProgressMessage(){return this.get("ProgressMessage")}get SummaryMessage(){return this.get("SummaryMessage")}get State(){return this.get("State",0)}get SourceLogicalName(){return this.get("SourceLogicalName")}get SourceIP(){return this.get("SourceIP")}get SourceFilePath(){return this.get("SourceFilePath")}get SourceDali(){return this.get("SourceDali")}get SourceRecordSize(){return this.get("SourceRecordSize")}get SourceFormat(){return this.get("SourceFormat")}get RowTag(){return this.get("RowTag")}get SourceNumParts(){return this.get("SourceNumParts")}get SourceDirectory(){return this.get("SourceDirectory")}get DestLogicalName(){return this.get("DestLogicalName")}get DestGroupName(){return this.get("DestGroupName")}get DestDirectory(){return this.get("DestDirectory")}get DestIP(){return this.get("DestIP")}get DestFilePath(){return this.get("DestFilePath")}get DestFormat(){return this.get("DestFormat")}get DestNumParts(){return this.get("DestNumParts")}get DestRecordSize(){return this.get("DestRecordSize")}get Replicate(){return this.get("Replicate")}get Overwrite(){return this.get("Overwrite")}get Compress(){return this.get("Compress")}get SourceCsvSeparate(){return this.get("SourceCsvSeparate")}get SourceCsvQuote(){return this.get("SourceCsvQuote")}get SourceCsvTerminate(){return this.get("SourceCsvTerminate")}get SourceCsvEscape(){return this.get("SourceCsvEscape")}get TimeStarted(){return this.get("TimeStarted")}get TimeStopped(){return this.get("TimeStopped")}get StateMessage(){return this.get("StateMessage")}get MonitorEventName(){return this.get("MonitorEventName")}get MonitorSub(){return this.get("MonitorSub")}get MonitorShotLimit(){return this.get("MonitorShotLimit")}get SourceDiffKeyName(){return this.get("SourceDiffKeyName")}get DestDiffKeyName(){return this.get("DestDiffKeyName")}get Archived(){return this.get("Archived")}get encrypt(){return this.get("encrypt")}get decrypt(){return this.get("decrypt")}get failIfNoSourceFile(){return this.get("failIfNoSourceFile")}get recordStructurePresent(){return this.get("recordStructurePresent")}get quotedTerminator(){return this.get("quotedTerminator")}get preserveCompression(){return this.get("preserveCompression")}get expireDays(){return this.get("expireDays")}get PreserveFileParts(){return this.get("PreserveFileParts")}get FileAccessCost(){return this.get("FileAccessCost")}get KbPerSecAve(){return this.get("KbPerSecAve")}get KbPerSec(){return this.get("KbPerSec")}static create(e,t){let s=new n(e);return s.connection.CreateDFUWorkunit({DFUServerQueue:t}).then(r=>(ci.set(s),s.set(r.result),s))}static attach(e,t,s){let r=ci.get({BaseUrl:e.baseUrl,ID:t},()=>new n(e,t));return s&&r.set(s),r}static sprayFixed(e,t){let s=new Xe(e);return s.SprayFixedEx({...t}).then(r=>{let i=r.wuid;return s.GetDFUWorkunit({wuid:i}).then(o=>n.attach(e,i,o.result))})}static sprayVariable(e,t){let s=new Xe(e);return s.SprayVariableEx({...t}).then(r=>{let i=r.wuid;return s.GetDFUWorkunit({wuid:i}).then(o=>n.attach(e,i,o.result))})}static despray(e,t){let s=new Xe(e);return s.DesprayEx({...t}).then(r=>{let i=r.wuid;return s.GetDFUWorkunit({wuid:i}).then(o=>n.attach(e,i,o.result))})}update(e){return this.connection.UpdateDFUWorkunitEx({wu:{JobName:e?.wu?.JobName??this.JobName,isProtected:e?.wu?.isProtected??this.isProtected,ID:this.ID,State:this.State},ClusterOrig:this.ClusterName,JobNameOrig:this.JobName,isProtectedOrig:this.isProtected,StateOrig:this.State})}isComplete(){switch(this.State){case 6:case 5:case 4:case 999:return!0;default:}return!1}isFailed(){return!!(this.isComplete()&&this.State!==6)}isDeleted(){return this.State===999}isRunning(){return!this.isComplete()}abort(){return this.connection.AbortDFUWorkunit({wuid:this.ID})}delete(){return this.DFUWUAction(Dt.DFUWUActions.Delete).then(e=>this.refresh().then(()=>(this._monitor(),e)))}async refresh(e=!1){return await this.GetDFUWorkunit(),this}fetchXML(e){return this.DFUWUFile()}_monitor(){if(this.isComplete()){this._monitorTickCount=0;return}super._monitor()}_monitorTimeoutDuration(){let e=super._monitorTimeoutDuration();return this._monitorTickCount<=1?3e3:this._monitorTickCount<=5?6e3:this._monitorTickCount<=7?12e3:e}DFUWUFile(e={}){return this.connection.DFUWUFileEx({...e,Wuid:this.ID}).then(t=>t).catch(t=>"")}DFUWUAction(e){return this.connection.DFUWorkunitsAction({wuids:{Item:[this.ID]},Type:e}).then(t=>e===Dt.DFUWUActions.Delete?t:this.refresh().then(()=>(this._monitor(),t)))}on(e,t,s){if(this.isCallback(t))switch(e){case"finished":super.on("propChanged","State",r=>{this.isComplete()&&t([r])});break;case"changed":super.on(e,t);break;default:}else e==="changed"&&super.on(e,t,s);return this._monitor(),this}watchUntilComplete(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),this.isComplete()&&(r.release(),t(this))})})}watchUntilRunning(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),(this.isComplete()||this.isRunning())&&(r.release(),t(this))})})}constructor(e,t){super(),this.connection=new Xe(e),this.topologyConnection=new oe(e),this.clearState(t)}clearState(e){this.clear({ID:e,State:0})}GetDFUWorkunit(e={}){return this.connection.GetDFUWorkunit({...e,wuid:this.ID}).then(t=>(this.set(t.result),t)).catch(t=>{if(!t.Exception.some(r=>r.Code===20080||r.Code===20081?(this.clearState(this.ID),this.set("State",999),!0):!1))throw ma.warning(`Unexpected ESP exception: ${t.message}`),t;return{}})}};var Di=Pe(require("node:child_process"),1),Ci=Pe(require("node:crypto"),1),me=Pe(require("node:fs"),1),ke=Pe(require("node:os"),1),De=Pe(require("node:path"),1),Pt=require("@hpcc-js/util");var mt=Pe(require("node:fs"),1),$=Pe(require("node:path"),1),Ae=require("@hpcc-js/util");var fa=(0,Ae.scopedLogger)("clienttools/eclmeta"),ha=!1;function Ut(n,e,t){if(ha){for(let s in n){let r=`${e}.${s}`;s!=="$"&&t[s]===void 0&&t[s.toLowerCase()+"s"]===void 0&&fa.debug(r)}n.$&&Ut(n.$,e+".$",t)}}var fn=class{__attrs;name;constructor(e){this.__attrs=e.$,this.name=e.$.name}},hn=class{__attrs;definition;get scope(){return this.definition}name;type;constructor(e,t){this.__attrs=t.$,this.definition=e,this.name=t.$.name,this.type=t.$.type}},ft=class{get scope(){return this}name;type;sourcePath;line;start;body;end;definitions;constructor(e,t,s,r,i=1,o=0,u=0,p=Number.MAX_VALUE){this.name=e,this.type=t,this.sourcePath=$.normalize(s),this.line=+i-1,this.start=+o,this.body=+u,this.end=+p,this.definitions=this.parseDefinitions(r)}parseDefinitions(e=[]){return e.map(t=>{let s=new Dn(this.sourcePath,t);return Ut(t,"definition",s),s})}contains(e){return e>=this.start&&e<=this.end}scopeStackAt(e){let t=[];return this.contains(e)&&(t.push(this),this.definitions.forEach(s=>{t=s.scopeStackAt(e).concat(t)})),t}_resolve(e=[],t){let s=t.split("."),r=s.shift(),i=(0,Ae.find)(e,o=>typeof o.name=="string"&&typeof r=="string"&&o.name.toLowerCase()===r.toLowerCase());return i&&i.definitions.length&&s.length?this._resolve(i.definitions,s.join(".")):i}resolve(e){return this._resolve(this.definitions,e)}suggestions(){return this.definitions.map(e=>({name:e.name,type:this.type}))}},Dn=class extends ft{__attrs;exported;shared;fullname;inherittype;attrs;fields;constructor(e,t){super(t.$.name,t.$.type,e,t.children("Definition"),t.$.line,t.$.start,t.$.body,t.$.end),this.__attrs=t.$,this.exported=!!t.$.exported,this.shared=!!t.$.shared,this.fullname=t.$.fullname,this.inherittype=t.$.inherittype,this.attrs=this.parseAttrs(t.children("Attr")),this.fields=this.parseFields(t.children("Field"))}parseAttrs(e=[]){return e.map(t=>{let s=new fn(t);return Ut(t,"attr",s),s})}parseFields(e=[]){return e.map(t=>{let s=new hn(this,t);return Ut(t,"field",s),s})}suggestions(){return super.suggestions().concat(this.fields.map(e=>({name:e.name,type:e.type})))}},rs=class{__attrs;name;ref;start;end;line;constructor(e){this.__attrs=e.$,this.name=e.$.name,this.ref=e.$.ref,this.start=e.$.start,this.end=e.$.end,this.line=e.$.line}},Cn=class extends ft{imports;__attrs;constructor(e){super(e.$.name,"source",e.$.sourcePath,e.children("Definition")),this.__attrs=e.$;let t=e.$.name.split(".");t.pop();let s=new Ae.XMLNode("");s.appendAttribute("name","$"),s.appendAttribute("ref",t.join(".")),this.imports=[new rs(s),...this.parseImports(e.children("Import"))]}parseImports(e=[]){return e.map(t=>{let s=new rs(t);return Ut(t,"import",s),s})}resolve(e,t){let s;return!s&&t!==void 0&&this.scopeStackAt(t).some(i=>(s=i.resolve(e),!!s)),s||(s=super.resolve(e)),s}},Da=n=>$.basename(n).indexOf(".")===0,li=n=>mt.lstatSync(n).isDirectory()&&!Da(n),Ca=n=>[".ecl",".ecllib"].indexOf($.extname(n).toLowerCase())>=0,pi=n=>mt.readdirSync(n).map(e=>$.join(n,e)).filter(e=>li(e)||Ca(e)),Rn=class extends ft{constructor(e,t){super(e,"file",t,[])}suggestions(){return[]}},Sn=class extends ft{constructor(e,t){super(e,"folder",t,[])}suggestions(){return pi(this.sourcePath).map(e=>({name:$.basename(e,".ecl"),type:"folder"}))}},yn=class{_workspacePath;_eclccPath;_clientTools;_sourceByID=new Ae.DictionaryNoCase;_sourceByPath=new Ae.Dictionary;_test=new Ae.DictionaryNoCase;constructor(e,t){this._workspacePath=e,this._eclccPath=t}refresh(){this.primeWorkspace(),this.primeClientTools()}primeClientTools(){return fr(this._eclccPath,"",this._workspacePath).then(e=>(this._clientTools=e,e.paths())).then(e=>{for(let t of["ECLCC_ECLLIBRARY_PATH","ECLCC_PLUGIN_PATH"])e[t]&&mt.existsSync(e[t])&&this.walkChildFolders(e[t],e[t]);return this})}primeWorkspace(){mt.existsSync(this._workspacePath)&&this.visitFolder(this._workspacePath,this._workspacePath)}walkChildFolders(e,t,s=!1){for(let r of pi(e))li(r)?this.visitFolder(r,t,s):this.visitFile(r,t,s)}visitFile(e,t,s=!1){let r=$.parse(e),i=$.join(r.dir,r.name),o=$.relative(t,i).split($.sep).join(".");(s||!this._test.has(o))&&this._test.set(o,new Rn("",e))}visitFolder(e,t,s=!1){let r=$.relative(t,e).split($.sep).join(".");(s||!this._test.has(r))&&(this._test.set(r,new Sn(r,e)),this.walkChildFolders(e,t,s))}buildStack(e,t,s){let r=t.split(".");s&&e[e.length-1]===r[0]&&r.shift();let i=[...e,...r],o=i.join(".");return{stack:i,qid:o}}walkECLScope(e,t){let s=this.buildStack(e,t.name,!0);this._test.set(s.qid,t);for(let r of t.definitions)this.walkDefinition(s.stack,r)}walkField(e,t){let s=this.buildStack(e,t.name,!1);this._test.set(s.qid,t)}walkDefinition(e,t){let s=this.buildStack(e,t.name,!0);this.walkECLScope(e,t);for(let r of t.fields)this.walkField(s.stack,r)}walkSource(e){this.walkECLScope([],e)}parseSources(e=[]){for(let t of e)if(t.$.name){let s=new Cn(t);if(Ut(t,"source",s),this._sourceByID.set(s.name,s),this._sourceByPath.set(s.sourcePath,s),s.name){let i=s.name.split(".").length;if(i>1){let o=s.sourcePath;for(;i>1;)o=$.dirname(o),--i;this.visitFolder(o,$.dirname(o))}}this.walkSource(s)}}parseMetaXML(e){let t=new mr;return t.parse(e),this.parseSources(t.sources),t.sources.map(s=>$.normalize(s.$.sourcePath))}resolveQualifiedID(e,t,s){let r;if(!r&&this._test.has(t)&&(r=this._test.get(t).scope),!r&&this._sourceByPath.has(e)){let i=this._sourceByPath.get(e),o=t.split(".");for(let p of i.imports)if(p.name.toLowerCase()===o[0].toLowerCase()){p.ref?o[0]=p.ref:o.shift();break}let u=o.join(".");!r&&this._test.has(u)&&(r=this._test.get(u).scope),r||(u=[...i.name.split("."),...o].join("."),this._test.has(u)&&(r=this._test.get(u).scope))}return r}resolvePartialID(e,t,s){t=t.toLowerCase();let r=t.split(".");r.pop();let i=r.length===1?r[0]:r.join(".");return this.resolveQualifiedID(e,i,s)}},dr=new Ae.Dictionary;function tt(n,e){let t=$.normalize(n);if(!dr.has(t)){let s=new yn(t,e);dr.set(t,s),s.refresh()}return dr.get(t)}function Ra(n,e,t){if(e<0)return!1;let s=n.charAt(e);return(t?/[a-zA-Z\d_\.$]/:/[a-zA-Z\d_]/).test(s)}function Sa(n,e,t){for(;Ra(n,e,t);)e+=t?-1:1;return e+(t?1:-1)}var mr=class extends Ae.SAXStackParser{sources=[];endXMLNode(e){e.name==="Source"&&this.sources.push(e),super.endXMLNode(e)}};var Et=(0,Pt.scopedLogger)("clienttools/eclcc"),hr=ke.type()==="Windows_NT"?".exe":"";function gi(n){return n.split(`\r
915
+ </div>`}},yt=class extends Js{wu;constructor(e,t){super(t),this.wu=e}};var ti=require("@hpcc-js/util");var Kt=class extends ti.StateObject{connection;get properties(){return this.get()}get Wuid(){return this.get("Wuid")}get FileCluster(){return this.get("FileCluster")}get Name(){return this.get("Name")}get IsSuperFile(){return this.get("IsSuperFile")}get Subs(){return this.get("Subs")}get Count(){return this.get("Count")}get ECLSourceFiles(){return this.get("ECLSourceFiles")}constructor(e,t,s){super(),e instanceof re?this.connection=e:this.connection=new re(e),this.set({Wuid:t,...s})}};var Ks=require("@hpcc-js/util");var Zt=class extends Ks.StateObject{connection;get properties(){return this.get()}get Wuid(){return this.get("Wuid")}get Name(){return this.get("Name")}get Value(){return this.get("Value")}get Seconds(){return this.get("Seconds")}get GraphName(){return this.get("GraphName")}get SubGraphId(){return this.get("SubGraphId")}get HasSubGraphId(){return this.get("HasSubGraphId")}get count(){return this.get("count")}get Timestamp(){return this.get("Timestamp")}get When(){return this.get("When")}constructor(e,t,s){super(),e instanceof re?this.connection=e:this.connection=new re(e);let r=(0,Ks.espTime2Seconds)(s.Value);this.set({Wuid:t,Seconds:Math.round(r*1e3)/1e3,HasSubGraphId:s.SubGraphId!==void 0,...s})}};var jo=(0,sn.utcFormat)("%Y-%m-%dT%H:%M:%S.%LZ"),Oo=(0,sn.utcParse)("%Y-%m-%dT%H:%M:%S.%LZ"),_o=(0,ri.format)(",");function Yo(n){return n&&!isNaN(+n)?_o(+n):n}var si="DefinitionList",Xo=/([a-zA-Z]:)?(.*[\\\/])(.*)(\((\d+),(\d+)\))/,ii=["Avg","Min","Max","Delta","StdDev"],oi=["SkewMin","SkewMax","NodeMin","NodeMax"],qo=/[A-Z][a-z]*/g;function zo(n){for(let t of oi){let s=n.indexOf(t);if(s===0){let i=n.slice(s+t.length);return{measure:"",ext:t,label:i}}}let e=n.match(qo);if(e?.length){let t=e.shift(),s=e.join("");for(let r of ii){let i=s.indexOf(r);if(i===0)return s=s.slice(i+r.length),{measure:t,ext:r,label:s}}return{measure:t,ext:"",label:s}}return{measure:"",ext:"",label:n}}var ni={};function ai(n){let e=ni[n];return e||(e=zo(n),ni[n]=e),e}function Le(n,e){return n.__formattedProps?.[e]??n[e]}function Zs(n){if(n===void 0)return;let e=parseFloat(n);return isNaN(e)?void 0:e}function Jo(n,e,t){let s=ai(e);if(!t[s.measure]){t[s.label]=!0;let r=Zs(n[`${s.measure}Avg${s.label}`]),i=Zs(n[`${s.measure}Min${s.label}`]),o=Zs(n[`${s.measure}Max${s.label}`]),u=Zs(n[`${s.measure}StdDev${s.label}`]),p=Math.max((r-i)/u,(o-r)/u);return{Key:`${s.measure}${s.label}`,Value:Le(n,`${s.measure}${s.label}`),Avg:Le(n,`${s.measure}Avg${s.label}`),Min:Le(n,`${s.measure}Min${s.label}`),Max:Le(n,`${s.measure}Max${s.label}`),Delta:Le(n,`${s.measure}Delta${s.label}`),StdDev:Le(n,`${s.measure}StdDev${s.label}`),StdDevs:isNaN(p)?void 0:p,SkewMin:Le(n,`SkewMin${s.label}`),SkewMax:Le(n,`SkewMax${s.label}`),NodeMin:Le(n,`NodeMin${s.label}`),NodeMax:Le(n,`NodeMax${s.label}`)}}return null}var $s=(0,We.scopedLogger)("workunit.ts"),tn=class extends We.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Wuid}`)}},en=new tn,ut=class n extends We.StateObject{connection;topologyConnection;get BaseUrl(){return this.connection.baseUrl}_debugMode=!1;_debugAllGraph;_submitAction;get properties(){return this.get()}get Wuid(){return this.get("Wuid")}get Owner(){return this.get("Owner","")}get Cluster(){return this.get("Cluster","")}get Jobname(){return this.get("Jobname","")}get Description(){return this.get("Description","")}get ActionEx(){return this.get("ActionEx","")}get StateID(){return this.get("StateID",0)}get State(){return this.get("State")||js[this.StateID]}get Protected(){return this.get("Protected",!1)}get Exceptions(){return this.get("Exceptions",{ECLException:[]})}get ResultViews(){return this.get("ResultViews",{View:[]})}_resultCache=new Jt;get ResultCount(){return this.get("ResultCount",0)}get Results(){return this.get("Results",{ECLResult:[]})}get CResults(){return this.Results.ECLResult.map(e=>this._resultCache.get(e,()=>zt.attach(this.connection,this.Wuid,e,this.ResultViews.View)))}get SequenceResults(){let e={};return this.CResults.forEach(t=>{e[t.Sequence]=t}),e}get Timers(){return this.get("Timers",{ECLTimer:[]})}get CTimers(){return this.Timers.ECLTimer.map(e=>new Zt(this.connection,this.Wuid,e))}_graphCache=new vt;get GraphCount(){return this.get("GraphCount",0)}get Graphs(){return this.get("Graphs",{ECLGraph:[]})}get CGraphs(){return this.Graphs.ECLGraph.map(e=>this._graphCache.get(e,()=>new kt(this,e,this.CTimers)))}get ThorLogList(){return this.get("ThorLogList")}get ResourceURLCount(){return this.get("ResourceURLCount",0)}get ResourceURLs(){return this.get("ResourceURLs",{URL:[]})}get CResourceURLs(){return this.ResourceURLs.URL.map(e=>new jt(this,e))}get TotalClusterTime(){return this.get("TotalClusterTime","")}get DateTimeScheduled(){return this.get("DateTimeScheduled")}get IsPausing(){return this.get("IsPausing")}get ThorLCR(){return this.get("ThorLCR")}get ApplicationValues(){return this.get("ApplicationValues",{ApplicationValue:[]})}get HasArchiveQuery(){return this.get("HasArchiveQuery")}get StateEx(){return this.get("StateEx")}get PriorityClass(){return this.get("PriorityClass")}get PriorityLevel(){return this.get("PriorityLevel")}get Snapshot(){return this.get("Snapshot")}get ResultLimit(){return this.get("ResultLimit")}get EventSchedule(){return this.get("EventSchedule")}get Query(){return this.get("Query")}get HelpersCount(){return this.get("HelpersCount",0)}get Helpers(){return this.get("Helpers",{ECLHelpFile:[]})}get DebugValues(){return this.get("DebugValues")}get AllowedClusters(){return this.get("AllowedClusters")}get ErrorCount(){return this.get("ErrorCount",0)}get WarningCount(){return this.get("WarningCount",0)}get InfoCount(){return this.get("InfoCount",0)}get AlertCount(){return this.get("AlertCount",0)}get SourceFileCount(){return this.get("SourceFileCount",0)}get SourceFiles(){return this.get("SourceFiles",{ECLSourceFile:[]})}get CSourceFiles(){return this.SourceFiles.ECLSourceFile.map(e=>new Kt(this.connection,this.Wuid,e))}get VariableCount(){return this.get("VariableCount",0)}get Variables(){return this.get("Variables",{ECLResult:[]})}get TimerCount(){return this.get("TimerCount",0)}get HasDebugValue(){return this.get("HasDebugValue")}get ApplicationValueCount(){return this.get("ApplicationValueCount",0)}get XmlParams(){return this.get("XmlParams")}get AccessFlag(){return this.get("AccessFlag")}get ClusterFlag(){return this.get("ClusterFlag")}get ResultViewCount(){return this.get("ResultViewCount",0)}get DebugValueCount(){return this.get("DebugValueCount",0)}get WorkflowCount(){return this.get("WorkflowCount",0)}get Archived(){return this.get("Archived")}get RoxieCluster(){return this.get("RoxieCluster")}get DebugState(){return this.get("DebugState",{})}get Queue(){return this.get("Queue")}get Active(){return this.get("Active")}get Action(){return this.get("Action")}get Scope(){return this.get("Scope")}get AbortBy(){return this.get("AbortBy")}get AbortTime(){return this.get("AbortTime")}get Workflows(){return this.get("Workflows")}get TimingData(){return this.get("TimingData")}get HelpersDesc(){return this.get("HelpersDesc")}get GraphsDesc(){return this.get("GraphsDesc")}get SourceFilesDesc(){return this.get("SourceFilesDesc")}get ResultsDesc(){return this.get("ResultsDesc")}get VariablesDesc(){return this.get("VariablesDesc")}get TimersDesc(){return this.get("TimersDesc")}get DebugValuesDesc(){return this.get("DebugValuesDesc")}get ApplicationValuesDesc(){return this.get("ApplicationValuesDesc")}get WorkflowsDesc(){return this.get("WorkflowsDesc")}get ServiceNames(){return this.get("ServiceNames")}get CompileCost(){return this.get("CompileCost")}get ExecuteCost(){return this.get("ExecuteCost")}get FileAccessCost(){return this.get("FileAccessCost")}get NoAccess(){return this.get("NoAccess")}get ECLWUProcessList(){return this.get("ECLWUProcessList")}get CostSavingPotential(){return this.get("CostSavingPotential")}static create(e){let t=new n(e);return t.connection.WUCreate().then(s=>(en.set(t),t.set(s.Workunit),t))}static attach(e,t,s){let r=en.get({BaseUrl:e.baseUrl,Wuid:t},()=>new n(e,t));return s&&r.set(s),r}static existsLocal(e,t){return en.has({BaseUrl:e,Wuid:t})}static submit(e,t,s,r=!1){return n.create(e).then(i=>i.update({QueryText:s})).then(i=>r?i.submit(t,ze.Action.Compile):i.submit(t))}static compile(e,t,s){return n.submit(e,t,s,!0)}static query(e,t){return new re(e).WUQuery(t).then(r=>r.Workunits.ECLWorkunit.map(function(i){return n.attach(e,i.Wuid,i)}))}constructor(e,t){super(),this.connection=new re(e),this.topologyConnection=new oe(e),this.clearState(t)}clearState(e){this.clear({Wuid:e,StateID:0})}update(e){return this.connection.WUUpdate({...e,Wuid:this.Wuid,StateOrig:this.StateID,JobnameOrig:this.Jobname,DescriptionOrig:this.Description,ProtectedOrig:this.Protected,ClusterOrig:this.Cluster}).then(t=>(this.set(t.Workunit),this))}submit(e,t=ze.Action.Run,s){let r;return e!==void 0?r=Promise.resolve(e):r=this.topologyConnection.DefaultTpLogicalClusterQuery().then(i=>i.Name),this._debugMode=!1,t===ze.Action.Debug&&(t=ze.Action.Run,this._debugMode=!0),r.then(i=>this.connection.WUUpdate({Wuid:this.Wuid,Action:t,ResultLimit:s,DebugValues:{DebugValue:[{Name:"Debug",Value:this._debugMode?"1":""}]}}).then(o=>(this.set(o.Workunit),this._submitAction=t,this.connection.WUSubmit({Wuid:this.Wuid,Cluster:i})))).then(()=>this)}isComplete(){switch(this.StateID){case 1:return this.ActionEx==="compile"||this._submitAction===ze.Action.Compile;case 3:case 4:case 7:case 999:return!0;default:}return!1}isFailed(){switch(this.StateID){case 7:case 4:return!0;default:}return!1}isDeleted(){return this.StateID===999}isDebugging(){switch(this.StateID){case 14:case 15:return!0;default:}return this._debugMode}isRunning(){switch(this.StateID){case 1:case 2:case 6:case 8:case 14:case 15:return!0;default:}return!1}setToFailed(){return this.WUAction(de.ECLWUActions.SetToFailed)}pause(){return this.WUAction(de.ECLWUActions.Pause)}pauseNow(){return this.WUAction(de.ECLWUActions.PauseNow)}resume(){return this.WUAction(de.ECLWUActions.Resume)}abort(){return this.WUAction(de.ECLWUActions.Abort)}protect(){return this.WUAction(de.ECLWUActions.Protect)}unprotect(){return this.WUAction(de.ECLWUActions.Unprotect)}delete(){return this.WUAction(de.ECLWUActions.Delete)}restore(){return this.WUAction(de.ECLWUActions.Restore)}deschedule(){return this.WUAction(de.ECLWUActions.Deschedule)}reschedule(){return this.WUAction(de.ECLWUActions.Reschedule)}resubmit(){return this.WUResubmit({CloneWorkunit:!1,ResetWorkflow:!1}).then(()=>(this.clearState(this.Wuid),this.refresh().then(()=>(this._monitor(),this))))}clone(){return this.WUResubmit({CloneWorkunit:!0,ResetWorkflow:!1}).then(e=>n.attach(this.connection.opts(),e.WUs.WU[0].WUID).refresh())}async refreshState(){return await this.WUQuery(),this.StateID===1&&!this.ActionEx&&!this._submitAction&&await this.refreshInfo(),this}async refreshInfo(e){return await this.WUInfo(e),this}async refreshDebug(){return await this.debugStatus(),this}async refresh(e=!1,t){return e?await Promise.all([this.refreshInfo(t),this.refreshDebug()]):await this.refreshState(),this}eclExceptions(){return this.Exceptions.ECLException}fetchArchive(){return this.connection.WUFileEx({Wuid:this.Wuid,Type:"ArchiveQuery"})}fetchECLExceptions(){return this.WUInfo({IncludeExceptions:!0}).then(()=>this.eclExceptions())}fetchResults(){return this.WUInfo({IncludeResults:!0}).then(()=>this.CResults)}fetchGraphs(){return this.WUInfo({IncludeGraphs:!0}).then(()=>this.CGraphs)}fetchQuery(){return this.WUInfo({IncludeECL:!0,TruncateEclTo64k:!1}).then(()=>this.Query)}fetchHelpers(){return this.WUInfo({IncludeHelpers:!0}).then(()=>this.Helpers?.ECLHelpFile||[])}fetchAllowedClusters(){return this.WUInfo({IncludeAllowedClusters:!0}).then(()=>this.AllowedClusters?.AllowedCluster||[])}fetchTotalClusterTime(){return this.WUInfo({IncludeTotalClusterTime:!0}).then(()=>this.TotalClusterTime)}fetchServiceNames(){return this.WUInfo({IncludeServiceNames:!0}).then(()=>this.ServiceNames?.Item)}fetchDetailsMeta(e={}){return this.WUDetailsMeta(e)}fetchDetailsRaw(e={}){return this.WUDetails(e).then(t=>t.Scopes.Scope)}normalizeDetails(e,t){let s={id:{Measure:"label"},name:{Measure:"label"},type:{Measure:"label"}},r=new Map;for(let o of e.Activities?.Activity??[])r.set(o.Kind,o.Name);let i=new Array(t.length);for(let o=0;o<t.length;o++){let u=t[o],p={},A={};if(u.Properties?.Property)for(let V of u.Properties.Property){let N=V.Measure,q=V.Name,k=V.RawValue;if(N==="ns"&&(V.Measure="s"),q==="Kind"){let I=parseInt(k,10);V.Formatted=r.get(I)??k}switch(s[q]={Name:V.Name,Measure:V.Measure,Creator:V.Creator,CreatorType:V.CreatorType},V.Measure){case"bool":p[q]=!!+k;break;case"sz":p[q]=+k;break;case"s":p[q]=+k/1e9;break;case"ns":p[q]=+k;break;case"ts":p[q]=new Date(+k/1e3).toISOString();break;case"cnt":p[q]=+k;break;case"cost":p[q]=+k/1e6;break;case"node":p[q]=+k;break;case"skw":p[q]=+k;break;default:p[q]=k}A[q]=Yo(V.Formatted??p[q])}let l={id:u.Id,name:u.ScopeName,type:u.ScopeType,Kind:u.Kind,Label:u.Label,__formattedProps:A,__groupedProps:{},__groupedRawProps:{},__StdDevs:0,__StdDevsSource:"",...p},x=l[si];if(x)try{let V=JSON.parse(x.split("\\").join("\\\\")),N=[];for(let q=0;q<V.length;q++){let k=V[q].match(Xo);k&&N.push({filePath:(k[1]??"")+k[2]+k[3],line:parseInt(k[5],10),col:parseInt(k[6],10)})}l[si]=N}catch{$s.error(`Unexpected "DefinitionList": ${x}`)}let S={},M=0,Q="";for(let V in l)if(!V.startsWith("__")){let N=Jo(l,V,S);N&&(l.__groupedProps[N.Key]=N,!isNaN(N.StdDevs)&&N.StdDevs>M&&(M=N.StdDevs,Q=N.Key))}l.__StdDevs=M,l.__StdDevsSource=Q,i[o]=l}return{meta:e,columns:s,data:i}}fetchDetailsNormalized(e={}){return Promise.all([this.fetchDetailsMeta(),this.fetchDetailsRaw(e)]).then(t=>this.normalizeDetails(t[0],t[1]))}fetchInfo(e={}){return this.WUInfo(e)}fetchDetails(e={}){return this.WUDetails(e).then(t=>t.Scopes.Scope.map(s=>new yt(this,s)))}fetchDetailsHierarchy(e={}){return this.WUDetails(e).then(t=>{let s=[],r={};t.Scopes.Scope.forEach(i=>{if(r[i.ScopeName])return r[i.ScopeName].update(i),null;{let o=new yt(this,i);return r[o.ScopeName]=o,o}});for(let i in r)if(r.hasOwnProperty(i)){let o=r[i],u=o.parentScope();u&&r[u]?r[u].children().push(o):s.push(o)}return s})}fetchGraphDetails(e=[],t){return this.fetchDetails({ScopeFilter:{MaxDepth:999999,Ids:e,ScopeTypes:t},NestedFilter:{Depth:999999,ScopeTypes:["graph","subgraph","activity","edge","function"]},PropertiesToReturn:{AllStatistics:!0,AllAttributes:!0,AllHints:!0,AllProperties:!0,AllScopes:!0},ScopeOptions:{IncludeId:!0,IncludeScope:!0,IncludeScopeType:!0},PropertyOptions:{IncludeName:!0,IncludeRawValue:!0,IncludeFormatted:!0,IncludeMeasure:!0,IncludeCreator:!1,IncludeCreatorType:!1}})}fetchScopeGraphs(e=[]){return this.fetchGraphDetails(e,["graph"]).then(t=>Ht(t))}fetchTimeElapsed(){return this.fetchDetails({ScopeFilter:{PropertyFilters:{PropertyFilter:[{Name:"TimeElapsed"}]}}}).then(e=>{let t={};e.forEach(r=>{t[r.ScopeName]=t[r.ScopeName]||{scope:r.ScopeName,start:null,elapsed:null,finish:null},r.CAttributes.forEach(i=>{i.Name==="TimeElapsed"?t[r.ScopeName].elapsed=+i.RawValue:i.Measure==="ts"&&i.Name.indexOf("Started")>=0&&(t[r.ScopeName].start=i.Formatted)})});let s=[];for(let r in t){let i=t[r];if(i.start&&i.elapsed){let o=Oo(i.start);o.setMilliseconds(o.getMilliseconds()+i.elapsed/1e6),i.finish=jo(o),s.push(i)}}return s.sort((r,i)=>r.start<i.start?-1:r.start>i.start?1:0),s})}_monitor(){if(this.isComplete()){this._monitorTickCount=0;return}super._monitor()}_monitorTimeoutDuration(){let e=super._monitorTimeoutDuration();return this._monitorTickCount<=1?1e3:this._monitorTickCount<=3?3e3:this._monitorTickCount<=5?5e3:this._monitorTickCount<=7?1e4:e}on(e,t,s){if(this.isCallback(t))switch(e){case"completed":super.on("propChanged","StateID",r=>{this.isComplete()&&t([r])});break;case"changed":super.on(e,t);break;default:}else e==="changed"&&super.on(e,t,s);return this._monitor(),this}watchUntilComplete(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),this.isComplete()&&(r.release(),t(this))})})}watchUntilRunning(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),(this.isComplete()||this.isRunning())&&(r.release(),t(this))})})}WUQuery(e={}){return this.connection.WUQuery({...e,Wuid:this.Wuid}).then(t=>(t.Workunits.ECLWorkunit.length===0?(this.clearState(this.Wuid),this.set("StateID",999)):this.set(t.Workunits.ECLWorkunit[0]),t)).catch(t=>{if(!t.Exception.some(r=>r.Code===20081?(this.clearState(this.Wuid),this.set("StateID",999),!0):!1))throw $s.warning(`Unexpected ESP exception: ${t.message}`),t;return{}})}WUCreate(){return this.connection.WUCreate().then(e=>(this.set(e.Workunit),en.set(this),e))}WUInfo(e={}){let t=e.IncludeResults||e.IncludeResultsViewNames;return this.connection.WUInfo({...e,Wuid:this.Wuid,IncludeResults:t,IncludeResultsViewNames:t,SuppressResultSchemas:!1}).then(s=>(this.set(s.Workunit),t&&this.set({ResultViews:s.ResultViews}),s)).catch(s=>{if(!s.Exception.some(i=>i.Code===20080?(this.clearState(this.Wuid),this.set("StateID",999),!0):!1))throw $s.warning(`Unexpected ESP exception: ${s.message}`),s;return{}})}WUResubmit(e){return this.connection.WUResubmit((0,We.deepMixinT)({},e,{Wuids:{Item:[this.Wuid]}}))}WUDetailsMeta(e){return this.connection.WUDetailsMeta(e)}WUDetails(e){return this.connection.WUDetails((0,We.deepMixinT)({ScopeFilter:{MaxDepth:9999},ScopeOptions:{IncludeMatchedScopesInResults:!0,IncludeScope:!0,IncludeId:!1,IncludeScopeType:!1},PropertyOptions:{IncludeName:!0,IncludeRawValue:!1,IncludeFormatted:!0,IncludeMeasure:!0,IncludeCreator:!1,IncludeCreatorType:!1}},e,{WUID:this.Wuid})).then(t=>(0,We.deepMixinT)({Scopes:{Scope:[]}},t))}WUAction(e){return this.connection.WUAction({Wuids:{Item:[this.Wuid]},WUActionType:e}).then(t=>this.refresh().then(()=>(this._monitor(),t)))}publish(e){return this.connection.WUPublishWorkunit({Wuid:this.Wuid,Cluster:this.Cluster,JobName:e||this.Jobname,AllowForeignFiles:!0,Activate:de.WUQueryActivationMode.ActivateQuery,Wait:5e3})}publishEx(e){let t=new Gt({baseUrl:""}),s={Wuid:this.Wuid,Cluster:this.Cluster,JobName:this.Jobname,AllowForeignFiles:!0,Activate:1,Wait:5e3,...e};return t.WUPublishWorkunitEx(s)}WUCDebug(e,t={}){let s="";for(let r in t)t.hasOwnProperty(r)&&(s+=` ${r}='${t[r]}'`);return this.connection.WUCDebugEx({Wuid:this.Wuid,Command:`<debug:${e} uid='${this.Wuid}'${s}/>`}).then(r=>r)}debug(e,t){return this.isDebugging()?this.WUCDebug(e,t).then(s=>{let r=s.children(e);return r.length?r[0]:new We.XMLNode(e)}).catch(s=>($s.error(s),Promise.resolve(new We.XMLNode(e)))):Promise.resolve(new We.XMLNode(e))}debugStatus(){return this.isDebugging()?this.debug("status").then(e=>{let t={...this.DebugState,...e.$};return this.set({DebugState:t}),e}):Promise.resolve({DebugState:{state:"unknown"}})}debugContinue(e=""){return this.debug("continue",{mode:e})}debugStep(e){return this.debug("step",{mode:e})}debugPause(){return this.debug("interrupt")}debugQuit(){return this.debug("quit")}debugDeleteAllBreakpoints(){return this.debug("delete",{idx:0})}debugBreakpointResponseParser(e){return e.children().map(t=>{if(t.name==="break")return t.$})}debugBreakpointAdd(e,t,s){return this.debug("breakpoint",{id:e,mode:t,action:s}).then(r=>this.debugBreakpointResponseParser(r))}debugBreakpointList(){return this.debug("list").then(e=>this.debugBreakpointResponseParser(e))}debugGraph(){return this._debugAllGraph&&this.DebugState._prevGraphSequenceNum===this.DebugState.graphSequenceNum?Promise.resolve(this._debugAllGraph):this.debug("graph",{name:"all"}).then(e=>(this.DebugState._prevGraphSequenceNum=this.DebugState.graphSequenceNum,this._debugAllGraph=tr(this.Wuid,e),this._debugAllGraph))}debugBreakpointValid(e){return this.debugGraph().then(t=>$o(t,e))}debugPrint(e,t=0,s=10){return this.debug("print",{edgeID:e,startRow:t,numRows:s}).then(r=>r.children().map(i=>{let o={};return i.children().forEach(u=>{o[u.name]=u.content}),o}))}},rr="definition";function Ko(n){return n._[rr]!==void 0}function Zo(n){let e=/([a-z]:\\(?:[-\w\.\d]+\\)*(?:[-\w\.\d]+)?|(?:\/[\w\.\-]+)+)\((\d*),(\d*)\)/.exec(n._[rr]);if(e){let[,t,s,r]=e;return t.replace(/\/\.\//g,"/"),{id:n._.id,file:t,line:+s,column:+r}}throw new Error(`Bad definition: ${n._[rr]}`)}function $o(n,e){let t=[];for(let s of n.vertices)if(Ko(s)){let r=Zo(s);(r&&!e||e===r.file)&&t.push(r)}return t.sort((s,r)=>s.line-r.line)}var nn,ir=class n extends rn.StateObject{connection;get properties(){return this.get()}get Exceptions(){return this.get("Exceptions")}get Build(){return this.get("Build")}get ThorClusterList(){return this.get("ThorClusterList")}get RoxieClusterList(){return this.get("RoxieClusterList")}get HThorClusterList(){return this.get("HThorClusterList")}get DFUJobs(){return this.get("DFUJobs")}get Running(){return this.get("Running",{ActiveWorkunit:[]})}get BannerContent(){return this.get("BannerContent")}get BannerColor(){return this.get("BannerColor")}get BannerSize(){return this.get("BannerSize")}get BannerScroll(){return this.get("BannerScroll")}get ChatURL(){return this.get("ChatURL")}get ShowBanner(){return this.get("ShowBanner")}get ShowChatURL(){return this.get("ShowChatURL")}get SortBy(){return this.get("SortBy")}get Descending(){return this.get("Descending")}get SuperUser(){return this.get("SuperUser")}get AccessRight(){return this.get("AccessRight")}get ServerJobQueues(){return this.get("ServerJobQueues")}get ActivityTime(){return this.get("ActivityTime")}get DaliDetached(){return this.get("DaliDetached")}static attach(e,t){return nn||(nn=new n(e)),t&&nn.set(t),nn}constructor(e){super(),e instanceof Rt?this.connection=e:this.connection=new Rt(e),this.clear({})}runningWorkunits(e=""){return this.Running.ActiveWorkunit.filter(t=>e===""||t.ClusterName===e).map(t=>ut.attach(this.connection.connectionOptions(),t.Wuid,t))}setBanner(e){return this.connection.SetBanner({...e}).then(t=>(this.set(t),this))}lazyRefresh=(0,rn.debounce)(async()=>{let e=await this.connection.Activity({});return this.set(e),this});async refresh(){return this.lazyRefresh()}};var xt=require("@hpcc-js/util");var ea=(0,xt.scopedLogger)("logicalFile.ts"),on=class extends xt.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Cluster}-${e.Name}`)}},ta=new on,or=class n extends xt.StateObject{connection;get BaseUrl(){return this.connection.baseUrl}get Cluster(){return this.get("Cluster")}get Name(){return this.get("Name")}get Filename(){return this.get("Filename")}get Prefix(){return this.get("Prefix")}get NodeGroup(){return this.get("NodeGroup")}get NumParts(){return this.get("NumParts")}get Description(){return this.get("Description")}get Dir(){return this.get("Dir")}get PathMask(){return this.get("PathMask")}get Filesize(){return this.get("Filesize")}get FileSizeInt64(){return this.get("FileSizeInt64")}get RecordSize(){return this.get("RecordSize")}get RecordCount(){return this.get("RecordCount")}get RecordSizeInt64(){return this.get("RecordSizeInt64")}get RecordCountInt64(){return this.get("RecordCountInt64")}get Wuid(){return this.get("Wuid")}get Owner(){return this.get("Owner")}get JobName(){return this.get("JobName")}get Persistent(){return this.get("Persistent")}get Format(){return this.get("Format")}get MaxRecordSize(){return this.get("MaxRecordSize")}get CsvSeparate(){return this.get("CsvSeparate")}get CsvQuote(){return this.get("CsvQuote")}get CsvTerminate(){return this.get("CsvTerminate")}get CsvEscape(){return this.get("CsvEscape")}get Modified(){return this.get("Modified")}get Ecl(){return this.get("Ecl")}get Stat(){return this.get("Stat")}get DFUFilePartsOnClusters(){return this.get("DFUFilePartsOnClusters")}get isSuperfile(){return this.get("isSuperfile")}get ShowFileContent(){return this.get("ShowFileContent")}get subfiles(){return this.get("subfiles")}get Superfiles(){return this.get("Superfiles")}get ProtectList(){return this.get("ProtectList")}get FromRoxieCluster(){return this.get("FromRoxieCluster")}get Graphs(){return this.get("Graphs")}get UserPermission(){return this.get("UserPermission")}get ContentType(){return this.get("ContentType")}get CompressedFileSize(){return this.get("CompressedFileSize")}get PercentCompressed(){return this.get("PercentCompressed")}get IsCompressed(){return this.get("IsCompressed")}get BrowseData(){return this.get("BrowseData")}get jsonInfo(){return this.get("jsonInfo")}get binInfo(){return this.get("binInfo")}get PackageID(){return this.get("PackageID")}get Partition(){return this.get("Partition")}get Blooms(){return this.get("Blooms")}get ExpireDays(){return this.get("ExpireDays")}get KeyType(){return this.get("KeyType")}get IsRestricted(){return this.get("IsRestricted")}get AtRestCost(){return this.get("AtRestCost")}get AccessCost(){return this.get("AccessCost")}get StateID(){return this.get("StateID")}get ExpirationDate(){return this.get("ExpirationDate")}get ExtendedIndexInfo(){return this.get("ExtendedIndexInfo")}get CompressionType(){return this.get("CompressionType")}get properties(){return this.get()}static attach(e,t,s,r){let i=ta.get({BaseUrl:e.baseUrl,Cluster:t,Name:s},()=>new n(e,t,s));return r&&i.set(r),i}constructor(e,t,s){super(),e instanceof Ct?this.connection=e:this.connection=new Ct(e),this.clear({Cluster:t,Name:s})}filePartsOnCluster(){return[...this.DFUFilePartsOnClusters?.DFUFilePartsOnCluster||[]]}fileParts(){let e=[];for(let t of this.DFUFilePartsOnClusters?.DFUFilePartsOnCluster||[])for(let s of t?.DFUFileParts?.DFUPart||[]){let r={...t,...s};delete r.DFUFileParts,e.push(r)}return e}update(e){return this.connection.DFUInfo({...e,Cluster:this.Cluster,Name:this.Name}).then(t=>(this.set({Cluster:this.Cluster,...t.FileDetail}),t))}fetchInfo(){return this.connection.DFUInfo({Cluster:this.Cluster,Name:this.Name}).then(e=>(this.set({Cluster:this.Cluster,...e.FileDetail,ProtectList:e?.FileDetail?.ProtectList??{DFUFileProtect:[]}}),e.FileDetail)).catch(e=>{if(!e.Exception.some(s=>s.Code===20038?(this.set("Name",this.Name+" (Deleted)"),this.set("StateID",999),!0):!1))throw ea.warning(`Unexpected ESP exception: ${e.message}`),e;return{}})}fetchDefFile(e){return this.connection.DFUFile({Name:this.Name,Format:e})}fetchAllLogicalFiles(){return this.connection.recursiveFetchLogicalFiles([this])}fetchListHistory(){return this.connection.ListHistory({Name:this.Name}).then(e=>e?.History?.Origin||[])}eraseHistory(){return this.connection.EraseHistory({Name:this.Name}).then(e=>e?.History?.Origin||[])}};var un=require("@hpcc-js/util");var an=class extends un.Cache{constructor(){super(e=>e.Address)}},sa=new an,$t=class n extends un.StateObject{connection;get Address(){return this.get("Address")}get ConfigAddress(){return this.get("ConfigAddress")}get Name(){return this.get("Name")}get ProcessType(){return this.get("ProcessType")}get DisplayType(){return this.get("DisplayType")}get Description(){return this.get("Description")}get AgentVersion(){return this.get("AgentVersion")}get Contact(){return this.get("Contact")}get Location(){return this.get("Location")}get UpTime(){return this.get("UpTime")}get ComponentName(){return this.get("ComponentName")}get ComponentPath(){return this.get("ComponentPath")}get RoxieState(){return this.get("RoxieState")}get RoxieStateDetails(){return this.get("RoxieStateDetails")}get OS(){return this.get("OS")}get ProcessNumber(){return this.get("ProcessNumber")}get Channels(){return this.get("Channels")}get Processors(){return this.get("Processors")}get Storage(){return this.get("Storage")}get Running(){return this.get("Running")}get PhysicalMemory(){return this.get("PhysicalMemory")}get VirtualMemory(){return this.get("VirtualMemory")}get ComponentInfo(){return this.get("ComponentInfo")}get Exception(){return this.get("Exception")}static attach(e,t,s){let r=sa.get({Address:t},()=>new n(e));return s&&r.set(s),r}constructor(e){super(),e instanceof Ge?this.connection=e:this.connection=new Ge(e)}};var dt=require("@hpcc-js/util"),ui=Pe(Xn(),1);var lt=require("@hpcc-js/util");var ln=require("@hpcc-js/util");var cn=class extends ln.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Name}`)}},na=new cn,ct=class n extends ln.StateObject{connection;machineConnection;get BaseUrl(){return this.connection.baseUrl}get Name(){return this.get("Name")}get Prefix(){return this.get("Prefix")}get Type(){return this.get("Type")}get IsDefault(){return this.get("IsDefault")}get TpClusters(){return this.get("TpClusters")}get TpEclCCServers(){return this.get("TpEclCCServers")}get TpEclServers(){return this.get("TpEclServers")}get TpEclAgents(){return this.get("TpEclAgents")}get TpEclSchedulers(){return this.get("TpEclSchedulers")}get MachineInfoEx(){return this.get("MachineInfoEx",[])}get CMachineInfoEx(){return this.MachineInfoEx.map(e=>$t.attach(this.machineConnection,e.Address,e))}static attach(e,t,s){let r=na.get({BaseUrl:e.baseUrl,Name:t},()=>new n(e,t));return s&&r.set(s),r}constructor(e,t){super(),e instanceof oe?(this.connection=e,this.machineConnection=new Ge(e.connectionOptions())):(this.connection=new oe(e),this.machineConnection=new Ge(e)),this.clear({Name:t})}fetchMachines(e={}){return this.machineConnection.GetTargetClusterInfo({TargetClusters:{Item:[`${this.Type}:${this.Name}`]},...e}).then(t=>{let s=[];for(let r of t.TargetClusterInfoList.TargetClusterInfo)for(let i of r.Processes.MachineInfoEx)s.push(i);return this.set("MachineInfoEx",s),this.CMachineInfoEx})}machineStats(){let e=0,t=0,s=0;for(let r of this.CMachineInfoEx)for(let i of r.Storage.StorageInfo){t+=i.Available,s+=i.Total;let o=1-i.Available/i.Total;o>e&&(e=o)}return{maxDisk:e,meanDisk:1-(s?t/s:1)}}fetchUsage(){return this.machineConnection.GetTargetClusterUsageEx([this.Name])}};function ra(n){let e;return n instanceof oe?e=n:e=new oe(n),e.TpListTargetClusters({}).then(t=>t.TargetClusters.TpClusterNameType.map(s=>ct.attach(n,s.Name,s)))}var ar={};function ia(n){if(!ar[n.baseUrl]){let e;n instanceof oe?e=n:e=new oe(n),ar[n.baseUrl]=e.TpListTargetClusters({}).then(t=>{let s,r,i;t.TargetClusters.TpClusterNameType.forEach(u=>{s||(s=u),!r&&u.IsDefault===!0&&(r=u),!i&&u.Type==="hthor"&&(i=u)});let o=r||i||s;return ct.attach(n,o.Name,o)})}return ar[n.baseUrl]}var pn=class extends lt.Cache{constructor(){super(e=>e.BaseUrl)}},oa=new pn,es=class n extends lt.StateObject{connection;get BaseUrl(){return this.connection.baseUrl}get properties(){return this.get()}get TargetClusters(){return this.get("TargetClusters")}get CTargetClusters(){return this.TargetClusters.map(e=>ct.attach(this.connection,e.Name,e))}get LogicalClusters(){return this.get("LogicalClusters")}get Services(){return this.get("Services")}static attach(e,t){let s=oa.get({BaseUrl:e.baseUrl},()=>new n(e));return t&&s.set(t),s}constructor(e){super(),e instanceof oe?this.connection=e:this.connection=new oe(e)}GetESPServiceBaseURL(e=""){return this.connection.TpServiceQuery({}).then(t=>{let s=this.connection.protocol(),r=this.connection.ip(),i=s==="https:"?"18002":"8002";if((0,lt.exists)("ServiceList.TpEspServers.TpEspServer",t)){for(let o of t.ServiceList.TpEspServers.TpEspServer)if((0,lt.exists)("TpBindings.TpBinding",o))for(let u of o.TpBindings.TpBinding)u.Service===e&&u.Protocol+":"===s&&(i=u.Port)}return`${s}//${r}:${i}/`})}fetchTargetClusters(){return this.connection.TpTargetClusterQuery({Type:"ROOT"}).then(e=>(this.set({TargetClusters:e.TpTargetClusters?.TpTargetCluster??[]}),this.CTargetClusters))}fetchLogicalClusters(e={}){return this.connection.TpLogicalClusterQuery(e).then(t=>(this.set({LogicalClusters:t.TpLogicalClusters.TpLogicalCluster}),this.LogicalClusters))}fetchServices(e={}){return this.connection.TpServiceQuery(e).then(t=>(this.set({Services:t.ServiceList}),this.Services))}_prevRefresh;refresh(e=!1){return(!this._prevRefresh||e)&&(this._prevRefresh=Promise.all([this.fetchTargetClusters(),this.fetchLogicalClusters(),this.fetchServices()]).then(()=>this)),this._prevRefresh}on(e,t,s){return this.isCallback(t)?e==="changed"&&super.on(e,t):e==="changed"&&super.on(e,t,s),this._monitor(),this}};function Ke(n,e,t){e==="__proto__"||e==="constructor"||e==="prototype"||(n[e]=t)}function ts(n){return n=""+n,n.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&apos;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/\n/g,"&#10;").replace(/\r/g,"&#13;")}function aa(n){if(n){if(!isNaN(+n))return parseFloat(n)}else return 0;let t=/(?:(?:(\d+).days.)?(?:(\d+)h)?(?:(\d+)m)?(?:(\d+\.\d+|\d+)s))|(?:(\d+\.\d+|\d+)ms|(\d+\.\d+|\d+)us|(\d+\.\d+|\d+)ns)/.exec(n);if(!t)return 0;let s=+t[1]||0,r=+t[2]||0,i=+t[3]||0,o=+t[4]||0,u=+t[5]||0,p=+t[6]||0,A=+t[7]||0;return s*24*60*60+r*60*60+i*60+o+u/1e3+p/1e6+A/1e9}function Ze(n,e){let t=n.indexOf(e);return t!==-1?parseFloat(n.substring(0,t)):-1}function ua(n){if(n){if(!isNaN(+n))return parseFloat(n)}else return 0;let e=Ze(n,"Kb");return e>=0?e*1024:(e=Ze(n,"Mb"),e>=0?e*Math.pow(1024,2):(e=Ze(n,"Gb"),e>=0?e*Math.pow(1024,3):(e=Ze(n,"Tb"),e>=0?e*Math.pow(1024,4):(e=Ze(n,"Pb"),e>=0?e*Math.pow(1024,5):(e=Ze(n,"Eb"),e>=0?e*Math.pow(1024,6):(e=Ze(n,"Zb"),e>=0?e*Math.pow(1024,7):(e=Ze(n,"b"),e>=0?e:0)))))))}function ca(n){return n?parseFloat(n):0}var ur=class{graph;m_xgmml;m_visibleSubgraphs;m_visibleVertices;m_semiVisibleVertices;m_visibleEdges;noSpills;constructor(e){this.graph=e,this.m_xgmml="",this.m_visibleSubgraphs={},this.m_visibleVertices={},this.m_semiVisibleVertices={},this.m_visibleEdges={}}calcVisibility(e,t,s,r){this.noSpills=r,e.forEach(i=>{this.graph.isVertex(i)?(this.calcInVertexVisibility(i,s),this.calcOutVertexVisibility(i,s)):this.graph.isEdge(i)?(this.calcInVertexVisibility(i.getSource(),s-1),this.calcOutVertexVisibility(i.getTarget(),s-1)):this.graph.isSubgraph(i)&&(this.m_visibleSubgraphs[i.__hpcc_id]=i,this.calcSubgraphVisibility(i,t-1))}),this.calcVisibility2()}calcInVertexVisibility(e,t){this.noSpills&&e.isSpill()&&t++,this.m_visibleVertices[e.__hpcc_id]=e,t>0&&e.getInEdges().forEach(s=>{this.calcInVertexVisibility(s.getSource(),t-1)})}calcOutVertexVisibility(e,t){this.noSpills&&e.isSpill()&&t++,this.m_visibleVertices[e.__hpcc_id]=e,t>0&&e.getOutEdges().forEach(s=>{this.calcOutVertexVisibility(s.getTarget(),t-1)})}calcSubgraphVisibility(e,t){if(t<0)return;t>0&&e.__hpcc_subgraphs.forEach((r,i)=>{this.calcSubgraphVisibility(r,t-1)}),e.__hpcc_subgraphs.forEach((r,i)=>{this.m_visibleSubgraphs[r.__hpcc_id]=r}),e.__hpcc_vertices.forEach((r,i)=>{this.m_visibleVertices[r.__hpcc_id]=r});let s={};this.graph.edges.forEach((r,i)=>{r.getSource().__hpcc_parent!==r.getTarget().__hpcc_parent&&e===this.getCommonAncestor(r)&&(s[r.getSource().__hpcc_parent.__hpcc_id+"::"+r.getTarget().__hpcc_parent.__hpcc_id]||(s[r.getSource().__hpcc_parent.__hpcc_id+"::"+r.getTarget().__hpcc_parent.__hpcc_id]=!0,this.m_visibleEdges[r.__hpcc_id]=r))})}buildVertexString(e,t){let s="",r="",i=e.getProperties();for(let o in i)t&&o.indexOf("_kind")>=0?r+='<att name="_kind" value="point"/>':o==="id"||o==="label"?s+=" "+o+'="'+ts(i[o])+'"':r+='<att name="'+o+'" value="'+ts(i[o])+'"/>';return"<node"+s+">"+r+"</node>"}buildEdgeString(e){let t="",s="",r=e.getProperties();for(let i in r)i.toLowerCase()==="id"||i.toLowerCase()==="label"||i.toLowerCase()==="source"||i.toLowerCase()==="target"?t+=" "+i+'="'+ts(r[i])+'"':s+='<att name="'+i+'" value="'+ts(r[i])+'"/>';return"<edge"+t+">"+s+"</edge>"}getAncestors(e,t){let s=e.__hpcc_parent;for(;s;)t.push(s),s=s.__hpcc_parent}getCommonAncestorV(e,t){let s=[],r=[];this.getAncestors(e,s),this.getAncestors(t,r);let i=s.length-1,o=r.length-1,u=null;for(;i>=0&&o>=0&&s[i]===r[o];)u=s[i],--i,--o;return u}getCommonAncestor(e){return this.getCommonAncestorV(e.getSource(),e.getTarget())}calcAncestorVisibility(e){let t=[];this.getAncestors(e,t),t.forEach((s,r)=>{this.m_visibleSubgraphs[s.__hpcc_id]=s})}calcVisibility2(){for(let e in this.m_visibleVertices){let t=this.m_visibleVertices[e];t.getInEdges().forEach((s,r)=>{this.m_visibleEdges[s.__hpcc_id]=s}),t.getOutEdges().forEach((s,r)=>{this.m_visibleEdges[s.__hpcc_id]=s}),this.calcAncestorVisibility(t)}this.calcSemiVisibleVertices()}addSemiVisibleEdge(e){e&&!this.m_visibleEdges[e.__hpcc_id]&&(this.m_visibleEdges[e.__hpcc_id]=e)}addSemiVisibleVertex(e){this.m_visibleVertices[e.__hpcc_id]||(this.m_semiVisibleVertices[e.__hpcc_id]=e,this.calcAncestorVisibility(e))}calcSemiVisibleVertices(){for(let e in this.m_visibleEdges){let t=this.m_visibleEdges[e],s=t.getSource();for(this.addSemiVisibleVertex(s);this.noSpills&&s.isSpill();){let i=s.getInEdges();if(i.length)this.addSemiVisibleEdge(i[0]),s=i[0].getSource(),this.addSemiVisibleVertex(s);else break}let r=t.getTarget();for(this.addSemiVisibleVertex(r);this.noSpills&&r.isSpill();){let i=r.getOutEdges();if(i.length)this.addSemiVisibleEdge(i[0]),r=i[0].getTarget(),this.addSemiVisibleVertex(r);else break}}}writeXgmml(){this.subgraphVisited(this.graph.subgraphs[0],!0),this.graph.edges.forEach((e,t)=>{this.edgeVisited(e)})}subgraphVisited(e,t=!1){if(this.m_visibleSubgraphs[e.__hpcc_id]){let s="";this.m_xgmml+=t?"":'<node id="'+e.__hpcc_id+'"><att><graph>';let r=this.m_xgmml.length;if(e.walkSubgraphs(this),e.walkVertices(this),r===this.m_xgmml.length){let o=e.__hpcc_vertices[0];o&&(this.m_xgmml+=this.buildVertexString(o,!0))}let i=e.getProperties();for(let o in i)s+='<att name="'+o+'" value="'+ts(i[o])+'"/>';this.m_xgmml+=t?"":"</graph></att>"+s+"</node>"}return!1}vertexVisited(e){this.m_visibleVertices[e.__hpcc_id]?this.m_xgmml+=this.buildVertexString(e,!1):this.m_semiVisibleVertices[e.__hpcc_id]&&(this.m_xgmml+=this.buildVertexString(e,!0))}edgeVisited(e){this.m_visibleEdges[e.__hpcc_id]&&(this.m_xgmml+=this.buildEdgeString(e))}},ss=class{__hpcc_graph;__hpcc_parent;__widget;__hpcc_id;_globalID;constructor(e,t){this.__hpcc_graph=e,this.__hpcc_id=t,this._globalID=t}getProperties(){let e={};for(let t in this)t.indexOf("__")!==0&&this.hasOwnProperty(t)&&(e[t]=this[t]);return e}},$e=class extends ss{_globalType;__hpcc_subgraphs;__hpcc_vertices;__hpcc_edges;id;constructor(e,t){super(e,t),this._globalType=t==="0"?"Graph":"Cluster",this.__hpcc_subgraphs=[],this.__hpcc_vertices=[],this.__hpcc_edges=[],this.id=t}addSubgraph(e){e.__hpcc_parent=this,this.__hpcc_subgraphs.some(t=>e===t)||this.__hpcc_subgraphs.push(e)}addVertex(e){e.__hpcc_parent=this,this.__hpcc_vertices.some(t=>e===t)||this.__hpcc_vertices.push(e)}removeVertex(e){this.__hpcc_vertices=this.__hpcc_vertices.filter(t=>e!==t)}addEdge(e){e.__hpcc_parent=this,this.__hpcc_edges.some(t=>e===t)||this.__hpcc_edges.push(e)}removeEdge(e){this.__hpcc_edges=this.__hpcc_edges.filter(t=>e!==t)}remove(){this.__hpcc_subgraphs.forEach(e=>e.__hpcc_parent=this.__hpcc_parent),this.__hpcc_vertices.forEach(e=>e.__hpcc_parent=this.__hpcc_parent),this.__hpcc_edges.forEach(e=>e.__hpcc_parent=this.__hpcc_parent),delete this.__hpcc_parent,this.__hpcc_graph.removeItem(this)}walkSubgraphs(e){this.__hpcc_subgraphs.forEach((t,s)=>{e.subgraphVisited(t)&&t.walkSubgraphs(e)})}walkVertices(e){this.__hpcc_vertices.forEach((t,s)=>{e.vertexVisited(t)})}},pt=class extends ss{_globalType="Vertex";_isSpill;constructor(e,t){super(e,t)}isSpill(){return this._isSpill}remove(){let e=this.getInVertices();e.length<=1&&console.warn(this.__hpcc_id+": remove only supports single or zero inputs activities..."),this.getInEdges().forEach(t=>{t.remove()}),this.getOutEdges().forEach(t=>{t.setSource(e[0])}),this.__hpcc_parent?.removeVertex(this),this.__hpcc_graph.removeItem(this)}getInVertices(){return this.getInEdges().map(e=>e.getSource())}getInEdges(){return this.__hpcc_graph.edges.filter(e=>e.getTarget()===this)}getOutVertices(){return this.getOutEdges().map(e=>e.getTarget())}getOutEdges(){return this.__hpcc_graph.edges.filter(e=>e.getSource()===this)}},gt=class extends ss{_globalType="Edge";_sourceActivity;source;_targetActivity;target;constructor(e,t){super(e,t),this._globalType="Edge"}remove(){this.__hpcc_graph.subgraphs.forEach(e=>{e.removeEdge(this)}),this.__hpcc_graph.removeItem(this)}getSource(){return this.__hpcc_graph.idx[this._sourceActivity||this.source]}setSource(e){this._sourceActivity?this._sourceActivity=e.__hpcc_id:this.source&&(this.source=e.__hpcc_id),this.__widget&&this.__widget.setSource(this.getSource().__widget)}getTarget(){return this.__hpcc_graph.idx[this._targetActivity||this.target]}},ns=class n{idx={};subgraphs=[];vertices=[];edges=[];xgmml="";constructor(){this.clear()}clear(){this.xgmml="",this.idx={},this.subgraphs=[],this.vertices=[],this.edges=[]}load(e){this.clear(),this.merge(e)}merge(e){this.xgmml=e;let s=new DOMParser().parseFromString(e,"text/xml");this.walkDocument(s.documentElement,"0")}isSubgraph(e){return e instanceof $e}isVertex(e){return e instanceof pt}isEdge(e){return e instanceof gt}getGlobalType(e){return e instanceof pt?3:e instanceof gt?4:e instanceof $e?2:e instanceof n?1:0}getGlobalTypeString(e){return e instanceof pt?"Vertex":e instanceof gt?"Edge":e instanceof $e?"Cluster":e instanceof n?"Graph":"Unknown"}getItem(e,t){if(!this.idx[t])switch(e.tagName){case"graph":let r=new $e(this,t);this.subgraphs.push(r),this.idx[t]=r;break;case"node":let i=new pt(this,t);this.vertices.push(i),this.idx[t]=i;break;case"edge":let o=new gt(this,t);this.edges.push(o),this.idx[t]=o;break;default:console.warn("Graph.getItem - Unknown Node Type!");break}let s=this.idx[t];return Array.from(e.attributes).forEach(r=>{Ke(s,r.name,r.value)}),s}removeItem(e){delete this.idx[e.__hpcc_id],e instanceof $e?this.subgraphs=this.subgraphs.filter(t=>e!==t):e instanceof pt?this.vertices=this.vertices.filter(t=>e!==t):e instanceof gt&&(this.edges=this.edges.filter(t=>e!==t))}getChildByTagName(e,t){let s=null;return Array.from(e.childNodes).some(r=>{if(r.tagName===t)return s=r,!0}),s}walkDocument(e,t){let s=this.getItem(e,t);return e.childNodes.forEach(r=>{switch(r.nodeType){case 1:switch(r.tagName){case"graph":break;case"node":let i=!1,o=this.getChildByTagName(r,"att");if(o){let x=this.getChildByTagName(o,"graph");if(x){i=!0;let S=this.walkDocument(x,r.getAttribute("id"));s.addSubgraph(S)}}if(!i){let x=this.walkDocument(r,r.getAttribute("id"));s.addVertex(x)}break;case"att":let u=r.getAttribute("name"),p="_"+u,A=r.getAttribute("value");u.indexOf("Time")===0?(Ke(s,p,A),Ke(s,u,""+aa(A))):u.indexOf("Size")===0?(Ke(s,p,A),Ke(s,u,""+ua(A))):u.indexOf("Skew")===0?(Ke(s,p,A),Ke(s,u,""+ca(A))):Ke(s,u,A);break;case"edge":let l=this.walkDocument(r,r.getAttribute("id"));if(l.NumRowsProcessed!==void 0?l._eclwatchCount=l.NumRowsProcessed.replace(/\B(?=(\d{3})+(?!\d))/g,","):l.Count!==void 0?l._eclwatchCount=l.Count.replace(/\B(?=(\d{3})+(?!\d))/g,","):l.count!==void 0&&(l._eclwatchCount=l.count.replace(/\B(?=(\d{3})+(?!\d))/g,",")),l.inputProgress&&(l._eclwatchInputProgress="["+l.inputProgress.replace(/\B(?=(\d{3})+(?!\d))/g,",")+"]"),l.SkewMaxRowsProcessed&&l.SkewMinRowsProcessed&&(l._eclwatchSkew="+"+l.SkewMaxRowsProcessed+", "+l.SkewMinRowsProcessed),!l._dependsOn){if(!l._childGraph){if(l._sourceActivity||l._targetActivity){l._isSpill=!0;let x=l.getSource();x&&(x._isSpill=!0);let S=l.getTarget();S&&(S._isSpill=!0)}}}s.addEdge(l);break;default:break}break;case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:case 11:case 12:break;default:break}}),s}removeSubgraphs(){[...this.subgraphs].forEach(t=>{t.__hpcc_parent instanceof $e&&t.remove()})}removeSpillVertices(){[...this.vertices].forEach(t=>{t.isSpill()&&t.remove()})}getLocalisedXGMML(e,t,s,r){let i=new ur(this);return i.calcVisibility(e,t,s,r),i.writeXgmml(),"<graph>"+i.m_xgmml+"</graph>"}};var gn=(0,dt.scopedLogger)("@hpcc-js/comms/ecl/query.ts"),la=(0,ui.format)("~s");function pa(n){return!isNaN(parseFloat(n))&&!isNaN(n-0)}var cr=class extends dt.Cache{constructor(){super(e=>dt.Cache.hash([e.QueryId,e.QuerySet]))}},ga=new cr,lr=class n extends dt.StateObject{wsWorkunitsService;get BaseUrl(){return this.wsWorkunitsService.baseUrl}topology;_requestSchema;_responseSchema;get properties(){return this.get()}get Exceptions(){return this.get("Exceptions")}get QueryId(){return this.get("QueryId")}get QuerySet(){return this.get("QuerySet")}get QueryName(){return this.get("QueryName")}get Wuid(){return this.get("Wuid")}get Dll(){return this.get("Dll")}get Suspended(){return this.get("Suspended")}get Activated(){return this.get("Activated")}get SuspendedBy(){return this.get("SuspendedBy")}get Clusters(){return this.get("Clusters")}get PublishedBy(){return this.get("PublishedBy")}get Comment(){return this.get("Comment")}get LogicalFiles(){return this.get("LogicalFiles")}get SuperFiles(){return this.get("SuperFiles")}get IsLibrary(){return this.get("IsLibrary")}get Priority(){return this.get("Priority")}get WUSnapShot(){return this.get("WUSnapShot")}get CompileTime(){return this.get("CompileTime")}get LibrariesUsed(){return this.get("LibrariesUsed")}get CountGraphs(){return this.get("CountGraphs")}get ResourceURLCount(){return this.get("ResourceURLCount")}get WsEclAddresses(){return this.get("WsEclAddresses")}get WUGraphs(){return this.get("WUGraphs")}get WUTimers(){return this.get("WUTimers")}get PriorityID(){return this.get("PriorityID")}constructor(e,t,s,r){super(),e instanceof re?this.wsWorkunitsService=e:this.wsWorkunitsService=new re(e),this.topology=es.attach(this.wsWorkunitsService.opts()),this.set({QuerySet:t,QueryId:s,...r})}static attach(e,t,s,r){let i=ga.get({BaseUrl:e.baseUrl,QuerySet:t,QueryId:s},()=>new n(e,t,s));return r&&i.set(r),i}_eclService;async wsEclService(){return this._eclService||(this._eclService=this.topology.fetchServices({}).then(e=>{for(let t of e?.TpEspServers?.TpEspServer??[])for(let s of t?.TpBindings?.TpBinding??[])if(s?.Service==="ws_ecl"){let r=`${s.Protocol}://${globalThis.location.hostname}:${s.Port}`;return new Qt({baseUrl:r})}})),this._eclService}async fetchDetails(){let e=await this.wsWorkunitsService.WUQueryDetails({QuerySet:this.QuerySet,QueryId:this.QueryId,IncludeStateOnClusters:!0,IncludeSuperFiles:!0,IncludeWsEclAddresses:!0,CheckAllNodes:!1});this.set({...e})}async fetchRequestSchema(){let e=await this.wsEclService();try{this._requestSchema=await e?.requestJson(this.QuerySet,this.QueryId)??[]}catch(t){gn.debug(t.message??t),this._requestSchema=[]}}async fetchResponseSchema(){let e=await this.wsEclService();try{this._responseSchema=await e?.responseJson(this.QuerySet,this.QueryId)??{}}catch(t){gn.debug(t.message??t),this._responseSchema={}}}async fetchSchema(){await Promise.all([this.fetchRequestSchema(),this.fetchResponseSchema()])}fetchSummaryStats(){return this.wsWorkunitsService.WUQueryGetSummaryStats({Target:this.QuerySet,QueryId:this.QueryId})}fetchGraph(e="",t=""){return this.wsWorkunitsService.WUQueryGetGraph({Target:this.QuerySet,QueryId:this.QueryId,GraphName:e,SubGraphId:t}).then(s=>{let r=new ns,i=!0;for(let o of s?.Graphs?.ECLGraphEx||[])i?(r.load(o.Graph),i=!1):r.merge(o.Graph);return r})}fetchDetailsNormalized(e={}){let t=ut.attach(this.wsWorkunitsService,this.Wuid);return t?Promise.all([this.fetchGraph(),t.fetchDetailsMeta(),t.fetchDetailsRaw(e)]).then(s=>{let r=s[0],i=s[1],u=s[2].map(p=>{let A=p.Id[0];if(A==="a"||A==="e"){let l=r.idx[p.Id.substring(1)];if(!l)return gn.debug(`Missing graph data for metric ID: ${p.Id}`),p;let x=new Set(p.Properties.Property.map(M=>M.Name)),S=[];for(let M in l){let Q=M.charAt(0);if(Q!=="_"&&Q===Q.toUpperCase()&&!x.has(M)){let V=l[M],N=typeof V;if(N==="string"||N==="number"||N==="boolean"){let k=pa(V)?parseFloat(V):V,I=V;M.indexOf("Time")>=0&&(k=k/1e9,I=la(k)+"s"),S.push({Name:M,RawValue:k,Formatted:I})}}}S.length>0&&p.Properties.Property.push(...S)}return p});return t.normalizeDetails(i,u)}):Promise.resolve({meta:void 0,columns:void 0,data:void 0})}async submit(e){let t=await this.wsEclService();try{return t?.submit(this.QuerySet,this.QueryId,e).then(s=>{for(let r in s)s[r]=s[r].Row;return s})??[]}catch(s){return gn.debug(s.message??s),[]}}async refresh(){return await Promise.all([this.fetchDetails(),this.fetchSchema()]),this}requestFields(){return this._requestSchema?this._requestSchema:[]}responseFields(){return this._responseSchema?this._responseSchema:{}}resultNames(){let e=[];for(let t in this.responseFields())e.push(t);return e}resultFields(e){return this._responseSchema[e]?this._responseSchema[e]:[]}};var Wt=require("@hpcc-js/util");var dn=class extends Wt.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.Name}:${e.UserSpecific}-${e.Namespace}`)}},da=new dn,et=class extends Wt.Message{constructor(t,s,r){super();this.key=t;this.value=s;this.oldValue=r}key;value;oldValue;get canConflate(){return!0}conflate(t){return this.key===t.key?(this.value=t.value,!0):!1}void(){return this.value===this.oldValue}},pr=class n{connection;get BaseUrl(){return this.connection.baseUrl}Name;UserSpecific;Namespace;_dispatch=new Wt.Dispatch;static attach(e,t="HPCCApps",s,r=!0){return da.get({BaseUrl:e.baseUrl,Name:t,UserSpecific:r,Namespace:s},()=>new n(e,t,s,r))}constructor(e,t,s,r){e instanceof St?this.connection=e:this.connection=new St(e),this.Name=t,this.UserSpecific=r,this.Namespace=s}_knownValues={};create(){this.connection.CreateStore({Name:this.Name,Type:"",Description:""})}set(e,t,s=!0){return this.connection.Set({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace,Key:e,Value:t}).then(r=>{let i=this._knownValues[e];this._knownValues[e]=t,s&&this._dispatch.post(new et(e,t,i))}).catch(r=>{console.error(`Store.set("${e}", "${t}") failed:`,r)})}get(e,t=!0){return this.connection.Fetch({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace,Key:e}).then(s=>{let r=this._knownValues[e];return this._knownValues[e]=s.Value,t&&this._dispatch.post(new et(e,s.Value,r)),s.Value}).catch(s=>{console.error(`Store.get(${e}) failed:`,s)})}getAll(e=!0){return this.connection.FetchAll({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace}).then(t=>{let s={},r=this._knownValues;if(this._knownValues={},t.Pairs.Pair.forEach(i=>{let o=this._knownValues[i.Key];this._knownValues[i.Key]=i.Value,delete r[i.Key],s[i.Key]=i.Value,e&&this._dispatch.post(new et(i.Key,i.Value,o))}),e)for(let i in r)this._dispatch.post(new et(i,void 0,r[i]));return s}).catch(t=>(console.error("Store.getAll failed:",t),{}))}delete(e,t=!0){return this.connection.Delete({StoreName:this.Name,UserSpecific:this.UserSpecific,Namespace:this.Namespace,Key:e}).then(s=>{let r=this._knownValues[e];delete this._knownValues[e],t&&this._dispatch.post(new et(e,void 0,r))}).catch(s=>{console.error(`Store.delete(${e}) failed:`,s)})}monitor(e){return this._dispatch.attach(e)}};var At=require("@hpcc-js/util");var ma=(0,At.scopedLogger)("@hpcc-js/comms/dfuWorkunit.ts");var mn=class extends At.Cache{constructor(){super(e=>`${e.BaseUrl}-${e.ID}`)}},ci=new mn,gr=class n extends At.StateObject{connection;topologyConnection;get BaseUrl(){return this.connection.baseUrl}get properties(){return this.get()}get ID(){return this.get("ID")}get DFUServerName(){return this.get("DFUServerName")}get ClusterName(){return this.get("ClusterName")}get JobName(){return this.get("JobName")}get Queue(){return this.get("Queue")}get User(){return this.get("User")}get isProtected(){return this.get("isProtected")}get Command(){return this.get("Command")}get CommandMessage(){return this.get("CommandMessage")}get PercentDone(){return this.get("PercentDone")}get SecsLeft(){return this.get("SecsLeft")}get ProgressMessage(){return this.get("ProgressMessage")}get SummaryMessage(){return this.get("SummaryMessage")}get State(){return this.get("State",0)}get SourceLogicalName(){return this.get("SourceLogicalName")}get SourceIP(){return this.get("SourceIP")}get SourceFilePath(){return this.get("SourceFilePath")}get SourceDali(){return this.get("SourceDali")}get SourceRecordSize(){return this.get("SourceRecordSize")}get SourceFormat(){return this.get("SourceFormat")}get RowTag(){return this.get("RowTag")}get SourceNumParts(){return this.get("SourceNumParts")}get SourceDirectory(){return this.get("SourceDirectory")}get DestLogicalName(){return this.get("DestLogicalName")}get DestGroupName(){return this.get("DestGroupName")}get DestDirectory(){return this.get("DestDirectory")}get DestIP(){return this.get("DestIP")}get DestFilePath(){return this.get("DestFilePath")}get DestFormat(){return this.get("DestFormat")}get DestNumParts(){return this.get("DestNumParts")}get DestRecordSize(){return this.get("DestRecordSize")}get Replicate(){return this.get("Replicate")}get Overwrite(){return this.get("Overwrite")}get Compress(){return this.get("Compress")}get SourceCsvSeparate(){return this.get("SourceCsvSeparate")}get SourceCsvQuote(){return this.get("SourceCsvQuote")}get SourceCsvTerminate(){return this.get("SourceCsvTerminate")}get SourceCsvEscape(){return this.get("SourceCsvEscape")}get TimeStarted(){return this.get("TimeStarted")}get TimeStopped(){return this.get("TimeStopped")}get StateMessage(){return this.get("StateMessage")}get MonitorEventName(){return this.get("MonitorEventName")}get MonitorSub(){return this.get("MonitorSub")}get MonitorShotLimit(){return this.get("MonitorShotLimit")}get SourceDiffKeyName(){return this.get("SourceDiffKeyName")}get DestDiffKeyName(){return this.get("DestDiffKeyName")}get Archived(){return this.get("Archived")}get encrypt(){return this.get("encrypt")}get decrypt(){return this.get("decrypt")}get failIfNoSourceFile(){return this.get("failIfNoSourceFile")}get recordStructurePresent(){return this.get("recordStructurePresent")}get quotedTerminator(){return this.get("quotedTerminator")}get preserveCompression(){return this.get("preserveCompression")}get expireDays(){return this.get("expireDays")}get PreserveFileParts(){return this.get("PreserveFileParts")}get FileAccessCost(){return this.get("FileAccessCost")}get KbPerSecAve(){return this.get("KbPerSecAve")}get KbPerSec(){return this.get("KbPerSec")}static create(e,t){let s=new n(e);return s.connection.CreateDFUWorkunit({DFUServerQueue:t}).then(r=>(ci.set(s),s.set(r.result),s))}static attach(e,t,s){let r=ci.get({BaseUrl:e.baseUrl,ID:t},()=>new n(e,t));return s&&r.set(s),r}static sprayFixed(e,t){let s=new Xe(e);return s.SprayFixedEx({...t}).then(r=>{let i=r.wuid;return s.GetDFUWorkunit({wuid:i}).then(o=>n.attach(e,i,o.result))})}static sprayVariable(e,t){let s=new Xe(e);return s.SprayVariableEx({...t}).then(r=>{let i=r.wuid;return s.GetDFUWorkunit({wuid:i}).then(o=>n.attach(e,i,o.result))})}static despray(e,t){let s=new Xe(e);return s.DesprayEx({...t}).then(r=>{let i=r.wuid;return s.GetDFUWorkunit({wuid:i}).then(o=>n.attach(e,i,o.result))})}update(e){return this.connection.UpdateDFUWorkunitEx({wu:{JobName:e?.wu?.JobName??this.JobName,isProtected:e?.wu?.isProtected??this.isProtected,ID:this.ID,State:this.State},ClusterOrig:this.ClusterName,JobNameOrig:this.JobName,isProtectedOrig:this.isProtected,StateOrig:this.State})}isComplete(){switch(this.State){case 6:case 5:case 4:case 999:return!0;default:}return!1}isFailed(){return!!(this.isComplete()&&this.State!==6)}isDeleted(){return this.State===999}isRunning(){return!this.isComplete()}abort(){return this.connection.AbortDFUWorkunit({wuid:this.ID})}delete(){return this.DFUWUAction(Dt.DFUWUActions.Delete).then(e=>this.refresh().then(()=>(this._monitor(),e)))}async refresh(e=!1){return await this.GetDFUWorkunit(),this}fetchXML(e){return this.DFUWUFile()}_monitor(){if(this.isComplete()){this._monitorTickCount=0;return}super._monitor()}_monitorTimeoutDuration(){let e=super._monitorTimeoutDuration();return this._monitorTickCount<=1?3e3:this._monitorTickCount<=5?6e3:this._monitorTickCount<=7?12e3:e}DFUWUFile(e={}){return this.connection.DFUWUFileEx({...e,Wuid:this.ID}).then(t=>t).catch(t=>"")}DFUWUAction(e){return this.connection.DFUWorkunitsAction({wuids:{Item:[this.ID]},Type:e}).then(t=>e===Dt.DFUWUActions.Delete?t:this.refresh().then(()=>(this._monitor(),t)))}on(e,t,s){if(this.isCallback(t))switch(e){case"finished":super.on("propChanged","State",r=>{this.isComplete()&&t([r])});break;case"changed":super.on(e,t);break;default:}else e==="changed"&&super.on(e,t,s);return this._monitor(),this}watchUntilComplete(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),this.isComplete()&&(r.release(),t(this))})})}watchUntilRunning(e){return new Promise((t,s)=>{let r=this.watch(i=>{e&&e(i),(this.isComplete()||this.isRunning())&&(r.release(),t(this))})})}constructor(e,t){super(),this.connection=new Xe(e),this.topologyConnection=new oe(e),this.clearState(t)}clearState(e){this.clear({ID:e,State:0})}GetDFUWorkunit(e={}){return this.connection.GetDFUWorkunit({...e,wuid:this.ID}).then(t=>(this.set(t.result),t)).catch(t=>{if(!t.Exception.some(r=>r.Code===20080||r.Code===20081?(this.clearState(this.ID),this.set("State",999),!0):!1))throw ma.warning(`Unexpected ESP exception: ${t.message}`),t;return{}})}};var Di=Pe(require("node:child_process"),1),Ci=Pe(require("node:crypto"),1),me=Pe(require("node:fs"),1),ke=Pe(require("node:os"),1),De=Pe(require("node:path"),1),Pt=require("@hpcc-js/util");var mt=Pe(require("node:fs"),1),$=Pe(require("node:path"),1),Ae=require("@hpcc-js/util");var fa=(0,Ae.scopedLogger)("clienttools/eclmeta"),ha=!1;function Ut(n,e,t){if(ha){for(let s in n){let r=`${e}.${s}`;s!=="$"&&t[s]===void 0&&t[s.toLowerCase()+"s"]===void 0&&fa.debug(r)}n.$&&Ut(n.$,e+".$",t)}}var fn=class{__attrs;name;constructor(e){this.__attrs=e.$,this.name=e.$.name}},hn=class{__attrs;definition;get scope(){return this.definition}name;type;constructor(e,t){this.__attrs=t.$,this.definition=e,this.name=t.$.name,this.type=t.$.type}},ft=class{get scope(){return this}name;type;sourcePath;line;start;body;end;definitions;constructor(e,t,s,r,i=1,o=0,u=0,p=Number.MAX_VALUE){this.name=e,this.type=t,this.sourcePath=$.normalize(s),this.line=+i-1,this.start=+o,this.body=+u,this.end=+p,this.definitions=this.parseDefinitions(r)}parseDefinitions(e=[]){return e.map(t=>{let s=new Dn(this.sourcePath,t);return Ut(t,"definition",s),s})}contains(e){return e>=this.start&&e<=this.end}scopeStackAt(e){let t=[];return this.contains(e)&&(t.push(this),this.definitions.forEach(s=>{t=s.scopeStackAt(e).concat(t)})),t}_resolve(e=[],t){let s=t.split("."),r=s.shift(),i=(0,Ae.find)(e,o=>typeof o.name=="string"&&typeof r=="string"&&o.name.toLowerCase()===r.toLowerCase());return i&&i.definitions.length&&s.length?this._resolve(i.definitions,s.join(".")):i}resolve(e){return this._resolve(this.definitions,e)}suggestions(){return this.definitions.map(e=>({name:e.name,type:this.type}))}},Dn=class extends ft{__attrs;exported;shared;fullname;inherittype;attrs;fields;constructor(e,t){super(t.$.name,t.$.type,e,t.children("Definition"),t.$.line,t.$.start,t.$.body,t.$.end),this.__attrs=t.$,this.exported=!!t.$.exported,this.shared=!!t.$.shared,this.fullname=t.$.fullname,this.inherittype=t.$.inherittype,this.attrs=this.parseAttrs(t.children("Attr")),this.fields=this.parseFields(t.children("Field"))}parseAttrs(e=[]){return e.map(t=>{let s=new fn(t);return Ut(t,"attr",s),s})}parseFields(e=[]){return e.map(t=>{let s=new hn(this,t);return Ut(t,"field",s),s})}suggestions(){return super.suggestions().concat(this.fields.map(e=>({name:e.name,type:e.type})))}},rs=class{__attrs;name;ref;start;end;line;constructor(e){this.__attrs=e.$,this.name=e.$.name,this.ref=e.$.ref,this.start=e.$.start,this.end=e.$.end,this.line=e.$.line}},Cn=class extends ft{imports;__attrs;constructor(e){super(e.$.name,"source",e.$.sourcePath,e.children("Definition")),this.__attrs=e.$;let t=e.$.name.split(".");t.pop();let s=new Ae.XMLNode("");s.appendAttribute("name","$"),s.appendAttribute("ref",t.join(".")),this.imports=[new rs(s),...this.parseImports(e.children("Import"))]}parseImports(e=[]){return e.map(t=>{let s=new rs(t);return Ut(t,"import",s),s})}resolve(e,t){let s;return!s&&t!==void 0&&this.scopeStackAt(t).some(i=>(s=i.resolve(e),!!s)),s||(s=super.resolve(e)),s}},Da=n=>$.basename(n).indexOf(".")===0,li=n=>mt.lstatSync(n).isDirectory()&&!Da(n),Ca=n=>[".ecl",".ecllib"].indexOf($.extname(n).toLowerCase())>=0,pi=n=>mt.readdirSync(n).map(e=>$.join(n,e)).filter(e=>li(e)||Ca(e)),Rn=class extends ft{constructor(e,t){super(e,"file",t,[])}suggestions(){return[]}},Sn=class extends ft{constructor(e,t){super(e,"folder",t,[])}suggestions(){return pi(this.sourcePath).map(e=>({name:$.basename(e,".ecl"),type:"folder"}))}},yn=class{_workspacePath;_eclccPath;_clientTools;_sourceByID=new Ae.DictionaryNoCase;_sourceByPath=new Ae.Dictionary;_test=new Ae.DictionaryNoCase;constructor(e,t){this._workspacePath=e,this._eclccPath=t}refresh(){this.primeWorkspace(),this.primeClientTools()}primeClientTools(){return fr(this._eclccPath,"",this._workspacePath).then(e=>(this._clientTools=e,e.paths())).then(e=>{for(let t of["ECLCC_ECLLIBRARY_PATH","ECLCC_PLUGIN_PATH"])e[t]&&mt.existsSync(e[t])&&this.walkChildFolders(e[t],e[t]);return this})}primeWorkspace(){mt.existsSync(this._workspacePath)&&this.visitFolder(this._workspacePath,this._workspacePath)}walkChildFolders(e,t,s=!1){for(let r of pi(e))li(r)?this.visitFolder(r,t,s):this.visitFile(r,t,s)}visitFile(e,t,s=!1){let r=$.parse(e),i=$.join(r.dir,r.name),o=$.relative(t,i).split($.sep).join(".");(s||!this._test.has(o))&&this._test.set(o,new Rn("",e))}visitFolder(e,t,s=!1){let r=$.relative(t,e).split($.sep).join(".");(s||!this._test.has(r))&&(this._test.set(r,new Sn(r,e)),this.walkChildFolders(e,t,s))}buildStack(e,t,s){let r=t.split(".");s&&e[e.length-1]===r[0]&&r.shift();let i=[...e,...r],o=i.join(".");return{stack:i,qid:o}}walkECLScope(e,t){let s=this.buildStack(e,t.name,!0);this._test.set(s.qid,t);for(let r of t.definitions)this.walkDefinition(s.stack,r)}walkField(e,t){let s=this.buildStack(e,t.name,!1);this._test.set(s.qid,t)}walkDefinition(e,t){let s=this.buildStack(e,t.name,!0);this.walkECLScope(e,t);for(let r of t.fields)this.walkField(s.stack,r)}walkSource(e){this.walkECLScope([],e)}parseSources(e=[]){for(let t of e)if(t.$.name){let s=new Cn(t);if(Ut(t,"source",s),this._sourceByID.set(s.name,s),this._sourceByPath.set(s.sourcePath,s),s.name){let i=s.name.split(".").length;if(i>1){let o=s.sourcePath;for(;i>1;)o=$.dirname(o),--i;this.visitFolder(o,$.dirname(o))}}this.walkSource(s)}}parseMetaXML(e){let t=new mr;return t.parse(e),this.parseSources(t.sources),t.sources.map(s=>$.normalize(s.$.sourcePath))}resolveQualifiedID(e,t,s){let r;if(!r&&this._test.has(t)&&(r=this._test.get(t).scope),!r&&this._sourceByPath.has(e)){let i=this._sourceByPath.get(e),o=t.split(".");for(let p of i.imports)if(p.name.toLowerCase()===o[0].toLowerCase()){p.ref?o[0]=p.ref:o.shift();break}let u=o.join(".");!r&&this._test.has(u)&&(r=this._test.get(u).scope),r||(u=[...i.name.split("."),...o].join("."),this._test.has(u)&&(r=this._test.get(u).scope))}return r}resolvePartialID(e,t,s){t=t.toLowerCase();let r=t.split(".");r.pop();let i=r.length===1?r[0]:r.join(".");return this.resolveQualifiedID(e,i,s)}},dr=new Ae.Dictionary;function tt(n,e){let t=$.normalize(n);if(!dr.has(t)){let s=new yn(t,e);dr.set(t,s),s.refresh()}return dr.get(t)}function Ra(n,e,t){if(e<0)return!1;let s=n.charAt(e);return(t?/[a-zA-Z\d_\.$]/:/[a-zA-Z\d_]/).test(s)}function Sa(n,e,t){for(;Ra(n,e,t);)e+=t?-1:1;return e+(t?1:-1)}var mr=class extends Ae.SAXStackParser{sources=[];endXMLNode(e){e.name==="Source"&&this.sources.push(e),super.endXMLNode(e)}};var Et=(0,Pt.scopedLogger)("clienttools/eclcc"),hr=ke.type()==="Windows_NT"?".exe":"";function gi(n){return n.split(`\r
916
916
  `).join(`
917
917
  `).split("\r").join(`
918
918
  `)}var Ft=class{prefix="";major=0;minor=0;patch=0;postfix="";constructor(e){let t=e.split(" ");if(t.length){let s=/(?:(\w+)_)?(\d+)\.(\d+)\.(\d+)(?:-(.*))?/.exec(t[t.length-1]);s&&(this.prefix=s[1]||"",this.major=+s[2]||0,this.minor=+s[3]||0,this.patch=+s[4]||0,this.postfix=s[5]||"")}}parse(e){}exists(){return this.major!==0||this.minor!==0||this.patch!==0||this.postfix!==""}compare(e){return this.major>e.major?1:this.major<e.major?-1:this.minor>e.minor?1:this.minor<e.minor?-1:this.patch>e.patch?1:this.patch<e.patch?-1:this.postfix===""&&e.postfix!==""?1:this.postfix.localeCompare(e.postfix)}toString(){return`${this.prefix}_${this.major}.${this.minor}.${this.patch}-${this.postfix}`}},di="error",mi="warning",os=class{_checked;errWarn=[];errOther=[];constructor(e){this._checked=e}checked(){return this._checked}all(){return this.errWarn}errors(){return this.errWarn.filter(e=>e.severity===di)}hasError(){return this.errors().length>0}warnings(){return this.errWarn.filter(e=>e.severity===mi)}hasWarning(){return this.warnings().length>0}info(){return this.errWarn.filter(e=>[di,mi].indexOf(e.severity)<0)}hasOther(){return this.info().length>0}unknown(){return this.errOther}hasUnknown(){return this.unknown().length>0}},as=class extends os{constructor(e,t){if(super(t),e&&e.length)for(let s of e.split(ke.EOL)){let r=/([a-zA-Z]:\\(?:[- \w\.\d]+\\)*(?:[- \w\.\d]+)?|(?:\/[\w\.\-]+)+)\((\d*),(\d*)\) ?: ?(error|warning|info) C(\d*) ?: ?(.*)/.exec(s);if(r){let[,i,o,u,p,A,l]=r,x=+o,S=+u,M=A+": "+l;this.errWarn.push({filePath:i,line:x,col:S,msg:M,severity:p});continue}if(r=/(error|warning|info): (.*)/i.exec(s),r){let[,i,o]=r;this.errWarn.push({filePath:"",line:0,col:0,msg:o,severity:i});continue}r=/\d error(s?), \d warning(s?)/.exec(s),!r&&(Et.warning(`parseECLErrors: Unable to parse "${s}"`),this.errOther.push(s))}this._checked=t}},Wn=class extends os{_lines;constructor(e,t,s){super(s);let r=me.readFileSync(e,"utf8");if(r=r.replace(/\r\n/g,`