@magic-xpa/engine 4.1100.0-dev4110.106 → 4.1100.0-dev4110.109

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 (381) hide show
  1. package/esm2020/index.mjs +188 -2
  2. package/esm2020/src/AccessHelper.mjs +9 -0
  3. package/esm2020/src/ClientManager.mjs +399 -0
  4. package/esm2020/src/CommandsProcessorBase.mjs +58 -0
  5. package/esm2020/src/CommandsProcessorManager.mjs +26 -0
  6. package/esm2020/src/CommandsTable.mjs +162 -0
  7. package/esm2020/src/ConstInterface.mjs +516 -0
  8. package/esm2020/src/CurrentClientVersion.mjs +2 -0
  9. package/esm2020/src/FlowMonitorInterface.mjs +16 -0
  10. package/esm2020/src/GUIManager.mjs +62 -0
  11. package/esm2020/src/GlobalCommandsManager.mjs +34 -0
  12. package/esm2020/src/GuiEventsProcessor.mjs +154 -0
  13. package/esm2020/src/ICommandsTable.mjs +2 -0
  14. package/esm2020/src/ServerConfig.mjs +117 -0
  15. package/esm2020/src/bridge/IGuiEvent.mjs +20 -0
  16. package/esm2020/src/bridge/MagicBridge.mjs +41 -0
  17. package/esm2020/src/commands/ClientOriginatedCommandTaskTag.mjs +11 -0
  18. package/esm2020/src/commands/ClientToServer/AddUserLocateDataViewCommand.mjs +9 -0
  19. package/esm2020/src/commands/ClientToServer/AddUserRangeDataviewCommand.mjs +9 -0
  20. package/esm2020/src/commands/ClientToServer/AddUserSortDataViewCommand.mjs +9 -0
  21. package/esm2020/src/commands/ClientToServer/BrowserEscEventCommand.mjs +23 -0
  22. package/esm2020/src/commands/ClientToServer/ClientOriginatedCommand.mjs +15 -0
  23. package/esm2020/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs +60 -0
  24. package/esm2020/src/commands/ClientToServer/ColumnSortEventCommand.mjs +26 -0
  25. package/esm2020/src/commands/ClientToServer/CommandFactory.mjs +260 -0
  26. package/esm2020/src/commands/ClientToServer/CommandSerializationHelper.mjs +69 -0
  27. package/esm2020/src/commands/ClientToServer/ComputeEventCommand.mjs +23 -0
  28. package/esm2020/src/commands/ClientToServer/ContextTerminationEventCommand.mjs +21 -0
  29. package/esm2020/src/commands/ClientToServer/ContextTimeoutResetCommand.mjs +20 -0
  30. package/esm2020/src/commands/ClientToServer/ControlItemsRefreshCommand.mjs +8 -0
  31. package/esm2020/src/commands/ClientToServer/DataViewOutputCommand.mjs +13 -0
  32. package/esm2020/src/commands/ClientToServer/DataviewCommand.mjs +44 -0
  33. package/esm2020/src/commands/ClientToServer/EvaluateCommand.mjs +36 -0
  34. package/esm2020/src/commands/ClientToServer/EventCommand.mjs +40 -0
  35. package/esm2020/src/commands/ClientToServer/ExecOperCommand.mjs +67 -0
  36. package/esm2020/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +22 -0
  37. package/esm2020/src/commands/ClientToServer/GlobalParamsQueryCommand.mjs +11 -0
  38. package/esm2020/src/commands/ClientToServer/ICommandTaskTag.mjs +2 -0
  39. package/esm2020/src/commands/ClientToServer/IndexChangeEventCommand.mjs +21 -0
  40. package/esm2020/src/commands/ClientToServer/IniputForceWriteCommand.mjs +23 -0
  41. package/esm2020/src/commands/ClientToServer/NonReversibleExitEventCommand.mjs +23 -0
  42. package/esm2020/src/commands/ClientToServer/QueryCommand.mjs +21 -0
  43. package/esm2020/src/commands/ClientToServer/RecomputeCommand.mjs +27 -0
  44. package/esm2020/src/commands/ClientToServer/RefreshEventCommand.mjs +27 -0
  45. package/esm2020/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +24 -0
  46. package/esm2020/src/commands/ClientToServer/RollbackEventCommand.mjs +39 -0
  47. package/esm2020/src/commands/ClientToServer/SelectProgramCommand.mjs +15 -0
  48. package/esm2020/src/commands/ClientToServer/SetTransactionStateDataviewCommand.mjs +9 -0
  49. package/esm2020/src/commands/ClientToServer/SubformOpenEventCommand.mjs +21 -0
  50. package/esm2020/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +24 -0
  51. package/esm2020/src/commands/ClientToServer/TransactionCommand.mjs +28 -0
  52. package/esm2020/src/commands/ClientToServer/UnloadCommand.mjs +15 -0
  53. package/esm2020/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +18 -0
  54. package/esm2020/src/commands/DataViewCommandBase.mjs +10 -0
  55. package/esm2020/src/commands/IClientCommand.mjs +2 -0
  56. package/esm2020/src/commands/IClientTargetedCommand.mjs +9 -0
  57. package/esm2020/src/commands/IClientToServerCommandInfo.mjs +2 -0
  58. package/esm2020/src/commands/ServerToClient/AbortCommand.mjs +65 -0
  59. package/esm2020/src/commands/ServerToClient/AddLocateCommand.mjs +22 -0
  60. package/esm2020/src/commands/ServerToClient/AddRangeCommand.mjs +62 -0
  61. package/esm2020/src/commands/ServerToClient/AddSortCommand.mjs +33 -0
  62. package/esm2020/src/commands/ServerToClient/ClientRefreshCommand.mjs +25 -0
  63. package/esm2020/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +27 -0
  64. package/esm2020/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +45 -0
  65. package/esm2020/src/commands/ServerToClient/OpenURLCommand.mjs +221 -0
  66. package/esm2020/src/commands/ServerToClient/ResetLocateCommand.mjs +15 -0
  67. package/esm2020/src/commands/ServerToClient/ResetRangeCommand.mjs +15 -0
  68. package/esm2020/src/commands/ServerToClient/ResetSortCommand.mjs +15 -0
  69. package/esm2020/src/commands/ServerToClient/ResultCommand.mjs +37 -0
  70. package/esm2020/src/commands/ServerToClient/VerifyCommand.mjs +83 -0
  71. package/esm2020/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs +132 -0
  72. package/esm2020/src/communications/IConnectionStateManager.mjs +2 -0
  73. package/esm2020/src/communications/InteractiveCommunicationsFailureHandler.mjs +17 -0
  74. package/esm2020/src/data/DataSourceIdKey.mjs +3 -0
  75. package/esm2020/src/data/DataView.mjs +1610 -0
  76. package/esm2020/src/data/DataViewBase.mjs +4 -0
  77. package/esm2020/src/data/DataviewManager.mjs +28 -0
  78. package/esm2020/src/data/DataviewManagerBase.mjs +15 -0
  79. package/esm2020/src/data/DvCache.mjs +67 -0
  80. package/esm2020/src/data/Field.mjs +646 -0
  81. package/esm2020/src/data/FieldBase.mjs +18 -0
  82. package/esm2020/src/data/FieldsTable.mjs +103 -0
  83. package/esm2020/src/data/IRecordsTable.mjs +2 -0
  84. package/esm2020/src/data/Key.mjs +88 -0
  85. package/esm2020/src/data/Record.mjs +846 -0
  86. package/esm2020/src/data/RecordOutOfDataViewException.mjs +16 -0
  87. package/esm2020/src/data/RecordsTable.mjs +267 -0
  88. package/esm2020/src/data/TaskTransactionManager.mjs +103 -0
  89. package/esm2020/src/data/XMLBasedDcValuesBuilder.mjs +74 -0
  90. package/esm2020/src/enums.mjs +24 -0
  91. package/esm2020/src/env/EnvVariablesTable.mjs +340 -0
  92. package/esm2020/src/env/Environment.mjs +489 -0
  93. package/esm2020/src/env/ILanguageData.mjs +2 -0
  94. package/esm2020/src/env/LanguageData.mjs +226 -0
  95. package/esm2020/src/env/MirrorString.mjs +65 -0
  96. package/esm2020/src/event/ActionManager.mjs +91 -0
  97. package/esm2020/src/event/Event.mjs +1333 -0
  98. package/esm2020/src/event/EventHandler.mjs +766 -0
  99. package/esm2020/src/event/EventHandlerPosition.mjs +204 -0
  100. package/esm2020/src/event/EventsManager.mjs +2975 -0
  101. package/esm2020/src/event/IEventsManager.mjs +7 -0
  102. package/esm2020/src/event/RunTimeEvent.mjs +392 -0
  103. package/esm2020/src/event/RunTimeEventBase.mjs +4 -0
  104. package/esm2020/src/event/UserEventsTable.mjs +47 -0
  105. package/esm2020/src/exp/ExpTable.mjs +59 -0
  106. package/esm2020/src/exp/Expression.mjs +200 -0
  107. package/esm2020/src/exp/ExpressionDict.mjs +727 -0
  108. package/esm2020/src/exp/ExpressionEvaluator.mjs +4208 -0
  109. package/esm2020/src/exp/ExpressionLocalJpn.mjs +314 -0
  110. package/esm2020/src/exp/GlobalParamsTable.mjs +85 -0
  111. package/esm2020/src/exp/YesNoExp.mjs +36 -0
  112. package/esm2020/src/gui/CreatedFormVector.mjs +23 -0
  113. package/esm2020/src/gui/FormsTable.mjs +66 -0
  114. package/esm2020/src/gui/MgControl.mjs +353 -0
  115. package/esm2020/src/gui/MgForm.mjs +1181 -0
  116. package/esm2020/src/http/HttpManager.mjs +97 -0
  117. package/esm2020/src/http/client/HttpClientAsync.mjs +67 -0
  118. package/esm2020/src/http/client/HttpClientBase.mjs +132 -0
  119. package/esm2020/src/http/client/HttpClientEvents.mjs +39 -0
  120. package/esm2020/src/http/client/HttpClientSync.mjs +42 -0
  121. package/esm2020/src/http/client/HttpUtility.mjs +84 -0
  122. package/esm2020/src/http/client/ICommunicationsFailureHandler.mjs +2 -0
  123. package/esm2020/src/remote/AddUserLocateRemoteDataViewCommand.mjs +18 -0
  124. package/esm2020/src/remote/AddUserRangeRemoteDataViewCommand.mjs +18 -0
  125. package/esm2020/src/remote/AddUserSortRemoteDataViewCommand.mjs +18 -0
  126. package/esm2020/src/remote/RemoteCommandsProcessor.mjs +880 -0
  127. package/esm2020/src/remote/RemoteControlItemsRefreshCommand.mjs +25 -0
  128. package/esm2020/src/remote/RemoteDataViewCommandBase.mjs +24 -0
  129. package/esm2020/src/remote/RemoteDataViewCommandFactory.mjs +61 -0
  130. package/esm2020/src/remote/RemoteDataViewCommandUpdateNonModifiable.mjs +16 -0
  131. package/esm2020/src/remote/RemoteDataviewManager.mjs +17 -0
  132. package/esm2020/src/remote/RemoteInitDataViewCommand.mjs +11 -0
  133. package/esm2020/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +17 -0
  134. package/esm2020/src/remote/ResetUserRangeRemoteDataviewCommand.mjs +13 -0
  135. package/esm2020/src/remote/ResetUserSortRemoteDataviewCommand.mjs +16 -0
  136. package/esm2020/src/remote/ServerError.mjs +40 -0
  137. package/esm2020/src/remote/SetTransactionStateRemoteDataViewCommand.mjs +20 -0
  138. package/esm2020/src/rt/Argument.mjs +265 -0
  139. package/esm2020/src/rt/ArgumentsList.mjs +103 -0
  140. package/esm2020/src/rt/Boundary.mjs +152 -0
  141. package/esm2020/src/rt/CompMainPrgTable.mjs +65 -0
  142. package/esm2020/src/rt/DataviewHeaderBase.mjs +96 -0
  143. package/esm2020/src/rt/DataviewHeaderFactory.mjs +7 -0
  144. package/esm2020/src/rt/DataviewHeaders.mjs +53 -0
  145. package/esm2020/src/rt/DataviewHeadersSaxHandler.mjs +38 -0
  146. package/esm2020/src/rt/ExecutionStack.mjs +94 -0
  147. package/esm2020/src/rt/ExecutionStackEntry.mjs +17 -0
  148. package/esm2020/src/rt/HandlersTable.mjs +96 -0
  149. package/esm2020/src/rt/IDataSourceViewDefinition.mjs +2 -0
  150. package/esm2020/src/rt/IDataviewHeader.mjs +2 -0
  151. package/esm2020/src/rt/IResultValue.mjs +2 -0
  152. package/esm2020/src/rt/LastFocusedManager.mjs +67 -0
  153. package/esm2020/src/rt/Operation.mjs +735 -0
  154. package/esm2020/src/rt/OperationTable.mjs +67 -0
  155. package/esm2020/src/rt/Recompute.mjs +355 -0
  156. package/esm2020/src/rt/RecomputeTable.mjs +63 -0
  157. package/esm2020/src/rt/RemoteDataviewHeader.mjs +108 -0
  158. package/esm2020/src/rt/ResultValue.mjs +12 -0
  159. package/esm2020/src/rt/TableCache.mjs +177 -0
  160. package/esm2020/src/rt/TableCacheManager.mjs +67 -0
  161. package/esm2020/src/rt/Transaction.mjs +53 -0
  162. package/esm2020/src/security/UserDetails.mjs +71 -0
  163. package/esm2020/src/tasks/IMGDataCollection.mjs +2 -0
  164. package/esm2020/src/tasks/MGData.mjs +552 -0
  165. package/esm2020/src/tasks/MGDataCollection.mjs +252 -0
  166. package/esm2020/src/tasks/RCTimer.mjs +63 -0
  167. package/esm2020/src/tasks/RemoteTaskService.mjs +45 -0
  168. package/esm2020/src/tasks/Task.mjs +2496 -0
  169. package/esm2020/src/tasks/TaskBase.mjs +87 -0
  170. package/esm2020/src/tasks/TaskServiceBase.mjs +25 -0
  171. package/esm2020/src/tasks/TasksTable.mjs +80 -0
  172. package/esm2020/src/tasks/sort/Sort.mjs +7 -0
  173. package/esm2020/src/tasks/sort/SortCollection.mjs +67 -0
  174. package/esm2020/src/util/ConstUtils.mjs +14 -0
  175. package/esm2020/src/util/FlowMonitorQueue.mjs +453 -0
  176. package/esm2020/src/util/HeapSort.mjs +70 -0
  177. package/esm2020/src/util/IMirrorXML.mjs +2 -0
  178. package/esm2020/src/util/IServerConfig.mjs +2 -0
  179. package/esm2020/src/util/MgBlockingQueue.mjs +2 -0
  180. package/esm2020/src/util/MgPriorityBlockingQueue.mjs +74 -0
  181. package/esm2020/src/util/MgPriorityQueue.mjs +66 -0
  182. package/esm2020/src/util/ParamParseResult.mjs +8 -0
  183. package/esm2020/src/util/PrmMap.mjs +151 -0
  184. package/esm2020/src/util/ReturnResult.mjs +46 -0
  185. package/esm2020/src/util/ReturnResultBase.mjs +18 -0
  186. package/esm2020/src/util/Scrambler.mjs +89 -0
  187. package/esm2020/src/util/UniqueIDUtils.mjs +12 -0
  188. package/esm2020/src/util/cookie.service.mjs +92 -0
  189. package/fesm2015/magic-xpa-engine.mjs +30835 -0
  190. package/fesm2015/magic-xpa-engine.mjs.map +1 -1
  191. package/fesm2020/magic-xpa-engine.mjs +30004 -0
  192. package/fesm2020/magic-xpa-engine.mjs.map +1 -1
  193. package/index.d.ts +187 -1
  194. package/package.json +4 -4
  195. package/src/AccessHelper.d.ts +20 -0
  196. package/src/ClientManager.d.ts +32 -0
  197. package/src/CommandsProcessorBase.d.ts +23 -0
  198. package/src/CommandsProcessorManager.d.ts +6 -0
  199. package/src/CommandsTable.d.ts +22 -0
  200. package/src/ConstInterface.d.ts +515 -0
  201. package/src/CurrentClientVersion.d.ts +1 -0
  202. package/src/FlowMonitorInterface.d.ts +15 -0
  203. package/src/GUIManager.d.ts +17 -0
  204. package/src/GlobalCommandsManager.d.ts +17 -0
  205. package/src/GuiEventsProcessor.d.ts +24 -0
  206. package/src/ICommandsTable.d.ts +9 -0
  207. package/src/ServerConfig.d.ts +34 -0
  208. package/src/bridge/IGuiEvent.d.ts +19 -0
  209. package/src/bridge/MagicBridge.d.ts +16 -0
  210. package/src/commands/ClientOriginatedCommandTaskTag.d.ts +8 -0
  211. package/src/commands/ClientToServer/AddUserLocateDataViewCommand.d.ts +4 -0
  212. package/src/commands/ClientToServer/AddUserRangeDataviewCommand.d.ts +6 -0
  213. package/src/commands/ClientToServer/AddUserSortDataViewCommand.d.ts +6 -0
  214. package/src/commands/ClientToServer/BrowserEscEventCommand.d.ts +8 -0
  215. package/src/commands/ClientToServer/ClientOriginatedCommand.d.ts +8 -0
  216. package/src/commands/ClientToServer/ClientOriginatedCommandSerializer.d.ts +6 -0
  217. package/src/commands/ClientToServer/ColumnSortEventCommand.d.ts +10 -0
  218. package/src/commands/ClientToServer/CommandFactory.d.ts +64 -0
  219. package/src/commands/ClientToServer/CommandSerializationHelper.d.ts +20 -0
  220. package/src/commands/ClientToServer/ComputeEventCommand.d.ts +8 -0
  221. package/src/commands/ClientToServer/ContextTerminationEventCommand.d.ts +7 -0
  222. package/src/commands/ClientToServer/ContextTimeoutResetCommand.d.ts +7 -0
  223. package/src/commands/ClientToServer/ControlItemsRefreshCommand.d.ts +6 -0
  224. package/src/commands/ClientToServer/DataViewOutputCommand.d.ts +9 -0
  225. package/src/commands/ClientToServer/DataviewCommand.d.ts +32 -0
  226. package/src/commands/ClientToServer/EvaluateCommand.d.ts +15 -0
  227. package/src/commands/ClientToServer/EventCommand.d.ts +15 -0
  228. package/src/commands/ClientToServer/ExecOperCommand.d.ts +23 -0
  229. package/src/commands/ClientToServer/FetchDataControlValuesEventCommand.d.ts +8 -0
  230. package/src/commands/ClientToServer/GlobalParamsQueryCommand.d.ts +5 -0
  231. package/src/commands/ClientToServer/ICommandTaskTag.d.ts +3 -0
  232. package/src/commands/ClientToServer/IndexChangeEventCommand.d.ts +8 -0
  233. package/src/commands/ClientToServer/IniputForceWriteCommand.d.ts +10 -0
  234. package/src/commands/ClientToServer/NonReversibleExitEventCommand.d.ts +8 -0
  235. package/src/commands/ClientToServer/QueryCommand.d.ts +8 -0
  236. package/src/commands/ClientToServer/RecomputeCommand.d.ts +11 -0
  237. package/src/commands/ClientToServer/RefreshEventCommand.d.ts +12 -0
  238. package/src/commands/ClientToServer/RefreshScreenEventCommand.d.ts +10 -0
  239. package/src/commands/ClientToServer/RollbackEventCommand.d.ts +14 -0
  240. package/src/commands/ClientToServer/SelectProgramCommand.d.ts +6 -0
  241. package/src/commands/ClientToServer/SetTransactionStateDataviewCommand.d.ts +5 -0
  242. package/src/commands/ClientToServer/SubformOpenEventCommand.d.ts +8 -0
  243. package/src/commands/ClientToServer/SubformRefreshEventCommand.d.ts +9 -0
  244. package/src/commands/ClientToServer/TransactionCommand.d.ts +12 -0
  245. package/src/commands/ClientToServer/UnloadCommand.d.ts +7 -0
  246. package/src/commands/ClientToServer/WriteMessageToServerLogCommand.d.ts +6 -0
  247. package/src/commands/DataViewCommandBase.d.ts +6 -0
  248. package/src/commands/IClientCommand.d.ts +2 -0
  249. package/src/commands/IClientTargetedCommand.d.ts +12 -0
  250. package/src/commands/IClientToServerCommandInfo.d.ts +3 -0
  251. package/src/commands/ServerToClient/AbortCommand.d.ts +11 -0
  252. package/src/commands/ServerToClient/AddLocateCommand.d.ts +6 -0
  253. package/src/commands/ServerToClient/AddRangeCommand.d.ts +10 -0
  254. package/src/commands/ServerToClient/AddSortCommand.d.ts +9 -0
  255. package/src/commands/ServerToClient/ClientRefreshCommand.d.ts +7 -0
  256. package/src/commands/ServerToClient/ClientTargetedCommandBase.d.ts +12 -0
  257. package/src/commands/ServerToClient/EnhancedVerifyCommand.d.ts +13 -0
  258. package/src/commands/ServerToClient/OpenURLCommand.d.ts +21 -0
  259. package/src/commands/ServerToClient/ResetLocateCommand.d.ts +6 -0
  260. package/src/commands/ServerToClient/ResetRangeCommand.d.ts +6 -0
  261. package/src/commands/ServerToClient/ResetSortCommand.d.ts +6 -0
  262. package/src/commands/ServerToClient/ResultCommand.d.ts +10 -0
  263. package/src/commands/ServerToClient/VerifyCommand.d.ts +17 -0
  264. package/src/commands/ServerToClient/XMLBasedCommandBuilder.d.ts +11 -0
  265. package/src/communications/IConnectionStateManager.d.ts +4 -0
  266. package/src/communications/InteractiveCommunicationsFailureHandler.d.ts +6 -0
  267. package/src/data/DataSourceIdKey.d.ts +2 -0
  268. package/src/data/DataView.d.ts +162 -0
  269. package/src/data/DataViewBase.d.ts +12 -0
  270. package/src/data/DataviewManager.d.ts +14 -0
  271. package/src/data/DataviewManagerBase.d.ts +11 -0
  272. package/src/data/DvCache.d.ts +15 -0
  273. package/src/data/Field.d.ts +103 -0
  274. package/src/data/FieldBase.d.ts +23 -0
  275. package/src/data/FieldsTable.d.ts +27 -0
  276. package/src/data/IRecordsTable.d.ts +7 -0
  277. package/src/data/Key.d.ts +15 -0
  278. package/src/data/Record.d.ts +156 -0
  279. package/src/data/RecordOutOfDataViewException.d.ts +10 -0
  280. package/src/data/RecordsTable.d.ts +38 -0
  281. package/src/data/TaskTransactionManager.d.ts +17 -0
  282. package/src/data/XMLBasedDcValuesBuilder.d.ts +11 -0
  283. package/src/enums.d.ts +21 -0
  284. package/src/env/EnvVariablesTable.d.ts +17 -0
  285. package/src/env/Environment.d.ts +118 -0
  286. package/src/env/ILanguageData.d.ts +3 -0
  287. package/src/env/LanguageData.d.ts +20 -0
  288. package/src/env/MirrorString.d.ts +15 -0
  289. package/src/event/ActionManager.d.ts +14 -0
  290. package/src/event/Event.d.ts +79 -0
  291. package/src/event/EventHandler.d.ts +66 -0
  292. package/src/event/EventHandlerPosition.d.ts +25 -0
  293. package/src/event/EventsManager.d.ts +204 -0
  294. package/src/event/IEventsManager.d.ts +77 -0
  295. package/src/event/RunTimeEvent.d.ts +123 -0
  296. package/src/event/RunTimeEventBase.d.ts +5 -0
  297. package/src/event/UserEventsTable.d.ts +11 -0
  298. package/src/exp/ExpTable.d.ts +11 -0
  299. package/src/exp/Expression.d.ts +37 -0
  300. package/src/exp/ExpressionDict.d.ts +12 -0
  301. package/src/exp/ExpressionEvaluator.d.ts +198 -0
  302. package/src/exp/ExpressionLocalJpn.d.ts +18 -0
  303. package/src/exp/GlobalParamsTable.d.ts +19 -0
  304. package/src/exp/YesNoExp.d.ts +9 -0
  305. package/src/gui/CreatedFormVector.d.ts +10 -0
  306. package/src/gui/FormsTable.d.ts +15 -0
  307. package/src/gui/MgControl.d.ts +60 -0
  308. package/src/gui/MgForm.d.ts +93 -0
  309. package/src/http/HttpManager.d.ts +25 -0
  310. package/src/http/client/HttpClientAsync.d.ts +16 -0
  311. package/src/http/client/HttpClientBase.d.ts +30 -0
  312. package/src/http/client/HttpClientEvents.d.ts +18 -0
  313. package/src/http/client/HttpClientSync.d.ts +17 -0
  314. package/src/http/client/HttpUtility.d.ts +10 -0
  315. package/src/http/client/ICommunicationsFailureHandler.d.ts +5 -0
  316. package/src/remote/AddUserLocateRemoteDataViewCommand.d.ts +8 -0
  317. package/src/remote/AddUserRangeRemoteDataViewCommand.d.ts +8 -0
  318. package/src/remote/AddUserSortRemoteDataViewCommand.d.ts +8 -0
  319. package/src/remote/RemoteCommandsProcessor.d.ts +51 -0
  320. package/src/remote/RemoteControlItemsRefreshCommand.d.ts +8 -0
  321. package/src/remote/RemoteDataViewCommandBase.d.ts +10 -0
  322. package/src/remote/RemoteDataViewCommandFactory.d.ts +6 -0
  323. package/src/remote/RemoteDataViewCommandUpdateNonModifiable.d.ts +8 -0
  324. package/src/remote/RemoteDataviewManager.d.ts +9 -0
  325. package/src/remote/RemoteInitDataViewCommand.d.ts +7 -0
  326. package/src/remote/ResetUserLocateRemoteDataviewCommand.d.ts +7 -0
  327. package/src/remote/ResetUserRangeRemoteDataviewCommand.d.ts +7 -0
  328. package/src/remote/ResetUserSortRemoteDataviewCommand.d.ts +7 -0
  329. package/src/remote/ServerError.d.ts +16 -0
  330. package/src/remote/SetTransactionStateRemoteDataViewCommand.d.ts +8 -0
  331. package/src/rt/Argument.d.ts +36 -0
  332. package/src/rt/ArgumentsList.d.ts +24 -0
  333. package/src/rt/Boundary.d.ts +27 -0
  334. package/src/rt/CompMainPrgTable.d.ts +10 -0
  335. package/src/rt/DataviewHeaderBase.d.ts +34 -0
  336. package/src/rt/DataviewHeaderFactory.d.ts +5 -0
  337. package/src/rt/DataviewHeaders.d.ts +12 -0
  338. package/src/rt/DataviewHeadersSaxHandler.d.ts +10 -0
  339. package/src/rt/ExecutionStack.d.ts +22 -0
  340. package/src/rt/ExecutionStackEntry.d.ts +7 -0
  341. package/src/rt/HandlersTable.d.ts +19 -0
  342. package/src/rt/IDataSourceViewDefinition.d.ts +6 -0
  343. package/src/rt/IDataviewHeader.d.ts +10 -0
  344. package/src/rt/IResultValue.d.ts +4 -0
  345. package/src/rt/LastFocusedManager.d.ts +23 -0
  346. package/src/rt/Operation.d.ts +97 -0
  347. package/src/rt/OperationTable.d.ts +15 -0
  348. package/src/rt/Recompute.d.ts +41 -0
  349. package/src/rt/RecomputeTable.d.ts +9 -0
  350. package/src/rt/RemoteDataviewHeader.d.ts +14 -0
  351. package/src/rt/ResultValue.d.ts +7 -0
  352. package/src/rt/TableCache.d.ts +29 -0
  353. package/src/rt/TableCacheManager.d.ts +10 -0
  354. package/src/rt/Transaction.d.ts +23 -0
  355. package/src/security/UserDetails.d.ts +16 -0
  356. package/src/tasks/IMGDataCollection.d.ts +26 -0
  357. package/src/tasks/MGData.d.ts +63 -0
  358. package/src/tasks/MGDataCollection.d.ts +42 -0
  359. package/src/tasks/RCTimer.d.ts +13 -0
  360. package/src/tasks/RemoteTaskService.d.ts +16 -0
  361. package/src/tasks/Task.d.ts +312 -0
  362. package/src/tasks/TaskBase.d.ts +123 -0
  363. package/src/tasks/TaskServiceBase.d.ts +16 -0
  364. package/src/tasks/TasksTable.d.ts +21 -0
  365. package/src/tasks/sort/Sort.d.ts +4 -0
  366. package/src/tasks/sort/SortCollection.d.ts +11 -0
  367. package/src/util/ConstUtils.d.ts +3 -0
  368. package/src/util/FlowMonitorQueue.d.ts +70 -0
  369. package/src/util/HeapSort.d.ts +6 -0
  370. package/src/util/IMirrorXML.d.ts +6 -0
  371. package/src/util/IServerConfig.d.ts +11 -0
  372. package/src/util/MgBlockingQueue.d.ts +5 -0
  373. package/src/util/MgPriorityBlockingQueue.d.ts +17 -0
  374. package/src/util/MgPriorityQueue.d.ts +13 -0
  375. package/src/util/ParamParseResult.d.ts +6 -0
  376. package/src/util/PrmMap.d.ts +28 -0
  377. package/src/util/ReturnResult.d.ts +18 -0
  378. package/src/util/ReturnResultBase.d.ts +11 -0
  379. package/src/util/Scrambler.d.ts +10 -0
  380. package/src/util/UniqueIDUtils.d.ts +4 -0
  381. package/src/util/cookie.service.d.ts +8 -0
@@ -0,0 +1,880 @@
1
+ import { Base64, JSON_Utils, Logger, Logger_LogLevels, Misc, MsgInterface, OSEnvironment, RequestInfo, StrUtil, XMLConstants } from "@magic-xpa/utils";
2
+ import { Debug, Encoding, Exception, List, NString, RefParam, StringBuilder, isNullOrUndefined, isUndefined } from "@magic-xpa/mscorelib";
3
+ import { Commands, RuntimeContextBase, Styles, UsernamePasswordCredentials } from "@magic-xpa/gui";
4
+ import { ExecOperCommand } from '../commands/ClientToServer/ExecOperCommand';
5
+ import { CommandsProcessorBase, CommandsProcessorBase_SendingInstruction, CommandsProcessorBase_SessionStage } from "../CommandsProcessorBase";
6
+ import { HttpManager } from "../http/HttpManager";
7
+ import { ConstInterface } from "../ConstInterface";
8
+ import { Scrambler } from "../util/Scrambler";
9
+ import { ServerError } from "./ServerError";
10
+ import { FlowMonitorQueue } from "../util/FlowMonitorQueue";
11
+ import { OpeningTaskDetails } from "../tasks/TaskBase";
12
+ import { HttpUtility } from "../http/client/HttpUtility";
13
+ import { HttpClientEvents } from "../http/client/HttpClientEvents";
14
+ import { ServerConfig } from "../ServerConfig";
15
+ import { AccessHelper } from "../AccessHelper";
16
+ import { Environment, Event, EventCommand, EventsManager, GUIManager } from "../../";
17
+ import { MGDataCollection } from "../tasks/MGDataCollection";
18
+ import { timer } from "rxjs";
19
+ var RequestStatus;
20
+ (function (RequestStatus) {
21
+ RequestStatus[RequestStatus["Handled"] = 0] = "Handled";
22
+ RequestStatus[RequestStatus["Retry"] = 1] = "Retry";
23
+ RequestStatus[RequestStatus["Abort"] = 2] = "Abort";
24
+ })(RequestStatus || (RequestStatus = {}));
25
+ export class RemoteCommandsProcessor extends CommandsProcessorBase {
26
+ static GetInstance() {
27
+ if (RemoteCommandsProcessor._instance === null) {
28
+ RemoteCommandsProcessor._instance = new RemoteCommandsProcessor();
29
+ }
30
+ return RemoteCommandsProcessor._instance;
31
+ }
32
+ constructor() {
33
+ super();
34
+ this._lastRequestTime = 0;
35
+ this.ServerUrl = null;
36
+ this.DelayCommandExecution = false;
37
+ this._requestInfo = new RequestInfo();
38
+ this.ServerUrl = ServerConfig.Instance.getServerURL();
39
+ HttpManager.GetInstance();
40
+ this.RegisterDelegates();
41
+ }
42
+ CheckAndSetSessionCounter(newSessionCounter) {
43
+ if (newSessionCounter === ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION) {
44
+ Debug.Assert(this.GetSessionCounter() === ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION);
45
+ }
46
+ else {
47
+ Debug.Assert(newSessionCounter === this.GetSessionCounter() + 1);
48
+ this.SetSessionCounter(newSessionCounter);
49
+ Logger.Instance.WriteServerToLog(NString.Format("Session Counter --> {0}", this._sessionCounter));
50
+ }
51
+ }
52
+ ClearSessionCounter() {
53
+ this._sessionCounter = 0;
54
+ Logger.Instance.WriteServerToLog(NString.Format("Session Counter --> {0}", this._sessionCounter));
55
+ }
56
+ SetSessionCounter(newSessionCounter) {
57
+ this._sessionCounter = newSessionCounter;
58
+ }
59
+ get GetLastRequestTime() {
60
+ return this._lastRequestTime;
61
+ }
62
+ async ReStartSession() {
63
+ RemoteCommandsProcessor.IsSessionReInitializing = true;
64
+ await this.StoreSessionReInitializingDataOnLocalStorage();
65
+ let navigateRootRoute = false;
66
+ if (!RuntimeContextBase.Instance.RemovedContextFromServer)
67
+ navigateRootRoute = Environment.Instance.getSpecialRouteToRootProgOnContextRecreation() ? true : false;
68
+ Commands.addRefreshPage(navigateRootRoute, RemoteCommandsProcessor.InitialUrl);
69
+ throw new Exception('');
70
+ }
71
+ async StoreSessionReInitializingDataOnLocalStorage() {
72
+ let mainPrgViewStringForServer = await this.BuildXMLForMainProgramDataView();
73
+ let globalParamsString = AccessHelper.globalParams.mirrorAllToXML();
74
+ let changedEnvVarList = AccessHelper.envParamsTable.mirrorAllToXML();
75
+ let dataStorage = window.localStorage;
76
+ dataStorage.setItem(ConstInterface.IS_SESSION_REINITIALIZING, "true");
77
+ dataStorage.setItem(ConstInterface.MAIN_PROG_VIEW, mainPrgViewStringForServer.toString());
78
+ dataStorage.setItem(ConstInterface.GLOBAL_PARAM_LIST, globalParamsString);
79
+ dataStorage.setItem(ConstInterface.ENV_VAR_LIST, changedEnvVarList);
80
+ dataStorage.setItem(ConstInterface.LAST_EXCEPTION, RemoteCommandsProcessor.lastExceptionMessage);
81
+ if (RuntimeContextBase.Instance.RemovedContextFromServer)
82
+ dataStorage.setItem(ConstInterface.CTX_REMOVED_FROM_SRVR, "1");
83
+ EventsManager.Instance.storeLastSavedRouteEventOnLocalStorage();
84
+ }
85
+ RestoreSessionReInitializingDataFromLocalStorage(key) {
86
+ let dataStorage = window.localStorage;
87
+ let val = dataStorage.getItem(key);
88
+ return val;
89
+ }
90
+ async StartSession() {
91
+ let authenticationCancelled = false;
92
+ let handshakeResponse = null;
93
+ try {
94
+ let lastTypedUserId = null;
95
+ let handshakeInitialTokens = new StringBuilder();
96
+ handshakeInitialTokens.Append(ConstInterface.UTF8TRANS +
97
+ ConstInterface.REQ_APP_NAME + "=" +
98
+ HttpUtility.UrlEncode(ServerConfig.Instance.getAppName(), Encoding.UTF8));
99
+ handshakeInitialTokens.Append("&" + ConstInterface.REQ_ARGS + "=" + ConstInterface.REQ_ARG_ALPHA +
100
+ "<Richclient><Requires EncryptionKey=\"False\"/><RIAProtocolVersion=\"" + RemoteCommandsProcessor.WEB_COMMUNICATION_PROTOCOL_VERSION + "\"/></Richclient>");
101
+ Logger.Instance.WriteDevToLog(NString.Format("Handshake request #1 (not scrambled) : {0}", this.ServerUrl + ConstInterface.REQ_ARG_START +
102
+ ConstInterface.RC_INDICATION_INITIAL + handshakeInitialTokens));
103
+ let handshakeInitialUrl = this.ServerUrl + ConstInterface.REQ_ARG_START +
104
+ ConstInterface.RC_INDICATION_INITIAL +
105
+ ConstInterface.RC_TOKEN_DATA +
106
+ HttpUtility.UrlEncode(Scrambler.Scramble(handshakeInitialTokens.ToString()), Encoding.UTF8);
107
+ Logger.Instance.WriteServerMessagesToLog("");
108
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("Handshake request #1: {0}", handshakeInitialUrl));
109
+ let ctxGroup = ServerConfig.Instance.getCtxGroup();
110
+ while (!authenticationCancelled) {
111
+ let requestStatus = new RefParam(RequestStatus.Handled);
112
+ let responseStr = await this.DispatchRequest(handshakeInitialUrl, null, CommandsProcessorBase_SessionStage.HANDSHAKE, requestStatus);
113
+ if (NString.IsNullOrEmpty(responseStr)) {
114
+ throw new ServerError("Client failed to initialize a session." + OSEnvironment.EolSeq +
115
+ "Empty response was received from the web server." + OSEnvironment.EolSeq + OSEnvironment.EolSeq + this.ServerUrl);
116
+ }
117
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("Handshake response #1: {0}", responseStr));
118
+ Logger.Instance.WriteServerMessagesToLog("");
119
+ handshakeResponse = new HandshakeResponse(responseStr);
120
+ RuntimeContextBase.Instance.ContextID = handshakeResponse.ContextId;
121
+ this.SessionId = handshakeResponse.GetSessionId;
122
+ HttpManager.GetInstance().HttpCommunicationTimeoutMS = handshakeResponse.HttpTimeout * 1000;
123
+ if (NString.IsNullOrEmpty(ServerConfig.Instance.getCtxGroup())) {
124
+ ctxGroup = handshakeResponse.ContextId;
125
+ }
126
+ let credentials = null;
127
+ if (ServerConfig.Instance.getSkipAuthenticationDialog()) {
128
+ if (ServerConfig.Instance.getUsername() !== null) {
129
+ credentials = new UsernamePasswordCredentials(ServerConfig.Instance.getUsername(), ServerConfig.Instance.getPassword());
130
+ ServerConfig.Instance.setUsername("");
131
+ ServerConfig.Instance.setPassword("");
132
+ }
133
+ }
134
+ else if (handshakeResponse.InputPassword && handshakeResponse.SystemLogin !== HandshakeResponse.SYSTEM_LOGIN_AD) {
135
+ if (lastTypedUserId !== null) {
136
+ let title = AccessHelper.languageData.getConstMessage(MsgInterface.BRKTAB_STR_ERROR);
137
+ let error = AccessHelper.languageData.getConstMessage(MsgInterface.USRINP_STR_BADPASSW);
138
+ await GUIManager.Instance.MessageBox(title, error, Styles.MSGBOX_ICON_ERROR | Styles.MSGBOX_BUTTON_OK);
139
+ }
140
+ }
141
+ if (authenticationCancelled) {
142
+ this.SetSessionCounter(ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION);
143
+ }
144
+ let handshakeAuthUrl = this.PrepareAuthenticationUrl(handshakeResponse.ContextId, ctxGroup, this.GetSessionCounter());
145
+ try {
146
+ if (credentials !== null) {
147
+ let credentialsStr = credentials.Username + ":";
148
+ if (!NString.IsNullOrEmpty(credentials.Password)) {
149
+ credentialsStr = credentialsStr + credentials.Password + ":";
150
+ }
151
+ credentialsStr += handshakeResponse.ContextId;
152
+ credentialsStr = Scrambler.Scramble(credentialsStr);
153
+ credentialsStr = Base64.encode(credentialsStr, true, Encoding.UTF8);
154
+ handshakeAuthUrl += ("&USERNAME=" + HttpUtility.UrlEncode(credentialsStr, Encoding.UTF8));
155
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("Handshake request #2: {0}", handshakeAuthUrl));
156
+ let statusRequest = new RefParam(RequestStatus.Handled);
157
+ responseStr = await this.DispatchRequest(handshakeAuthUrl, null, CommandsProcessorBase_SessionStage.HANDSHAKE, statusRequest);
158
+ if (responseStr.indexOf(handshakeResponse.ContextId) === -1) {
159
+ throw new ServerError(AccessHelper.languageData.getConstMessage(MsgInterface.USRINP_STR_BADPASSW));
160
+ }
161
+ ServerConfig.Instance.setUsername(credentials.Username);
162
+ ServerConfig.Instance.setPassword(credentials.Password);
163
+ }
164
+ else {
165
+ let requestStatus = new RefParam(RequestStatus.Handled);
166
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("Handshake request #2: {0}", handshakeAuthUrl));
167
+ responseStr = await this.DispatchRequest(handshakeAuthUrl, null, CommandsProcessorBase_SessionStage.HANDSHAKE, requestStatus);
168
+ }
169
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("Handshake response #2: {0}", responseStr));
170
+ Logger.Instance.WriteServerMessagesToLog("");
171
+ break;
172
+ }
173
+ catch (ex) {
174
+ if (ex instanceof ServerError) {
175
+ let serverError = ex;
176
+ if (ServerConfig.Instance.getSkipAuthenticationDialog()) {
177
+ switch (serverError.GetCode()) {
178
+ case ServerError.ERR_ACCESS_DENIED:
179
+ case ServerError.ERR_AUTHENTICATION:
180
+ ServerConfig.Instance.setSkipAuthenticationDialog(false);
181
+ throw serverError;
182
+ }
183
+ }
184
+ if (!handshakeResponse.InputPassword)
185
+ throw serverError;
186
+ if (serverError.GetCode() !== ServerError.ERR_AUTHENTICATION &&
187
+ (!authenticationCancelled || serverError.GetCode() !== ServerError.INF_NO_RESULT)) {
188
+ throw serverError;
189
+ }
190
+ }
191
+ else
192
+ throw ex;
193
+ }
194
+ }
195
+ ServerConfig.Instance.setSkipAuthenticationDialog(true);
196
+ ServerConfig.Instance.setCtxGroup(ctxGroup);
197
+ RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages = handshakeResponse.ScrambleMessages;
198
+ if (Logger.Instance.LogLevel !== Logger_LogLevels.Basic) {
199
+ let maxInternalLogLevel = handshakeResponse.MaxInternalLogLevel;
200
+ if (maxInternalLogLevel !== null) {
201
+ let maxLogLevel = this.parseLogLevel(maxInternalLogLevel);
202
+ if (maxLogLevel < Logger.Instance.LogLevel) {
203
+ ServerConfig.Instance.setInternalLogLevel(maxInternalLogLevel);
204
+ Logger.Instance.WriteToLog(NString.Format("Internal log level was restricted to '{0}' by the Magic xpa server.", maxInternalLogLevel), false);
205
+ Logger.Instance.LogLevel = maxLogLevel;
206
+ }
207
+ }
208
+ }
209
+ if (!authenticationCancelled) {
210
+ await this.ExecuteInitialRequest();
211
+ }
212
+ }
213
+ catch (ex) {
214
+ if (ex instanceof ServerError)
215
+ throw ex;
216
+ if (isNullOrUndefined(ex.InnerException))
217
+ throw new ServerError(ex.message, new Exception(ex));
218
+ else
219
+ throw new ServerError(ex.message, ex.InnerException);
220
+ }
221
+ return !authenticationCancelled;
222
+ }
223
+ PrepareAuthenticationUrl(contextId, ctxGroup, sessionCount) {
224
+ let handshakeAuthUrl = this.ServerUrl + ConstInterface.REQ_ARG_START +
225
+ ConstInterface.RC_INDICATION + ConstInterface.UTF8TRANS +
226
+ ConstInterface.RC_TOKEN_CTX_ID + contextId;
227
+ if (!isNullOrUndefined(this.SessionId))
228
+ handshakeAuthUrl += (ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.RC_TOKEN_SESSION_ID + this.SessionId);
229
+ handshakeAuthUrl += (ConstInterface.REQ_ARG_SEPARATOR +
230
+ ConstInterface.RC_TOKEN_SESSION_COUNT + sessionCount +
231
+ ConstInterface.REQ_ARG_SEPARATOR +
232
+ ConstInterface.RC_TOKEN_CTX_GROUP + ctxGroup +
233
+ ConstInterface.REQ_ARG_SEPARATOR +
234
+ ConstInterface.RC_AUTHENTICATION_REQUEST);
235
+ return handshakeAuthUrl;
236
+ }
237
+ async ExecuteInitialRequest() {
238
+ await this.Execute_1(CommandsProcessorBase_SendingInstruction.TASKS_AND_COMMANDS, CommandsProcessorBase_SessionStage.INITIAL, null);
239
+ }
240
+ GetTaskTree(task) {
241
+ let taskTree = new List();
242
+ while (!isNullOrUndefined(task)) {
243
+ taskTree.push(task.getTaskInfo());
244
+ task = task.getParent();
245
+ }
246
+ return taskTree;
247
+ }
248
+ async UpdateRequestInfo() {
249
+ let currMGData = AccessHelper.mgDataTable.getCurrMGData();
250
+ let eventsManager = AccessHelper.eventsManager;
251
+ let operExecution = false;
252
+ let cmdsToServer = currMGData.CmdsToServer;
253
+ for (let i = 0; i < cmdsToServer.getSize(); i++) {
254
+ if (cmdsToServer.getCmd(i) instanceof ExecOperCommand) {
255
+ let operCmd = currMGData.CmdsToServer.getCmd(i);
256
+ this._requestInfo.serverCallAt = operCmd.getCommandInfo();
257
+ this._requestInfo.runtimeTaskTree = this.GetTaskTree(operCmd.getTask());
258
+ operExecution = true;
259
+ break;
260
+ }
261
+ }
262
+ this._requestInfo.extraInfo.contextID = RuntimeContextBase.Instance.ContextID;
263
+ this._requestInfo.extraInfo.sessionCounter = this.GetSessionCounter();
264
+ if (!operExecution) {
265
+ if (eventsManager.getLastRtEvent() != null && eventsManager.getLastRtEvent().InternalEvent != 0) {
266
+ let rtEvt = eventsManager.getLastRtEvent();
267
+ this._requestInfo.runtimeTaskTree = this.GetTaskTree(rtEvt.getTask());
268
+ let eventDescription = rtEvt.isNewInternalEvent()
269
+ ? NString.TrimEnd(rtEvt.getNewInternalEventDescription())
270
+ : Event.getInternalEvtDescription(rtEvt.InternalEvent);
271
+ let cmd = cmdsToServer.getCmd(cmdsToServer.getSize() - 1);
272
+ if (cmd) {
273
+ let commandInfo = NString.IsNullOrEmpty(cmd.getCommandInfo())
274
+ ? NString.Empty
275
+ : cmd.getCommandInfo();
276
+ if (cmd instanceof EventCommand && rtEvt.InternalEvent == cmd.MagicEvent)
277
+ eventDescription = NString.Empty;
278
+ this._requestInfo.serverCallAt = 'Event ' + commandInfo +
279
+ (!NString.IsNullOrEmpty(eventDescription)
280
+ ? NString.Format(' while executing [{0}]', eventDescription)
281
+ : NString.Empty);
282
+ }
283
+ }
284
+ }
285
+ }
286
+ async BuildXMLForMainProgramDataView() {
287
+ let message = new StringBuilder();
288
+ let firstMgData = MGDataCollection.Instance.getMGData(0);
289
+ let mainPrg = firstMgData.getMainProg(0);
290
+ while (mainPrg != null) {
291
+ await mainPrg.buildXML(message);
292
+ mainPrg = firstMgData.getNextMainProg(mainPrg.getCtlIdx());
293
+ }
294
+ if (RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages) {
295
+ let scrambledChanges = Scrambler.Scramble(message.ToString());
296
+ message = new StringBuilder(scrambledChanges);
297
+ }
298
+ message.Insert(0, XMLConstants.MG_TAG_OPEN);
299
+ message.Append(XMLConstants.MG_TAG_XML_END_TAGGED);
300
+ return message.ToString();
301
+ }
302
+ async Execute_1(sendingInstruction, sessionStage, res) {
303
+ let reqBuf;
304
+ let isInitialCall = sessionStage === CommandsProcessorBase_SessionStage.INITIAL;
305
+ let globalParamsString = null;
306
+ let envVarsString = null;
307
+ if (this.DelayCommandExecution)
308
+ return;
309
+ if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo && !isInitialCall)
310
+ await this.UpdateRequestInfo();
311
+ if (isInitialCall) {
312
+ let val = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.IS_SESSION_REINITIALIZING);
313
+ if (val === 'true') {
314
+ RemoteCommandsProcessor.IsSessionReInitializing = (val === "true") ? true : false;
315
+ RemoteCommandsProcessor.lastExceptionMessage = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.LAST_EXCEPTION);
316
+ let ctxRemoved = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.CTX_REMOVED_FROM_SRVR);
317
+ if (ctxRemoved !== '1') {
318
+ Logger.Instance.WriteErrorToLog(RemoteCommandsProcessor.lastExceptionMessage);
319
+ Logger.Instance.WriteToLog("Session is reinitializing...", true);
320
+ }
321
+ }
322
+ }
323
+ if (sendingInstruction === CommandsProcessorBase_SendingInstruction.NO_TASKS_OR_COMMANDS)
324
+ reqBuf = null;
325
+ else {
326
+ reqBuf = await this.PrepareRequest(sendingInstruction === CommandsProcessorBase_SendingInstruction.TASKS_AND_COMMANDS);
327
+ if (RemoteCommandsProcessor.IsSessionReInitializing || !isInitialCall) {
328
+ let changes = new StringBuilder();
329
+ let buffer = new StringBuilder();
330
+ if (!RemoteCommandsProcessor.IsSessionReInitializing)
331
+ buffer.Append(reqBuf);
332
+ if (RemoteCommandsProcessor.IsSessionReInitializing) {
333
+ globalParamsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.GLOBAL_PARAM_LIST);
334
+ envVarsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.ENV_VAR_LIST);
335
+ }
336
+ else {
337
+ globalParamsString = AccessHelper.globalParams.mirrorToXML();
338
+ envVarsString = AccessHelper.envParamsTable.mirrorToXML();
339
+ }
340
+ changes.Append(globalParamsString);
341
+ changes.Append(envVarsString);
342
+ if (changes.Length > 0) {
343
+ changes.Insert(0, "<" + ConstInterface.MG_TAG_ENV_CHANGES + ">");
344
+ changes.Append("</" + ConstInterface.MG_TAG_ENV_CHANGES + ">");
345
+ if (RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages) {
346
+ let scrambledChanges = Scrambler.Scramble(changes.ToString());
347
+ changes = new StringBuilder(scrambledChanges);
348
+ }
349
+ changes.Insert(0, XMLConstants.MG_TAG_OPEN);
350
+ changes.Append(XMLConstants.MG_TAG_XML_END_TAGGED);
351
+ buffer.Append(changes.ToString());
352
+ }
353
+ reqBuf = buffer.ToString();
354
+ }
355
+ }
356
+ let requestStatus = new RefParam(RequestStatus.Handled);
357
+ let respBuf = null;
358
+ if (RemoteCommandsProcessor.IsSessionReInitializing) {
359
+ reqBuf = reqBuf + this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.MAIN_PROG_VIEW);
360
+ }
361
+ if (RuntimeContextBase.Instance.RemovedContextFromServer)
362
+ requestStatus.value = RequestStatus.Retry;
363
+ else {
364
+ if (RuntimeContextBase.Instance.RemovingContextFromServer)
365
+ RuntimeContextBase.Instance.RemovedContextFromServer = true;
366
+ respBuf = await this.DispatchRequest(this.ServerUrl, reqBuf, sessionStage, requestStatus);
367
+ }
368
+ if (requestStatus.value == RequestStatus.Retry) {
369
+ await this.ReStartSession();
370
+ }
371
+ if (respBuf == null)
372
+ return;
373
+ if (isInitialCall) {
374
+ RemoteCommandsProcessor.InitialUrl = window.location.href;
375
+ if (RemoteCommandsProcessor.IsSessionReInitializing) {
376
+ let dataStorage = window.localStorage;
377
+ dataStorage.removeItem(ConstInterface.IS_SESSION_REINITIALIZING);
378
+ dataStorage.removeItem(ConstInterface.MAIN_PROG_VIEW);
379
+ dataStorage.removeItem(ConstInterface.GLOBAL_PARAM_LIST);
380
+ dataStorage.removeItem(ConstInterface.ENV_VAR_LIST);
381
+ dataStorage.removeItem(ConstInterface.LAST_EXCEPTION);
382
+ }
383
+ }
384
+ FlowMonitorQueue.Instance.enable(false);
385
+ await this.ProcessResponse(respBuf, AccessHelper.mgDataTable.currMgdID, null, res);
386
+ if (RemoteCommandsProcessor.IsSessionReInitializing) {
387
+ AccessHelper.globalParams.RestoreParams(globalParamsString);
388
+ AccessHelper.envParamsTable.RestoreParams(envVarsString);
389
+ let dataStorage = window.localStorage;
390
+ let ctxRemoved = dataStorage.getItem(ConstInterface.CTX_REMOVED_FROM_SRVR);
391
+ if (ctxRemoved === "1") {
392
+ EventsManager.Instance.restoreLastSavedRouteEventFromLocalStorage();
393
+ dataStorage.removeItem(ConstInterface.CTX_REMOVED_FROM_SRVR);
394
+ dataStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT);
395
+ dataStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_SRC_TSK);
396
+ dataStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_ARG_LIST);
397
+ }
398
+ RemoteCommandsProcessor.IsSessionReInitializing = false;
399
+ }
400
+ if (sendingInstruction === CommandsProcessorBase_SendingInstruction.TASKS_AND_COMMANDS) {
401
+ AccessHelper.mgDataTable.startTasksIteration();
402
+ let task;
403
+ while ((task = AccessHelper.mgDataTable.getNextTask()) !== null) {
404
+ let dataViewWasRetrieved = task.DataViewWasRetrieved;
405
+ if (dataViewWasRetrieved) {
406
+ await task.RefreshDisplay();
407
+ }
408
+ }
409
+ }
410
+ if (isInitialCall)
411
+ ServerConfig.Instance.setGlobalParams(null);
412
+ }
413
+ async DispatchRequest(url, reqBuf, sessionStage, requestStatus) {
414
+ let response = null;
415
+ let encodedBody = null;
416
+ requestStatus.value = RequestStatus.Handled;
417
+ if (url === null) {
418
+ Logger.Instance.WriteExceptionToLogWithMsg("in sendMsgToSrvr() unknown server");
419
+ return response;
420
+ }
421
+ if (sessionStage !== CommandsProcessorBase_SessionStage.HANDSHAKE) {
422
+ let urlSuffix = this.BuildUrlSuffix(reqBuf !== null, sessionStage === CommandsProcessorBase_SessionStage.INITIAL);
423
+ let reqBufEncoded = HttpUtility.UrlEncode(reqBuf, Encoding.UTF8);
424
+ encodedBody = urlSuffix + reqBufEncoded;
425
+ }
426
+ try {
427
+ if (Logger.Instance.ShouldLogExtendedServerRelatedMessages())
428
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("MESSAGE TO SERVER:\n URL: {0}\n BODY: {1}", url, encodedBody));
429
+ response = await this.ExecuteRequest(url, encodedBody);
430
+ if (!response.toUpperCase().startsWith("<HTML")) {
431
+ let startIdx = response.indexOf("<xml id=\"MGDATA\">");
432
+ if (startIdx > 0)
433
+ response = response.substr(startIdx);
434
+ }
435
+ Logger.Instance.WriteServerMessagesToLog("MESSAGE FROM SERVER: " + response);
436
+ if (sessionStage === CommandsProcessorBase_SessionStage.HANDSHAKE ||
437
+ (response.length > 0 &&
438
+ RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages && response !== "<xml id=\"MGDATA\">\n</xml>")) {
439
+ if (sessionStage === CommandsProcessorBase_SessionStage.HANDSHAKE) {
440
+ Debug.Assert(response.length > 0 && response[0] !== '<');
441
+ }
442
+ response = CommandsProcessorBase.UnScramble(response);
443
+ }
444
+ Logger.Instance.WriteDevToLog("MESSAGE FROM SERVER: (size = " + response.length + ")" + OSEnvironment.EolSeq + response);
445
+ this._lastRequestTime = Misc.getSystemMilliseconds();
446
+ }
447
+ catch (ex) {
448
+ if (ex instanceof ServerError) {
449
+ requestStatus.value = RequestStatus.Abort;
450
+ if (sessionStage == CommandsProcessorBase_SessionStage.NORMAL) {
451
+ if (ex.GetCode() == ServerError.ERR_CTX_NOT_FOUND || ex.GetCode() == ServerError.ERR_THREAD_ABORTED) {
452
+ if (RuntimeContextBase.Instance.RemovedContextFromServer) {
453
+ requestStatus.value = RequestStatus.Retry;
454
+ }
455
+ else {
456
+ switch (Environment.Instance.getWebClientReinitSession()) {
457
+ case 'Y':
458
+ requestStatus.value = RequestStatus.Retry;
459
+ break;
460
+ case 'A':
461
+ let retval = await GUIManager.Instance.MessageBox("Error", "Unknown error occurred at server-side." +
462
+ " Would you like to reinitialize the session?", Styles.MSGBOX_BUTTON_YES_NO);
463
+ requestStatus.value = (retval == Styles.MSGBOX_RESULT_YES) ? RequestStatus.Retry : RequestStatus.Abort;
464
+ break;
465
+ case 'N':
466
+ default:
467
+ requestStatus.value = RequestStatus.Abort;
468
+ break;
469
+ }
470
+ }
471
+ if (requestStatus.value == RequestStatus.Abort) {
472
+ Environment.Instance.setWebClientReinitSession('N');
473
+ throw ex;
474
+ }
475
+ else {
476
+ let errForConsole = StrUtil.getConsoleErorString(ex.GetMessage());
477
+ RemoteCommandsProcessor.lastExceptionMessage = "Exception Occured at server side : " + ex.GetCode().toString() + " : " + errForConsole;
478
+ console.log(RemoteCommandsProcessor.lastExceptionMessage);
479
+ }
480
+ return null;
481
+ }
482
+ }
483
+ }
484
+ this.clearLocalStorage();
485
+ throw ex;
486
+ }
487
+ return response;
488
+ }
489
+ clearLocalStorage() {
490
+ window.localStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT);
491
+ window.localStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_SRC_TSK);
492
+ window.localStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_ARG_LIST);
493
+ window.localStorage.removeItem(ConstInterface.IS_SESSION_REINITIALIZING);
494
+ window.localStorage.removeItem(ConstInterface.MAIN_PROG_VIEW);
495
+ window.localStorage.removeItem(ConstInterface.GLOBAL_PARAM_LIST);
496
+ window.localStorage.removeItem(ConstInterface.ENV_VAR_LIST);
497
+ window.localStorage.removeItem(ConstInterface.LAST_EXCEPTION);
498
+ window.localStorage.removeItem(ConstInterface.CTX_REMOVED_FROM_SRVR);
499
+ }
500
+ HandleErrorResponse(response) {
501
+ try {
502
+ Logger.Instance.WriteServerMessagesToLog("MESSAGE FROM SERVER: " + response);
503
+ response = CommandsProcessorBase.UnScramble(response);
504
+ Logger.Instance.WriteServerMessagesToLog("MESSAGE FROM SERVER: " + StrUtil.getConsoleErorString(response));
505
+ }
506
+ catch (ex) {
507
+ }
508
+ if (response.startsWith("<xmlerr")) {
509
+ let errorMessageXml = new ErrorMessageXml(response, this._lastRequestTime, AccessHelper.environment.getContextInactivityTimeout());
510
+ throw new ServerError(errorMessageXml.GetMessage(), errorMessageXml.GetCode());
511
+ }
512
+ else if (response.toUpperCase().startsWith("<HTML")) {
513
+ throw new ServerError(response);
514
+ }
515
+ }
516
+ async ExecuteRequest(url, encodedBody) {
517
+ return await this.GetContent(url, false, encodedBody);
518
+ }
519
+ async GetContent(requestedURL, useCache, requestContent) {
520
+ if (isUndefined(requestContent))
521
+ requestContent = null;
522
+ let responseStr;
523
+ try {
524
+ if (requestedURL.startsWith("/"))
525
+ requestedURL = ServerConfig.Instance.getProtocol() + "://" + ServerConfig.Instance.getServer() + requestedURL;
526
+ var spinnerTimer = timer(50, 50);
527
+ var spinnerTimerSubscription = spinnerTimer.subscribe(() => {
528
+ AccessHelper.eventsManager.CheckAndShowSpinner(true);
529
+ });
530
+ let isError = new RefParam(false);
531
+ responseStr = await HttpManager.GetInstance().GetContent(requestedURL, requestContent, useCache, isError);
532
+ spinnerTimerSubscription.unsubscribe();
533
+ spinnerTimerSubscription = null;
534
+ if (isError.value) {
535
+ this.HandleErrorResponse(responseStr);
536
+ }
537
+ }
538
+ catch (ex) {
539
+ if (!(ex instanceof ServerError) || Logger.Instance.LogLevel !== Logger_LogLevels.Basic) {
540
+ Logger.Instance.WriteExceptionToLog(ex, NString.Format("requested URL = \"{0}\"", requestedURL));
541
+ }
542
+ if (!(ex instanceof ServerError)) {
543
+ ex = new ServerError(ex.Message, ex.InnerException ? ex.InnerException : ex);
544
+ }
545
+ throw ex;
546
+ }
547
+ finally {
548
+ if (spinnerTimerSubscription != null)
549
+ spinnerTimerSubscription.unsubscribe();
550
+ }
551
+ return responseStr;
552
+ }
553
+ ClientActivated() {
554
+ }
555
+ BuildUrlSuffix(hasContent, isInitialCall) {
556
+ let prefix = ConstInterface.RC_INDICATION + ConstInterface.RC_TOKEN_CTX_ID + RuntimeContextBase.Instance.ContextID;
557
+ if (!isNullOrUndefined(this.SessionId))
558
+ prefix += (ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.RC_TOKEN_SESSION_ID + this.SessionId);
559
+ if (isInitialCall) {
560
+ if (RemoteCommandsProcessor.IsSessionReInitializing)
561
+ prefix += (ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.WEBCLIENT_REINITIALIZE_REQUEST);
562
+ let globalParams = ServerConfig.Instance.getGlobalParams();
563
+ if (globalParams !== null) {
564
+ globalParams = NString.Replace(globalParams, "+", "%2B");
565
+ prefix += ("&" + ConstInterface.MG_TAG_GLOBALPARAMS + "=" + globalParams);
566
+ }
567
+ }
568
+ if (hasContent) {
569
+ prefix += ("&" + ConstInterface.RC_TOKEN_SESSION_COUNT + this.GetSessionCounter() +
570
+ ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.RC_TOKEN_DATA);
571
+ }
572
+ return prefix;
573
+ }
574
+ async SendMonitorOnly() {
575
+ let flowMonitor = FlowMonitorQueue.Instance;
576
+ if (AccessHelper.mgDataTable == null || AccessHelper.mgDataTable.getMGData(0) == null || AccessHelper.mgDataTable.getMGData(0).IsAborting)
577
+ return;
578
+ if (!flowMonitor.isEmpty()) {
579
+ let buffer = this.BuildMonitorMessage();
580
+ let shouldAccumulateClientLog = false;
581
+ if (shouldAccumulateClientLog) {
582
+ }
583
+ else {
584
+ try {
585
+ let requestStatus = new RefParam(RequestStatus.Handled);
586
+ await this.DispatchRequest(this.ServerUrl, buffer.ToString(), CommandsProcessorBase_SessionStage.NORMAL, requestStatus);
587
+ }
588
+ catch (err) {
589
+ }
590
+ }
591
+ }
592
+ }
593
+ BuildMonitorMessage() {
594
+ let buffer = new StringBuilder(1000);
595
+ let flowMonitor = FlowMonitorQueue.Instance;
596
+ if (!RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages) {
597
+ buffer.Append(XMLConstants.MG_TAG_OPEN);
598
+ flowMonitor.buildXML(buffer);
599
+ }
600
+ else {
601
+ flowMonitor.buildXML(buffer);
602
+ let scrambledOut = Scrambler.Scramble(buffer.ToString());
603
+ buffer = new StringBuilder(1000);
604
+ buffer.Append(XMLConstants.MG_TAG_OPEN + scrambledOut);
605
+ }
606
+ buffer.Append("</" + XMLConstants.MG_TAG_XML + XMLConstants.TAG_CLOSE);
607
+ return buffer;
608
+ }
609
+ RegisterDelegates() {
610
+ HttpClientEvents.GetSessionCounter_Event = this.GetSessionCounter.bind(this);
611
+ HttpClientEvents.CheckAndSetSessionCounter_Event = this.CheckAndSetSessionCounter.bind(this);
612
+ HttpClientEvents.ComputeAndLogRequestInfo_Event = this.ComputeAndLogRequestInfo.bind(this);
613
+ AccessHelper.eventsManager.SpinnerStopped.subscribe(clientBusyTime => this.ClientActivated());
614
+ }
615
+ ComputeAndLogRequestInfo(contentLength, roundTrip, isLoggingResponse) {
616
+ if (!isNullOrUndefined(this._requestInfo.serverCallAt)) {
617
+ this._requestInfo.extraInfo.contentLength = contentLength;
618
+ this._requestInfo.extraInfo.timeStamp = new Date().toString();
619
+ let extraMessageStr = isLoggingResponse ? 'Response ⤵' : 'Request ⤵';
620
+ if (isLoggingResponse) {
621
+ this._requestInfo.roundtripTime = roundTrip;
622
+ }
623
+ Logger.Instance.WriteRequestInfoToLog(this._requestInfo, extraMessageStr);
624
+ if (isLoggingResponse)
625
+ this._requestInfo.clear();
626
+ }
627
+ }
628
+ static set ShouldScrambleAndUnscrambleMessages(value) {
629
+ RemoteCommandsProcessor._shouldScrambleAndUnscrambleMessages = value;
630
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("ShouldScrambleAndUnscrambleMessages.Set: {0}", this._shouldScrambleAndUnscrambleMessages));
631
+ }
632
+ static get ShouldScrambleAndUnscrambleMessages() {
633
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("ShouldScrambleAndUnscrambleMessages.Get: {0}", this._shouldScrambleAndUnscrambleMessages));
634
+ return RemoteCommandsProcessor._shouldScrambleAndUnscrambleMessages;
635
+ }
636
+ parseLogLevel(strLogLevel) {
637
+ let logLevel = Logger_LogLevels.None;
638
+ if (!NString.IsNullOrEmpty(strLogLevel)) {
639
+ if (strLogLevel.toUpperCase().startsWith("SERVER"))
640
+ logLevel = strLogLevel.endsWith("#") ? Logger_LogLevels.ServerMessages : Logger_LogLevels.Server;
641
+ else if (strLogLevel.toUpperCase().startsWith("S") || strLogLevel.toUpperCase().startsWith("Q"))
642
+ logLevel = Logger_LogLevels.Support;
643
+ else if (strLogLevel.toUpperCase().startsWith("G"))
644
+ logLevel = Logger_LogLevels.Gui;
645
+ else if (strLogLevel.toUpperCase().startsWith("D"))
646
+ logLevel = Logger_LogLevels.Development;
647
+ else if (strLogLevel.toUpperCase().startsWith("B"))
648
+ logLevel = Logger_LogLevels.Basic;
649
+ else if (strLogLevel.toUpperCase().startsWith("R"))
650
+ logLevel = Logger_LogLevels.RequestInfo;
651
+ }
652
+ return logLevel;
653
+ }
654
+ async PrepareRequest(serializeTasks) {
655
+ let xmlBuf = new StringBuilder();
656
+ xmlBuf.Append(XMLConstants.MG_TAG_OPEN);
657
+ if (AccessHelper.mgDataTable.getCurrMGData() !== null) {
658
+ let xmlUnscrambled = new StringBuilder();
659
+ await AccessHelper.mgDataTable.buildXML(xmlUnscrambled, serializeTasks);
660
+ if (RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages)
661
+ xmlBuf.Append(Scrambler.Scramble(xmlUnscrambled.ToString()));
662
+ else
663
+ xmlBuf.Append(xmlUnscrambled.ToString());
664
+ }
665
+ xmlBuf.Append("</" + XMLConstants.MG_TAG_XML + XMLConstants.TAG_CLOSE);
666
+ return xmlBuf.ToString();
667
+ }
668
+ async ProcessResponse(response, currMgdID, openingTaskDetails, res) {
669
+ Logger.Instance.WriteDevToLog("<-- ProcessResponse started -->");
670
+ if (openingTaskDetails === null)
671
+ openingTaskDetails = new OpeningTaskDetails();
672
+ let systemMilliseconds = Misc.getSystemMilliseconds();
673
+ if (response === null || response.trim().length === 0)
674
+ return;
675
+ AccessHelper.mgDataTable.currMgdID = currMgdID;
676
+ RuntimeContextBase.Instance.Parser.push();
677
+ RuntimeContextBase.Instance.Parser.setXMLdata(response);
678
+ RuntimeContextBase.Instance.Parser.setCurrIndex(0);
679
+ let currMGData = AccessHelper.mgDataTable.getCurrMGData();
680
+ await currMGData.fillData(openingTaskDetails, RuntimeContextBase.Instance.Parser);
681
+ RuntimeContextBase.Instance.Parser.setXMLdata(null);
682
+ RuntimeContextBase.Instance.Parser.pop();
683
+ Logger.Instance.WriteDevToLog("<-- ProcessResponse finished --> (" + (Misc.getSystemMilliseconds() - systemMilliseconds) + ")");
684
+ await currMGData.CmdsToClient.Execute(res);
685
+ await this.ProcessRecovery();
686
+ }
687
+ async ProcessRecovery() {
688
+ AccessHelper.eventsManager.pushNewExecStacks();
689
+ await AccessHelper.mgDataTable.processRecovery();
690
+ AccessHelper.eventsManager.popNewExecStacks();
691
+ }
692
+ }
693
+ RemoteCommandsProcessor.RC_NO_CONTEXT_ID = '-1';
694
+ RemoteCommandsProcessor._instance = null;
695
+ RemoteCommandsProcessor.IsSessionReInitializing = false;
696
+ RemoteCommandsProcessor.lastExceptionMessage = null;
697
+ RemoteCommandsProcessor.InitialUrl = null;
698
+ RemoteCommandsProcessor.WEB_COMMUNICATION_PROTOCOL_VERSION = "14002";
699
+ RemoteCommandsProcessor._shouldScrambleAndUnscrambleMessages = false;
700
+ class HandshakeResponse {
701
+ get ScrambleMessages() {
702
+ return this._scrambleMessages;
703
+ }
704
+ get ContextId() {
705
+ return this._contextId;
706
+ }
707
+ get GetSessionId() {
708
+ return this._privateSessionId;
709
+ }
710
+ get InputPassword() {
711
+ return this._inputPassword;
712
+ }
713
+ get HttpTimeout() {
714
+ return this._httpTimeout;
715
+ }
716
+ get SystemLogin() {
717
+ return this._systemLogin;
718
+ }
719
+ get MaxInternalLogLevel() {
720
+ return this._maxInternalLogLevel;
721
+ }
722
+ constructor(responseXML) {
723
+ this._scrambleMessages = true;
724
+ this._contextId = null;
725
+ this._privateSessionId = null;
726
+ this._inputPassword = false;
727
+ this._httpTimeout = 0;
728
+ this._systemLogin = null;
729
+ this._maxInternalLogLevel = null;
730
+ try {
731
+ JSON_Utils.JSONFromXML(responseXML, this.FillFromJSON.bind(this));
732
+ }
733
+ catch (ex) {
734
+ Logger.Instance.WriteExceptionToLog(ex, responseXML);
735
+ }
736
+ }
737
+ FillFromJSON(error, result) {
738
+ if (error != null) {
739
+ throw error;
740
+ }
741
+ let response = result['Richclientresponse'];
742
+ for (let elementName in response) {
743
+ if (response.hasOwnProperty(elementName)) {
744
+ switch (elementName) {
745
+ case "ContextID":
746
+ this._contextId = response[elementName][0];
747
+ break;
748
+ case "SessionID":
749
+ this._privateSessionId = response[elementName][0];
750
+ break;
751
+ case "Environment":
752
+ let envAttributes = response["Environment"][0]['$'];
753
+ if (!isNullOrUndefined(envAttributes["ScrambleMessages"])) {
754
+ Debug.Assert(envAttributes["ScrambleMessages"] === "N");
755
+ this._scrambleMessages = false;
756
+ }
757
+ if (!isNullOrUndefined(envAttributes["MaxInternalLogLevel"]))
758
+ this._maxInternalLogLevel = envAttributes["MaxInternalLogLevel"];
759
+ if (!isNullOrUndefined(envAttributes["InputPassword"]) && envAttributes["InputPassword"].toLocaleLowerCase() === "y")
760
+ this._inputPassword = true;
761
+ if (!isNullOrUndefined(envAttributes["SystemLogin"]))
762
+ this._systemLogin = envAttributes["SystemLogin"];
763
+ if (!isNullOrUndefined(envAttributes[ConstInterface.MG_TAG_HTTP_COMMUNICATION_TIMEOUT]))
764
+ this._httpTimeout = +envAttributes[ConstInterface.MG_TAG_HTTP_COMMUNICATION_TIMEOUT];
765
+ if (!isNullOrUndefined(envAttributes["ForwardSlash"]))
766
+ AccessHelper.environment.ForwardSlashUsage = envAttributes["ForwardSlash"];
767
+ break;
768
+ }
769
+ }
770
+ }
771
+ }
772
+ }
773
+ HandshakeResponse.SYSTEM_LOGIN_AD = 'D';
774
+ class ErrorMessageXml {
775
+ constructor(xmlContent, lastRequestTime, contextInactivityTimeout) {
776
+ this._lastRequestTime = 0;
777
+ this._errorMessage = null;
778
+ this._errorCode = 0;
779
+ this._middlewareAddress = null;
780
+ this._parsingFailed = false;
781
+ this._lastRequestTime = lastRequestTime;
782
+ this.contextInactivityTimeout = contextInactivityTimeout;
783
+ try {
784
+ JSON_Utils.JSONFromXML(xmlContent, this.FillFromJSON.bind(this));
785
+ }
786
+ catch (ex) {
787
+ Logger.Instance.WriteExceptionToLog(ex);
788
+ Misc.WriteStackTrace(ex);
789
+ this._parsingFailed = true;
790
+ }
791
+ }
792
+ FillFromJSON(error, result) {
793
+ if (error != null) {
794
+ throw error;
795
+ }
796
+ let xmlerr = result['xmlerr'];
797
+ for (let elementName in xmlerr) {
798
+ if (xmlerr.hasOwnProperty(elementName)) {
799
+ switch (elementName) {
800
+ case "errmsg":
801
+ this._errorMessage = xmlerr[elementName][0];
802
+ break;
803
+ case "errcode":
804
+ this._errorCode = +(xmlerr[elementName]);
805
+ break;
806
+ case "server":
807
+ this._middlewareAddress = xmlerr[elementName][0];
808
+ break;
809
+ case "appname":
810
+ case "prgname":
811
+ case "arguments":
812
+ case "username":
813
+ case "xmlerr":
814
+ break;
815
+ default:
816
+ Logger.Instance.WriteExceptionToLogWithMsg(NString.Format("Unknown element: '{0}'", elementName));
817
+ break;
818
+ }
819
+ }
820
+ }
821
+ }
822
+ GetCode() {
823
+ return this._errorCode;
824
+ }
825
+ GetMessage() {
826
+ let sb = new StringBuilder();
827
+ if (this._parsingFailed) {
828
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.RC_STR_F7_UNEXPECTED_ERR));
829
+ }
830
+ else {
831
+ switch (this._errorCode) {
832
+ case ServerError.ERR_CTX_NOT_FOUND:
833
+ if (this.InactivityTimeoutExpired())
834
+ sb.Append(NString.Format("{0} ({1} {2})", AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_SESSION_CLOSED_INACTIVITY), Math.floor(this.contextInactivityTimeout / 600), AccessHelper.languageData.getConstMessage(MsgInterface.STR_MINUTES)));
835
+ else
836
+ sb.Append(NString.Format("{0} ({1}).", AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_SESSION_CLOSED), this._errorCode));
837
+ break;
838
+ case ServerError.ERR_WEBCLIENT_PROGRAM_RELOADED:
839
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_WEBCLIENT_PROGRAM_RELOADED));
840
+ break;
841
+ case ServerError.ERR_EXECUTED_PROGRAM_CHANGED:
842
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_EXECUTED_PROGRAM_CHANGED));
843
+ break;
844
+ case ServerError.ERR_AUTHENTICATION:
845
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.USRINP_STR_BADPASSW));
846
+ break;
847
+ case ServerError.ERR_ACCESS_DENIED:
848
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_AUTHORIZATION_FAILURE));
849
+ break;
850
+ default:
851
+ sb.Append(this._errorMessage);
852
+ break;
853
+ }
854
+ sb.Append(OSEnvironment.EolSeq + OSEnvironment.EolSeq);
855
+ if (!ServerConfig.Instance.ShouldDisplayGenericError()) {
856
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.BROWSER_OPT_INFO_SERVER_STR) + ": ");
857
+ sb.Append(ServerConfig.Instance.getServer());
858
+ if (!NString.IsNullOrEmpty(this._middlewareAddress)) {
859
+ sb.Append(" --> ");
860
+ sb.Append(this._middlewareAddress);
861
+ }
862
+ sb.Append(OSEnvironment.EolSeq);
863
+ }
864
+ sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.TASKRULE_STR_APPLICATION) + ": \"");
865
+ sb.Append(ServerConfig.Instance.getAppName());
866
+ sb.Append("\" (\"");
867
+ sb.Append("\")");
868
+ }
869
+ return sb.ToString();
870
+ }
871
+ InactivityTimeoutExpired() {
872
+ let expired = false;
873
+ if (this.contextInactivityTimeout > 0) {
874
+ let currTimeMilli = Misc.getSystemMilliseconds();
875
+ expired = ((currTimeMilli - this._lastRequestTime) > (this.contextInactivityTimeout * 100));
876
+ }
877
+ return expired;
878
+ }
879
+ }
880
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RemoteCommandsProcessor.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/remote/RemoteCommandsProcessor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Base64,\r\n  JSON_Utils,\r\n  Logger,\r\n  Logger_LogLevels,\r\n  Misc,\r\n  MsgInterface,\r\n  OSEnvironment,\r\n  RequestInfo,\r\n  StrUtil,\r\n  XMLConstants\r\n} from \"@magic-xpa/utils\";\r\nimport {\r\n  Debug,\r\n  Encoding,\r\n  Exception,\r\n  List,\r\n  NString,\r\n  RefParam,\r\n  StringBuilder,\r\n  isNullOrUndefined,\r\n  isUndefined\r\n} from \"@magic-xpa/mscorelib\";\r\nimport {\r\n  Commands,\r\n  RuntimeContextBase,\r\n  Styles,\r\n  UsernamePasswordCredentials\r\n} from \"@magic-xpa/gui\";\r\nimport { ExecOperCommand } from '../commands/ClientToServer/ExecOperCommand';\r\nimport { Task } from '../tasks/Task';\r\nimport {\r\n  CommandsProcessorBase,\r\n  CommandsProcessorBase_SendingInstruction,\r\n  CommandsProcessorBase_SessionStage\r\n} from \"../CommandsProcessorBase\";\r\nimport { HttpManager } from \"../http/HttpManager\";\r\nimport { ConstInterface } from \"../ConstInterface\";\r\nimport { Scrambler } from \"../util/Scrambler\";\r\nimport { ServerError } from \"./ServerError\";\r\nimport { IResultValue } from \"../rt/IResultValue\";\r\nimport { FlowMonitorQueue } from \"../util/FlowMonitorQueue\";\r\nimport { OpeningTaskDetails, TaskBase } from \"../tasks/TaskBase\";\r\nimport { HttpUtility } from \"../http/client/HttpUtility\";\r\nimport { HttpClientEvents } from \"../http/client/HttpClientEvents\";\r\nimport { ServerConfig } from \"../ServerConfig\";\r\nimport { MGData } from \"../tasks/MGData\";\r\nimport { CommandsTable } from \"../CommandsTable\";\r\nimport { AccessHelper } from \"../AccessHelper\";\r\nimport { Environment, Event, EventCommand, EventsManager, GUIManager, IClientCommand, RunTimeEvent } from \"../../\";\r\nimport { IClientToServerCommandInfo } from \"../commands/IClientToServerCommandInfo\";\r\nimport { MGDataCollection } from \"../tasks/MGDataCollection\";\r\nimport { Subscription, timer } from \"rxjs\";\r\n\r\n/// <summary> Represents the status of a request </summary>\r\nenum RequestStatus {\r\n  Handled, //the request was successfully handled.\r\n  Retry,   //the request should be re-sent.\r\n  Abort   //the request could not be handled and should be aborted.\r\n}\r\n\r\n// @dynamic\r\nexport class RemoteCommandsProcessor extends CommandsProcessorBase {\r\n  static readonly RC_NO_CONTEXT_ID: string = '-1';\r\n  private static _instance: RemoteCommandsProcessor = null;\r\n  public static IsSessionReInitializing = false;\r\n  private static lastExceptionMessage = null;\r\n  private static InitialUrl: string = null;\r\n\r\n\r\n  // *****************************************************************************************************\r\n  // *****************************************************************************************************\r\n  // ******** When changing WEB_COMMUNICATION_PROTOCOL_VERSION, please change on mobile platforms as well:\r\n  // ******** W10M: RemoteCommandsProcessor.cs\r\n  private static readonly WEB_COMMUNICATION_PROTOCOL_VERSION: string = \"14002\";\r\n  // *****************************************************************************************************\r\n  // *****************************************************************************************************\r\n\r\n  // TODO: Check if we need _logAccumulator.\r\n  // private _logAccumulator: ClientLogAccumulator = null;\r\n\r\n  private _lastRequestTime: number = 0; // the time of the last request to the server\r\n\r\n  ServerUrl: string = null;\r\n  private static _shouldScrambleAndUnscrambleMessages: boolean = false; // static because it is initialized before the execution props are available\r\n\r\n  public SessionId: string;\r\n\r\n  public DelayCommandExecution: boolean = false;\r\n  private _requestInfo = new RequestInfo();\r\n\r\n  static GetInstance(): RemoteCommandsProcessor {\r\n    if (RemoteCommandsProcessor._instance === null) {\r\n      RemoteCommandsProcessor._instance = new RemoteCommandsProcessor();\r\n    }\r\n\r\n    return RemoteCommandsProcessor._instance;\r\n  }\r\n\r\n  private constructor() {\r\n    super();\r\n    this.ServerUrl = ServerConfig.Instance.getServerURL();\r\n\r\n    HttpManager.GetInstance();\r\n\r\n    this.RegisterDelegates();\r\n  }\r\n\r\n  /// <summary>\r\n  /// Checks that session counter is consecutive during the session and sets new value.\r\n  /// The only exception is in case the client sent to the server ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION,\r\n  ///    the server is expected to return ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION in response (RequestsServerBase::ProcessRequest), to acknowledge the request to close the context.\r\n  /// </summary>\r\n  /// <param name=\"newSessionCounter\">!!.</param>\r\n  CheckAndSetSessionCounter(newSessionCounter: number): void {\r\n    if (newSessionCounter === ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION) {\r\n      Debug.Assert(this.GetSessionCounter() === ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION);\r\n    } else {\r\n      Debug.Assert(newSessionCounter === this.GetSessionCounter() + 1);\r\n      this.SetSessionCounter(newSessionCounter);\r\n      Logger.Instance.WriteServerToLog(NString.Format(\"Session Counter --> {0}\", this._sessionCounter));\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// Zero session counter when reinitializing server communication details\r\n  /// </summary>\r\n  /// <returns></returns>\r\n  ClearSessionCounter(): void {\r\n    this._sessionCounter = 0;\r\n    Logger.Instance.WriteServerToLog(NString.Format(\"Session Counter --> {0}\", this._sessionCounter));\r\n  }\r\n\r\n  /// <summary>\r\n  /// </summary>\r\n  /// <param name=\"newSessionCounter\"></param>\r\n  private SetSessionCounter(newSessionCounter: number): void {\r\n    this._sessionCounter = newSessionCounter;\r\n  }\r\n\r\n  public get GetLastRequestTime() {\r\n    return this._lastRequestTime;\r\n  }\r\n\r\n  /// <summary>\r\n  /// ReStartSession\r\n  /// </summary>\r\n  async ReStartSession(): Promise<void> {\r\n\r\n    RemoteCommandsProcessor.IsSessionReInitializing = true;\r\n\r\n    await this.StoreSessionReInitializingDataOnLocalStorage();\r\n    let navigateRootRoute = false;\r\n    if (!RuntimeContextBase.Instance.RemovedContextFromServer)\r\n      navigateRootRoute = Environment.Instance.getSpecialRouteToRootProgOnContextRecreation() ? true : false;\r\n    Commands.addRefreshPage(navigateRootRoute, RemoteCommandsProcessor.InitialUrl);\r\n    //stop the execution by throwing exception.\r\n    throw new Exception('');\r\n\r\n  }\r\n\r\n  /// <summary>\r\n  /// StoreSessionReInitializingDataOnLocalStorage\r\n  /// </summary>\r\n  async StoreSessionReInitializingDataOnLocalStorage(): Promise<void> {\r\n\r\n    let mainPrgViewStringForServer = await this.BuildXMLForMainProgramDataView();\r\n    let globalParamsString = AccessHelper.globalParams.mirrorAllToXML();\r\n    let changedEnvVarList = AccessHelper.envParamsTable.mirrorAllToXML();\r\n    // store mainPrgViewStringForServer, IsSessionReInitializing and globalParamsString on local\r\n    // storage in order to use it for next session.\r\n    let dataStorage = window.localStorage;\r\n    dataStorage.setItem(ConstInterface.IS_SESSION_REINITIALIZING, \"true\");\r\n    dataStorage.setItem(ConstInterface.MAIN_PROG_VIEW, mainPrgViewStringForServer.toString());\r\n    dataStorage.setItem(ConstInterface.GLOBAL_PARAM_LIST, globalParamsString);\r\n    dataStorage.setItem(ConstInterface.ENV_VAR_LIST, changedEnvVarList);\r\n    dataStorage.setItem(ConstInterface.LAST_EXCEPTION, RemoteCommandsProcessor.lastExceptionMessage);\r\n    if (RuntimeContextBase.Instance.RemovedContextFromServer)\r\n      dataStorage.setItem(ConstInterface.CTX_REMOVED_FROM_SRVR, \"1\");\r\n    EventsManager.Instance.storeLastSavedRouteEventOnLocalStorage();\r\n  }\r\n\r\n  /// <summary>\r\n  /// RestoreSessionReInitializingDataFromLocalStorage\r\n  /// </summary>\r\n  RestoreSessionReInitializingDataFromLocalStorage(key: string): string {\r\n\r\n    let dataStorage = window.localStorage;\r\n    let val = dataStorage.getItem(key);\r\n    return val;\r\n  }\r\n\r\n  /// <summary>Prepare and execute the 1st & 2nd handshake requests:\r\n  /// 1st request:  UTF8TRANS=..&appname=..&prgname=..&arguments=-A<Richclient><RequestingVersionDetails=\"..\"/></Richclient>\r\n  ///     response: instructions to the client - whether to display authentication dialog, the server's version, and more ..\r\n  ///               e.g. <Richclientresponse><ContextID>120308789726371200</ContextID><Environment InputPassword=\"N\" SystemLogin=\"N\" ScrambleMessages=\"N\" MaxInternalLogLevel=\"Server#\" HttpTimeout=\"10\" ClientNetworkRecoveryInterval=\"0\" ForwardSlash=\"web\"/></Richclientresponse>\r\n  /// 2nd request: authentication (optional, depending on the 1st request).\r\n  /// </summary>\r\n  /// <returns>true only if the client should continue to start the actual program (i.e. after handshake).</returns>\r\n  async StartSession(): Promise<boolean> {\r\n    let authenticationCancelled: boolean = false;\r\n    let handshakeResponse: HandshakeResponse = null;\r\n\r\n    try {\r\n      let lastTypedUserId: string = null;\r\n\r\n      // ----------------------------------------------------------------------\r\n      // 1st handshake request: prepare 1st handshake request and scramble it\r\n      // ----------------------------------------------------------------------\r\n      let handshakeInitialTokens: StringBuilder = new StringBuilder();\r\n      handshakeInitialTokens.Append(ConstInterface.UTF8TRANS +\r\n        ConstInterface.REQ_APP_NAME + \"=\" +\r\n        HttpUtility.UrlEncode(ServerConfig.Instance.getAppName(), Encoding.UTF8));\r\n\r\n      handshakeInitialTokens.Append(\"&\" + ConstInterface.REQ_ARGS + \"=\" + ConstInterface.REQ_ARG_ALPHA +\r\n        \"<Richclient><Requires EncryptionKey=\\\"False\\\"/><RIAProtocolVersion=\\\"\" + RemoteCommandsProcessor.WEB_COMMUNICATION_PROTOCOL_VERSION + \"\\\"/></Richclient>\");\r\n\r\n      Logger.Instance.WriteDevToLog(NString.Format(\"Handshake request #1 (not scrambled) : {0}\",\r\n        this.ServerUrl + ConstInterface.REQ_ARG_START +\r\n        ConstInterface.RC_INDICATION_INITIAL + handshakeInitialTokens));\r\n\r\n      let handshakeInitialUrl: string = this.ServerUrl + ConstInterface.REQ_ARG_START +\r\n        ConstInterface.RC_INDICATION_INITIAL +\r\n        ConstInterface.RC_TOKEN_DATA +\r\n        HttpUtility.UrlEncode(Scrambler.Scramble(handshakeInitialTokens.ToString()), Encoding.UTF8);\r\n\r\n      Logger.Instance.WriteServerMessagesToLog(\"\");\r\n      Logger.Instance.WriteServerMessagesToLog(NString.Format(\"Handshake request #1: {0}\", handshakeInitialUrl));\r\n\r\n      // Initialize temp ctxGroup with CtxGroup from execution.properties\r\n      let ctxGroup: string = ServerConfig.Instance.getCtxGroup();\r\n\r\n      while (!authenticationCancelled) {\r\n        let requestStatus: RefParam<RequestStatus> = new RefParam(RequestStatus.Handled);\r\n        // execute the 1st request\r\n        let responseStr: string = await this.DispatchRequest(handshakeInitialUrl, null, CommandsProcessorBase_SessionStage.HANDSHAKE, requestStatus);\r\n\r\n        // process the 1st response - check if the response is error, unscramble and parse it\r\n        if (NString.IsNullOrEmpty(responseStr)) {\r\n          throw new ServerError(\"Client failed to initialize a session.\" + OSEnvironment.EolSeq +\r\n            \"Empty response was received from the web server.\" + OSEnvironment.EolSeq + OSEnvironment.EolSeq + this.ServerUrl);\r\n        }\r\n\r\n        Logger.Instance.WriteServerMessagesToLog(NString.Format(\"Handshake response #1: {0}\", responseStr));\r\n        Logger.Instance.WriteServerMessagesToLog(\"\");\r\n\r\n        handshakeResponse = new HandshakeResponse(responseStr);\r\n\r\n        RuntimeContextBase.Instance.ContextID = handshakeResponse.ContextId;\r\n\r\n        // save session id on client which is received in 1st response.\r\n        this.SessionId = handshakeResponse.GetSessionId;\r\n\r\n        HttpManager.GetInstance().HttpCommunicationTimeoutMS = handshakeResponse.HttpTimeout * 1000;\r\n\r\n        // During authentication, if authentication failed then server unloads ctx and creates new ctx for next authentication request.\r\n        // So every time after authentication fails we receive new ctxid for next authentication request.\r\n        // Hence take ctxgroup in local variable and update ClientManager only after authentication is done.\r\n        if (NString.IsNullOrEmpty(ServerConfig.Instance.getCtxGroup())) {\r\n          ctxGroup = handshakeResponse.ContextId;\r\n        }\r\n\r\n        // -----------------------\r\n        // 2nd handshake request\r\n        // -----------------------\r\n        let credentials: UsernamePasswordCredentials = null;\r\n        if (ServerConfig.Instance.getSkipAuthenticationDialog()) {\r\n          // skip authentication (to the runtime-engine) dialog\r\n          if (ServerConfig.Instance.getUsername() !== null) {\r\n            // user the userId & password that were passed, and reset them (they'll be set below, if authenticated by the runtime-engine)\r\n            credentials = new UsernamePasswordCredentials(ServerConfig.Instance.getUsername(), ServerConfig.Instance.getPassword());\r\n            ServerConfig.Instance.setUsername(\"\");\r\n            ServerConfig.Instance.setPassword(\"\");\r\n          }\r\n        } else if (handshakeResponse.InputPassword && handshakeResponse.SystemLogin !== HandshakeResponse.SYSTEM_LOGIN_AD) {\r\n          // authentication (to the runtime-engine) dialog\r\n          if (lastTypedUserId !== null) {\r\n            let title: string = AccessHelper.languageData.getConstMessage(MsgInterface.BRKTAB_STR_ERROR);\r\n            let error: string = AccessHelper.languageData.getConstMessage(MsgInterface.USRINP_STR_BADPASSW);\r\n            await GUIManager.Instance.MessageBox(title, error, Styles.MSGBOX_ICON_ERROR | Styles.MSGBOX_BUTTON_OK);\r\n          }\r\n\r\n          // TODO: implement authentication dialog\r\n          // let userId: string = lastTypedUserId;\r\n          //\r\n          // if (dialog === null) {\r\n          //   dialog = new AuthenticationDialogHandler(userId, GetLogonDialogExecProps());\r\n          // }\r\n          // dialog.openDialog();\r\n\r\n          // credentials = dialog.getCredentials();\r\n          // if (credentials !== null)\r\n          //   lastTypedUserId = credentials.Username;\r\n          // else\r\n          //   authenticationCancelled = true;\r\n        }\r\n\r\n        // ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION instructs the server to close the context.\r\n        // (note: unloading a context post handshake should be done using Command.createUnloadCommand).\r\n        if (authenticationCancelled) {\r\n          this.SetSessionCounter(ConstInterface.SESSION_COUNTER_CLOSE_CTX_INDICATION);\r\n        }\r\n\r\n        let handshakeAuthUrl: string = this.PrepareAuthenticationUrl(handshakeResponse.ContextId, ctxGroup, this.GetSessionCounter());\r\n\r\n        try {\r\n          if (credentials !== null) {\r\n            let credentialsStr: string = credentials.Username + \":\";\r\n            if (!NString.IsNullOrEmpty(credentials.Password)) {\r\n              credentialsStr = credentialsStr + credentials.Password + \":\";\r\n            }\r\n            credentialsStr += handshakeResponse.ContextId;\r\n            credentialsStr = Scrambler.Scramble(credentialsStr);\r\n            credentialsStr = Base64.encode(credentialsStr, true, Encoding.UTF8);\r\n            handshakeAuthUrl += (\"&USERNAME=\" + HttpUtility.UrlEncode(credentialsStr, Encoding.UTF8));\r\n\r\n            // send 2nd handshake request - with authentication\r\n            Logger.Instance.WriteServerMessagesToLog(NString.Format(\"Handshake request #2: {0}\", handshakeAuthUrl));\r\n            let statusRequest: RefParam<RequestStatus> = new RefParam(RequestStatus.Handled);\r\n            responseStr = await this.DispatchRequest(handshakeAuthUrl, null, CommandsProcessorBase_SessionStage.HANDSHAKE, statusRequest);\r\n\r\n            // verify that the response wasn't replayed\r\n            if (responseStr.indexOf(handshakeResponse.ContextId) === -1) {\r\n              throw new ServerError(AccessHelper.languageData.getConstMessage(MsgInterface.USRINP_STR_BADPASSW));\r\n            }\r\n\r\n            ServerConfig.Instance.setUsername(credentials.Username);\r\n            ServerConfig.Instance.setPassword(credentials.Password);\r\n          } else {\r\n            let requestStatus: RefParam<RequestStatus> = new RefParam(RequestStatus.Handled);\r\n            // send 2nd handshake request - without authentication\r\n            Logger.Instance.WriteServerMessagesToLog(NString.Format(\"Handshake request #2: {0}\", handshakeAuthUrl));\r\n            responseStr = await this.DispatchRequest(handshakeAuthUrl, null, CommandsProcessorBase_SessionStage.HANDSHAKE, requestStatus);\r\n          }\r\n          Logger.Instance.WriteServerMessagesToLog(NString.Format(\"Handshake response #2: {0}\", responseStr));\r\n          Logger.Instance.WriteServerMessagesToLog(\"\");\r\n          break;\r\n        } catch (ex) {\r\n          if (ex instanceof ServerError) {\r\n            let serverError: ServerError = <ServerError>ex;\r\n            if (ServerConfig.Instance.getSkipAuthenticationDialog()) {\r\n              switch (serverError.GetCode()) {\r\n                case ServerError.ERR_ACCESS_DENIED:\r\n                // External Authenticator authenticated the user, access to the application wasn't authorized.\r\n                case ServerError.ERR_AUTHENTICATION:\r\n                  // External Authenticator authenticated the user but application authentication failed\r\n                  ServerConfig.Instance.setSkipAuthenticationDialog(false);\r\n                  throw serverError;\r\n              }\r\n            }\r\n\r\n            // the session will never provide a way to change the credentials, therefore abort\r\n            if (!handshakeResponse.InputPassword)\r\n              throw serverError;\r\n\r\n            // Error.INF_NO_RESULT:\r\n            //    if authentication dialog was canceled, the request was sent only to close the context,\r\n            //    and the server isn't expected to return a response\r\n            if (serverError.GetCode() !== ServerError.ERR_AUTHENTICATION &&\r\n              (!authenticationCancelled || serverError.GetCode() !== ServerError.INF_NO_RESULT)) {\r\n              throw serverError;\r\n            }\r\n          } else\r\n            throw ex;\r\n        }\r\n      }\r\n\r\n      // store an indication to skip future authentication (session restart, parallel program)\r\n      ServerConfig.Instance.setSkipAuthenticationDialog(true);\r\n\r\n      // save context group\r\n      ServerConfig.Instance.setCtxGroup(ctxGroup);\r\n\r\n      // ------------------------\r\n      // set session properties\r\n      // ------------------------\r\n      RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages = handshakeResponse.ScrambleMessages;\r\n      if (Logger.Instance.LogLevel !== Logger_LogLevels.Basic) {\r\n        // maximal value of the InternalLogLevel that can be set by the client.\r\n        // if set, it controls the maximal value; otherwise, any log level is allowed.\r\n        let maxInternalLogLevel: string = handshakeResponse.MaxInternalLogLevel;\r\n        if (maxInternalLogLevel !== null) {\r\n          let maxLogLevel: Logger_LogLevels = this.parseLogLevel(maxInternalLogLevel);\r\n          if (maxLogLevel < Logger.Instance.LogLevel) {\r\n            // textual value (as loaded from the execution properties)\r\n            ServerConfig.Instance.setInternalLogLevel(maxInternalLogLevel);\r\n\r\n            // set the actual log level to the level allowed by the server\r\n            Logger.Instance.WriteToLog(NString.Format(\"Internal log level was restricted to '{0}' by the Magic xpa server.\", maxInternalLogLevel), false);\r\n            Logger.Instance.LogLevel = maxLogLevel;\r\n          }\r\n        }\r\n      }\r\n\r\n      // ----------------------------------------------------------------------\r\n      // 3rd request: Executes the initial program in the server.\r\n      // ----------------------------------------------------------------------\r\n      if (!authenticationCancelled) {\r\n        await this.ExecuteInitialRequest();\r\n      }\r\n    } catch (ex) {\r\n      if (ex instanceof ServerError)\r\n        throw ex;\r\n\r\n      if (isNullOrUndefined(ex.InnerException))\r\n        throw  new ServerError(ex.message, new Exception(ex));\r\n      else\r\n        throw new ServerError(ex.message, ex.InnerException);\r\n    }\r\n\r\n    return !authenticationCancelled;\r\n  }\r\n\r\n  /// <summary>\r\n  /// prepares handshake request url for authentication\r\n  /// </summary>\r\n  /// <param name=\"contextId\"></param>\r\n  /// <param name=\"ctxGroup\"></param>\r\n  /// <param name=\"sessionCount\"></param>\r\n  /// <returns></returns>\r\n  private PrepareAuthenticationUrl(contextId: string, ctxGroup: string, sessionCount: number): string {\r\n    let handshakeAuthUrl: string = this.ServerUrl + ConstInterface.REQ_ARG_START +\r\n      ConstInterface.RC_INDICATION + ConstInterface.UTF8TRANS +\r\n      ConstInterface.RC_TOKEN_CTX_ID + contextId;\r\n\r\n    if (!isNullOrUndefined(this.SessionId))\r\n      handshakeAuthUrl += (ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.RC_TOKEN_SESSION_ID + this.SessionId);\r\n\r\n    handshakeAuthUrl += (ConstInterface.REQ_ARG_SEPARATOR +\r\n      ConstInterface.RC_TOKEN_SESSION_COUNT + sessionCount +\r\n      ConstInterface.REQ_ARG_SEPARATOR +\r\n      ConstInterface.RC_TOKEN_CTX_GROUP + ctxGroup +\r\n      ConstInterface.REQ_ARG_SEPARATOR +\r\n      ConstInterface.RC_AUTHENTICATION_REQUEST);\r\n\r\n    return handshakeAuthUrl;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Executes the initial program in the server:\r\n  /// </summary>\r\n  private async ExecuteInitialRequest(): Promise<void> {\r\n    // send the INITIAL request to the server.\r\n    await this.Execute_1(CommandsProcessorBase_SendingInstruction.TASKS_AND_COMMANDS, CommandsProcessorBase_SessionStage.INITIAL, null);\r\n  }\r\n\r\n  // private static GetLogonDialogExecProps(): Dictionary<string, string> {\r\n  //   let dictionary: Dictionary<string, string> = new Dictionary<string, string>();\r\n  //   let value: string = ClientManager.Instance.getLogonWindowTitle();\r\n  //   let flag: boolean = NString.IsNullOrEmpty(value);\r\n  //   if (flag) {\r\n  //     value = \"Logon - \" + ClientManager.Instance.getAppName();\r\n  //   }\r\n  //   dictionary.Add(\"LogonWindowTitle\", value);\r\n  //   let text: string = ClientManager.Instance.getLogonGroupTitle();\r\n  //   let flag2: boolean = !NString.IsNullOrEmpty(text);\r\n  //   if (flag2) {\r\n  //     text = ((text.length > 62) ? NString.Substring(text, 0, 62) : text);\r\n  //   }\r\n  //   else {\r\n  //     text = \"Logon Parameters\";\r\n  //   }\r\n  //   dictionary.Add(\"LogonGroupTitle\", text);\r\n  //   let text2: string = ClientManager.Instance.getLogonMsgCaption();\r\n  //   let flag3: boolean = !NString.IsNullOrEmpty(text2);\r\n  //   if (flag3) {\r\n  //     text2 = ((text2.length > 56) ? NString.Substring(text2, 0, 56) : text2);\r\n  //     dictionary.Add(\"LogonMessageCaption\", text2);\r\n  //   }\r\n  //   let logonWindowIconURL: Uri = ClientManager.Instance.getLogonWindowIconURL();\r\n  //   let flag4: boolean = Uri.op_Inequality(logonWindowIconURL, null) && !NString.IsNullOrEmpty(logonWindowIconURL.ToString());\r\n  //   if (flag4) {\r\n  //     dictionary.Add(\"LogonWindowIconURL\", logonWindowIconURL.ToString());\r\n  //   }\r\n  //   let logonWindowImageURL: Uri = ClientManager.Instance.getLogonWindowImageURL();\r\n  //   let flag5: boolean = Uri.op_Inequality(logonWindowImageURL, null) && !NString.IsNullOrEmpty(logonWindowImageURL.ToString());\r\n  //   if (flag5) {\r\n  //     dictionary.Add(\"LogonImageURL\", logonWindowImageURL.ToString());\r\n  //   }\r\n  //   let text3: string = ClientManager.Instance.getLogonUserIdCaption();\r\n  //   let flag6: boolean = !NString.IsNullOrEmpty(text3);\r\n  //   if (flag6) {\r\n  //     text3 = ((text3.length > 9) ? NString.Substring(text3, 0, 9) : text3);\r\n  //     dictionary.Add(\"LogonUserIDCaption\", text3);\r\n  //   }\r\n  //   let text4: string = ClientManager.Instance.getLogonPasswordCaption();\r\n  //   let flag7: boolean = !NString.IsNullOrEmpty(text4);\r\n  //   if (flag7) {\r\n  //     text4 = ((text4.length > 9) ? NString.Substring(text4, 0, 9) : text4);\r\n  //     dictionary.Add(\"LogonPasswordCaption\", text4);\r\n  //   }\r\n  //   let logonOKCaption: string = ClientManager.Instance.getLogonOKCaption();\r\n  //   let flag8: boolean = !NString.IsNullOrEmpty(logonOKCaption);\r\n  //   if (flag8) {\r\n  //     dictionary.Add(\"LogonOKCaption\", logonOKCaption);\r\n  //   }\r\n  //   let logonCancelCaption: string = ClientManager.Instance.getLogonCancelCaption();\r\n  //   let flag9: boolean = !NString.IsNullOrEmpty(logonCancelCaption);\r\n  //   if (flag9) {\r\n  //     dictionary.Add(\"LogonCancelCaption\", logonCancelCaption);\r\n  //   }\r\n  //   return dictionary;\r\n  // }\r\n\r\n\r\n  /// <summary>\r\n  /// Return the string representation of runtime task tree structure by going up from the current task\r\n  /// </summary>\r\n  private GetTaskTree(task: Task): List<string> {\r\n    let taskTree: List<string> = new List<string>();\r\n\r\n    while (!isNullOrUndefined(task)) {\r\n      taskTree.push(task.getTaskInfo());\r\n      task = <Task>task.getParent();\r\n    }\r\n\r\n    return taskTree;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Update the request info object using information obtained from current operation being executed.\r\n  /// </summary>\r\n  private async UpdateRequestInfo(): Promise<void> {\r\n    let currMGData: MGData = AccessHelper.mgDataTable.getCurrMGData();\r\n    let eventsManager: EventsManager = <EventsManager>AccessHelper.eventsManager;\r\n    let operExecution: boolean = false;\r\n    let cmdsToServer: CommandsTable = <CommandsTable>currMGData.CmdsToServer;\r\n\r\n    for (let i = 0; i < cmdsToServer.getSize(); i++) {\r\n      // When the request is being sent to server due to an operation execution, get the information of current operation from CmdsToServer\r\n      if (cmdsToServer.getCmd(i) instanceof ExecOperCommand) {\r\n        let operCmd: ExecOperCommand = <ExecOperCommand>(<CommandsTable>currMGData.CmdsToServer).getCmd(i);\r\n\r\n        this._requestInfo.serverCallAt = operCmd.getCommandInfo();\r\n\r\n        this._requestInfo.runtimeTaskTree = this.GetTaskTree(operCmd.getTask());\r\n        operExecution = true;\r\n        break;\r\n      }\r\n    }\r\n\r\n    this._requestInfo.extraInfo.contextID = RuntimeContextBase.Instance.ContextID;\r\n    this._requestInfo.extraInfo.sessionCounter = this.GetSessionCounter();\r\n\r\n    // Log information about magic internal events causing requests to server\r\n    if (!operExecution) {\r\n      if (eventsManager.getLastRtEvent() != null && eventsManager.getLastRtEvent().InternalEvent != 0) {\r\n        let rtEvt: RunTimeEvent = eventsManager.getLastRtEvent();\r\n        this._requestInfo.runtimeTaskTree = this.GetTaskTree(<Task>rtEvt.getTask());\r\n\r\n        // return description as per new/old internal event desc\r\n        let eventDescription: string = rtEvt.isNewInternalEvent()\r\n          ? NString.TrimEnd(rtEvt.getNewInternalEventDescription())\r\n          : Event.getInternalEvtDescription(rtEvt.InternalEvent);\r\n\r\n\r\n        // e.g. Event [<Next Chunk>] while executing [<View Refresh>]\r\n        let cmd: IClientCommand = cmdsToServer.getCmd(cmdsToServer.getSize() - 1);\r\n        if (cmd as IClientToServerCommandInfo) {\r\n          let commandInfo: string = NString.IsNullOrEmpty((<IClientToServerCommandInfo>cmd).getCommandInfo())\r\n            ? NString.Empty\r\n            : (<IClientToServerCommandInfo>cmd).getCommandInfo();\r\n\r\n          // In case the runtime event and Event command are same, no need to log the extra information\r\n          if (cmd instanceof EventCommand && rtEvt.InternalEvent == (<EventCommand>cmd).MagicEvent)\r\n            eventDescription = NString.Empty;\r\n\r\n          this._requestInfo.serverCallAt = 'Event ' + commandInfo +\r\n            (!NString.IsNullOrEmpty(eventDescription)\r\n              ? NString.Format(' while executing [{0}]', eventDescription)\r\n              : NString.Empty);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// Build xml for main prog dataview. required for re-initializing session.\r\n  /// </summary>\r\n  private async BuildXMLForMainProgramDataView(): Promise<String> {\r\n    let message: StringBuilder = new StringBuilder();\r\n    let firstMgData: MGData = MGDataCollection.Instance.getMGData(0);\r\n    let mainPrg: Task = firstMgData.getMainProg(0);\r\n\r\n    while (mainPrg != null) {\r\n      await mainPrg.buildXML(message);\r\n      mainPrg = firstMgData.getNextMainProg(mainPrg.getCtlIdx());\r\n    }\r\n\r\n    if (RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages) {\r\n      let scrambledChanges: string = Scrambler.Scramble(message.ToString());\r\n      message = new StringBuilder(scrambledChanges);\r\n    }\r\n\r\n    message.Insert(0, XMLConstants.MG_TAG_OPEN);\r\n    message.Append(XMLConstants.MG_TAG_XML_END_TAGGED);\r\n\r\n    return message.ToString();\r\n  }\r\n\r\n\r\n  async Execute_1(sendingInstruction: CommandsProcessorBase_SendingInstruction, sessionStage: CommandsProcessorBase_SessionStage, res: IResultValue): Promise<void> {\r\n    let reqBuf: string;\r\n    let isInitialCall: boolean = sessionStage === CommandsProcessorBase_SessionStage.INITIAL;\r\n    let globalParamsString: string = null;\r\n    let envVarsString: string = null;\r\n\r\n    if (this.DelayCommandExecution)\r\n      return;\r\n\r\n    if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo && !isInitialCall)\r\n      await this.UpdateRequestInfo();\r\n\r\n    if (isInitialCall) {\r\n      let val = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.IS_SESSION_REINITIALIZING);\r\n      if (val === 'true') {\r\n        RemoteCommandsProcessor.IsSessionReInitializing = (val === \"true\") ? true : false;\r\n        RemoteCommandsProcessor.lastExceptionMessage = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.LAST_EXCEPTION);\r\n        let ctxRemoved = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.CTX_REMOVED_FROM_SRVR);\r\n\r\n        if (ctxRemoved !== '1') {\r\n          Logger.Instance.WriteErrorToLog(RemoteCommandsProcessor.lastExceptionMessage);\r\n          Logger.Instance.WriteToLog(\"Session is reinitializing...\", true);\r\n        }\r\n      }\r\n    }\r\n\r\n    if (sendingInstruction === CommandsProcessorBase_SendingInstruction.NO_TASKS_OR_COMMANDS)\r\n      reqBuf = null;\r\n    else {\r\n      reqBuf = await this.PrepareRequest(sendingInstruction === CommandsProcessorBase_SendingInstruction.TASKS_AND_COMMANDS);\r\n\r\n      if (RemoteCommandsProcessor.IsSessionReInitializing || !isInitialCall) {\r\n        let changes: StringBuilder = new StringBuilder();\r\n        let buffer: StringBuilder = new StringBuilder();\r\n        if (!RemoteCommandsProcessor.IsSessionReInitializing)\r\n          buffer.Append(reqBuf);\r\n\r\n        // send activity monitor logs to the server\r\n        // if (this._logAccumulator !== null && !this._logAccumulator.Empty())\r\n        //   buffer.Append(this._logAccumulator.Read());\r\n\r\n        // synchronize client-side SetParams and INIPut data to the server\r\n        if (RemoteCommandsProcessor.IsSessionReInitializing)\r\n        {\r\n          globalParamsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.GLOBAL_PARAM_LIST);\r\n          envVarsString = this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.ENV_VAR_LIST);\r\n        }\r\n        else\r\n        {\r\n          globalParamsString = AccessHelper.globalParams.mirrorToXML();\r\n          envVarsString = AccessHelper.envParamsTable.mirrorToXML();\r\n        }\r\n        changes.Append(globalParamsString);\r\n        changes.Append(envVarsString);\r\n\r\n        // If there is stuff to synchronize, wrap it, scramble it and add the MGDATA flag\r\n        if (changes.Length > 0) {\r\n          changes.Insert(0, \"<\" + ConstInterface.MG_TAG_ENV_CHANGES + \">\");\r\n          changes.Append(\"</\" + ConstInterface.MG_TAG_ENV_CHANGES + \">\");\r\n\r\n          if (RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages) {\r\n            let scrambledChanges: string = Scrambler.Scramble(changes.ToString());\r\n            changes = new StringBuilder(scrambledChanges);\r\n          }\r\n          changes.Insert(0, XMLConstants.MG_TAG_OPEN);\r\n          changes.Append(XMLConstants.MG_TAG_XML_END_TAGGED);\r\n\r\n          buffer.Append(changes.ToString());\r\n        }\r\n\r\n        reqBuf = buffer.ToString();\r\n      }\r\n    }\r\n\r\n    let requestStatus: RefParam<RequestStatus> = new RefParam(RequestStatus.Handled);\r\n    let respBuf: string = null;\r\n\r\n    if (RemoteCommandsProcessor.IsSessionReInitializing) {\r\n      reqBuf = reqBuf + this.RestoreSessionReInitializingDataFromLocalStorage(ConstInterface.MAIN_PROG_VIEW);\r\n    }\r\n\r\n    if (RuntimeContextBase.Instance.RemovedContextFromServer)\r\n      requestStatus.value = RequestStatus.Retry; //try to re-start session first\r\n    else {\r\n      if (RuntimeContextBase.Instance.RemovingContextFromServer)\r\n        RuntimeContextBase.Instance.RemovedContextFromServer = true;\r\n\r\n      respBuf = await this.DispatchRequest(this.ServerUrl, reqBuf, sessionStage, requestStatus);\r\n    }\r\n\r\n    if (requestStatus.value == RequestStatus.Retry) {\r\n      await this.ReStartSession();\r\n    }\r\n    if (respBuf == null)\r\n      return;\r\n\r\n    if (isInitialCall) {\r\n      RemoteCommandsProcessor.InitialUrl = window.location.href;\r\n      if (RemoteCommandsProcessor.IsSessionReInitializing) {\r\n        let dataStorage = window.localStorage;\r\n        dataStorage.removeItem(ConstInterface.IS_SESSION_REINITIALIZING);\r\n        dataStorage.removeItem(ConstInterface.MAIN_PROG_VIEW);\r\n        dataStorage.removeItem(ConstInterface.GLOBAL_PARAM_LIST);\r\n        dataStorage.removeItem(ConstInterface.ENV_VAR_LIST);\r\n        dataStorage.removeItem(ConstInterface.LAST_EXCEPTION);\r\n      }\r\n    }\r\n\r\n    FlowMonitorQueue.Instance.enable(false);\r\n    await this.ProcessResponse(respBuf, AccessHelper.mgDataTable.currMgdID, null, res);\r\n\r\n    if (RemoteCommandsProcessor.IsSessionReInitializing) {\r\n        AccessHelper.globalParams.RestoreParams(globalParamsString);\r\n        AccessHelper.envParamsTable.RestoreParams(envVarsString);\r\n\r\n      let dataStorage = window.localStorage;\r\n      let ctxRemoved = dataStorage.getItem(ConstInterface.CTX_REMOVED_FROM_SRVR);\r\n\r\n      if (ctxRemoved === \"1\") {\r\n\r\n        EventsManager.Instance.restoreLastSavedRouteEventFromLocalStorage();\r\n\r\n        dataStorage.removeItem(ConstInterface.CTX_REMOVED_FROM_SRVR);\r\n        dataStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT);\r\n        dataStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_SRC_TSK);\r\n        dataStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_ARG_LIST);\r\n      }\r\n\r\n      RemoteCommandsProcessor.IsSessionReInitializing = false;\r\n    }\r\n    // if (isInitialCall) {\r\n    //   // If it was initial call, we will send all pending logs (Failed earlier execution scenario)\r\n    //   // They will be sent here, after first request is served.\r\n    //   if (ClientManager.Instance.getLogClientSequenceForActivityMonitor() && ClientLogAccumulator.ExistingLogsFound()) {\r\n    //     let success: boolean = this.SendPendingLogsToServer();\r\n    //\r\n    //     // if we have successfully sent the pending logs delete them\r\n    //     if (success) {\r\n    //       RemoteCommandsProcessor.DeletePendingLogs();\r\n    //     }\r\n    //   }\r\n    // }\r\n    // else if (this._logAccumulator !== null && !this._logAccumulator.Empty()) {\r\n    //   // Accumulated logs were sent, so reset (delete) them now\r\n    //   this._logAccumulator.Reset();\r\n    // }\r\n\r\n    // refresh the displays\r\n    if (sendingInstruction === CommandsProcessorBase_SendingInstruction.TASKS_AND_COMMANDS) {\r\n      AccessHelper.mgDataTable.startTasksIteration();\r\n      let task: TaskBase;\r\n      while ((task = <TaskBase>AccessHelper.mgDataTable.getNextTask()) !== null) {\r\n        let dataViewWasRetrieved: boolean = task.DataViewWasRetrieved;\r\n        if (dataViewWasRetrieved) {\r\n          await task.RefreshDisplay();\r\n        }\r\n      }\r\n    }\r\n\r\n    if (isInitialCall)\r\n      ServerConfig.Instance.setGlobalParams(null);\r\n  }\r\n\r\n  /// <summary>send 'reqBuf' to 'url'; receive a response.\r\n  /// For Normal/InitialCall requests, the url points to the web-requester.\r\n  /// The other parameters and data goes as the encoded body.\r\n  /// This means that it is a POST request.\r\n  /// On the other hand, HandShake request is a GET request and so the parameters are\r\n  /// sent in the URL itself. In this case, encodedBody has to be null.\r\n  /// </summary>\r\n  /// <param name=\"url\">URL to be accessed.</param>\r\n  /// <param name=\"reqBuf\">data to be sent to the url</param>\r\n  /// <param name=\"sessionStage\">HANDSHAKE / INITIAL / NORMAL.</param>\r\n  /// <returns>response</returns>\r\n  private async DispatchRequest(url: string, reqBuf: string, sessionStage: CommandsProcessorBase_SessionStage, requestStatus: RefParam<RequestStatus>): Promise<string> {\r\n    let response: string = null;\r\n    let encodedBody: string = null;\r\n    requestStatus.value = RequestStatus.Handled;\r\n\r\n    if (url === null) {\r\n      Logger.Instance.WriteExceptionToLogWithMsg(\"in sendMsgToSrvr() unknown server\");\r\n      return response;\r\n    }\r\n\r\n    if (sessionStage !== CommandsProcessorBase_SessionStage.HANDSHAKE) {\r\n      let urlSuffix: string = this.BuildUrlSuffix(reqBuf !== null, sessionStage === CommandsProcessorBase_SessionStage.INITIAL);\r\n      let reqBufEncoded: string = HttpUtility.UrlEncode(reqBuf, Encoding.UTF8);\r\n      encodedBody = urlSuffix + reqBufEncoded;\r\n    }\r\n\r\n\r\n    try {\r\n      if (Logger.Instance.ShouldLogExtendedServerRelatedMessages())\r\n        Logger.Instance.WriteServerMessagesToLog(NString.Format(\"MESSAGE TO SERVER:\\n URL: {0}\\n BODY: {1}\", url, encodedBody));\r\n\r\n      response = await this.ExecuteRequest(url, encodedBody);\r\n\r\n      /* remove the unwanted data before the MGDATA tag */\r\n      if (!response.toUpperCase().startsWith(\"<HTML\")) {\r\n        let startIdx: number = response.indexOf(\"<xml id=\\\"MGDATA\\\">\");\r\n        if (startIdx > 0)\r\n          response = response.substr(startIdx);\r\n      }\r\n\r\n      Logger.Instance.WriteServerMessagesToLog(\"MESSAGE FROM SERVER: \" + response);\r\n\r\n      // handshake requests are always scrambled (the scrambling can be disabled starting from the 3rd request).\r\n      if (sessionStage === CommandsProcessorBase_SessionStage.HANDSHAKE ||\r\n        (response.length > 0 &&\r\n          RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages && response !== \"<xml id=\\\"MGDATA\\\">\\n</xml>\")) {\r\n        if (sessionStage === CommandsProcessorBase_SessionStage.HANDSHAKE) {\r\n          // handshake requests are always scrambled.\r\n          Debug.Assert(response.length > 0 && response[0] !== '<');\r\n        }\r\n        response = CommandsProcessorBase.UnScramble(response);\r\n      }\r\n\r\n      Logger.Instance.WriteDevToLog(\"MESSAGE FROM SERVER: (size = \" + response.length + \")\" + OSEnvironment.EolSeq + response);\r\n\r\n      this._lastRequestTime = Misc.getSystemMilliseconds();\r\n    } catch (ex) {\r\n      if (ex instanceof ServerError) {\r\n        requestStatus.value = RequestStatus.Abort;\r\n\r\n\r\n        if (sessionStage == CommandsProcessorBase_SessionStage.NORMAL) {\r\n          // If context is not found at server due to crash or thread is aborted due to crash,\r\n          // check WebClientReinitSession. based on the flag, re-initializing request should be sent to create\r\n          // a new context and it should be executed in this new context.\r\n          // so, set the RequestStatus to Retry so that the client will resend request.\r\n          if (ex.GetCode() == ServerError.ERR_CTX_NOT_FOUND || ex.GetCode() == ServerError.ERR_THREAD_ABORTED) {\r\n            if (RuntimeContextBase.Instance.RemovedContextFromServer) {\r\n              requestStatus.value = RequestStatus.Retry;\r\n            } else {\r\n              switch (Environment.Instance.getWebClientReinitSession()) {\r\n                case 'Y' :\r\n                  requestStatus.value = RequestStatus.Retry;\r\n                  break;\r\n                case 'A':\r\n                  let retval = await GUIManager.Instance.MessageBox(\"Error\", \"Unknown error occurred at server-side.\" +\r\n                    \" Would you like to reinitialize the session?\", Styles.MSGBOX_BUTTON_YES_NO);\r\n                  requestStatus.value = (retval == Styles.MSGBOX_RESULT_YES) ? RequestStatus.Retry : RequestStatus.Abort;\r\n                  break;\r\n                case 'N':\r\n                default:\r\n                  requestStatus.value = RequestStatus.Abort;\r\n                  break;\r\n              }\r\n            }\r\n            if (requestStatus.value == RequestStatus.Abort) {\r\n              Environment.Instance.setWebClientReinitSession('N');\r\n              throw  ex;\r\n            } else {\r\n              let errForConsole = StrUtil.getConsoleErorString(ex.GetMessage());\r\n              RemoteCommandsProcessor.lastExceptionMessage = \"Exception Occured at server side : \" + ex.GetCode().toString() + \" : \" + errForConsole;\r\n              console.log(RemoteCommandsProcessor.lastExceptionMessage);\r\n            }\r\n            return null;\r\n          }\r\n        }\r\n      }\r\n      this.clearLocalStorage();\r\n      throw ex;\r\n    }\r\n    return response;\r\n  }\r\n\r\n  // <summary> If any items are stored on local storage clear it now as session cannot continued.\r\n  // Clearing only the local storage items which are stored by magic library.\r\n  clearLocalStorage(){\r\n    window.localStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT);\r\n    window.localStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_SRC_TSK);\r\n    window.localStorage.removeItem(ConstInterface.LAST_ROUTE_EVENT_ARG_LIST);\r\n    window.localStorage.removeItem(ConstInterface.IS_SESSION_REINITIALIZING);\r\n    window.localStorage.removeItem(ConstInterface.MAIN_PROG_VIEW);\r\n    window.localStorage.removeItem(ConstInterface.GLOBAL_PARAM_LIST);\r\n    window.localStorage.removeItem(ConstInterface.ENV_VAR_LIST);\r\n    window.localStorage.removeItem(ConstInterface.LAST_EXCEPTION);\r\n    window.localStorage.removeItem(ConstInterface.CTX_REMOVED_FROM_SRVR);\r\n  }\r\n\r\n  /// <summary> Checks the response string, throws an error if the response string contains\r\n  /// an xml/html error</summary>\r\n  /// <param name=\"response\"></param>\r\n  private HandleErrorResponse(response: string): void {\r\n    try {\r\n      // error responses are always scrambled by the web server.\r\n      Logger.Instance.WriteServerMessagesToLog(\"MESSAGE FROM SERVER: \" + response);\r\n      response = CommandsProcessorBase.UnScramble(response);\r\n      Logger.Instance.WriteServerMessagesToLog(\"MESSAGE FROM SERVER: \" + StrUtil.getConsoleErorString(response));\r\n    } catch (ex) {\r\n    }\r\n\r\n    if (response.startsWith(\"<xmlerr\")) {\r\n      let errorMessageXml: ErrorMessageXml = new ErrorMessageXml(response, this._lastRequestTime, AccessHelper.environment.getContextInactivityTimeout());\r\n      throw new ServerError(errorMessageXml.GetMessage(), errorMessageXml.GetCode());\r\n    } else if (response.toUpperCase().startsWith(\"<HTML\")) {\r\n      throw new ServerError(response);\r\n    }\r\n  }\r\n\r\n  /// <summary>send 'encodedBody' to 'url' and receive a response.\r\n  /// </summary>\r\n  /// <param name=\"url\">URL to be accessed.</param>\r\n  /// <param name=\"encodedBody\">In case of POST, content to be sent to server. For other methods, null.</param>\r\n  /// <returns>the response from the server</returns>\r\n  private async ExecuteRequest(url: string, encodedBody: string): Promise<string> {\r\n    return await this.GetContent(url, false, encodedBody);\r\n  }\r\n\r\n  async GetContent(requestedURL: string, useCache: boolean, requestContent?: string): Promise<string> {\r\n    if (isUndefined(requestContent))\r\n      requestContent = null;\r\n\r\n    let responseStr: string;\r\n\r\n    try {\r\n      // if relative, prefix with the 'protocol://server/' from which the rich-client was activated\r\n      if (requestedURL.startsWith(\"/\"))\r\n        requestedURL = ServerConfig.Instance.getProtocol() + \"://\" + ServerConfig.Instance.getServer() + requestedURL;\r\n\r\n      var spinnerTimer = timer(50, 50);\r\n      var spinnerTimerSubscription: Subscription = spinnerTimer.subscribe(() => {\r\n        AccessHelper.eventsManager.CheckAndShowSpinner(true);\r\n      });\r\n\r\n      let isError: RefParam<boolean> = new RefParam(false);\r\n\r\n      responseStr = await HttpManager.GetInstance().GetContent(requestedURL, requestContent, useCache, isError);\r\n\r\n      spinnerTimerSubscription.unsubscribe();\r\n      spinnerTimerSubscription = null;\r\n\r\n      if (isError.value) {\r\n        this.HandleErrorResponse(responseStr);\r\n      }\r\n    } catch (ex) {\r\n      // don't write server error to log when the log level is basic\r\n      if (!(ex instanceof ServerError) || Logger.Instance.LogLevel !== Logger_LogLevels.Basic) {\r\n        Logger.Instance.WriteExceptionToLog(ex, NString.Format(\"requested URL = \\\"{0}\\\"\", requestedURL));\r\n      }\r\n\r\n      // the exception should be thrown and the callers should handle it.\r\n      if (!(ex instanceof ServerError)) {\r\n        ex = new ServerError(ex.Message, ex.InnerException ? ex.InnerException : ex);\r\n      }\r\n\r\n      throw ex;\r\n    } finally {\r\n      if (spinnerTimerSubscription != null)\r\n        spinnerTimerSubscription.unsubscribe();\r\n    }\r\n\r\n    return responseStr;\r\n  }\r\n\r\n\r\n  ClientActivated() {\r\n\r\n    // log the values as client is active again\r\n    // TODO - formatting\r\n    // console.log('Logging Summary ' + '\\n' +\r\n    //   'Total number requests : ' + RemoteCommandsProcessor.requestNumber + '\\n' +\r\n    //   'Total time needed for http requests : ' + RemoteCommandsProcessor.totalTimeForHTTPRequests + ' ms ' + '\\n' +\r\n    //   'Total time needed for client to get active : ' + executionTime + ' ms ' + '\\n'\r\n    // );\r\n    //\r\n    // // TODO - move it to method\r\n    // RemoteCommandsProcessor.requestNumber = 0;\r\n    // RemoteCommandsProcessor.totalTimeForHTTPRequests = 0;\r\n    // RemoteCommandsProcessor.totalRequestDataLength = 0;\r\n    // RemoteCommandsProcessor.totalResponseDataLength = 0;\r\n  }\r\n\r\n  /// <summary> When LogClientSequenceForActivityMonitor = Y we will be keeping the logs in file and send the file with next\r\n  /// server access. If client is abnormally terminated then there can be 1 or more files containing logs since\r\n  /// last server access.Now these logs will be sent to server, when next time RC program is executed,.</summary>\r\n  /// <returns> If sending was successful</returns>\r\n  //   TODO: Handle pending logs.\r\n  // private SendPendingLogsToServer(): boolean {\r\n  //   let success: boolean = true;\r\n  //\r\n  //   The pending logs cannot be read from the file system since WebClient doesn't have access to that.\r\n  //   Maybe, the logs should be written into LocalStorage ad read from there.\r\n  //\r\n  //   let stringBuilder: StringBuilder = new StringBuilder(1000);\r\n  //   let flowMonitor: FlowMonitorQueue = FlowMonitorQueue.Instance;\r\n  //\r\n  //   // Get iterator to names of log files.\r\n  //   let enumerator: IEnumerator<string> = ClientLogAccumulator.ExistingLogIterator();\r\n  //\r\n  //   // while there are more files\r\n  //   while (enumerator.MoveNext()) {\r\n  //     // Take next file name\r\n  //     let logName: string = enumerator.Current;\r\n  //     // Prepare the header line (Client log file : <Context : XXXXXX>) and add it to\r\n  //     // flow monitor build monitor message\r\n  //     let headerLine: string = ClientLogAccumulator.BuildLogHeaderLine(logName);\r\n  //     flowMonitor.addFlowVerifyInfo(headerLine);\r\n  //     let logCtxBuf: StringBuilder = RemoteCommandsProcessor.BuildMonitorMessage();\r\n  //\r\n  //     let fileContents: string = HandleFiles.readToString(logName);\r\n  //     logCtxBuf.Append(fileContents);\r\n  //     stringBuilder.Append(logCtxBuf.ToString());\r\n  //   }\r\n  //\r\n  //   let respBuf: string = null;\r\n  //\r\n  //   try {\r\n  //     respBuf = this.DispatchRequest(this.ServerUrl, stringBuilder.ToString(), CommandsProcessorBase_SessionStage.NORMAL);\r\n  //   }\r\n  //   catch (ex) {\r\n  //     // do nothing. if sending log fails, there is no harm.\r\n  //   }\r\n  //\r\n  //   if (respBuf === null) {\r\n  //     success = false;\r\n  //   }\r\n  //\r\n  //   return success;\r\n  // }\r\n\r\n  // TODO: Handle pending logs.\r\n  // private static DeletePendingLogs(): void {\r\n  //   let enumerator: IEnumerator = ClientLogAccumulator.ExistingLogIterator();\r\n  //   while (enumerator.MoveNext()) {\r\n  //     let filename: string = <string>enumerator.Current;\r\n  //     HandleFiles.deleteFile(filename);\r\n  //   }\r\n  // }\r\n\r\n  /// <summary> get the suffix of the URL to be sent to the server. This includes the CTX, SESSION and DATA parameters.</summary>\r\n  /// <param name=\"hasContent\">if true, the HTTP DATA parameter contains something.</param>\r\n  /// <param name=\"isInitialCall\">if true then the generated suffix has no specific context data</param>\r\n  /// <returns> the URL suffix (i.e. \"CTX=...&SESSION=...&DATA=\"</returns>\r\n  private BuildUrlSuffix(hasContent: boolean, isInitialCall: boolean): string {\r\n    let prefix: string = ConstInterface.RC_INDICATION + ConstInterface.RC_TOKEN_CTX_ID + RuntimeContextBase.Instance.ContextID;\r\n\r\n    // Append session id in url only when it is not null or empty\r\n    // NOTE: session id will be send by server only for GS as middleware\r\n    //       and when sepecial flag (SpecialRIAGenerateAndValidateSessionID) is on\r\n    //       so session id will be null for broker middleware and when special flag is OFF.\r\n    if (!isNullOrUndefined(this.SessionId))\r\n      prefix += (ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.RC_TOKEN_SESSION_ID + this.SessionId);\r\n\r\n    if (isInitialCall) {\r\n      // TODO: How to get environment variables?\r\n      // let envVars: string = ClientManager.Instance.getEnvVars();\r\n      // if (!NString.IsNullOrEmpty(envVars)) {\r\n      //   // environment variables: ENV1,ENV2,.. --> &ENV1=val1&ENV2=val2...\r\n      //   let envVarsVec: string[] = envVars.split(\",\");\r\n      //   for (let i: number = 0; i < envVarsVec.length; i = i + 1) {\r\n      //     prefix += (\"&\" + envVarsVec[i] + \"=\" + OSEnvironment.get(envVarsVec[i]));\r\n      //   }\r\n      // }\r\n      if (RemoteCommandsProcessor.IsSessionReInitializing)\r\n        prefix += (ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.WEBCLIENT_REINITIALIZE_REQUEST);\r\n\r\n      let globalParams: string = ServerConfig.Instance.getGlobalParams();\r\n      if (globalParams !== null) {\r\n        globalParams = NString.Replace(globalParams, \"+\", \"%2B\");\r\n        prefix += (\"&\" + ConstInterface.MG_TAG_GLOBALPARAMS + \"=\" + globalParams);\r\n      }\r\n    } // isInitialCall\r\n\r\n    if (hasContent) {\r\n      prefix += (\"&\" + ConstInterface.RC_TOKEN_SESSION_COUNT + this.GetSessionCounter() +\r\n        ConstInterface.REQ_ARG_SEPARATOR + ConstInterface.RC_TOKEN_DATA);\r\n    }\r\n\r\n    return prefix;\r\n  }\r\n\r\n  /// <summary>send Monitor messaging to the server</summary>\r\n  public async SendMonitorOnly(): Promise<void> {\r\n    let flowMonitor: FlowMonitorQueue = FlowMonitorQueue.Instance;\r\n\r\n    if (AccessHelper.mgDataTable == null || AccessHelper.mgDataTable.getMGData(0) == null || AccessHelper.mgDataTable.getMGData(0).IsAborting)\r\n      return;\r\n\r\n    if (!flowMonitor.isEmpty()) {\r\n      // build out message\r\n      let buffer: StringBuilder = this.BuildMonitorMessage();\r\n\r\n      // If client sequence is to be accumulated until next server access.\r\n      let shouldAccumulateClientLog: boolean = false;\r\n      // shouldAccumulateClientLog = ClientManager.Instance.getLogClientSequenceForActivityMonitor();\r\n      // if (shouldAccumulateClientLog) {\r\n      //   if (this._logAccumulator == null)\r\n      //     this._logAccumulator = new ClientLogAccumulator(ClientManagerRuntime.Instance.RuntimeCtx.ContextID);\r\n      //\r\n      //   // If we're unable to open the file, deactivate logging accumulation,\r\n      //   //    and let the message be sent to the server as done without accumulated logging\r\n      //   if (this._logAccumulator.IsFailed())\r\n      //     shouldAccumulateClientLog = false;\r\n      // }\r\n\r\n      if (shouldAccumulateClientLog) {\r\n        // Write message to file.\r\n        // this._logAccumulator.Write(buffer.ToString());\r\n      } else {\r\n        try {\r\n          let requestStatus: RefParam<RequestStatus> = new RefParam(RequestStatus.Handled);\r\n          await this.DispatchRequest(this.ServerUrl, buffer.ToString(), CommandsProcessorBase_SessionStage.NORMAL, requestStatus);\r\n        } catch (err) {\r\n          // do nothing. if sending log fails, there is no harm.\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>build Flow Monitor message</summary>\r\n  private BuildMonitorMessage(): StringBuilder {\r\n    let buffer: StringBuilder = new StringBuilder(1000);\r\n    let flowMonitor: FlowMonitorQueue = FlowMonitorQueue.Instance;\r\n\r\n    if (!RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages) {\r\n      buffer.Append(XMLConstants.MG_TAG_OPEN);\r\n      flowMonitor.buildXML(buffer);\r\n    } else {\r\n      flowMonitor.buildXML(buffer);\r\n      let scrambledOut: string = Scrambler.Scramble(buffer.ToString());\r\n      buffer = new StringBuilder(1000);\r\n      buffer.Append(XMLConstants.MG_TAG_OPEN + scrambledOut);\r\n    }\r\n    buffer.Append(\"</\" + XMLConstants.MG_TAG_XML + XMLConstants.TAG_CLOSE);\r\n\r\n    return buffer;\r\n  }\r\n\r\n  RegisterDelegates(): void {\r\n    HttpClientEvents.GetSessionCounter_Event = this.GetSessionCounter.bind(this);\r\n    HttpClientEvents.CheckAndSetSessionCounter_Event = this.CheckAndSetSessionCounter.bind(this);\r\n    HttpClientEvents.ComputeAndLogRequestInfo_Event = this.ComputeAndLogRequestInfo.bind(this);\r\n    AccessHelper.eventsManager.SpinnerStopped.subscribe(clientBusyTime => this.ClientActivated());\r\n  }\r\n\r\n  /// <summary>\r\n  /// Log the current request information in console\r\n  /// </summary>\r\n  ComputeAndLogRequestInfo(contentLength: number, roundTrip: number, isLoggingResponse: boolean): void {\r\n    if (!isNullOrUndefined(this._requestInfo.serverCallAt)) {\r\n\r\n      this._requestInfo.extraInfo.contentLength = contentLength;\r\n      this._requestInfo.extraInfo.timeStamp = new Date().toString();\r\n      let extraMessageStr: string = isLoggingResponse ? 'Response ⤵' : 'Request ⤵';\r\n\r\n      if (isLoggingResponse) {\r\n        this._requestInfo.roundtripTime = roundTrip;\r\n      }\r\n\r\n\r\n      Logger.Instance.WriteRequestInfoToLog(this._requestInfo, extraMessageStr);\r\n\r\n      // Clear the client session after logging the response\r\n      if (isLoggingResponse)\r\n        this._requestInfo.clear();\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// When true, requests are scrambled and responses are unscrambled.\r\n  /// </summary>\r\n  static set ShouldScrambleAndUnscrambleMessages(value: boolean) {\r\n    RemoteCommandsProcessor._shouldScrambleAndUnscrambleMessages = value;\r\n    Logger.Instance.WriteServerMessagesToLog(NString.Format(\"ShouldScrambleAndUnscrambleMessages.Set: {0}\", this._shouldScrambleAndUnscrambleMessages));\r\n  }\r\n\r\n  static get ShouldScrambleAndUnscrambleMessages(): boolean {\r\n    Logger.Instance.WriteServerMessagesToLog(NString.Format(\"ShouldScrambleAndUnscrambleMessages.Get: {0}\", this._shouldScrambleAndUnscrambleMessages));\r\n    return RemoteCommandsProcessor._shouldScrambleAndUnscrambleMessages;\r\n  }\r\n\r\n\r\n  /// <summary>parse the log level from a string value</summary>\r\n  /// <param name=\"strLogLevel\">string value of the log level</param>\r\n  /// <returns>log level</returns>\r\n  parseLogLevel(strLogLevel: string): Logger_LogLevels {\r\n    let logLevel: Logger_LogLevels = Logger_LogLevels.None;\r\n\r\n    if (!NString.IsNullOrEmpty(strLogLevel)) {\r\n      if (strLogLevel.toUpperCase().startsWith(\"SERVER\"))\r\n        logLevel = strLogLevel.endsWith(\"#\") ? Logger_LogLevels.ServerMessages : Logger_LogLevels.Server; // only requests to the server\r\n      else if (strLogLevel.toUpperCase().startsWith(\"S\") || strLogLevel.toUpperCase().startsWith(\"Q\"))\r\n        logLevel = Logger_LogLevels.Support;\r\n      else if (strLogLevel.toUpperCase().startsWith(\"G\"))\r\n        logLevel = Logger_LogLevels.Gui;\r\n      else if (strLogLevel.toUpperCase().startsWith(\"D\"))\r\n        logLevel = Logger_LogLevels.Development;\r\n      else if (strLogLevel.toUpperCase().startsWith(\"B\"))\r\n        logLevel = Logger_LogLevels.Basic;\r\n      else if (strLogLevel.toUpperCase().startsWith(\"R\"))\r\n        logLevel = Logger_LogLevels.RequestInfo;\r\n    }\r\n\r\n    return logLevel;\r\n  }\r\n\r\n\r\n  /// <summary> build the XML string of the data that should be sent to the server</summary>\r\n  /// <param name=\"serializeTasks\">if true, tasks in the current execution will also be serialized.</param>\r\n  async PrepareRequest(serializeTasks: boolean): Promise<string> {\r\n    let xmlBuf: StringBuilder = new StringBuilder();\r\n    xmlBuf.Append(XMLConstants.MG_TAG_OPEN);\r\n\r\n    // the client no longer sends (and empties) the event queue to the server\r\n    // since the server has nothing useful to do with the client pending events\r\n    if (AccessHelper.mgDataTable.getCurrMGData() !== null) {\r\n      let xmlUnscrambled: StringBuilder = new StringBuilder();\r\n      await AccessHelper.mgDataTable.buildXML(xmlUnscrambled, serializeTasks);\r\n\r\n      if (RemoteCommandsProcessor.ShouldScrambleAndUnscrambleMessages)\r\n        xmlBuf.Append(Scrambler.Scramble(xmlUnscrambled.ToString()));\r\n      else\r\n        xmlBuf.Append(xmlUnscrambled.ToString());\r\n    }\r\n    xmlBuf.Append(\"</\" + XMLConstants.MG_TAG_XML + XMLConstants.TAG_CLOSE);\r\n\r\n    return xmlBuf.ToString();\r\n  }\r\n\r\n\r\n  /// <summary>parse a response (from the Server) and execute commands if returned within the response.</summary>\r\n  /// <param name=\"response\">(XML formatted) response.</param>\r\n  /// <param name=\"currMgdID\">number of window in global array</param>\r\n  /// <param name=\"openingTaskDetails\">additional information of opening task</param>\r\n  /// <param name=\"res\">result to be read from command returned witin the response.</param>\r\n  async ProcessResponse(response: string, currMgdID: number, openingTaskDetails: OpeningTaskDetails, res: IResultValue): Promise<void> {\r\n    Logger.Instance.WriteDevToLog(\"<-- ProcessResponse started -->\");\r\n    if (openingTaskDetails === null)\r\n      openingTaskDetails = new OpeningTaskDetails();\r\n\r\n    let systemMilliseconds: number = Misc.getSystemMilliseconds();\r\n    if (response === null || response.trim().length === 0)\r\n      return;\r\n\r\n    AccessHelper.mgDataTable.currMgdID = currMgdID;\r\n\r\n    RuntimeContextBase.Instance.Parser.push(); // allow recursive parsing\r\n    RuntimeContextBase.Instance.Parser.setXMLdata(response);\r\n    RuntimeContextBase.Instance.Parser.setCurrIndex(0);\r\n\r\n    let currMGData: MGData = AccessHelper.mgDataTable.getCurrMGData();\r\n    await currMGData.fillData(openingTaskDetails, RuntimeContextBase.Instance.Parser);\r\n\r\n    // free memory\r\n    RuntimeContextBase.Instance.Parser.setXMLdata(null);\r\n    RuntimeContextBase.Instance.Parser.pop();\r\n\r\n    Logger.Instance.WriteDevToLog(\"<-- ProcessResponse finished --> (\" + (Misc.getSystemMilliseconds() - systemMilliseconds) + \")\");\r\n    // execute the commands that were returned in the response\r\n    await (<CommandsTable>currMGData.CmdsToClient).Execute(res);\r\n    await this.ProcessRecovery();\r\n  }\r\n\r\n  /// <summary>\r\n  /// processRecovery\r\n  /// </summary>\r\n  async ProcessRecovery(): Promise<void> {\r\n\r\n    // QCR #771012 - process data error recovery only after the parsing process is over.\r\n    AccessHelper.eventsManager.pushNewExecStacks();\r\n    await AccessHelper.mgDataTable.processRecovery();\r\n    AccessHelper.eventsManager.popNewExecStacks();\r\n  }\r\n}\r\n\r\n/// <summary>helper class: details from the runtime-engine - environment values.\r\n/// Handshake response: <Richclientresponse> <ContextID>...</ContextID> <Environment InputPassword=\"Y|N\"\r\n/// SystemLogin=\"F|N|D|L\" /> </Richclientresponse>\r\n/// </summary>\r\nclass HandshakeResponse {\r\n  static readonly SYSTEM_LOGIN_AD: string = 'D';\r\n\r\n  private _scrambleMessages: boolean = true; // true if messages should be scrambled/unscrambled by the client and server\r\n  get ScrambleMessages(): boolean {\r\n    return this._scrambleMessages;\r\n  }\r\n\r\n  private _contextId: string = null;\r\n\r\n  get ContextId(): string {\r\n    return this._contextId;\r\n  }\r\n\r\n  private _privateSessionId: string = null;\r\n\r\n  get GetSessionId(): string {\r\n    return this._privateSessionId;\r\n  }\r\n\r\n  private _inputPassword: boolean = false;\r\n\r\n  get InputPassword(): boolean {\r\n    return this._inputPassword;\r\n  }\r\n\r\n  private _httpTimeout: number = 0;\r\n\r\n  get HttpTimeout(): number {\r\n    return this._httpTimeout;\r\n  }\r\n\r\n  private _systemLogin: string = null;\r\n\r\n  get SystemLogin(): string {\r\n    return this._systemLogin;\r\n  }\r\n\r\n  private _maxInternalLogLevel: string = null;\r\n\r\n  get MaxInternalLogLevel(): string {\r\n    return this._maxInternalLogLevel;\r\n  }\r\n\r\n  constructor(responseXML: string) {\r\n    try {\r\n      JSON_Utils.JSONFromXML(responseXML, this.FillFromJSON.bind(this));\r\n    } catch (ex) {\r\n      Logger.Instance.WriteExceptionToLog(ex, responseXML);\r\n    }\r\n  }\r\n\r\n  private FillFromJSON(error, result): void {\r\n\r\n    // If there was an error in parsing the XML,\r\n    if (error != null) {\r\n      throw error;\r\n    }\r\n\r\n    let response = result['Richclientresponse'];\r\n\r\n    for (let elementName in response) {\r\n      if (response.hasOwnProperty(elementName)) {\r\n\r\n        switch (elementName) {\r\n          case \"ContextID\":\r\n            this._contextId = response[elementName][0];\r\n            break;\r\n          case \"SessionID\":\r\n            this._privateSessionId = response[elementName][0];\r\n            break;\r\n          case \"Environment\":\r\n            let envAttributes = response[\"Environment\"][0]['$'];\r\n\r\n            if (!isNullOrUndefined(envAttributes[\"ScrambleMessages\"])) {\r\n              Debug.Assert(envAttributes[\"ScrambleMessages\"] === \"N\");\r\n              this._scrambleMessages = false;\r\n            }\r\n            if (!isNullOrUndefined(envAttributes[\"MaxInternalLogLevel\"]))\r\n              this._maxInternalLogLevel = envAttributes[\"MaxInternalLogLevel\"];\r\n            if (!isNullOrUndefined(envAttributes[\"InputPassword\"]) && envAttributes[\"InputPassword\"].toLocaleLowerCase() === \"y\")\r\n              this._inputPassword = true;\r\n            if (!isNullOrUndefined(envAttributes[\"SystemLogin\"]))\r\n              this._systemLogin = envAttributes[\"SystemLogin\"];\r\n            if (!isNullOrUndefined(envAttributes[ConstInterface.MG_TAG_HTTP_COMMUNICATION_TIMEOUT]))\r\n              this._httpTimeout = +envAttributes[ConstInterface.MG_TAG_HTTP_COMMUNICATION_TIMEOUT];\r\n            if (!isNullOrUndefined(envAttributes[\"ForwardSlash\"]))\r\n              AccessHelper.environment.ForwardSlashUsage = envAttributes[\"ForwardSlash\"];\r\n            break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n/// <summary>This class implements MgSAXHandlerInterface, which means that it defines all the \"callback\"\r\n/// methods that the SAX parser will invoke to notify the application. In this example we override the\r\n/// methods that we require.</summary>\r\nclass ErrorMessageXml {\r\n  private _lastRequestTime: number = 0;\r\n  contextInactivityTimeout: number;\r\n\r\n  private _errorMessage: string = null;\r\n  private _errorCode: number = 0;\r\n  private _middlewareAddress: string = null;\r\n  private readonly _parsingFailed: boolean = false;\r\n\r\n  constructor(xmlContent: string, lastRequestTime: number, contextInactivityTimeout: number) {\r\n    this._lastRequestTime = lastRequestTime;\r\n    this.contextInactivityTimeout = contextInactivityTimeout;\r\n    try {\r\n      JSON_Utils.JSONFromXML(xmlContent, this.FillFromJSON.bind(this));\r\n    } catch (ex) {\r\n      Logger.Instance.WriteExceptionToLog(ex);\r\n      Misc.WriteStackTrace(ex);\r\n      this._parsingFailed = true;\r\n    }\r\n  }\r\n\r\n  private FillFromJSON(error, result): void {\r\n\r\n    // If there was an error in parsing the XML,\r\n    if (error != null) {\r\n      throw error;\r\n    }\r\n\r\n    let xmlerr = result['xmlerr'];\r\n\r\n    for (let elementName in xmlerr) {\r\n      if (xmlerr.hasOwnProperty(elementName)) {\r\n        switch (elementName) {\r\n          case \"errmsg\":\r\n            this._errorMessage = xmlerr[elementName][0];\r\n            break;\r\n          case \"errcode\":\r\n            this._errorCode = +(xmlerr[elementName]);\r\n            break;\r\n          case \"server\":\r\n            this._middlewareAddress = xmlerr[elementName][0];\r\n            break;\r\n          case \"appname\": // ignored - the client lists this value from the execution properties\r\n          case \"prgname\": // ignored - the client lists this value from the execution properties\r\n          case \"arguments\": // ignored\r\n          case \"username\":  // ignored\r\n          case \"xmlerr\": // end of the error message\r\n            break;\r\n          default:\r\n            Logger.Instance.WriteExceptionToLogWithMsg(NString.Format(\"Unknown element: '{0}'\", elementName));\r\n            break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  GetCode(): number {\r\n    return this._errorCode;\r\n  }\r\n\r\n  // build & return a formatted error message\r\n  GetMessage(): string {\r\n    let sb: StringBuilder = new StringBuilder();\r\n\r\n    if (this._parsingFailed) {\r\n      sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.RC_STR_F7_UNEXPECTED_ERR));\r\n    } else {\r\n      switch (this._errorCode) {\r\n        case ServerError.ERR_CTX_NOT_FOUND:\r\n          if (this.InactivityTimeoutExpired())\r\n            sb.Append(NString.Format(\"{0} ({1} {2})\",\r\n              AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_SESSION_CLOSED_INACTIVITY),\r\n              Math.floor(this.contextInactivityTimeout / 600), // conversion from 1/10 of seconds to minutes\r\n              AccessHelper.languageData.getConstMessage(MsgInterface.STR_MINUTES)));\r\n          else\r\n            sb.Append(NString.Format(\"{0} ({1}).\", AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_SESSION_CLOSED), this._errorCode));\r\n          break;\r\n\r\n        case ServerError.ERR_WEBCLIENT_PROGRAM_RELOADED:\r\n          sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_WEBCLIENT_PROGRAM_RELOADED));\r\n          break;\r\n\r\n        case ServerError.ERR_EXECUTED_PROGRAM_CHANGED:\r\n          sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_EXECUTED_PROGRAM_CHANGED));\r\n          break;\r\n\r\n        case ServerError.ERR_AUTHENTICATION:\r\n          sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.USRINP_STR_BADPASSW));\r\n          break;\r\n\r\n        case ServerError.ERR_ACCESS_DENIED:\r\n          sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.STR_ERR_AUTHORIZATION_FAILURE));\r\n          break;\r\n\r\n        default:\r\n          sb.Append(this._errorMessage);\r\n          break;\r\n      }\r\n\r\n      sb.Append(OSEnvironment.EolSeq + OSEnvironment.EolSeq);\r\n\r\n      if (!ServerConfig.Instance.ShouldDisplayGenericError()) {\r\n        sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.BROWSER_OPT_INFO_SERVER_STR) + \":   \");\r\n        sb.Append(ServerConfig.Instance.getServer());\r\n        if (!NString.IsNullOrEmpty(this._middlewareAddress)) {\r\n          sb.Append(\" --> \");\r\n          sb.Append(this._middlewareAddress);\r\n        }\r\n        sb.Append(OSEnvironment.EolSeq);\r\n      }\r\n\r\n      sb.Append(AccessHelper.languageData.getConstMessage(MsgInterface.TASKRULE_STR_APPLICATION) + \":   \\\"\");\r\n      sb.Append(ServerConfig.Instance.getAppName());\r\n      sb.Append(\"\\\" (\\\"\");\r\n      sb.Append(\"\\\")\");\r\n    }\r\n\r\n    return sb.ToString();\r\n  }\r\n\r\n  private InactivityTimeoutExpired(): boolean {\r\n    let expired: boolean = false;\r\n    if (this.contextInactivityTimeout > 0) {\r\n      let currTimeMilli: number = Misc.getSystemMilliseconds();\r\n      expired = ((currTimeMilli - this._lastRequestTime) > (this.contextInactivityTimeout * 100));\r\n    }\r\n    return expired;\r\n  }\r\n}\r\n\r\n// TODO: Implement this class\r\n// class ClientLogAccumulator {\r\n//\r\n//   private static CLIENT_LOG_HDR_MSG: string = \"Client log file\";\r\n//   private static _existingLogNames: List<string> = new List<string>();\r\n//   private _clientLogOs: StreamWriter = null;\r\n//   private _contextId: number = 0;\r\n//   private _failed: boolean = false;\r\n//   private _fileName: string = null;\r\n//\r\n//   constructor(contextID: number) {\r\n//     this._contextId = contextID;\r\n//     this._fileName = this.BuildFileName();\r\n//     this.OpenForWrite();\r\n//   }\r\n//\r\n//   Write(buffer: string): void {\r\n//     try {\r\n//       let flag: boolean = !this._failed;\r\n//       if (!flag) {\r\n//         throw new IOException(\"ClientLogSequence : Loging client sequence is deactivated\");\r\n//       }\r\n//       let flag2: boolean = this.OpenForWrite();\r\n//       if (flag2) {\r\n//         this._clientLogOs.Write(buffer);\r\n//         this._clientLogOs.Close();\r\n//         this._clientLogOs = null;\r\n//         this.OpenForWrite();\r\n//       }\r\n//     }\r\n//     catch (ex) {\r\n//       if (ex instanceof IOException) {\r\n//         Logger.Instance.WriteDevToLog(ex.Message);\r\n//         Misc.WriteStackTrace(ex, NConsole.Error);\r\n//       }\r\n//       else\r\n//         throw ex;\r\n//     }\r\n//   }\r\n//\r\n//   Read(): string {\r\n//     let result: string = null;\r\n//     try {\r\n//       let flag: boolean = !this._failed;\r\n//       if (!flag) {\r\n//         throw new IOException(\"ClientLogSequence : Loging client sequence is deactivated\");\r\n//       }\r\n//       this._clientLogOs.Close();\r\n//       this._clientLogOs = null;\r\n//       result = HandleFiles.readToString(this._fileName, Encoding.Default);\r\n//       this.OpenForWrite();\r\n//     }\r\n//     catch (ex) {\r\n//       if (ex instanceof IOException) {\r\n//         Logger.Instance.WriteDevToLog(ex.Message);\r\n//         Misc.WriteStackTrace(ex, NConsole.Error);\r\n//       }\r\n//       else\r\n//         throw ex;\r\n//     }\r\n//     return result;\r\n//   }\r\n//\r\n//   Reset(): void {\r\n//     try {\r\n//       let flag: boolean = !this._failed;\r\n//       if (!flag) {\r\n//         throw new IOException(\"ClientLogSequence : Loging client sequence is deactivated\");\r\n//       }\r\n//       this._clientLogOs.Close();\r\n//       this._clientLogOs = null;\r\n//       HandleFiles.deleteFile(this._fileName);\r\n//     }\r\n//     catch (ex) {\r\n//       if (ex instanceof IOException) {\r\n//         Logger.Instance.WriteExceptionToLog(ex);\r\n//       }\r\n//       else\r\n//         throw ex;\r\n//     }\r\n//   }\r\n//\r\n//   static ExistingLogsFound(): boolean {\r\n//     let result: boolean = false;\r\n//     ClientLogAccumulator.BuildexistingLogList();\r\n//     let flag: boolean = ClientLogAccumulator._existingLogNames !== null && ClientLogAccumulator._existingLogNames.Count > 0;\r\n//     if (flag) {\r\n//       result = true;\r\n//     }\r\n//     return result;\r\n//   }\r\n//\r\n//   static ExistingLogIterator(): IEnumerator<string> {\r\n//     return ClientLogAccumulator._existingLogNames.GetEnumerator();\r\n//   }\r\n//\r\n//   static BuildLogHeaderLine(logName: string): string {\r\n//     let stringBuilder: StringBuilder = new StringBuilder(\"Client log file\");\r\n//     let str: string = NString.Substring(logName, logName.LastIndexOf(NNumber.ToString(Path.DirectorySeparatorChar) + \"CS\") + 3, logName.LastIndexOf(\".log\") - (logName.LastIndexOf(NNumber.ToString(Path.DirectorySeparatorChar) + \"CS\") + 3));\r\n//     stringBuilder.Append(\" (Context : \");\r\n//     stringBuilder.Append(str + \" ) \");\r\n//     return stringBuilder.ToString();\r\n//   }\r\n//\r\n//   Empty(): boolean {\r\n//     return this._failed || !HandleFiles.isExists(this._fileName) || HandleFiles.getFileSize(this._fileName) === 0;\r\n//   }\r\n//\r\n//   IsFailed(): boolean {\r\n//     return this._failed;\r\n//   }\r\n//\r\n//   private static BuildexistingLogList(): void {\r\n//     let flag: boolean = ClientLogAccumulator._existingLogNames !== null && ClientLogAccumulator._existingLogNames.Count === 0;\r\n//     if (flag) {\r\n//       let path: string = \"\";\r\n//       ClientLogAccumulator._existingLogNames.AddRange(NArray.ToEnumerable(Directory.GetFiles(path, \"CS*.LOG\")));\r\n//     }\r\n//   }\r\n//\r\n//   private OpenForWrite(): boolean {\r\n//     let flag: boolean = this._clientLogOs === null;\r\n//     if (flag) {\r\n//       try {\r\n//         this._clientLogOs = new StreamWriter(this._fileName, true, Encoding.Default);\r\n//         this._failed = false;\r\n//       }\r\n//       catch (ex) {\r\n//         if (ex instanceof IOException) {\r\n//           Logger.Instance.WriteDevToLog(\"ClientLogSequences : \" + ex.Message);\r\n//           this._failed = true;\r\n//           this._clientLogOs = null;\r\n//           this._contextId = -1;\r\n//           this._fileName = null;\r\n//         }\r\n//         else\r\n//           throw ex;\r\n//       }\r\n//     }\r\n//     return !this._failed;\r\n//   }\r\n//\r\n//   private BuildFileName(): string {\r\n//     return \"\";\r\n//   }\r\n// }\r\n"]}