@magic-xpa/engine 4.1000.0-dev4100.99 → 4.1100.0-dev4110.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/esm2020/src/ClientManager.mjs +12 -12
  2. package/esm2020/src/ConstInterface.mjs +2 -1
  3. package/esm2020/src/CurrentClientVersion.mjs +2 -2
  4. package/esm2020/src/commands/ClientToServer/DataviewCommand.mjs +6 -6
  5. package/esm2020/src/commands/ClientToServer/EvaluateCommand.mjs +4 -4
  6. package/esm2020/src/commands/ClientToServer/EventCommand.mjs +8 -8
  7. package/esm2020/src/commands/ClientToServer/ExecOperCommand.mjs +4 -4
  8. package/esm2020/src/commands/ClientToServer/IniputForceWriteCommand.mjs +5 -5
  9. package/esm2020/src/commands/ClientToServer/RecomputeCommand.mjs +7 -7
  10. package/esm2020/src/commands/ClientToServer/TransactionCommand.mjs +6 -6
  11. package/esm2020/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +8 -8
  12. package/esm2020/src/commands/ServerToClient/ResultCommand.mjs +7 -7
  13. package/esm2020/src/data/DataView.mjs +34 -34
  14. package/esm2020/src/data/DataviewManager.mjs +7 -7
  15. package/esm2020/src/data/Record.mjs +10 -10
  16. package/esm2020/src/data/TaskTransactionManager.mjs +4 -4
  17. package/esm2020/src/data/XMLBasedDcValuesBuilder.mjs +5 -5
  18. package/esm2020/src/env/Environment.mjs +14 -7
  19. package/esm2020/src/event/Event.mjs +4 -1
  20. package/esm2020/src/event/EventHandler.mjs +8 -3
  21. package/esm2020/src/event/EventHandlerPosition.mjs +5 -1
  22. package/esm2020/src/event/EventsManager.mjs +10 -1
  23. package/esm2020/src/event/IEventsManager.mjs +1 -1
  24. package/esm2020/src/event/RunTimeEvent.mjs +16 -16
  25. package/esm2020/src/exp/ExpressionEvaluator.mjs +8 -4
  26. package/esm2020/src/gui/FormsTable.mjs +8 -8
  27. package/esm2020/src/gui/MgControl.mjs +10 -13
  28. package/esm2020/src/gui/MgForm.mjs +9 -23
  29. package/esm2020/src/http/HttpManager.mjs +8 -8
  30. package/esm2020/src/remote/RemoteCommandsProcessor.mjs +34 -23
  31. package/esm2020/src/rt/DataviewHeaderBase.mjs +16 -16
  32. package/esm2020/src/security/UserDetails.mjs +12 -12
  33. package/esm2020/src/tasks/MGData.mjs +4 -4
  34. package/esm2020/src/tasks/RCTimer.mjs +10 -10
  35. package/esm2020/src/tasks/Task.mjs +43 -42
  36. package/esm2020/src/util/FlowMonitorQueue.mjs +107 -2
  37. package/esm2020/src/util/PrmMap.mjs +5 -5
  38. package/esm2020/src/util/ReturnResult.mjs +7 -7
  39. package/fesm2015/magic-xpa-engine.mjs +461 -338
  40. package/fesm2015/magic-xpa-engine.mjs.map +1 -1
  41. package/fesm2020/magic-xpa-engine.mjs +456 -326
  42. package/fesm2020/magic-xpa-engine.mjs.map +1 -1
  43. package/package.json +6 -6
  44. package/src/ConstInterface.d.ts +1 -0
  45. package/src/env/Environment.d.ts +2 -0
  46. package/src/event/EventsManager.d.ts +3 -0
  47. package/src/event/IEventsManager.d.ts +2 -0
  48. package/src/exp/ExpressionEvaluator.d.ts +1 -1
  49. package/src/gui/MgControl.d.ts +0 -1
  50. package/src/gui/MgForm.d.ts +1 -3
  51. package/src/remote/RemoteCommandsProcessor.d.ts +1 -0
  52. package/src/util/FlowMonitorQueue.d.ts +8 -0
  53. package/magic-xpa-engine.d.ts +0 -2
@@ -1,5 +1,6 @@
1
+ import { BlobType, DisplayConvertor, PIC, VectorType } from '@magic-xpa/gui';
1
2
  import { DateTime, NString, StringBuilder } from '@magic-xpa/mscorelib';
2
- import { Constants, DateTimeUtils, InternalInterface, Logger, Queue, XMLConstants, XmlParser } from '@magic-xpa/utils';
3
+ import { Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser } from '@magic-xpa/utils';
3
4
  import { FlowMonitorInterface } from '../FlowMonitorInterface';
4
5
  import { ConstInterface } from '../ConstInterface';
5
6
  export class FlowMonitorQueue {
@@ -10,7 +11,17 @@ export class FlowMonitorQueue {
10
11
  this._isRecompute = false;
11
12
  this._isTask = false;
12
13
  this._isTaskFlow = false;
14
+ this._isDataView = false;
13
15
  this.ShouldSerialize = false;
16
+ this.padRight = (string, length, character = ' ') => {
17
+ let result = "";
18
+ let totalLength = length - string.length;
19
+ for (let i = 0; i < totalLength; i++) {
20
+ result = character + result;
21
+ }
22
+ result = result + string;
23
+ return result;
24
+ };
14
25
  }
15
26
  static get Instance() {
16
27
  if (FlowMonitorQueue._instance === null)
@@ -68,6 +79,9 @@ export class FlowMonitorQueue {
68
79
  case ConstInterface.MG_ATTR_TASKFLW:
69
80
  this._isTaskFlow = XmlParser.getBoolean(valueStr);
70
81
  break;
82
+ case ConstInterface.MG_TAG_DATAVIEW:
83
+ this._isDataView = XmlParser.getBoolean(valueStr);
84
+ break;
71
85
  case ConstInterface.MG_ATTR_RECOMP:
72
86
  this._isRecompute = XmlParser.getBoolean(valueStr);
73
87
  break;
@@ -125,6 +139,96 @@ export class FlowMonitorQueue {
125
139
  Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
126
140
  }
127
141
  }
142
+ appendVirtualsAndParameters(currentValues) {
143
+ let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);
144
+ act.setInfo(currentValues);
145
+ this._queue.put(act);
146
+ }
147
+ addDataViewFlow(task) {
148
+ if (this._isDataView) {
149
+ let fldTab = task.DataView.GetFieldsTab();
150
+ let preparedDisplayString = "";
151
+ let finaldisplayData = "\n";
152
+ let fldValue;
153
+ let data = "";
154
+ for (let i = 0; i < fldTab.getSize(); i++) {
155
+ let fldDef = fldTab.getField(i);
156
+ if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam()) {
157
+ fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);
158
+ data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);
159
+ preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);
160
+ finaldisplayData = finaldisplayData + preparedDisplayString + "\n";
161
+ }
162
+ }
163
+ this.appendVirtualsAndParameters(finaldisplayData);
164
+ }
165
+ }
166
+ getFieldData(Storagetype, data, picture, vecCellType, task) {
167
+ switch (Storagetype) {
168
+ case StorageAttribute.DOTNET:
169
+ data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
170
+ break;
171
+ case StorageAttribute.BLOB:
172
+ {
173
+ if (BlobType.isValidBlob(data)) {
174
+ let contentType = BlobType.getContentType(data);
175
+ if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)
176
+ data = data != null ? BlobType.getString(data) : "";
177
+ else
178
+ data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
179
+ }
180
+ else
181
+ data = "";
182
+ }
183
+ break;
184
+ case StorageAttribute.NUMERIC:
185
+ case StorageAttribute.DATE:
186
+ case StorageAttribute.TIME:
187
+ let conv = DisplayConvertor.Instance;
188
+ data = conv.mg2disp(data, " ", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);
189
+ break;
190
+ case StorageAttribute.BLOB_VECTOR:
191
+ let vecOutData;
192
+ if (data == null) {
193
+ vecOutData = "[]";
194
+ }
195
+ else {
196
+ let cellAtt = vecCellType;
197
+ let vector = new VectorType(data);
198
+ if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))
199
+ vecOutData = "[]";
200
+ else {
201
+ let vecSize = VectorType.getVecSize(data);
202
+ let cellPicture = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;
203
+ vecOutData = "[";
204
+ for (let i = 0; i < vecSize; i++) {
205
+ vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);
206
+ vecOutData += i < vecSize - 1 ? "," : "]";
207
+ }
208
+ }
209
+ }
210
+ data = vecOutData;
211
+ break;
212
+ case StorageAttribute.BOOLEAN:
213
+ data = data == "1" ? "TRUE" : "FALSE";
214
+ break;
215
+ }
216
+ return data;
217
+ }
218
+ PrepareDisplayString(mode, name, valueContent, addDoubleQuotes) {
219
+ let str = "";
220
+ let finalStringToDisplay = "";
221
+ if (addDoubleQuotes)
222
+ finalStringToDisplay = finalStringToDisplay + "\"";
223
+ finalStringToDisplay = finalStringToDisplay + name;
224
+ if (addDoubleQuotes)
225
+ finalStringToDisplay = finalStringToDisplay + "\"";
226
+ let paddedName = this.padRight(name, 34);
227
+ let formatOfStringVirtual = `Virtual`;
228
+ let formatOfStringParameter = `Parameter`;
229
+ str = (mode ? formatOfStringParameter : formatOfStringVirtual) + " : " + `${paddedName}` + " : " + `${valueContent.trim()}`;
230
+ return str;
231
+ }
128
232
  addTaskFlowRec(id, state, taskInfo) {
129
233
  if (this._enabled && this._isTaskFlow) {
130
234
  let info;
@@ -289,6 +393,7 @@ export class FlowMonitorQueue {
289
393
  }
290
394
  }
291
395
  FlowMonitorQueue._instance = null;
396
+ FlowMonitorQueue.UNPRINTABLE_STR_LOG = "#UNPRINTABLE#";
292
397
  FlowMonitorQueue.S_EVENT_STR1 = ">>Starts ";
293
398
  FlowMonitorQueue.S_EVENT_STR2 = " Event";
294
399
  FlowMonitorQueue.S_EVENT_PROPAGATED = "Event was propagated";
@@ -345,4 +450,4 @@ class ActivityItem {
345
450
  message.Append(XMLConstants.TAG_TERM);
346
451
  }
347
452
  }
348
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowMonitorQueue.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/FlowMonitorQueue.ts"],"names":[],"mappings":"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","sourcesContent":["import {IFlowMonitorQueue} from '@magic-xpa/gui';\r\nimport {DateTime, List, NString, StringBuilder} from '@magic-xpa/mscorelib';\r\nimport {Constants, DateTimeUtils, InternalInterface, Logger, Queue, XMLConstants, XmlParser} from '@magic-xpa/utils';\r\nimport {Operation} from '../rt/Operation';\r\nimport {FlowMonitorInterface} from '../FlowMonitorInterface';\r\nimport {ConstInterface} from '../ConstInterface';\r\n\r\n// @dynamic\r\nexport class FlowMonitorQueue implements IFlowMonitorQueue {\r\n  private static _instance: FlowMonitorQueue = null;\r\n  private static S_EVENT_STR1: string = \">>Starts \";\r\n  private static S_EVENT_STR2: string = \" Event\";\r\n  private static S_EVENT_PROPAGATED: string = \"Event was propagated\";\r\n  private static E_EVENT_STR: string = \"<<Ends Event\";\r\n\r\n  private static S_RECPRF_STR: string = \"Starts Record Prefix\";\r\n  private static E_RECPRF_STR: string = \"Ends Record Prefix\";\r\n  private static S_RECSUF_STR: string = \"Starts Record Suffix\";\r\n  private static E_RECSUF_STR: string = \"Ends Record Suffix\";\r\n  private static S_TASKSUF_STR: string = \"Starts Task Suffix\";\r\n  private static E_TASKSUF_STR: string = \"Ends Task Suffix\";\r\n  private static S_TASKPRF_STR: string = \"Starts Task Prefix\";\r\n  private static E_TASKPRF_STR: string = \"Ends Task Prefix\";\r\n  private static S_CTRLPRF_STR: string = \"Starts Control Prefix - \";\r\n  private static E_CTRLPRF_STR: string = \"Ends Control Prefix - \";\r\n  private static S_CTRLSUF_STR: string = \"Starts Control Suffix - \";\r\n  private static E_CTRLSUF_STR: string = \"Ends Control Suffix - \";\r\n  private static S_HANDLER_STR: string = \"Starts handling event {0}\";\r\n  private static E_HANDLER_STR: string = \"Ends handling event {0}\";\r\n  private static S_CTRLVER_STR: string = \"Starts Control Verification for Control - \";\r\n  private static E_CTRLVER_STR: string = \"Ends Control Verification for Control - \";\r\n  private static RECOMP_STR: string = \"Recomputes - \";\r\n  private static S_VARIABLE_STR: string = \"Starts Variable Change - \";\r\n  private static E_VARIABLE_STR: string = \"Ends Variable Change - \";\r\n  private static VARIABLE_REASON_STR: string = \" - Reason - Previous value\";\r\n\r\n\r\n  private static FLW_PERFIX: string = \"Flow - \";\r\n\r\n  private static ACT_TASK: string = 'T';\r\n  private static ACT_TASK_FLW: string = 'F';\r\n  private static ACT_RECOMPUTE: string = 'R';\r\n  private static ACT_FLW_OPER: string = 'T';\r\n\r\n  static LongTimePattern = \"HH:mm:ss:SSS\";\r\n  private _queue: Queue<ActivityItem> = new Queue<ActivityItem>();\r\n  private _enabled: boolean = false;\r\n  private _isFlowOperation: boolean = false;\r\n  private _isRecompute: boolean = false;\r\n  private _isTask: boolean = false;\r\n  private _isTaskFlow: boolean = false;\r\n  ShouldSerialize: boolean = false;\r\n\r\n  static get Instance(): FlowMonitorQueue {\r\n    if (FlowMonitorQueue._instance === null)\r\n      FlowMonitorQueue._instance = new FlowMonitorQueue();\r\n\r\n    return FlowMonitorQueue._instance;\r\n  }\r\n\r\n  addTaskCngMode(newTaskMode: string, taskInfo: string): void {\r\n    let info: string = \"Task Mode Change - \";\r\n    if (this._enabled && this._isTask) {\r\n      let activityItem: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_CHNG_MODE);\r\n\r\n      switch (newTaskMode) {\r\n        case Constants.TASK_MODE_MODIFY:\r\n          info += \"Modify\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_CREATE:\r\n          info += \"Create\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_DELETE:\r\n          info += \"Delete\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_QUERY:\r\n          info += \"Query\";\r\n          break;\r\n\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      activityItem.setInfo(info);\r\n      this._queue.put(activityItem);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    let endContext: number = parser.getXMLdata().indexOf(\"/>\", parser.getCurrIndex());\r\n    if (endContext !== -1 && endContext < parser.getXMLdata().length) {\r\n      // find last position of its tag\r\n      let tag: string = parser.getXMLsubstring(endContext);\r\n      parser.add2CurrIndex(tag.indexOf(\"flwmtr_config\") + \"flwmtr_config\".length);\r\n\r\n      let tokens: List<string> = XmlParser.getTokens(parser.getXMLsubstring(endContext), XMLConstants.XML_ATTR_DELIM);\r\n      Logger.Instance.WriteDevToLog(\"in FlowMonitorQueue.FillData: \" + tokens.toString());\r\n\r\n      this.initElements(tokens);\r\n      parser.setCurrIndex(endContext + XMLConstants.TAG_TERM.length); // to delete \"/>\" too\r\n      return;\r\n    }\r\n    Logger.Instance.WriteExceptionToLogWithMsg(\"in  FlowMonitorQueue.FillData() out of string bounds\");\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the XML data\r\n  /// </summary>\r\n  /// <param name = \"tokensVector\">attribute/value/...attribute/value/ vector</param>\r\n  private initElements(tokensVector: List<string>): void {\r\n\r\n    for (let j: number = 0; j < tokensVector.length; j = j + 2) {\r\n      let attribute: string = <string>tokensVector.get_Item(j);\r\n      let valueStr: string = <string>tokensVector.get_Item(j + 1);\r\n      Logger.Instance.WriteDevToLog(attribute + \" value: \" + valueStr);\r\n\r\n      switch (attribute) {\r\n        case ConstInterface.MG_ATTR_TASK:\r\n          this._isTask = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_TASKFLW:\r\n          this._isTaskFlow = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_RECOMP:\r\n          this._isRecompute = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_FLWOP:\r\n          this._isFlowOperation = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_ENABLED:\r\n          this.enable(XmlParser.getBoolean(valueStr));\r\n          break;\r\n\r\n        default:\r\n          Logger.Instance.WriteExceptionToLogWithMsg(\"in FlowMonitorQueue.initElements(): unknown  attribute: \" + attribute);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML and empty the inner queue\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    if (!this._queue.isEmpty() && this.ShouldSerialize) {\r\n      message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n\r\n      while (!this._queue.isEmpty()) {\r\n        let currAct: ActivityItem = <ActivityItem>this._queue.get();\r\n        currAct.buildXML(message);\r\n      } // fill activities\r\n\r\n      message.Append(\"</\" + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n    } // the queue is not empty\r\n  }\r\n\r\n  /// <summary>\r\n  ///   is the Flow Monitor Queue empty\r\n  /// </summary>\r\n  isEmpty(): boolean {\r\n    return this._queue.isEmpty();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   enable the flow monitor\r\n  /// </summary>\r\n  /// <returns>the previous state (enabled/disabled)</returns>\r\n  enable(value: boolean): boolean {\r\n    let wasEnabled: boolean = this._enabled;\r\n    this._enabled = value;\r\n    this.ShouldSerialize = this._enabled;\r\n    return wasEnabled;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   add Activities to the queue\r\n  /// </summary>\r\n  /// <param name = \"triggeredBy\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskEvent(triggeredBy: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTask) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_EVENT);\r\n\r\n      let info: string;\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = FlowMonitorQueue.S_EVENT_STR1 + triggeredBy + FlowMonitorQueue.S_EVENT_STR2;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = FlowMonitorQueue.E_EVENT_STR + triggeredBy;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_PROPAGATE:\r\n          info = FlowMonitorQueue.S_EVENT_PROPAGATED;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   add task flow for record prefix or sufix\r\n  /// </summary>\r\n  /// <param name = \"id\">is FLWMTR_PREFIX or FLWMTR_SUFFIX\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowRec(id: number, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_REC_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECPRF_STR\r\n            : FlowMonitorQueue.E_RECPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_REC_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECSUF_STR\r\n            : FlowMonitorQueue.E_RECSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKPRF_STR\r\n            : FlowMonitorQueue.E_TASKPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKSUF_STR\r\n            : FlowMonitorQueue.E_TASKSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"id\">is MG_ACT_VARIABLE</param>\r\n  /// <param name = \"fldName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowFld(id: number, fldName: string, state: number, taskInfo: string): void {\r\n    this.addTaskFlowCtrl(id, fldName, state, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"id\">is FLWMTR_CTRL_PREFIX or FLWMTR_CTRL_SUFFIX</param>\r\n  /// <param name = \"ctrlName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowCtrl(id: number, ctrlName: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_VARIABLE:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_VARIABLE_STR\r\n            : FlowMonitorQueue.E_VARIABLE_STR;\r\n          id = FlowMonitorInterface.FLWMTR_VARCHG_VALUE;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLPRF_STR\r\n            : FlowMonitorQueue.E_CTRLPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_PREFIX;\r\n          break;\r\n\r\n\r\n        case InternalInterface.MG_ACT_CTRL_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLSUF_STR\r\n            : FlowMonitorQueue.E_CTRLSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_VERIFICATION:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLVER_STR\r\n            : FlowMonitorQueue.E_CTRLVER_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      if (info !== null) {\r\n        info = info + ctrlName;\r\n        if (id === FlowMonitorInterface.FLWMTR_VARCHG_VALUE && state === FlowMonitorInterface.FLWMTR_START)\r\n          info = info + FlowMonitorQueue.VARIABLE_REASON_STR;\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"handlerId\">isid of the handler\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowHandler(handlerId: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, FlowMonitorInterface.FLWMTR_TSK_HANDLER);\r\n      let info: string;\r\n\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = NString.Format(FlowMonitorQueue.S_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = NString.Format(FlowMonitorQueue.E_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      if (info !== null) {\r\n        // BRK_LEVEL_HANDLER_INTERNAL,BRK_LEVEL_HANDLER_SYSTEM,BRK_LEVEL_HANDLER_TIMER\r\n        // BRK_LEVEL_HANDLER_EXPRESSION,BRK_LEVEL_HANDLER_ERROR,BRK_LEVEL_HANDLER_USER\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"triggeredByVarName\">var name , has triggered Recompute\r\n  /// </param>\r\n  addRecompute(triggeredByVarName: string, taskInfo: string): void {\r\n    if (this._enabled && this._isRecompute) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_RECOMPUTE, FlowMonitorInterface.FLWMTR_RECOMP);\r\n      let info = FlowMonitorQueue.RECOMP_STR + triggeredByVarName;\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Add a field flow operation activity item.\r\n  /// </summary>\r\n  /// <param name = \"oper\">The operation being logged.</param>\r\n  /// <param name = \"bExecuted\">Will the operation be executed.</param>\r\n  async addFlowFieldOperation(oper: Operation, bExecuted: boolean, taskInfo: string): Promise<void> {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n      let buffer: StringBuilder = new StringBuilder(FlowMonitorQueue.FLW_PERFIX);\r\n      await oper.AddFlowDescription(buffer);\r\n      buffer.Append(' ');\r\n\r\n\r\n      if (!bExecuted)\r\n        buffer.Append(\"[Not Executed]\");\r\n\r\n      let info = buffer.ToString();\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"state\">of the update\r\n  /// </param>\r\n  addFlowOperationUpdate(state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER); // MG_OPER_UPDATE\r\n      let info: string;\r\n      if (state === FlowMonitorInterface.FLWMTR_START)\r\n        info = \"Starts Update\";\r\n      else\r\n        info =  \"Ends Update\";\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"info\">string passed to status line verify action</param>\r\n  addFlowVerifyInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"info\">string added to flow monitor queue for InvokeOs</param>\r\n  addFlowInvokeOsInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   user string passed to status line for actions\r\n  /// </summary>\r\n  /// <param name = \"info\">\r\n  /// </param>\r\n  private addFlowInfo(info: string, taskInfo: string): void {\r\n    if (!this._enabled)\r\n      return;\r\n\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n    let buffer: StringBuilder = new StringBuilder(\"\");\r\n\r\n    if (!(info === \"\")) {\r\n      buffer.Append(\" >> INFORMATION >> \");\r\n      buffer.Append(info);\r\n    }\r\n    let newInfo = buffer.ToString();\r\n    act.setInfo(newInfo);\r\n    this._queue.put(act);\r\n\r\n    Logger.Instance.WriteSupportToLog(taskInfo +\": \" + newInfo, true);\r\n  }\r\n}\r\n\r\n/// <summary>\r\n///   all information about current Activity\r\n/// </summary>\r\nclass ActivityItem {\r\n  private _id: number = 0;\r\n  private _type: string = null; // ACTY_TASK|ACT_TASK_FLW|ACT_DATAVIEW|ACT_RECOMPUTE|ACT_FLW_OPER\r\n  private _info: string = null;\r\n  private _time: string = null;\r\n\r\n  constructor(enclosingInstance: FlowMonitorQueue, type: string, id: number) {\r\n    this._type = type;\r\n    this._id = id;\r\n    this.setTime();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   save current time in the needed format\r\n  /// </summary>\r\n  private setTime(): void {\r\n    this._time = DateTimeUtils.ToString(DateTime.Now, FlowMonitorQueue.LongTimePattern, Logger.Instance);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   set added information for the activity\r\n  /// </summary>\r\n  setInfo(info_: string): void {\r\n    this._info = ((info_ !== null) ? XmlParser.escape(info_) : info_);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML string for the activity item\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_ACT);\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_TYPE + \"=\\\"\" + this._type + \"\\\"\");\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_ID + \"=\\\"\" + this._id + \"\\\"\");\r\n    if (this._info != null)\r\n      message.Append(\" \" + ConstInterface.MG_ATTR_INFO + \"=\\\"\" + this._info + \"\\\"\");\r\n    message.Append(\" \" + ConstInterface.MG_ATTR_TIME + \"=\\\"\" + this._time + \"\\\"\");\r\n    message.Append(XMLConstants.TAG_TERM);\r\n  }\r\n}\r\n"]}
453
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowMonitorQueue.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/FlowMonitorQueue.ts"],"names":[],"mappings":"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","sourcesContent":["import {BlobType, DisplayConvertor, FieldsTable, IFlowMonitorQueue, PIC, VectorType} from '@magic-xpa/gui';\r\nimport {DateTime, List, NString, StringBuilder} from '@magic-xpa/mscorelib';\r\nimport {Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser} from '@magic-xpa/utils';\r\nimport {Operation} from '../rt/Operation';\r\nimport {FlowMonitorInterface} from '../FlowMonitorInterface';\r\nimport {ConstInterface} from '../ConstInterface';\r\nimport { Task } from '../tasks/Task';\r\nimport { Field } from '../data/Field';\r\n\r\n// @dynamic\r\nexport class FlowMonitorQueue implements IFlowMonitorQueue {\r\n  private static _instance: FlowMonitorQueue = null;\r\n  private static UNPRINTABLE_STR_LOG: string = \"#UNPRINTABLE#\";\r\n  private static S_EVENT_STR1: string = \">>Starts \";\r\n  private static S_EVENT_STR2: string = \" Event\";\r\n  private static S_EVENT_PROPAGATED: string = \"Event was propagated\";\r\n  private static E_EVENT_STR: string = \"<<Ends Event\";\r\n\r\n  private static S_RECPRF_STR: string = \"Starts Record Prefix\";\r\n  private static E_RECPRF_STR: string = \"Ends Record Prefix\";\r\n  private static S_RECSUF_STR: string = \"Starts Record Suffix\";\r\n  private static E_RECSUF_STR: string = \"Ends Record Suffix\";\r\n  private static S_TASKSUF_STR: string = \"Starts Task Suffix\";\r\n  private static E_TASKSUF_STR: string = \"Ends Task Suffix\";\r\n  private static S_TASKPRF_STR: string = \"Starts Task Prefix\";\r\n  private static E_TASKPRF_STR: string = \"Ends Task Prefix\";\r\n  private static S_CTRLPRF_STR: string = \"Starts Control Prefix - \";\r\n  private static E_CTRLPRF_STR: string = \"Ends Control Prefix - \";\r\n  private static S_CTRLSUF_STR: string = \"Starts Control Suffix - \";\r\n  private static E_CTRLSUF_STR: string = \"Ends Control Suffix - \";\r\n  private static S_HANDLER_STR: string = \"Starts handling event {0}\";\r\n  private static E_HANDLER_STR: string = \"Ends handling event {0}\";\r\n  private static S_CTRLVER_STR: string = \"Starts Control Verification for Control - \";\r\n  private static E_CTRLVER_STR: string = \"Ends Control Verification for Control - \";\r\n  private static RECOMP_STR: string = \"Recomputes - \";\r\n  private static S_VARIABLE_STR: string = \"Starts Variable Change - \";\r\n  private static E_VARIABLE_STR: string = \"Ends Variable Change - \";\r\n  private static VARIABLE_REASON_STR: string = \" - Reason - Previous value\";\r\n\r\n\r\n  private static FLW_PERFIX: string = \"Flow - \";\r\n\r\n  private static ACT_TASK: string = 'T';\r\n  private static ACT_TASK_FLW: string = 'F';\r\n  private static ACT_RECOMPUTE: string = 'R';\r\n  private static ACT_FLW_OPER: string = 'T';\r\n\r\n  static LongTimePattern = \"HH:mm:ss:SSS\";\r\n  private _queue: Queue<ActivityItem> = new Queue<ActivityItem>();\r\n  private _enabled: boolean = false;\r\n  private _isFlowOperation: boolean = false;\r\n  private _isRecompute: boolean = false;\r\n  private _isTask: boolean = false;\r\n  private _isTaskFlow: boolean = false;\r\n  private _isDataView: boolean = false;\r\n  ShouldSerialize: boolean = false;\r\n\r\n  static get Instance(): FlowMonitorQueue {\r\n    if (FlowMonitorQueue._instance === null)\r\n      FlowMonitorQueue._instance = new FlowMonitorQueue();\r\n\r\n    return FlowMonitorQueue._instance;\r\n  }\r\n\r\n  addTaskCngMode(newTaskMode: string, taskInfo: string): void {\r\n    let info: string = \"Task Mode Change - \";\r\n    if (this._enabled && this._isTask) {\r\n      let activityItem: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_CHNG_MODE);\r\n\r\n      switch (newTaskMode) {\r\n        case Constants.TASK_MODE_MODIFY:\r\n          info += \"Modify\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_CREATE:\r\n          info += \"Create\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_DELETE:\r\n          info += \"Delete\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_QUERY:\r\n          info += \"Query\";\r\n          break;\r\n\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      activityItem.setInfo(info);\r\n      this._queue.put(activityItem);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    let endContext: number = parser.getXMLdata().indexOf(\"/>\", parser.getCurrIndex());\r\n    if (endContext !== -1 && endContext < parser.getXMLdata().length) {\r\n      // find last position of its tag\r\n      let tag: string = parser.getXMLsubstring(endContext);\r\n      parser.add2CurrIndex(tag.indexOf(\"flwmtr_config\") + \"flwmtr_config\".length);\r\n\r\n      let tokens: List<string> = XmlParser.getTokens(parser.getXMLsubstring(endContext), XMLConstants.XML_ATTR_DELIM);\r\n      Logger.Instance.WriteDevToLog(\"in FlowMonitorQueue.FillData: \" + tokens.toString());\r\n\r\n      this.initElements(tokens);\r\n      parser.setCurrIndex(endContext + XMLConstants.TAG_TERM.length); // to delete \"/>\" too\r\n      return;\r\n    }\r\n    Logger.Instance.WriteExceptionToLogWithMsg(\"in  FlowMonitorQueue.FillData() out of string bounds\");\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the XML data\r\n  /// </summary>\r\n  /// <param name = \"tokensVector\">attribute/value/...attribute/value/ vector</param>\r\n  private initElements(tokensVector: List<string>): void {\r\n\r\n    for (let j: number = 0; j < tokensVector.length; j = j + 2) {\r\n      let attribute: string = <string>tokensVector.get_Item(j);\r\n      let valueStr: string = <string>tokensVector.get_Item(j + 1);\r\n      Logger.Instance.WriteDevToLog(attribute + \" value: \" + valueStr);\r\n\r\n      switch (attribute) {\r\n        case ConstInterface.MG_ATTR_TASK:\r\n          this._isTask = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_TASKFLW:\r\n          this._isTaskFlow = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_TAG_DATAVIEW:\r\n          this._isDataView = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_RECOMP:\r\n          this._isRecompute = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_FLWOP:\r\n          this._isFlowOperation = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_ENABLED:\r\n          this.enable(XmlParser.getBoolean(valueStr));\r\n          break;\r\n\r\n        default:\r\n          Logger.Instance.WriteExceptionToLogWithMsg(\"in FlowMonitorQueue.initElements(): unknown  attribute: \" + attribute);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML and empty the inner queue\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    if (!this._queue.isEmpty() && this.ShouldSerialize) {\r\n      message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n\r\n      while (!this._queue.isEmpty()) {\r\n        let currAct: ActivityItem = <ActivityItem>this._queue.get();\r\n        currAct.buildXML(message);\r\n      } // fill activities\r\n\r\n      message.Append(\"</\" + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n    } // the queue is not empty\r\n  }\r\n\r\n  /// <summary>\r\n  ///   is the Flow Monitor Queue empty\r\n  /// </summary>\r\n  isEmpty(): boolean {\r\n    return this._queue.isEmpty();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   enable the flow monitor\r\n  /// </summary>\r\n  /// <returns>the previous state (enabled/disabled)</returns>\r\n  enable(value: boolean): boolean {\r\n    let wasEnabled: boolean = this._enabled;\r\n    this._enabled = value;\r\n    this.ShouldSerialize = this._enabled;\r\n    return wasEnabled;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   add Activities to the queue\r\n  /// </summary>\r\n  /// <param name = \"triggeredBy\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskEvent(triggeredBy: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTask) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_EVENT);\r\n\r\n      let info: string;\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = FlowMonitorQueue.S_EVENT_STR1 + triggeredBy + FlowMonitorQueue.S_EVENT_STR2;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = FlowMonitorQueue.E_EVENT_STR + triggeredBy;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_PROPAGATE:\r\n          info = FlowMonitorQueue.S_EVENT_PROPAGATED;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  private appendVirtualsAndParameters(currentValues: string) : void\r\n  {\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);\r\n    act.setInfo(currentValues);\r\n    this._queue.put(act);\r\n  }\r\n\r\n  // /// <summary>\r\n  // ///   add virtual and parameter information and send it to server on record prefix\r\n  // /// </summary>\r\n  // /// <param name = \"task\">\r\n  // /// </param>\r\n  addDataViewFlow(task: Task) : void\r\n  { \r\n      if (this._isDataView)\r\n      {\r\n          let fldTab: FieldsTable = task.DataView.GetFieldsTab();\r\n          let preparedDisplayString: string = \"\";\r\n          let finaldisplayData: string = \"\\n\";\r\n          let fldValue: string;\r\n          let data: string = \"\";\r\n          for (let i: number = 0; i < fldTab.getSize(); i++)\r\n          {\r\n              let fldDef: Field = <Field>fldTab.getField(i);\r\n              if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam())\r\n              {\r\n                  fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);\r\n                  data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);\r\n                  preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);\r\n                  finaldisplayData = finaldisplayData + preparedDisplayString + \"\\n\";\r\n              }\r\n          }\r\n          this.appendVirtualsAndParameters(finaldisplayData);\r\n      }\r\n   }\r\n\r\n  // /// <summary>\r\n  // ///   Get virtuals and parameter values.\r\n  // /// </summary>\r\n  // /// <param name = \"Storagetype\"></param>\r\n  // /// <param name = \"data\"></param>\r\n  // /// <param name = \"picture\"></param>\r\n  // /// <param name = \"vecCellType\"></param>\r\n  // /// <param name = \"task\"></param>\r\n  // /// </param>\r\n  private getFieldData(Storagetype: StorageAttribute, data: string, picture: string, vecCellType: StorageAttribute, task: Task): string\r\n  {\r\n      switch (Storagetype)\r\n      {\r\n          case StorageAttribute.DOTNET:\r\n              data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;\r\n              break;\r\n\r\n          case StorageAttribute.BLOB:\r\n              {\r\n                if(BlobType.isValidBlob(data))\r\n                {\r\n                  let contentType: string = BlobType.getContentType(data);\r\n                  if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)\r\n                      data = data != null ? BlobType.getString(data) : \"\";\r\n                  else\r\n                      data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;\r\n                }\r\n                else\r\n                  data = \"\";\r\n              }\r\n              break;\r\n\r\n          case StorageAttribute.NUMERIC:\r\n          case StorageAttribute.DATE:\r\n          case StorageAttribute.TIME:\r\n              let conv: DisplayConvertor= DisplayConvertor.Instance;\r\n              data = conv.mg2disp(data, \" \", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);\r\n              break;\r\n\r\n          case StorageAttribute.BLOB_VECTOR:\r\n              let vecOutData: string;\r\n              if (data == null)\r\n              {\r\n                  vecOutData = \"[]\";\r\n              }\r\n              else\r\n              {\r\n                  let cellAtt: StorageAttribute = vecCellType;\r\n                  let vector: VectorType = new VectorType(data);\r\n                  if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))\r\n                      vecOutData = \"[]\";\r\n                  else\r\n                  {\r\n                      let vecSize: number = VectorType.getVecSize(data);\r\n                      let cellPicture: string = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;\r\n                      vecOutData = \"[\";\r\n                      for (let i : number = 0; i < vecSize; i++)\r\n                      {\r\n                          vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);\r\n                          vecOutData += i < vecSize - 1 ? \",\" : \"]\";\r\n                      }\r\n                  }\r\n              }\r\n              data = vecOutData;\r\n              break;\r\n\r\n          case StorageAttribute.BOOLEAN:\r\n              data = data == \"1\" ? \"TRUE\" : \"FALSE\";\r\n              break;\r\n      }\r\n      return data;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Prepare display string that will be sent to the server on record prefix.\r\n  /// </summary>\r\n  /// <param name = \"mode\"></param>\r\n  /// <param name = \"name\"></param>\r\n  /// <param name = \"valueContent\"></param>\r\n  /// <param name = \"addDoubleQuotes\"></param>\r\n  /// </param>\r\n  private PrepareDisplayString(mode: boolean, name: string, valueContent: string, addDoubleQuotes: boolean): string\r\n  {\r\n      let  str: string = \"\";\r\n      let finalStringToDisplay: string = \"\";\r\n      if (addDoubleQuotes)\r\n          finalStringToDisplay = finalStringToDisplay + \"\\\"\";\r\n      finalStringToDisplay = finalStringToDisplay + name;\r\n      if (addDoubleQuotes)\r\n          finalStringToDisplay = finalStringToDisplay + \"\\\"\";\r\n\r\n      let paddedName = this.padRight(name,34);\r\n      let formatOfStringVirtual:string = `Virtual` ;//: ${paddedName} : ${valueContent}`;\r\n      let formatOfStringParameter: string = `Parameter`;//` : ${paddedName} : ${valueContent}`;\r\n     \r\n      str = (mode ? formatOfStringParameter : formatOfStringVirtual) + \" : \" +`${paddedName}`+ \" : \"+`${valueContent.trim()}`;\r\n\r\n      return str;\r\n  }\r\n\r\n   private padRight = (string: string, length: number, character: string = ' '): string => {\r\n    let result = \"\";\r\n    let totalLength = length - string.length;\r\n    for (let i = 0; i < totalLength; i++) {\r\n      result = character + result;\r\n    }\r\n    result = result + string;\r\n    return result;\r\n  };\r\n  /// <summary>\r\n  ///   add task flow for record prefix or sufix\r\n  /// </summary>\r\n  /// <param name = \"id\">is FLWMTR_PREFIX or FLWMTR_SUFFIX\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowRec(id: number, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_REC_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECPRF_STR\r\n            : FlowMonitorQueue.E_RECPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_REC_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECSUF_STR\r\n            : FlowMonitorQueue.E_RECSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKPRF_STR\r\n            : FlowMonitorQueue.E_TASKPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKSUF_STR\r\n            : FlowMonitorQueue.E_TASKSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"id\">is MG_ACT_VARIABLE</param>\r\n  /// <param name = \"fldName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowFld(id: number, fldName: string, state: number, taskInfo: string): void {\r\n    this.addTaskFlowCtrl(id, fldName, state, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"id\">is FLWMTR_CTRL_PREFIX or FLWMTR_CTRL_SUFFIX</param>\r\n  /// <param name = \"ctrlName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowCtrl(id: number, ctrlName: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_VARIABLE:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_VARIABLE_STR\r\n            : FlowMonitorQueue.E_VARIABLE_STR;\r\n          id = FlowMonitorInterface.FLWMTR_VARCHG_VALUE;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLPRF_STR\r\n            : FlowMonitorQueue.E_CTRLPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_PREFIX;\r\n          break;\r\n\r\n\r\n        case InternalInterface.MG_ACT_CTRL_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLSUF_STR\r\n            : FlowMonitorQueue.E_CTRLSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_VERIFICATION:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLVER_STR\r\n            : FlowMonitorQueue.E_CTRLVER_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      if (info !== null) {\r\n        info = info + ctrlName;\r\n        if (id === FlowMonitorInterface.FLWMTR_VARCHG_VALUE && state === FlowMonitorInterface.FLWMTR_START)\r\n          info = info + FlowMonitorQueue.VARIABLE_REASON_STR;\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"handlerId\">isid of the handler\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowHandler(handlerId: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, FlowMonitorInterface.FLWMTR_TSK_HANDLER);\r\n      let info: string;\r\n\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = NString.Format(FlowMonitorQueue.S_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = NString.Format(FlowMonitorQueue.E_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      if (info !== null) {\r\n        // BRK_LEVEL_HANDLER_INTERNAL,BRK_LEVEL_HANDLER_SYSTEM,BRK_LEVEL_HANDLER_TIMER\r\n        // BRK_LEVEL_HANDLER_EXPRESSION,BRK_LEVEL_HANDLER_ERROR,BRK_LEVEL_HANDLER_USER\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"triggeredByVarName\">var name , has triggered Recompute\r\n  /// </param>\r\n  addRecompute(triggeredByVarName: string, taskInfo: string): void {\r\n    if (this._enabled && this._isRecompute) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_RECOMPUTE, FlowMonitorInterface.FLWMTR_RECOMP);\r\n      let info = FlowMonitorQueue.RECOMP_STR + triggeredByVarName;\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Add a field flow operation activity item.\r\n  /// </summary>\r\n  /// <param name = \"oper\">The operation being logged.</param>\r\n  /// <param name = \"bExecuted\">Will the operation be executed.</param>\r\n  async addFlowFieldOperation(oper: Operation, bExecuted: boolean, taskInfo: string): Promise<void> {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n      let buffer: StringBuilder = new StringBuilder(FlowMonitorQueue.FLW_PERFIX);\r\n      await oper.AddFlowDescription(buffer);\r\n      buffer.Append(' ');\r\n\r\n\r\n      if (!bExecuted)\r\n        buffer.Append(\"[Not Executed]\");\r\n\r\n      let info = buffer.ToString();\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"state\">of the update\r\n  /// </param>\r\n  addFlowOperationUpdate(state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER); // MG_OPER_UPDATE\r\n      let info: string;\r\n      if (state === FlowMonitorInterface.FLWMTR_START)\r\n        info = \"Starts Update\";\r\n      else\r\n        info =  \"Ends Update\";\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"info\">string passed to status line verify action</param>\r\n  addFlowVerifyInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"info\">string added to flow monitor queue for InvokeOs</param>\r\n  addFlowInvokeOsInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   user string passed to status line for actions\r\n  /// </summary>\r\n  /// <param name = \"info\">\r\n  /// </param>\r\n  private addFlowInfo(info: string, taskInfo: string): void {\r\n    if (!this._enabled)\r\n      return;\r\n\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n    let buffer: StringBuilder = new StringBuilder(\"\");\r\n\r\n    if (!(info === \"\")) {\r\n      buffer.Append(\" >> INFORMATION >> \");\r\n      buffer.Append(info);\r\n    }\r\n    let newInfo = buffer.ToString();\r\n    act.setInfo(newInfo);\r\n    this._queue.put(act);\r\n\r\n    Logger.Instance.WriteSupportToLog(taskInfo +\": \" + newInfo, true);\r\n  }\r\n}\r\n\r\n/// <summary>\r\n///   all information about current Activity\r\n/// </summary>\r\nclass ActivityItem {\r\n  private _id: number = 0;\r\n  private _type: string = null; // ACTY_TASK|ACT_TASK_FLW|ACT_DATAVIEW|ACT_RECOMPUTE|ACT_FLW_OPER\r\n  private _info: string = null;\r\n  private _time: string = null;\r\n\r\n  constructor(enclosingInstance: FlowMonitorQueue, type: string, id: number) {\r\n    this._type = type;\r\n    this._id = id;\r\n    this.setTime();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   save current time in the needed format\r\n  /// </summary>\r\n  private setTime(): void {\r\n    this._time = DateTimeUtils.ToString(DateTime.Now, FlowMonitorQueue.LongTimePattern, Logger.Instance);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   set added information for the activity\r\n  /// </summary>\r\n  setInfo(info_: string): void {\r\n    this._info = ((info_ !== null) ? XmlParser.escape(info_) : info_);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML string for the activity item\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_ACT);\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_TYPE + \"=\\\"\" + this._type + \"\\\"\");\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_ID + \"=\\\"\" + this._id + \"\\\"\");\r\n    if (this._info != null)\r\n      message.Append(\" \" + ConstInterface.MG_ATTR_INFO + \"=\\\"\" + this._info + \"\\\"\");\r\n    message.Append(\" \" + ConstInterface.MG_ATTR_TIME + \"=\\\"\" + this._time + \"\\\"\");\r\n    message.Append(XMLConstants.TAG_TERM);\r\n  }\r\n}\r\n"]}
@@ -3,10 +3,6 @@ import { Logger, XMLConstants, XmlParser } from '@magic-xpa/utils';
3
3
  import { ConstInterface } from '../ConstInterface';
4
4
  import { ParamParseResult } from "./ParamParseResult";
5
5
  export class PrmMap {
6
- constructor() {
7
- this.values = null;
8
- this.values = new Dictionary();
9
- }
10
6
  getvalue(s) {
11
7
  if (this.values.ContainsKey(s))
12
8
  return this.values.get_Item(s);
@@ -19,6 +15,10 @@ export class PrmMap {
19
15
  remove(s) {
20
16
  this.values.Remove(s);
21
17
  }
18
+ constructor() {
19
+ this.values = null;
20
+ this.values = new Dictionary();
21
+ }
22
22
  }
23
23
  export class MirrorPrmMap extends PrmMap {
24
24
  constructor(type) {
@@ -148,4 +148,4 @@ export class MirrorPrmMap extends PrmMap {
148
148
  }
149
149
  }
150
150
  }
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PrmMap.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/PrmMap.ts"],"names":[],"mappings":"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","sourcesContent":["import { Dictionary, List, StringBuilder } from '@magic-xpa/mscorelib';\r\nimport { Logger, XMLConstants, XmlParser } from '@magic-xpa/utils';\r\nimport { ConstInterface } from '../ConstInterface';\r\nimport { IMirrorXML } from './IMirrorXML';\r\nimport {ParamParseResult} from \"./ParamParseResult\";\r\n\r\n\r\n/// <summary> This class manages a dictionary of variables. then name of the variable is the key\r\n/// </summary>\r\nexport class PrmMap<TValue extends IMirrorXML>{\r\n  values: Dictionary<TValue> = null;\r\n\r\n  /// <summary> get the value\r\n  ///\r\n  /// </summary>\r\n  /// <param name=\"s\"></param>\r\n  /// <returns></returns>\r\n  protected getvalue(s: string): TValue {\r\n    if (this.values.ContainsKey(s))\r\n      return this.values.get_Item(s);\r\n    else\r\n      return null;\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  setValue(s: string, v: TValue): void {\r\n    this.values.set_Item(s, v);\r\n  }\r\n\r\n  /// <summary> remove an entry\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    this.values.Remove(s);\r\n  }\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor() {\r\n      this.values = new Dictionary<TValue>();\r\n  }\r\n}\r\n\r\n/// <summary> This class manages the mirroring. It holds a list of changed values that need to be\r\n/// mirrored, and manages the writing of those values to an XML buffer\r\n/// </summary>\r\nexport class MirrorPrmMap<TValue extends IMirrorXML> extends PrmMap<TValue> {\r\n\r\n  // List of changed variables\r\n  protected changes: List<string> = null;\r\n\r\n  // Type of variables in the table - use as an id in the XML buffer\r\n  protected  mirroredID: string = null;\r\n\r\n  private type ;\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor(type: new () => TValue) {\r\n    super();\r\n    this.type = type;\r\n    this.changes = new List<string>();\r\n  }\r\n\r\n  /// <summary>\r\n  /// create new instance of specified type\r\n  /// </summary>\r\n  private new(): TValue {\r\n    return new this.type();\r\n  }\r\n\r\n\r\n  setValue(s: string, v: TValue, addToChanges?: boolean): void {\r\n    if (arguments.length === 3)\r\n      this.setValue_0(s, v, addToChanges);\r\n    else\r\n      this.setValue_1(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_0(s: string, v: TValue, addToChanges: boolean): void {\r\n    if (addToChanges && !this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_1(s: string, v: TValue): void {\r\n    if (!this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> remove\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    if (!this.changes.Contains(s)) {\r\n      this.changes.push(s);\r\n    }\r\n    super.remove(s);\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each variable to write itself\r\n  /// </summary>\r\n  mirrorAllToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n\r\n    if (this.values != null) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all variables\r\n      for (let key of this.values.Keys) {\r\n\r\n        if (this.CheckIfSystemReservedParam(key))\r\n          continue;\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(key) + \"\\\" \");\r\n\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(key).mirrorToXML());\r\n\r\n        xml.Append(XMLConstants.TAG_TERM);\r\n      }\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary>\r\n  /// If system reserved param, then do not serialize for re-initialize session\r\n  /// </summary>\r\n  CheckIfSystemReservedParam(key: any): boolean\r\n  {\r\n    if (key == \"UTF8TRANS\" || key === \"REMOTE_HOST\" || key === \"REMOTE_ADDR\" ||\r\n      key === \"CTX\" || key === \"MGARG0\" || key === \"DATA\" || key === \"MGCURRENTREQUESTID\" ||\r\n      key === \"HTTP_MGXPARIAGLOBALUNIQUESESSIONID\" || key === \"MG_POST_BODY\")\r\n      return true;\r\n    else\r\n      return false;\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each changed variable to write itself\r\n  /// </summary>\r\n  mirrorToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n    if (this.changes.length > 0) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all changed variables\r\n\r\n\r\n      this.changes.forEach(change => {\r\n\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(change) + \"\\\" \");\r\n\r\n        if (this.values.ContainsKey(change))\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(change).mirrorToXML());\r\n        else\r\n          xml.Append(\"removed=\\\"Y\\\"\");\r\n        xml.Append(\">\");\r\n      });\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    this.changes.Clear();\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary> parse the XML and fill the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  RestoreParams (xml: string )\r\n  {\r\n    let parser: XmlParser = new XmlParser(xml);\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  /// <summary> fill from XML\r\n  /// </summary>\r\n  /// <param name=\"foundTagName\"></param>\r\n  /// <param name=\"xmlParser\"></param>\r\n  /// <returns></returns>\r\n  mirrorFromXML(foundTagName: string, xmlParser: XmlParser): boolean {\r\n    if (foundTagName === null)\r\n      return false;\r\n\r\n    if (foundTagName === this.mirroredID) {\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      this.fillDataEntry(xmlParser);\r\n      return true;\r\n    }\r\n    else if (foundTagName === (\"/\" + this.mirroredID)) {\r\n      // After updating from the server, clear the changes list so they won't be sent again\r\n      this.changes.Clear();\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      return false;\r\n    }\r\n    else {\r\n      Logger.Instance.WriteExceptionToLogWithMsg(\"There is no such tag in MirrorPrmMap.mirrorFromXML(): \" + foundTagName);\r\n      return false;\r\n    }\r\n  }\r\n\r\n\r\n  /// <summary>\r\n  /// parse and fill the params, until the section ends\r\n  /// </summary>\r\n  fillDataEntry(xmlParser: XmlParser): void {\r\n    let nextTag: string = xmlParser.getNextTag();\r\n\r\n    while (nextTag === ConstInterface.MG_TAG_PARAM) {\r\n      let nameStart: number = xmlParser.getXMLdata().indexOf(XMLConstants.MG_ATTR_NAME + \"=\\\"\", xmlParser.getCurrIndex()) +\r\n        XMLConstants.MG_ATTR_NAME.length + 2;\r\n\r\n      xmlParser.setCurrIndex(nameStart);\r\n      let nameEnd: number = xmlParser.getXMLdata().indexOf(\"\\\"\", nameStart);\r\n\r\n      // get the variables data\r\n      let name: string = xmlParser.getXMLsubstring(nameEnd).trim();\r\n      xmlParser.setCurrIndex(nameEnd);\r\n\r\n      // create and init the new value\r\n      let newVal: TValue = this.new();\r\n\r\n      switch (newVal.init(name, xmlParser)) {\r\n        case ParamParseResult.OK:\r\n          this.values.set_Item(name, newVal);\r\n          break;\r\n        case ParamParseResult.TOUPPER:\r\n          this.values.set_Item(name.toUpperCase(), newVal);\r\n          break;\r\n        case ParamParseResult.DELETE:\r\n          this.values.Remove(name);\r\n          break;\r\n      }\r\n\r\n      // move to next tag\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      nextTag = xmlParser.getNextTag();\r\n    }\r\n  }\r\n}\r\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PrmMap.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/PrmMap.ts"],"names":[],"mappings":"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","sourcesContent":["import { Dictionary, List, StringBuilder } from '@magic-xpa/mscorelib';\r\nimport { Logger, XMLConstants, XmlParser } from '@magic-xpa/utils';\r\nimport { ConstInterface } from '../ConstInterface';\r\nimport { IMirrorXML } from './IMirrorXML';\r\nimport {ParamParseResult} from \"./ParamParseResult\";\r\n\r\n\r\n/// <summary> This class manages a dictionary of variables. then name of the variable is the key\r\n/// </summary>\r\nexport class PrmMap<TValue extends IMirrorXML>{\r\n  values: Dictionary<TValue> = null;\r\n\r\n  /// <summary> get the value\r\n  ///\r\n  /// </summary>\r\n  /// <param name=\"s\"></param>\r\n  /// <returns></returns>\r\n  protected getvalue(s: string): TValue {\r\n    if (this.values.ContainsKey(s))\r\n      return this.values.get_Item(s);\r\n    else\r\n      return null;\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  setValue(s: string, v: TValue): void {\r\n    this.values.set_Item(s, v);\r\n  }\r\n\r\n  /// <summary> remove an entry\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    this.values.Remove(s);\r\n  }\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor() {\r\n      this.values = new Dictionary<TValue>();\r\n  }\r\n}\r\n\r\n/// <summary> This class manages the mirroring. It holds a list of changed values that need to be\r\n/// mirrored, and manages the writing of those values to an XML buffer\r\n/// </summary>\r\nexport class MirrorPrmMap<TValue extends IMirrorXML> extends PrmMap<TValue> {\r\n\r\n  // List of changed variables\r\n  protected changes: List<string> = null;\r\n\r\n  // Type of variables in the table - use as an id in the XML buffer\r\n  protected  mirroredID: string = null;\r\n\r\n  private type ;\r\n\r\n  /// <summary> CTOR\r\n  /// </summary>\r\n  constructor(type: new () => TValue) {\r\n    super();\r\n    this.type = type;\r\n    this.changes = new List<string>();\r\n  }\r\n\r\n  /// <summary>\r\n  /// create new instance of specified type\r\n  /// </summary>\r\n  private new(): TValue {\r\n    return new this.type();\r\n  }\r\n\r\n\r\n  setValue(s: string, v: TValue, addToChanges?: boolean): void {\r\n    if (arguments.length === 3)\r\n      this.setValue_0(s, v, addToChanges);\r\n    else\r\n      this.setValue_1(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_0(s: string, v: TValue, addToChanges: boolean): void {\r\n    if (addToChanges && !this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> set\r\n  /// </summary>\r\n  private setValue_1(s: string, v: TValue): void {\r\n    if (!this.changes.Contains(s))\r\n      this.changes.push(s);\r\n    super.setValue(s, v);\r\n  }\r\n\r\n  /// <summary> remove\r\n  /// </summary>\r\n  remove(s: string): void {\r\n    if (!this.changes.Contains(s)) {\r\n      this.changes.push(s);\r\n    }\r\n    super.remove(s);\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each variable to write itself\r\n  /// </summary>\r\n  mirrorAllToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n\r\n    if (this.values != null) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all variables\r\n      for (let key of this.values.Keys) {\r\n\r\n        if (this.CheckIfSystemReservedParam(key))\r\n          continue;\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(key) + \"\\\" \");\r\n\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(key).mirrorToXML());\r\n\r\n        xml.Append(XMLConstants.TAG_TERM);\r\n      }\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary>\r\n  /// If system reserved param, then do not serialize for re-initialize session\r\n  /// </summary>\r\n  CheckIfSystemReservedParam(key: any): boolean\r\n  {\r\n    if (key == \"UTF8TRANS\" || key === \"REMOTE_HOST\" || key === \"REMOTE_ADDR\" ||\r\n      key === \"CTX\" || key === \"MGARG0\" || key === \"DATA\" || key === \"MGCURRENTREQUESTID\" ||\r\n      key === \"HTTP_MGXPARIAGLOBALUNIQUESESSIONID\" || key === \"MG_POST_BODY\")\r\n      return true;\r\n    else\r\n      return false;\r\n  }\r\n\r\n  /// <summary>\r\n  /// write to an XML buff: write the ID and call each changed variable to write itself\r\n  /// </summary>\r\n  mirrorToXML(): string {\r\n    let xml: StringBuilder = new StringBuilder();\r\n\r\n    if (this.changes.length > 0) {\r\n\r\n      // write the id\r\n      xml.Append(\"<\" + this.mirroredID + \">\");\r\n\r\n      // loop on all changed variables\r\n\r\n\r\n      this.changes.forEach(change => {\r\n\r\n        xml.Append(\"<\" + ConstInterface.MG_TAG_PARAM + \" \" +\r\n          XMLConstants.MG_ATTR_NAME + \"=\\\"\" + XmlParser.escape(change) + \"\\\" \");\r\n\r\n        if (this.values.ContainsKey(change))\r\n        // call the variable to write it's own data\r\n          xml.Append(this.values.get_Item(change).mirrorToXML());\r\n        else\r\n          xml.Append(\"removed=\\\"Y\\\"\");\r\n        xml.Append(\">\");\r\n      });\r\n\r\n      xml.Append(\"</\" + this.mirroredID + \">\");\r\n    }\r\n    this.changes.Clear();\r\n    return xml.ToString();\r\n  }\r\n\r\n  /// <summary> parse the XML and fill the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  RestoreParams (xml: string )\r\n  {\r\n    let parser: XmlParser = new XmlParser(xml);\r\n    while (this.mirrorFromXML(parser.getNextTag(), parser)) {\r\n    }\r\n  }\r\n\r\n  /// <summary> fill from XML\r\n  /// </summary>\r\n  /// <param name=\"foundTagName\"></param>\r\n  /// <param name=\"xmlParser\"></param>\r\n  /// <returns></returns>\r\n  mirrorFromXML(foundTagName: string, xmlParser: XmlParser): boolean {\r\n    if (foundTagName === null)\r\n      return false;\r\n\r\n    if (foundTagName === this.mirroredID) {\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      this.fillDataEntry(xmlParser);\r\n      return true;\r\n    }\r\n    else if (foundTagName === (\"/\" + this.mirroredID)) {\r\n      // After updating from the server, clear the changes list so they won't be sent again\r\n      this.changes.Clear();\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      return false;\r\n    }\r\n    else {\r\n      Logger.Instance.WriteExceptionToLogWithMsg(\"There is no such tag in MirrorPrmMap.mirrorFromXML(): \" + foundTagName);\r\n      return false;\r\n    }\r\n  }\r\n\r\n\r\n  /// <summary>\r\n  /// parse and fill the params, until the section ends\r\n  /// </summary>\r\n  fillDataEntry(xmlParser: XmlParser): void {\r\n    let nextTag: string = xmlParser.getNextTag();\r\n\r\n    while (nextTag === ConstInterface.MG_TAG_PARAM) {\r\n      let nameStart: number = xmlParser.getXMLdata().indexOf(XMLConstants.MG_ATTR_NAME + \"=\\\"\", xmlParser.getCurrIndex()) +\r\n        XMLConstants.MG_ATTR_NAME.length + 2;\r\n\r\n      xmlParser.setCurrIndex(nameStart);\r\n      let nameEnd: number = xmlParser.getXMLdata().indexOf(\"\\\"\", nameStart);\r\n\r\n      // get the variables data\r\n      let name: string = xmlParser.getXMLsubstring(nameEnd).trim();\r\n      xmlParser.setCurrIndex(nameEnd);\r\n\r\n      // create and init the new value\r\n      let newVal: TValue = this.new();\r\n\r\n      switch (newVal.init(name, xmlParser)) {\r\n        case ParamParseResult.OK:\r\n          this.values.set_Item(name, newVal);\r\n          break;\r\n        case ParamParseResult.TOUPPER:\r\n          this.values.set_Item(name.toUpperCase(), newVal);\r\n          break;\r\n        case ParamParseResult.DELETE:\r\n          this.values.Remove(name);\r\n          break;\r\n      }\r\n\r\n      // move to next tag\r\n      xmlParser.setCurrIndex2EndOfTag();\r\n      nextTag = xmlParser.getNextTag();\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,6 +1,12 @@
1
1
  import { ReturnResultBase } from './ReturnResultBase';
2
2
  import { LanguageData } from '../env/LanguageData';
3
3
  export class ReturnResult extends ReturnResultBase {
4
+ get Success() {
5
+ return this.success;
6
+ }
7
+ get ErrorDescription() {
8
+ return this.errorDescription;
9
+ }
4
10
  constructor(errorDescriptionCodeOrErrorDescriptionOrInnerResult, innerResult) {
5
11
  super();
6
12
  this.errorDescription = null;
@@ -15,12 +21,6 @@ export class ReturnResult extends ReturnResultBase {
15
21
  else
16
22
  this.constructor_03(errorDescriptionCodeOrErrorDescriptionOrInnerResult);
17
23
  }
18
- get Success() {
19
- return this.success;
20
- }
21
- get ErrorDescription() {
22
- return this.errorDescription;
23
- }
24
24
  constructor_00(errorDescriptionCode) {
25
25
  this.success = false;
26
26
  this.ErrorId = errorDescriptionCode;
@@ -43,4 +43,4 @@ export class ReturnResult extends ReturnResultBase {
43
43
  }
44
44
  }
45
45
  ReturnResult.SuccessfulResult = new ReturnResult();
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmV0dXJuUmVzdWx0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZW5naW5lL3NyYy91dGlsL1JldHVyblJlc3VsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFLakQsTUFBTSxPQUFPLFlBQWEsU0FBUSxnQkFBZ0I7SUFtQmhELFlBQVksbURBQXlELEVBQUUsV0FBOEI7UUFDbkcsS0FBSyxFQUFFLENBQUM7UUFuQkYscUJBQWdCLEdBQVcsSUFBSSxDQUFDO1FBQ2hDLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFXakMsWUFBTyxHQUFXLElBQUksQ0FBQztRQVFyQixJQUFJLFNBQVMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsbURBQW1ELEtBQUssSUFBSSxJQUFJLG1EQUFtRCxDQUFDLFdBQVcsS0FBSyxNQUFNLENBQUM7WUFDeEssSUFBSSxDQUFDLGNBQWMsQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO2FBQ3RFLElBQUksU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDO1lBQzdCLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQzthQUNuQixJQUFJLFNBQVMsQ0FBQyxNQUFNLEtBQUssQ0FBQztZQUM3QixJQUFJLENBQUMsY0FBYyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7O1lBRXpFLElBQUksQ0FBQyxjQUFjLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUM3RSxDQUFDO0lBeEJELElBQUksT0FBTztRQUNULE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7SUFDL0IsQ0FBQztJQXVCTyxjQUFjLENBQUMsb0JBQTRCO1FBQ2pELElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxPQUFPLEdBQUcsb0JBQW9CLENBQUM7UUFDcEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFlBQVksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDdEYsQ0FBQztJQUtPLGNBQWM7UUFDcEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUtPLGNBQWMsQ0FBQyxnQkFBd0I7UUFDN0MsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDckIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLGdCQUFnQixDQUFDO0lBQzNDLENBQUM7SUFNTyxjQUFjLENBQUMsV0FBNkI7UUFDbEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDO1FBQ25DLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxXQUFXLENBQUMsZ0JBQWdCLENBQUM7SUFDdkQsQ0FBQztJQUVELFVBQVU7UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQzs7QUFoRU0sNkJBQWdCLEdBQWlCLElBQUksWUFBWSxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JldHVyblJlc3VsdEJhc2V9IGZyb20gJy4vUmV0dXJuUmVzdWx0QmFzZSc7XHJcbmltcG9ydCB7TGFuZ3VhZ2VEYXRhfSBmcm9tICcuLi9lbnYvTGFuZ3VhZ2VEYXRhJztcclxuXHJcbi8vLyA8c3VtbWFyeT5cclxuLy8vIGNsYXNzIHRvIGJlIHVzZWQgZm9yIHRoZSByZXN1bHQgb2Ygb3BlcmF0aW9ucyAtIGZhaWx1cmUgaW5kaWNhdG9yIGFuZCBhIHN0cmluZyBkZXNjcmliaW5nIHRoZSBwcm9ibGVtXHJcbi8vLyA8L3N1bW1hcnk+XHJcbmV4cG9ydCBjbGFzcyBSZXR1cm5SZXN1bHQgZXh0ZW5kcyBSZXR1cm5SZXN1bHRCYXNlIHtcclxuICBwcml2YXRlIGVycm9yRGVzY3JpcHRpb246IHN0cmluZyA9IG51bGw7XHJcbiAgcHJpdmF0ZSBzdWNjZXNzOiBib29sZWFuID0gZmFsc2U7XHJcbiAgc3RhdGljIFN1Y2Nlc3NmdWxSZXN1bHQ6IFJldHVyblJlc3VsdCA9IG5ldyBSZXR1cm5SZXN1bHQoKTtcclxuXHJcbiAgZ2V0IFN1Y2Nlc3MoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWNjZXNzO1xyXG4gIH1cclxuXHJcbiAgZ2V0IEVycm9yRGVzY3JpcHRpb24oKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmVycm9yRGVzY3JpcHRpb247XHJcbiAgfVxyXG5cclxuICBFcnJvcklkOiBzdHJpbmcgPSBudWxsO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpO1xyXG4gIGNvbnN0cnVjdG9yKGVycm9yRGVzY3JpcHRpb25Db2RlOiBzdHJpbmcpO1xyXG4gIGNvbnN0cnVjdG9yKGlubmVyUmVzdWx0OiBSZXR1cm5SZXN1bHRCYXNlKTtcclxuICBjb25zdHJ1Y3RvcihlcnJvckRlc2NyaXB0aW9uOiBzdHJpbmcsIGlubmVyUmVzdWx0OiBSZXR1cm5SZXN1bHRCYXNlKTtcclxuICBjb25zdHJ1Y3RvcihlcnJvckRlc2NyaXB0aW9uQ29kZU9yRXJyb3JEZXNjcmlwdGlvbk9ySW5uZXJSZXN1bHQ/OiBhbnksIGlubmVyUmVzdWx0PzogUmV0dXJuUmVzdWx0QmFzZSkge1xyXG4gICAgc3VwZXIoKTtcclxuICAgIGlmIChhcmd1bWVudHMubGVuZ3RoID09PSAxICYmIChlcnJvckRlc2NyaXB0aW9uQ29kZU9yRXJyb3JEZXNjcmlwdGlvbk9ySW5uZXJSZXN1bHQgPT09IG51bGwgfHwgZXJyb3JEZXNjcmlwdGlvbkNvZGVPckVycm9yRGVzY3JpcHRpb25PcklubmVyUmVzdWx0LmNvbnN0cnVjdG9yID09PSBTdHJpbmcpKVxyXG4gICAgICB0aGlzLmNvbnN0cnVjdG9yXzAwKGVycm9yRGVzY3JpcHRpb25Db2RlT3JFcnJvckRlc2NyaXB0aW9uT3JJbm5lclJlc3VsdCk7XHJcbiAgICBlbHNlIGlmIChhcmd1bWVudHMubGVuZ3RoID09PSAwKVxyXG4gICAgICB0aGlzLmNvbnN0cnVjdG9yXzAxKCk7XHJcbiAgICBlbHNlIGlmIChhcmd1bWVudHMubGVuZ3RoID09PSAyKVxyXG4gICAgICB0aGlzLmNvbnN0cnVjdG9yXzAyKGVycm9yRGVzY3JpcHRpb25Db2RlT3JFcnJvckRlc2NyaXB0aW9uT3JJbm5lclJlc3VsdCk7XHJcbiAgICBlbHNlXHJcbiAgICAgIHRoaXMuY29uc3RydWN0b3JfMDMoZXJyb3JEZXNjcmlwdGlvbkNvZGVPckVycm9yRGVzY3JpcHRpb25PcklubmVyUmVzdWx0KTtcclxuICB9XHJcblxyXG4gIC8vLyA8c3VtbWFyeT5cclxuICAvLy8gQ1RPUlxyXG4gIC8vLyA8L3N1bW1hcnk+XHJcbiAgcHJpdmF0ZSBjb25zdHJ1Y3Rvcl8wMChlcnJvckRlc2NyaXB0aW9uQ29kZTogc3RyaW5nKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1Y2Nlc3MgPSBmYWxzZTtcclxuICAgIHRoaXMuRXJyb3JJZCA9IGVycm9yRGVzY3JpcHRpb25Db2RlO1xyXG4gICAgdGhpcy5lcnJvckRlc2NyaXB0aW9uID0gTGFuZ3VhZ2VEYXRhLkluc3RhbmNlLmdldENvbnN0TWVzc2FnZShlcnJvckRlc2NyaXB0aW9uQ29kZSk7XHJcbiAgfVxyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIENUT1JcclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIHByaXZhdGUgY29uc3RydWN0b3JfMDEoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1Y2Nlc3MgPSB0cnVlO1xyXG4gICAgdGhpcy5FcnJvcklkID0gXCJcIjtcclxuICB9XHJcblxyXG4gIC8vLyA8c3VtbWFyeT5cclxuICAvLy8gQ1RPUiB3aXRoIGlubmVyIHJlc3VsdCBhbmQgZGVzY3JpcHRpb25cclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIHByaXZhdGUgY29uc3RydWN0b3JfMDIoZXJyb3JEZXNjcmlwdGlvbjogc3RyaW5nKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1Y2Nlc3MgPSBmYWxzZTtcclxuICAgIHRoaXMuZXJyb3JEZXNjcmlwdGlvbiA9IGVycm9yRGVzY3JpcHRpb247XHJcbiAgfVxyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIENUT1IgLSB1c2UgdGhlIGlubmVyIGNvbW1hbmQncyBzdWNjZXNzIGFkIGRlc2NyaXB0aW9uXHJcbiAgLy8vIDwvc3VtbWFyeT5cclxuICAvLy8gPHBhcmFtIG5hbWU9XCJpbm5lclJlc3VsdFwiPjwvcGFyYW0+XHJcbiAgcHJpdmF0ZSBjb25zdHJ1Y3Rvcl8wMyhpbm5lclJlc3VsdDogUmV0dXJuUmVzdWx0QmFzZSk6IHZvaWQge1xyXG4gICAgdGhpcy5zdWNjZXNzID0gaW5uZXJSZXN1bHQuU3VjY2VzcztcclxuICAgIHRoaXMuZXJyb3JEZXNjcmlwdGlvbiA9IGlubmVyUmVzdWx0LkVycm9yRGVzY3JpcHRpb247XHJcbiAgfVxyXG5cclxuICBHZXRFcnJvcklkKCk6IGFueSB7XHJcbiAgICByZXR1cm4gdGhpcy5FcnJvcklkO1xyXG4gIH1cclxufVxyXG4iXX0=
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmV0dXJuUmVzdWx0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZW5naW5lL3NyYy91dGlsL1JldHVyblJlc3VsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFLakQsTUFBTSxPQUFPLFlBQWEsU0FBUSxnQkFBZ0I7SUFLaEQsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFJLGdCQUFnQjtRQUNsQixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUMvQixDQUFDO0lBUUQsWUFBWSxtREFBeUQsRUFBRSxXQUE4QjtRQUNuRyxLQUFLLEVBQUUsQ0FBQztRQW5CRixxQkFBZ0IsR0FBVyxJQUFJLENBQUM7UUFDaEMsWUFBTyxHQUFZLEtBQUssQ0FBQztRQVdqQyxZQUFPLEdBQVcsSUFBSSxDQUFDO1FBUXJCLElBQUksU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksQ0FBQyxtREFBbUQsS0FBSyxJQUFJLElBQUksbURBQW1ELENBQUMsV0FBVyxLQUFLLE1BQU0sQ0FBQztZQUN4SyxJQUFJLENBQUMsY0FBYyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7YUFDdEUsSUFBSSxTQUFTLENBQUMsTUFBTSxLQUFLLENBQUM7WUFDN0IsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO2FBQ25CLElBQUksU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDO1lBQzdCLElBQUksQ0FBQyxjQUFjLENBQUMsbURBQW1ELENBQUMsQ0FBQzs7WUFFekUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0lBQzdFLENBQUM7SUFLTyxjQUFjLENBQUMsb0JBQTRCO1FBQ2pELElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxPQUFPLEdBQUcsb0JBQW9CLENBQUM7UUFDcEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFlBQVksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDdEYsQ0FBQztJQUtPLGNBQWM7UUFDcEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUtPLGNBQWMsQ0FBQyxnQkFBd0I7UUFDN0MsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDckIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLGdCQUFnQixDQUFDO0lBQzNDLENBQUM7SUFNTyxjQUFjLENBQUMsV0FBNkI7UUFDbEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDO1FBQ25DLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxXQUFXLENBQUMsZ0JBQWdCLENBQUM7SUFDdkQsQ0FBQztJQUVELFVBQVU7UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQzs7QUFoRU0sNkJBQWdCLEdBQWlCLElBQUksWUFBWSxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JldHVyblJlc3VsdEJhc2V9IGZyb20gJy4vUmV0dXJuUmVzdWx0QmFzZSc7XHJcbmltcG9ydCB7TGFuZ3VhZ2VEYXRhfSBmcm9tICcuLi9lbnYvTGFuZ3VhZ2VEYXRhJztcclxuXHJcbi8vLyA8c3VtbWFyeT5cclxuLy8vIGNsYXNzIHRvIGJlIHVzZWQgZm9yIHRoZSByZXN1bHQgb2Ygb3BlcmF0aW9ucyAtIGZhaWx1cmUgaW5kaWNhdG9yIGFuZCBhIHN0cmluZyBkZXNjcmliaW5nIHRoZSBwcm9ibGVtXHJcbi8vLyA8L3N1bW1hcnk+XHJcbmV4cG9ydCBjbGFzcyBSZXR1cm5SZXN1bHQgZXh0ZW5kcyBSZXR1cm5SZXN1bHRCYXNlIHtcclxuICBwcml2YXRlIGVycm9yRGVzY3JpcHRpb246IHN0cmluZyA9IG51bGw7XHJcbiAgcHJpdmF0ZSBzdWNjZXNzOiBib29sZWFuID0gZmFsc2U7XHJcbiAgc3RhdGljIFN1Y2Nlc3NmdWxSZXN1bHQ6IFJldHVyblJlc3VsdCA9IG5ldyBSZXR1cm5SZXN1bHQoKTtcclxuXHJcbiAgZ2V0IFN1Y2Nlc3MoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWNjZXNzO1xyXG4gIH1cclxuXHJcbiAgZ2V0IEVycm9yRGVzY3JpcHRpb24oKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmVycm9yRGVzY3JpcHRpb247XHJcbiAgfVxyXG5cclxuICBFcnJvcklkOiBzdHJpbmcgPSBudWxsO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpO1xyXG4gIGNvbnN0cnVjdG9yKGVycm9yRGVzY3JpcHRpb25Db2RlOiBzdHJpbmcpO1xyXG4gIGNvbnN0cnVjdG9yKGlubmVyUmVzdWx0OiBSZXR1cm5SZXN1bHRCYXNlKTtcclxuICBjb25zdHJ1Y3RvcihlcnJvckRlc2NyaXB0aW9uOiBzdHJpbmcsIGlubmVyUmVzdWx0OiBSZXR1cm5SZXN1bHRCYXNlKTtcclxuICBjb25zdHJ1Y3RvcihlcnJvckRlc2NyaXB0aW9uQ29kZU9yRXJyb3JEZXNjcmlwdGlvbk9ySW5uZXJSZXN1bHQ/OiBhbnksIGlubmVyUmVzdWx0PzogUmV0dXJuUmVzdWx0QmFzZSkge1xyXG4gICAgc3VwZXIoKTtcclxuICAgIGlmIChhcmd1bWVudHMubGVuZ3RoID09PSAxICYmIChlcnJvckRlc2NyaXB0aW9uQ29kZU9yRXJyb3JEZXNjcmlwdGlvbk9ySW5uZXJSZXN1bHQgPT09IG51bGwgfHwgZXJyb3JEZXNjcmlwdGlvbkNvZGVPckVycm9yRGVzY3JpcHRpb25PcklubmVyUmVzdWx0LmNvbnN0cnVjdG9yID09PSBTdHJpbmcpKVxyXG4gICAgICB0aGlzLmNvbnN0cnVjdG9yXzAwKGVycm9yRGVzY3JpcHRpb25Db2RlT3JFcnJvckRlc2NyaXB0aW9uT3JJbm5lclJlc3VsdCk7XHJcbiAgICBlbHNlIGlmIChhcmd1bWVudHMubGVuZ3RoID09PSAwKVxyXG4gICAgICB0aGlzLmNvbnN0cnVjdG9yXzAxKCk7XHJcbiAgICBlbHNlIGlmIChhcmd1bWVudHMubGVuZ3RoID09PSAyKVxyXG4gICAgICB0aGlzLmNvbnN0cnVjdG9yXzAyKGVycm9yRGVzY3JpcHRpb25Db2RlT3JFcnJvckRlc2NyaXB0aW9uT3JJbm5lclJlc3VsdCk7XHJcbiAgICBlbHNlXHJcbiAgICAgIHRoaXMuY29uc3RydWN0b3JfMDMoZXJyb3JEZXNjcmlwdGlvbkNvZGVPckVycm9yRGVzY3JpcHRpb25PcklubmVyUmVzdWx0KTtcclxuICB9XHJcblxyXG4gIC8vLyA8c3VtbWFyeT5cclxuICAvLy8gQ1RPUlxyXG4gIC8vLyA8L3N1bW1hcnk+XHJcbiAgcHJpdmF0ZSBjb25zdHJ1Y3Rvcl8wMChlcnJvckRlc2NyaXB0aW9uQ29kZTogc3RyaW5nKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1Y2Nlc3MgPSBmYWxzZTtcclxuICAgIHRoaXMuRXJyb3JJZCA9IGVycm9yRGVzY3JpcHRpb25Db2RlO1xyXG4gICAgdGhpcy5lcnJvckRlc2NyaXB0aW9uID0gTGFuZ3VhZ2VEYXRhLkluc3RhbmNlLmdldENvbnN0TWVzc2FnZShlcnJvckRlc2NyaXB0aW9uQ29kZSk7XHJcbiAgfVxyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIENUT1JcclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIHByaXZhdGUgY29uc3RydWN0b3JfMDEoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1Y2Nlc3MgPSB0cnVlO1xyXG4gICAgdGhpcy5FcnJvcklkID0gXCJcIjtcclxuICB9XHJcblxyXG4gIC8vLyA8c3VtbWFyeT5cclxuICAvLy8gQ1RPUiB3aXRoIGlubmVyIHJlc3VsdCBhbmQgZGVzY3JpcHRpb25cclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIHByaXZhdGUgY29uc3RydWN0b3JfMDIoZXJyb3JEZXNjcmlwdGlvbjogc3RyaW5nKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1Y2Nlc3MgPSBmYWxzZTtcclxuICAgIHRoaXMuZXJyb3JEZXNjcmlwdGlvbiA9IGVycm9yRGVzY3JpcHRpb247XHJcbiAgfVxyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIENUT1IgLSB1c2UgdGhlIGlubmVyIGNvbW1hbmQncyBzdWNjZXNzIGFkIGRlc2NyaXB0aW9uXHJcbiAgLy8vIDwvc3VtbWFyeT5cclxuICAvLy8gPHBhcmFtIG5hbWU9XCJpbm5lclJlc3VsdFwiPjwvcGFyYW0+XHJcbiAgcHJpdmF0ZSBjb25zdHJ1Y3Rvcl8wMyhpbm5lclJlc3VsdDogUmV0dXJuUmVzdWx0QmFzZSk6IHZvaWQge1xyXG4gICAgdGhpcy5zdWNjZXNzID0gaW5uZXJSZXN1bHQuU3VjY2VzcztcclxuICAgIHRoaXMuZXJyb3JEZXNjcmlwdGlvbiA9IGlubmVyUmVzdWx0LkVycm9yRGVzY3JpcHRpb247XHJcbiAgfVxyXG5cclxuICBHZXRFcnJvcklkKCk6IGFueSB7XHJcbiAgICByZXR1cm4gdGhpcy5FcnJvcklkO1xyXG4gIH1cclxufVxyXG4iXX0=