@magic-xpa/engine 4.1100.0-dev4110.25 → 4.1100.0-dev4110.250

Sign up to get free protection for your applications and to get access to all the features.
Files changed (521) hide show
  1. package/{esm2020 → esm2022}/index.mjs +188 -188
  2. package/{esm2020 → esm2022}/magic-xpa-engine.mjs +1 -1
  3. package/esm2022/src/AccessHelper.mjs +15 -0
  4. package/esm2022/src/ClientManager.mjs +416 -0
  5. package/esm2022/src/CommandsProcessorBase.mjs +56 -0
  6. package/esm2022/src/CommandsProcessorManager.mjs +26 -0
  7. package/esm2022/src/CommandsTable.mjs +162 -0
  8. package/esm2022/src/ConstInterface.mjs +517 -0
  9. package/{esm2020 → esm2022}/src/CurrentClientVersion.mjs +2 -2
  10. package/esm2022/src/FlowMonitorInterface.mjs +16 -0
  11. package/esm2022/src/GUIManager.mjs +62 -0
  12. package/esm2022/src/GlobalCommandsManager.mjs +34 -0
  13. package/esm2022/src/GuiEventsProcessor.mjs +156 -0
  14. package/{esm2020 → esm2022}/src/ICommandsTable.mjs +1 -1
  15. package/esm2022/src/ServerConfig.mjs +122 -0
  16. package/{esm2020 → esm2022}/src/bridge/IGuiEvent.mjs +19 -19
  17. package/esm2022/src/bridge/MagicBridge.mjs +41 -0
  18. package/esm2022/src/commands/ClientOriginatedCommandTaskTag.mjs +12 -0
  19. package/{esm2020 → esm2022}/src/commands/ClientToServer/AddUserLocateDataViewCommand.mjs +8 -8
  20. package/{esm2020 → esm2022}/src/commands/ClientToServer/AddUserRangeDataviewCommand.mjs +9 -9
  21. package/{esm2020 → esm2022}/src/commands/ClientToServer/AddUserSortDataViewCommand.mjs +9 -9
  22. package/esm2022/src/commands/ClientToServer/BrowserEscEventCommand.mjs +26 -0
  23. package/{esm2020 → esm2022}/src/commands/ClientToServer/ClientOriginatedCommand.mjs +14 -14
  24. package/esm2022/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs +60 -0
  25. package/esm2022/src/commands/ClientToServer/ColumnSortEventCommand.mjs +29 -0
  26. package/esm2022/src/commands/ClientToServer/CommandFactory.mjs +261 -0
  27. package/esm2022/src/commands/ClientToServer/CommandSerializationHelper.mjs +67 -0
  28. package/esm2022/src/commands/ClientToServer/ComputeEventCommand.mjs +26 -0
  29. package/{esm2020 → esm2022}/src/commands/ClientToServer/ContextTerminationEventCommand.mjs +24 -21
  30. package/{esm2020 → esm2022}/src/commands/ClientToServer/ContextTimeoutResetCommand.mjs +23 -20
  31. package/{esm2020 → esm2022}/src/commands/ClientToServer/ControlItemsRefreshCommand.mjs +8 -8
  32. package/esm2022/src/commands/ClientToServer/DataViewOutputCommand.mjs +13 -0
  33. package/{esm2020 → esm2022}/src/commands/ClientToServer/DataviewCommand.mjs +44 -44
  34. package/esm2022/src/commands/ClientToServer/EvaluateCommand.mjs +40 -0
  35. package/{esm2020 → esm2022}/src/commands/ClientToServer/EventCommand.mjs +43 -40
  36. package/esm2022/src/commands/ClientToServer/ExecOperCommand.mjs +70 -0
  37. package/esm2022/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +25 -0
  38. package/{esm2020 → esm2022}/src/commands/ClientToServer/GlobalParamsQueryCommand.mjs +10 -10
  39. package/{esm2020 → esm2022}/src/commands/ClientToServer/ICommandTaskTag.mjs +1 -1
  40. package/esm2022/src/commands/ClientToServer/IndexChangeEventCommand.mjs +24 -0
  41. package/esm2022/src/commands/ClientToServer/IniputForceWriteCommand.mjs +26 -0
  42. package/{esm2020 → esm2022}/src/commands/ClientToServer/NonReversibleExitEventCommand.mjs +26 -23
  43. package/{esm2020 → esm2022}/src/commands/ClientToServer/QueryCommand.mjs +20 -20
  44. package/esm2022/src/commands/ClientToServer/RecomputeCommand.mjs +30 -0
  45. package/esm2022/src/commands/ClientToServer/RefreshEventCommand.mjs +30 -0
  46. package/esm2022/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +27 -0
  47. package/esm2022/src/commands/ClientToServer/RollbackEventCommand.mjs +43 -0
  48. package/esm2022/src/commands/ClientToServer/SelectProgramCommand.mjs +19 -0
  49. package/{esm2020 → esm2022}/src/commands/ClientToServer/SetTransactionStateDataviewCommand.mjs +9 -9
  50. package/esm2022/src/commands/ClientToServer/SubformOpenEventCommand.mjs +24 -0
  51. package/esm2022/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +27 -0
  52. package/esm2022/src/commands/ClientToServer/TransactionCommand.mjs +34 -0
  53. package/{esm2020 → esm2022}/src/commands/ClientToServer/UnloadCommand.mjs +18 -15
  54. package/esm2022/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +18 -0
  55. package/esm2022/src/commands/DataViewCommandBase.mjs +8 -0
  56. package/{esm2020 → esm2022}/src/commands/IClientCommand.mjs +1 -1
  57. package/esm2022/src/commands/IClientTargetedCommand.mjs +13 -0
  58. package/{esm2020 → esm2022}/src/commands/IClientToServerCommandInfo.mjs +2 -2
  59. package/esm2022/src/commands/ServerToClient/AbortCommand.mjs +65 -0
  60. package/{esm2020 → esm2022}/src/commands/ServerToClient/AddLocateCommand.mjs +21 -21
  61. package/esm2022/src/commands/ServerToClient/AddRangeCommand.mjs +62 -0
  62. package/esm2022/src/commands/ServerToClient/AddSortCommand.mjs +33 -0
  63. package/esm2022/src/commands/ServerToClient/ClientRefreshCommand.mjs +25 -0
  64. package/esm2022/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +24 -0
  65. package/esm2022/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +45 -0
  66. package/esm2022/src/commands/ServerToClient/OpenURLCommand.mjs +221 -0
  67. package/{esm2020 → esm2022}/src/commands/ServerToClient/ResetLocateCommand.mjs +14 -14
  68. package/{esm2020 → esm2022}/src/commands/ServerToClient/ResetRangeCommand.mjs +14 -14
  69. package/{esm2020 → esm2022}/src/commands/ServerToClient/ResetSortCommand.mjs +14 -14
  70. package/esm2022/src/commands/ServerToClient/ResultCommand.mjs +37 -0
  71. package/esm2022/src/commands/ServerToClient/VerifyCommand.mjs +83 -0
  72. package/esm2022/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs +132 -0
  73. package/{esm2020 → esm2022}/src/communications/IConnectionStateManager.mjs +1 -1
  74. package/esm2022/src/communications/InteractiveCommunicationsFailureHandler.mjs +15 -0
  75. package/{esm2020 → esm2022}/src/data/DataSourceIdKey.mjs +2 -2
  76. package/esm2022/src/data/DataView.mjs +1613 -0
  77. package/{esm2020 → esm2022}/src/data/DataViewBase.mjs +3 -3
  78. package/esm2022/src/data/DataviewManager.mjs +28 -0
  79. package/esm2022/src/data/DataviewManagerBase.mjs +15 -0
  80. package/esm2022/src/data/DvCache.mjs +67 -0
  81. package/esm2022/src/data/Field.mjs +646 -0
  82. package/esm2022/src/data/FieldBase.mjs +15 -0
  83. package/esm2022/src/data/FieldsTable.mjs +103 -0
  84. package/{esm2020 → esm2022}/src/data/IRecordsTable.mjs +1 -1
  85. package/esm2022/src/data/Key.mjs +88 -0
  86. package/esm2022/src/data/Record.mjs +880 -0
  87. package/{esm2020 → esm2022}/src/data/RecordOutOfDataViewException.mjs +15 -15
  88. package/esm2022/src/data/RecordsTable.mjs +267 -0
  89. package/esm2022/src/data/TaskTransactionManager.mjs +107 -0
  90. package/esm2022/src/data/XMLBasedDcValuesBuilder.mjs +74 -0
  91. package/{esm2020 → esm2022}/src/enums.mjs +23 -23
  92. package/esm2022/src/env/EnvVariablesTable.mjs +340 -0
  93. package/esm2022/src/env/Environment.mjs +487 -0
  94. package/{esm2020 → esm2022}/src/env/ILanguageData.mjs +1 -1
  95. package/esm2022/src/env/LanguageData.mjs +227 -0
  96. package/esm2022/src/env/MirrorString.mjs +65 -0
  97. package/esm2022/src/event/ActionManager.mjs +91 -0
  98. package/esm2022/src/event/Event.mjs +1333 -0
  99. package/esm2022/src/event/EventHandler.mjs +766 -0
  100. package/esm2022/src/event/EventHandlerPosition.mjs +204 -0
  101. package/esm2022/src/event/EventsManager.mjs +2988 -0
  102. package/{esm2020 → esm2022}/src/event/IEventsManager.mjs +6 -6
  103. package/esm2022/src/event/RunTimeEvent.mjs +399 -0
  104. package/{esm2020 → esm2022}/src/event/RunTimeEventBase.mjs +3 -3
  105. package/esm2022/src/event/UserEventsTable.mjs +47 -0
  106. package/esm2022/src/exp/ExpTable.mjs +57 -0
  107. package/esm2022/src/exp/Expression.mjs +200 -0
  108. package/esm2022/src/exp/ExpressionDict.mjs +727 -0
  109. package/esm2022/src/exp/ExpressionEvaluator.mjs +4206 -0
  110. package/esm2022/src/exp/ExpressionLocalJpn.mjs +314 -0
  111. package/esm2022/src/exp/GlobalParamsTable.mjs +85 -0
  112. package/esm2022/src/exp/YesNoExp.mjs +36 -0
  113. package/esm2022/src/gui/CreatedFormVector.mjs +23 -0
  114. package/esm2022/src/gui/FormsTable.mjs +66 -0
  115. package/esm2022/src/gui/MgControl.mjs +363 -0
  116. package/esm2022/src/gui/MgForm.mjs +1224 -0
  117. package/esm2022/src/http/HttpManager.mjs +97 -0
  118. package/esm2022/src/http/client/HttpClientAsync.mjs +68 -0
  119. package/esm2022/src/http/client/HttpClientBase.mjs +132 -0
  120. package/esm2022/src/http/client/HttpClientEvents.mjs +39 -0
  121. package/esm2022/src/http/client/HttpClientSync.mjs +42 -0
  122. package/esm2022/src/http/client/HttpUtility.mjs +84 -0
  123. package/{esm2020 → esm2022}/src/http/client/ICommunicationsFailureHandler.mjs +1 -1
  124. package/esm2022/src/remote/AddUserLocateRemoteDataViewCommand.mjs +18 -0
  125. package/esm2022/src/remote/AddUserRangeRemoteDataViewCommand.mjs +18 -0
  126. package/esm2022/src/remote/AddUserSortRemoteDataViewCommand.mjs +18 -0
  127. package/esm2022/src/remote/RemoteCommandsProcessor.mjs +883 -0
  128. package/esm2022/src/remote/RemoteControlItemsRefreshCommand.mjs +25 -0
  129. package/esm2022/src/remote/RemoteDataViewCommandBase.mjs +24 -0
  130. package/esm2022/src/remote/RemoteDataViewCommandFactory.mjs +61 -0
  131. package/{esm2020 → esm2022}/src/remote/RemoteDataViewCommandUpdateNonModifiable.mjs +15 -15
  132. package/{esm2020 → esm2022}/src/remote/RemoteDataviewManager.mjs +17 -17
  133. package/{esm2020 → esm2022}/src/remote/RemoteInitDataViewCommand.mjs +10 -10
  134. package/esm2022/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +17 -0
  135. package/{esm2020 → esm2022}/src/remote/ResetUserRangeRemoteDataviewCommand.mjs +12 -12
  136. package/esm2022/src/remote/ResetUserSortRemoteDataviewCommand.mjs +16 -0
  137. package/esm2022/src/remote/ServerError.mjs +40 -0
  138. package/esm2022/src/remote/SetTransactionStateRemoteDataViewCommand.mjs +20 -0
  139. package/esm2022/src/rt/Argument.mjs +265 -0
  140. package/esm2022/src/rt/ArgumentsList.mjs +103 -0
  141. package/esm2022/src/rt/Boundary.mjs +152 -0
  142. package/esm2022/src/rt/CompMainPrgTable.mjs +63 -0
  143. package/{esm2020 → esm2022}/src/rt/DataviewHeaderBase.mjs +98 -96
  144. package/{esm2020 → esm2022}/src/rt/DataviewHeaderFactory.mjs +6 -6
  145. package/esm2022/src/rt/DataviewHeaders.mjs +53 -0
  146. package/esm2022/src/rt/DataviewHeadersSaxHandler.mjs +38 -0
  147. package/esm2022/src/rt/ExecutionStack.mjs +94 -0
  148. package/{esm2020 → esm2022}/src/rt/ExecutionStackEntry.mjs +17 -17
  149. package/esm2022/src/rt/HandlersTable.mjs +96 -0
  150. package/{esm2020 → esm2022}/src/rt/IDataSourceViewDefinition.mjs +1 -1
  151. package/{esm2020 → esm2022}/src/rt/IDataviewHeader.mjs +1 -1
  152. package/{esm2020 → esm2022}/src/rt/IResultValue.mjs +1 -1
  153. package/esm2022/src/rt/LastFocusedManager.mjs +65 -0
  154. package/esm2022/src/rt/Operation.mjs +735 -0
  155. package/esm2022/src/rt/OperationTable.mjs +67 -0
  156. package/esm2022/src/rt/Recompute.mjs +355 -0
  157. package/esm2022/src/rt/RecomputeTable.mjs +63 -0
  158. package/esm2022/src/rt/RemoteDataviewHeader.mjs +108 -0
  159. package/esm2022/src/rt/ResultValue.mjs +10 -0
  160. package/esm2022/src/rt/TableCache.mjs +177 -0
  161. package/esm2022/src/rt/TableCacheManager.mjs +67 -0
  162. package/esm2022/src/rt/Transaction.mjs +53 -0
  163. package/esm2022/src/security/UserDetails.mjs +71 -0
  164. package/{esm2020 → esm2022}/src/tasks/IMGDataCollection.mjs +1 -1
  165. package/esm2022/src/tasks/MGData.mjs +552 -0
  166. package/esm2022/src/tasks/MGDataCollection.mjs +252 -0
  167. package/esm2022/src/tasks/RCTimer.mjs +63 -0
  168. package/esm2022/src/tasks/RemoteTaskService.mjs +45 -0
  169. package/esm2022/src/tasks/Task.mjs +2499 -0
  170. package/esm2022/src/tasks/TaskBase.mjs +83 -0
  171. package/esm2022/src/tasks/TaskServiceBase.mjs +25 -0
  172. package/esm2022/src/tasks/TasksTable.mjs +80 -0
  173. package/esm2022/src/tasks/sort/Sort.mjs +5 -0
  174. package/esm2022/src/tasks/sort/SortCollection.mjs +67 -0
  175. package/esm2022/src/util/ConstUtils.mjs +14 -0
  176. package/esm2022/src/util/FlowMonitorQueue.mjs +451 -0
  177. package/esm2022/src/util/HeapSort.mjs +70 -0
  178. package/{esm2020 → esm2022}/src/util/IMirrorXML.mjs +1 -1
  179. package/{esm2020 → esm2022}/src/util/IServerConfig.mjs +1 -1
  180. package/{esm2020 → esm2022}/src/util/MgBlockingQueue.mjs +1 -1
  181. package/esm2022/src/util/MgPriorityBlockingQueue.mjs +74 -0
  182. package/esm2022/src/util/MgPriorityQueue.mjs +66 -0
  183. package/{esm2020 → esm2022}/src/util/ParamParseResult.mjs +7 -7
  184. package/esm2022/src/util/PrmMap.mjs +152 -0
  185. package/esm2022/src/util/ReturnResult.mjs +46 -0
  186. package/esm2022/src/util/ReturnResultBase.mjs +18 -0
  187. package/esm2022/src/util/Scrambler.mjs +89 -0
  188. package/esm2022/src/util/UniqueIDUtils.mjs +13 -0
  189. package/esm2022/src/util/cookie.service.mjs +92 -0
  190. package/{fesm2020 → fesm2022}/magic-xpa-engine.mjs +29883 -29693
  191. package/fesm2022/magic-xpa-engine.mjs.map +1 -0
  192. package/index.d.ts +187 -187
  193. package/package.json +8 -14
  194. package/src/AccessHelper.d.ts +20 -20
  195. package/src/ClientManager.d.ts +35 -32
  196. package/src/CommandsProcessorBase.d.ts +23 -23
  197. package/src/CommandsProcessorManager.d.ts +6 -6
  198. package/src/CommandsTable.d.ts +22 -22
  199. package/src/ConstInterface.d.ts +516 -515
  200. package/src/CurrentClientVersion.d.ts +1 -1
  201. package/src/FlowMonitorInterface.d.ts +15 -15
  202. package/src/GUIManager.d.ts +17 -17
  203. package/src/GlobalCommandsManager.d.ts +17 -17
  204. package/src/GuiEventsProcessor.d.ts +24 -24
  205. package/src/ICommandsTable.d.ts +9 -9
  206. package/src/ServerConfig.d.ts +35 -34
  207. package/src/bridge/IGuiEvent.d.ts +19 -19
  208. package/src/bridge/MagicBridge.d.ts +16 -16
  209. package/src/commands/ClientOriginatedCommandTaskTag.d.ts +8 -8
  210. package/src/commands/ClientToServer/AddUserLocateDataViewCommand.d.ts +4 -4
  211. package/src/commands/ClientToServer/AddUserRangeDataviewCommand.d.ts +6 -6
  212. package/src/commands/ClientToServer/AddUserSortDataViewCommand.d.ts +6 -6
  213. package/src/commands/ClientToServer/BrowserEscEventCommand.d.ts +9 -8
  214. package/src/commands/ClientToServer/ClientOriginatedCommand.d.ts +8 -8
  215. package/src/commands/ClientToServer/ClientOriginatedCommandSerializer.d.ts +6 -6
  216. package/src/commands/ClientToServer/ColumnSortEventCommand.d.ts +11 -10
  217. package/src/commands/ClientToServer/CommandFactory.d.ts +64 -64
  218. package/src/commands/ClientToServer/CommandSerializationHelper.d.ts +20 -20
  219. package/src/commands/ClientToServer/ComputeEventCommand.d.ts +9 -8
  220. package/src/commands/ClientToServer/ContextTerminationEventCommand.d.ts +8 -7
  221. package/src/commands/ClientToServer/ContextTimeoutResetCommand.d.ts +8 -7
  222. package/src/commands/ClientToServer/ControlItemsRefreshCommand.d.ts +6 -6
  223. package/src/commands/ClientToServer/DataViewOutputCommand.d.ts +9 -9
  224. package/src/commands/ClientToServer/DataviewCommand.d.ts +32 -32
  225. package/src/commands/ClientToServer/EvaluateCommand.d.ts +16 -15
  226. package/src/commands/ClientToServer/EventCommand.d.ts +16 -15
  227. package/src/commands/ClientToServer/ExecOperCommand.d.ts +24 -23
  228. package/src/commands/ClientToServer/FetchDataControlValuesEventCommand.d.ts +9 -8
  229. package/src/commands/ClientToServer/GlobalParamsQueryCommand.d.ts +5 -5
  230. package/src/commands/ClientToServer/ICommandTaskTag.d.ts +3 -3
  231. package/src/commands/ClientToServer/IndexChangeEventCommand.d.ts +9 -8
  232. package/src/commands/ClientToServer/IniputForceWriteCommand.d.ts +11 -10
  233. package/src/commands/ClientToServer/NonReversibleExitEventCommand.d.ts +9 -8
  234. package/src/commands/ClientToServer/QueryCommand.d.ts +8 -8
  235. package/src/commands/ClientToServer/RecomputeCommand.d.ts +12 -11
  236. package/src/commands/ClientToServer/RefreshEventCommand.d.ts +13 -12
  237. package/src/commands/ClientToServer/RefreshScreenEventCommand.d.ts +11 -10
  238. package/src/commands/ClientToServer/RollbackEventCommand.d.ts +15 -14
  239. package/src/commands/ClientToServer/SelectProgramCommand.d.ts +7 -6
  240. package/src/commands/ClientToServer/SetTransactionStateDataviewCommand.d.ts +5 -5
  241. package/src/commands/ClientToServer/SubformOpenEventCommand.d.ts +9 -8
  242. package/src/commands/ClientToServer/SubformRefreshEventCommand.d.ts +10 -9
  243. package/src/commands/ClientToServer/TransactionCommand.d.ts +14 -12
  244. package/src/commands/ClientToServer/UnloadCommand.d.ts +8 -7
  245. package/src/commands/ClientToServer/WriteMessageToServerLogCommand.d.ts +6 -6
  246. package/src/commands/DataViewCommandBase.d.ts +6 -6
  247. package/src/commands/IClientCommand.d.ts +2 -2
  248. package/src/commands/IClientTargetedCommand.d.ts +12 -12
  249. package/src/commands/IClientToServerCommandInfo.d.ts +4 -3
  250. package/src/commands/ServerToClient/AbortCommand.d.ts +11 -11
  251. package/src/commands/ServerToClient/AddLocateCommand.d.ts +6 -6
  252. package/src/commands/ServerToClient/AddRangeCommand.d.ts +10 -10
  253. package/src/commands/ServerToClient/AddSortCommand.d.ts +9 -9
  254. package/src/commands/ServerToClient/ClientRefreshCommand.d.ts +7 -7
  255. package/src/commands/ServerToClient/ClientTargetedCommandBase.d.ts +12 -12
  256. package/src/commands/ServerToClient/EnhancedVerifyCommand.d.ts +13 -13
  257. package/src/commands/ServerToClient/OpenURLCommand.d.ts +21 -21
  258. package/src/commands/ServerToClient/ResetLocateCommand.d.ts +6 -6
  259. package/src/commands/ServerToClient/ResetRangeCommand.d.ts +6 -6
  260. package/src/commands/ServerToClient/ResetSortCommand.d.ts +6 -6
  261. package/src/commands/ServerToClient/ResultCommand.d.ts +10 -10
  262. package/src/commands/ServerToClient/VerifyCommand.d.ts +17 -17
  263. package/src/commands/ServerToClient/XMLBasedCommandBuilder.d.ts +11 -11
  264. package/src/communications/IConnectionStateManager.d.ts +4 -4
  265. package/src/communications/InteractiveCommunicationsFailureHandler.d.ts +6 -6
  266. package/src/data/DataSourceIdKey.d.ts +2 -2
  267. package/src/data/DataView.d.ts +162 -162
  268. package/src/data/DataViewBase.d.ts +12 -12
  269. package/src/data/DataviewManager.d.ts +14 -14
  270. package/src/data/DataviewManagerBase.d.ts +11 -11
  271. package/src/data/DvCache.d.ts +15 -15
  272. package/src/data/Field.d.ts +103 -103
  273. package/src/data/FieldBase.d.ts +23 -23
  274. package/src/data/FieldsTable.d.ts +27 -27
  275. package/src/data/IRecordsTable.d.ts +7 -7
  276. package/src/data/Key.d.ts +15 -15
  277. package/src/data/Record.d.ts +157 -156
  278. package/src/data/RecordOutOfDataViewException.d.ts +10 -10
  279. package/src/data/RecordsTable.d.ts +38 -38
  280. package/src/data/TaskTransactionManager.d.ts +17 -17
  281. package/src/data/XMLBasedDcValuesBuilder.d.ts +11 -11
  282. package/src/enums.d.ts +21 -21
  283. package/src/env/EnvVariablesTable.d.ts +17 -17
  284. package/src/env/Environment.d.ts +118 -118
  285. package/src/env/ILanguageData.d.ts +3 -3
  286. package/src/env/LanguageData.d.ts +20 -20
  287. package/src/env/MirrorString.d.ts +15 -15
  288. package/src/event/ActionManager.d.ts +14 -14
  289. package/src/event/Event.d.ts +79 -79
  290. package/src/event/EventHandler.d.ts +66 -66
  291. package/src/event/EventHandlerPosition.d.ts +25 -25
  292. package/src/event/EventsManager.d.ts +205 -204
  293. package/src/event/IEventsManager.d.ts +77 -77
  294. package/src/event/RunTimeEvent.d.ts +126 -123
  295. package/src/event/RunTimeEventBase.d.ts +5 -5
  296. package/src/event/UserEventsTable.d.ts +11 -11
  297. package/src/exp/ExpTable.d.ts +11 -11
  298. package/src/exp/Expression.d.ts +37 -37
  299. package/src/exp/ExpressionDict.d.ts +12 -12
  300. package/src/exp/ExpressionEvaluator.d.ts +198 -198
  301. package/src/exp/ExpressionLocalJpn.d.ts +18 -18
  302. package/src/exp/GlobalParamsTable.d.ts +19 -19
  303. package/src/exp/YesNoExp.d.ts +9 -9
  304. package/src/gui/CreatedFormVector.d.ts +10 -10
  305. package/src/gui/FormsTable.d.ts +15 -15
  306. package/src/gui/MgControl.d.ts +60 -60
  307. package/src/gui/MgForm.d.ts +96 -93
  308. package/src/http/HttpManager.d.ts +25 -25
  309. package/src/http/client/HttpClientAsync.d.ts +16 -16
  310. package/src/http/client/HttpClientBase.d.ts +30 -30
  311. package/src/http/client/HttpClientEvents.d.ts +18 -18
  312. package/src/http/client/HttpClientSync.d.ts +17 -17
  313. package/src/http/client/HttpUtility.d.ts +10 -10
  314. package/src/http/client/ICommunicationsFailureHandler.d.ts +5 -5
  315. package/src/remote/AddUserLocateRemoteDataViewCommand.d.ts +8 -8
  316. package/src/remote/AddUserRangeRemoteDataViewCommand.d.ts +8 -8
  317. package/src/remote/AddUserSortRemoteDataViewCommand.d.ts +8 -8
  318. package/src/remote/RemoteCommandsProcessor.d.ts +51 -51
  319. package/src/remote/RemoteControlItemsRefreshCommand.d.ts +8 -8
  320. package/src/remote/RemoteDataViewCommandBase.d.ts +10 -10
  321. package/src/remote/RemoteDataViewCommandFactory.d.ts +6 -6
  322. package/src/remote/RemoteDataViewCommandUpdateNonModifiable.d.ts +8 -8
  323. package/src/remote/RemoteDataviewManager.d.ts +9 -9
  324. package/src/remote/RemoteInitDataViewCommand.d.ts +7 -7
  325. package/src/remote/ResetUserLocateRemoteDataviewCommand.d.ts +7 -7
  326. package/src/remote/ResetUserRangeRemoteDataviewCommand.d.ts +7 -7
  327. package/src/remote/ResetUserSortRemoteDataviewCommand.d.ts +7 -7
  328. package/src/remote/ServerError.d.ts +16 -16
  329. package/src/remote/SetTransactionStateRemoteDataViewCommand.d.ts +8 -8
  330. package/src/rt/Argument.d.ts +36 -36
  331. package/src/rt/ArgumentsList.d.ts +24 -24
  332. package/src/rt/Boundary.d.ts +27 -27
  333. package/src/rt/CompMainPrgTable.d.ts +10 -10
  334. package/src/rt/DataviewHeaderBase.d.ts +34 -34
  335. package/src/rt/DataviewHeaderFactory.d.ts +5 -5
  336. package/src/rt/DataviewHeaders.d.ts +12 -12
  337. package/src/rt/DataviewHeadersSaxHandler.d.ts +10 -10
  338. package/src/rt/ExecutionStack.d.ts +22 -22
  339. package/src/rt/ExecutionStackEntry.d.ts +7 -7
  340. package/src/rt/HandlersTable.d.ts +19 -19
  341. package/src/rt/IDataSourceViewDefinition.d.ts +6 -6
  342. package/src/rt/IDataviewHeader.d.ts +10 -10
  343. package/src/rt/IResultValue.d.ts +4 -4
  344. package/src/rt/LastFocusedManager.d.ts +23 -23
  345. package/src/rt/Operation.d.ts +97 -97
  346. package/src/rt/OperationTable.d.ts +15 -15
  347. package/src/rt/Recompute.d.ts +41 -41
  348. package/src/rt/RecomputeTable.d.ts +9 -9
  349. package/src/rt/RemoteDataviewHeader.d.ts +14 -14
  350. package/src/rt/ResultValue.d.ts +7 -7
  351. package/src/rt/TableCache.d.ts +29 -29
  352. package/src/rt/TableCacheManager.d.ts +10 -10
  353. package/src/rt/Transaction.d.ts +23 -23
  354. package/src/security/UserDetails.d.ts +16 -16
  355. package/src/tasks/IMGDataCollection.d.ts +26 -26
  356. package/src/tasks/MGData.d.ts +63 -63
  357. package/src/tasks/MGDataCollection.d.ts +42 -42
  358. package/src/tasks/RCTimer.d.ts +13 -13
  359. package/src/tasks/RemoteTaskService.d.ts +16 -16
  360. package/src/tasks/Task.d.ts +312 -312
  361. package/src/tasks/TaskBase.d.ts +123 -123
  362. package/src/tasks/TaskServiceBase.d.ts +16 -16
  363. package/src/tasks/TasksTable.d.ts +21 -21
  364. package/src/tasks/sort/Sort.d.ts +4 -4
  365. package/src/tasks/sort/SortCollection.d.ts +11 -11
  366. package/src/util/ConstUtils.d.ts +3 -3
  367. package/src/util/FlowMonitorQueue.d.ts +70 -70
  368. package/src/util/HeapSort.d.ts +6 -6
  369. package/src/util/IMirrorXML.d.ts +6 -6
  370. package/src/util/IServerConfig.d.ts +11 -11
  371. package/src/util/MgBlockingQueue.d.ts +5 -5
  372. package/src/util/MgPriorityBlockingQueue.d.ts +17 -17
  373. package/src/util/MgPriorityQueue.d.ts +13 -13
  374. package/src/util/ParamParseResult.d.ts +6 -6
  375. package/src/util/PrmMap.d.ts +28 -28
  376. package/src/util/ReturnResult.d.ts +18 -18
  377. package/src/util/ReturnResultBase.d.ts +11 -11
  378. package/src/util/Scrambler.d.ts +10 -10
  379. package/src/util/UniqueIDUtils.d.ts +4 -4
  380. package/src/util/cookie.service.d.ts +8 -8
  381. package/esm2020/src/AccessHelper.mjs +0 -9
  382. package/esm2020/src/ClientManager.mjs +0 -399
  383. package/esm2020/src/CommandsProcessorBase.mjs +0 -58
  384. package/esm2020/src/CommandsProcessorManager.mjs +0 -26
  385. package/esm2020/src/CommandsTable.mjs +0 -162
  386. package/esm2020/src/ConstInterface.mjs +0 -516
  387. package/esm2020/src/FlowMonitorInterface.mjs +0 -16
  388. package/esm2020/src/GUIManager.mjs +0 -62
  389. package/esm2020/src/GlobalCommandsManager.mjs +0 -34
  390. package/esm2020/src/GuiEventsProcessor.mjs +0 -154
  391. package/esm2020/src/ServerConfig.mjs +0 -117
  392. package/esm2020/src/bridge/MagicBridge.mjs +0 -41
  393. package/esm2020/src/commands/ClientOriginatedCommandTaskTag.mjs +0 -11
  394. package/esm2020/src/commands/ClientToServer/BrowserEscEventCommand.mjs +0 -23
  395. package/esm2020/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs +0 -60
  396. package/esm2020/src/commands/ClientToServer/ColumnSortEventCommand.mjs +0 -26
  397. package/esm2020/src/commands/ClientToServer/CommandFactory.mjs +0 -260
  398. package/esm2020/src/commands/ClientToServer/CommandSerializationHelper.mjs +0 -69
  399. package/esm2020/src/commands/ClientToServer/ComputeEventCommand.mjs +0 -23
  400. package/esm2020/src/commands/ClientToServer/DataViewOutputCommand.mjs +0 -13
  401. package/esm2020/src/commands/ClientToServer/EvaluateCommand.mjs +0 -36
  402. package/esm2020/src/commands/ClientToServer/ExecOperCommand.mjs +0 -67
  403. package/esm2020/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +0 -22
  404. package/esm2020/src/commands/ClientToServer/IndexChangeEventCommand.mjs +0 -21
  405. package/esm2020/src/commands/ClientToServer/IniputForceWriteCommand.mjs +0 -23
  406. package/esm2020/src/commands/ClientToServer/RecomputeCommand.mjs +0 -27
  407. package/esm2020/src/commands/ClientToServer/RefreshEventCommand.mjs +0 -27
  408. package/esm2020/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +0 -24
  409. package/esm2020/src/commands/ClientToServer/RollbackEventCommand.mjs +0 -39
  410. package/esm2020/src/commands/ClientToServer/SelectProgramCommand.mjs +0 -15
  411. package/esm2020/src/commands/ClientToServer/SubformOpenEventCommand.mjs +0 -21
  412. package/esm2020/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +0 -24
  413. package/esm2020/src/commands/ClientToServer/TransactionCommand.mjs +0 -28
  414. package/esm2020/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +0 -18
  415. package/esm2020/src/commands/DataViewCommandBase.mjs +0 -10
  416. package/esm2020/src/commands/IClientTargetedCommand.mjs +0 -9
  417. package/esm2020/src/commands/ServerToClient/AbortCommand.mjs +0 -65
  418. package/esm2020/src/commands/ServerToClient/AddRangeCommand.mjs +0 -62
  419. package/esm2020/src/commands/ServerToClient/AddSortCommand.mjs +0 -33
  420. package/esm2020/src/commands/ServerToClient/ClientRefreshCommand.mjs +0 -25
  421. package/esm2020/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +0 -27
  422. package/esm2020/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +0 -45
  423. package/esm2020/src/commands/ServerToClient/OpenURLCommand.mjs +0 -221
  424. package/esm2020/src/commands/ServerToClient/ResultCommand.mjs +0 -37
  425. package/esm2020/src/commands/ServerToClient/VerifyCommand.mjs +0 -83
  426. package/esm2020/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs +0 -132
  427. package/esm2020/src/communications/InteractiveCommunicationsFailureHandler.mjs +0 -17
  428. package/esm2020/src/data/DataView.mjs +0 -1610
  429. package/esm2020/src/data/DataviewManager.mjs +0 -28
  430. package/esm2020/src/data/DataviewManagerBase.mjs +0 -15
  431. package/esm2020/src/data/DvCache.mjs +0 -67
  432. package/esm2020/src/data/Field.mjs +0 -646
  433. package/esm2020/src/data/FieldBase.mjs +0 -18
  434. package/esm2020/src/data/FieldsTable.mjs +0 -103
  435. package/esm2020/src/data/Key.mjs +0 -88
  436. package/esm2020/src/data/Record.mjs +0 -846
  437. package/esm2020/src/data/RecordsTable.mjs +0 -267
  438. package/esm2020/src/data/TaskTransactionManager.mjs +0 -103
  439. package/esm2020/src/data/XMLBasedDcValuesBuilder.mjs +0 -74
  440. package/esm2020/src/env/EnvVariablesTable.mjs +0 -340
  441. package/esm2020/src/env/Environment.mjs +0 -489
  442. package/esm2020/src/env/LanguageData.mjs +0 -226
  443. package/esm2020/src/env/MirrorString.mjs +0 -65
  444. package/esm2020/src/event/ActionManager.mjs +0 -91
  445. package/esm2020/src/event/Event.mjs +0 -1333
  446. package/esm2020/src/event/EventHandler.mjs +0 -766
  447. package/esm2020/src/event/EventHandlerPosition.mjs +0 -204
  448. package/esm2020/src/event/EventsManager.mjs +0 -2975
  449. package/esm2020/src/event/RunTimeEvent.mjs +0 -392
  450. package/esm2020/src/event/UserEventsTable.mjs +0 -47
  451. package/esm2020/src/exp/ExpTable.mjs +0 -59
  452. package/esm2020/src/exp/Expression.mjs +0 -200
  453. package/esm2020/src/exp/ExpressionDict.mjs +0 -727
  454. package/esm2020/src/exp/ExpressionEvaluator.mjs +0 -4212
  455. package/esm2020/src/exp/ExpressionLocalJpn.mjs +0 -314
  456. package/esm2020/src/exp/GlobalParamsTable.mjs +0 -85
  457. package/esm2020/src/exp/YesNoExp.mjs +0 -36
  458. package/esm2020/src/gui/CreatedFormVector.mjs +0 -23
  459. package/esm2020/src/gui/FormsTable.mjs +0 -66
  460. package/esm2020/src/gui/MgControl.mjs +0 -353
  461. package/esm2020/src/gui/MgForm.mjs +0 -1181
  462. package/esm2020/src/http/HttpManager.mjs +0 -97
  463. package/esm2020/src/http/client/HttpClientAsync.mjs +0 -67
  464. package/esm2020/src/http/client/HttpClientBase.mjs +0 -132
  465. package/esm2020/src/http/client/HttpClientEvents.mjs +0 -39
  466. package/esm2020/src/http/client/HttpClientSync.mjs +0 -42
  467. package/esm2020/src/http/client/HttpUtility.mjs +0 -84
  468. package/esm2020/src/remote/AddUserLocateRemoteDataViewCommand.mjs +0 -18
  469. package/esm2020/src/remote/AddUserRangeRemoteDataViewCommand.mjs +0 -18
  470. package/esm2020/src/remote/AddUserSortRemoteDataViewCommand.mjs +0 -18
  471. package/esm2020/src/remote/RemoteCommandsProcessor.mjs +0 -880
  472. package/esm2020/src/remote/RemoteControlItemsRefreshCommand.mjs +0 -25
  473. package/esm2020/src/remote/RemoteDataViewCommandBase.mjs +0 -24
  474. package/esm2020/src/remote/RemoteDataViewCommandFactory.mjs +0 -61
  475. package/esm2020/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +0 -17
  476. package/esm2020/src/remote/ResetUserSortRemoteDataviewCommand.mjs +0 -16
  477. package/esm2020/src/remote/ServerError.mjs +0 -40
  478. package/esm2020/src/remote/SetTransactionStateRemoteDataViewCommand.mjs +0 -20
  479. package/esm2020/src/rt/Argument.mjs +0 -265
  480. package/esm2020/src/rt/ArgumentsList.mjs +0 -103
  481. package/esm2020/src/rt/Boundary.mjs +0 -152
  482. package/esm2020/src/rt/CompMainPrgTable.mjs +0 -65
  483. package/esm2020/src/rt/DataviewHeaders.mjs +0 -53
  484. package/esm2020/src/rt/DataviewHeadersSaxHandler.mjs +0 -38
  485. package/esm2020/src/rt/ExecutionStack.mjs +0 -94
  486. package/esm2020/src/rt/HandlersTable.mjs +0 -96
  487. package/esm2020/src/rt/LastFocusedManager.mjs +0 -67
  488. package/esm2020/src/rt/Operation.mjs +0 -735
  489. package/esm2020/src/rt/OperationTable.mjs +0 -67
  490. package/esm2020/src/rt/Recompute.mjs +0 -355
  491. package/esm2020/src/rt/RecomputeTable.mjs +0 -63
  492. package/esm2020/src/rt/RemoteDataviewHeader.mjs +0 -108
  493. package/esm2020/src/rt/ResultValue.mjs +0 -12
  494. package/esm2020/src/rt/TableCache.mjs +0 -177
  495. package/esm2020/src/rt/TableCacheManager.mjs +0 -67
  496. package/esm2020/src/rt/Transaction.mjs +0 -53
  497. package/esm2020/src/security/UserDetails.mjs +0 -71
  498. package/esm2020/src/tasks/MGData.mjs +0 -552
  499. package/esm2020/src/tasks/MGDataCollection.mjs +0 -252
  500. package/esm2020/src/tasks/RCTimer.mjs +0 -63
  501. package/esm2020/src/tasks/RemoteTaskService.mjs +0 -45
  502. package/esm2020/src/tasks/Task.mjs +0 -2495
  503. package/esm2020/src/tasks/TaskBase.mjs +0 -87
  504. package/esm2020/src/tasks/TaskServiceBase.mjs +0 -25
  505. package/esm2020/src/tasks/TasksTable.mjs +0 -80
  506. package/esm2020/src/tasks/sort/Sort.mjs +0 -7
  507. package/esm2020/src/tasks/sort/SortCollection.mjs +0 -67
  508. package/esm2020/src/util/ConstUtils.mjs +0 -14
  509. package/esm2020/src/util/FlowMonitorQueue.mjs +0 -453
  510. package/esm2020/src/util/HeapSort.mjs +0 -70
  511. package/esm2020/src/util/MgPriorityBlockingQueue.mjs +0 -74
  512. package/esm2020/src/util/MgPriorityQueue.mjs +0 -66
  513. package/esm2020/src/util/PrmMap.mjs +0 -151
  514. package/esm2020/src/util/ReturnResult.mjs +0 -46
  515. package/esm2020/src/util/ReturnResultBase.mjs +0 -18
  516. package/esm2020/src/util/Scrambler.mjs +0 -89
  517. package/esm2020/src/util/UniqueIDUtils.mjs +0 -12
  518. package/esm2020/src/util/cookie.service.mjs +0 -92
  519. package/fesm2015/magic-xpa-engine.mjs +0 -30835
  520. package/fesm2015/magic-xpa-engine.mjs.map +0 -1
  521. package/fesm2020/magic-xpa-engine.mjs.map +0 -1
@@ -0,0 +1,97 @@
1
+ import { ApplicationException, Debug, NString } from "@magic-xpa/mscorelib";
2
+ import { Logger } from "@magic-xpa/utils";
3
+ import { ConstInterface } from "../ConstInterface";
4
+ import { HttpClientEvents } from "./client/HttpClientEvents";
5
+ import { HttpClientSync } from "./client/HttpClientSync";
6
+ import { HttpClientAsync } from "./client/HttpClientAsync";
7
+ export class HttpManager {
8
+ static _instance = null;
9
+ static DEFAULT_HTTP_COMMUNICATION_TIMEOUT = 5 * 1000;
10
+ static DEFAULT_OFFLINE_HTTP_COMMUNICATION_TIMEOUT = 2 * 1000;
11
+ _httpCommunicationTimeoutMS = HttpManager.DEFAULT_HTTP_COMMUNICATION_TIMEOUT;
12
+ _httpClientAsync = null;
13
+ getHttpClient() {
14
+ if (this.IsAbortingMagicEngine)
15
+ return new HttpClientSync();
16
+ return this._httpClientAsync;
17
+ }
18
+ set HttpCommunicationTimeoutMS(value) {
19
+ this._httpCommunicationTimeoutMS = value;
20
+ }
21
+ static _nativeHttpClient = null;
22
+ static setNativeHttpClient(httpClient) {
23
+ HttpManager._nativeHttpClient = httpClient;
24
+ }
25
+ static GetInstance() {
26
+ if (HttpManager._instance === null) {
27
+ HttpManager._instance = new HttpManager();
28
+ }
29
+ return HttpManager._instance;
30
+ }
31
+ _isAbortingMagicEngine = false;
32
+ get IsAbortingMagicEngine() { return this._isAbortingMagicEngine; }
33
+ set IsAbortingMagicEngine(isAbortingMagicEngine) { this._isAbortingMagicEngine = isAbortingMagicEngine; }
34
+ constructor() {
35
+ this._httpClientAsync = new HttpClientAsync(HttpManager._nativeHttpClient);
36
+ this.RegisterBasicDelegates();
37
+ }
38
+ RegisterBasicDelegates() {
39
+ HttpClientEvents.GetHttpCommunicationTimeout_Event = this.GetHttpCommunicationTimeoutMS.bind(this);
40
+ }
41
+ GetHttpCommunicationTimeoutMS() {
42
+ return this._httpCommunicationTimeoutMS;
43
+ }
44
+ SetCommunicationsFailureHandler(handler) {
45
+ this.getHttpClient().CommunicationsFailureHandler = handler;
46
+ }
47
+ async GetContent(requestedURL, requestContent, useCache, isError) {
48
+ let response;
49
+ Debug.Assert(this.getHttpClient() != null);
50
+ try {
51
+ Logger.Instance.WriteServerToLog("*************************************************************************************************");
52
+ isError.value = false;
53
+ Logger.Instance.WriteServerToLog(requestedURL);
54
+ HttpManager.LogAccessToServer("", requestContent);
55
+ response = await this.getHttpClient().GetContent(requestedURL, requestContent, useCache);
56
+ Debug.Assert(response !== null);
57
+ let errorResponse = HttpManager.CheckAndGetErrorResponse(response);
58
+ if (errorResponse !== null) {
59
+ response = errorResponse;
60
+ isError.value = true;
61
+ }
62
+ return response;
63
+ }
64
+ catch (ex) {
65
+ let url = new URL(requestedURL);
66
+ throw new ApplicationException(ex.Message + "\n" + url.origin + url.pathname, ex);
67
+ }
68
+ finally {
69
+ }
70
+ }
71
+ static CheckAndGetErrorResponse(httpResponse) {
72
+ let errorResponse = null;
73
+ if (httpResponse.startsWith(ConstInterface.V24_RIA_ERROR_PREFIX))
74
+ errorResponse = httpResponse.substr(ConstInterface.V24_RIA_ERROR_PREFIX.length);
75
+ return errorResponse;
76
+ }
77
+ static LogAccessToServer(msg, requestContent) {
78
+ if (Logger.Instance.ShouldLogServerRelatedMessages()) {
79
+ if (!NString.IsNullOrEmpty(msg)) {
80
+ msg = msg + "; accessing server ...";
81
+ }
82
+ if (requestContent === null) {
83
+ if (!NString.IsNullOrEmpty(msg)) {
84
+ Logger.Instance.WriteServerToLog(msg);
85
+ }
86
+ }
87
+ else {
88
+ if (!NString.IsNullOrEmpty(msg)) {
89
+ msg = msg + " ";
90
+ }
91
+ msg = msg + "uploading " + requestContent.length + " bytes";
92
+ Logger.Instance.WriteServerToLog(msg);
93
+ }
94
+ }
95
+ }
96
+ }
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"HttpManager.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/http/HttpManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {ApplicationException, Debug, NString, RefParam} from \"@magic-xpa/mscorelib\";\r\nimport {Logger} from \"@magic-xpa/utils\";\r\nimport {HttpClient} from \"@angular/common/http\";\r\nimport {ConstInterface} from \"../ConstInterface\";\r\nimport {HttpClientBase} from \"./client/HttpClientBase\";\r\nimport {HttpClientEvents} from \"./client/HttpClientEvents\";\r\nimport {ICommunicationsFailureHandler} from \"./client/ICommunicationsFailureHandler\";\r\nimport {HttpClientSync} from \"./client/HttpClientSync\";\r\nimport {HttpClientAsync} from \"./client/HttpClientAsync\";\r\n\r\nexport class HttpManager {\r\n  private static _instance: HttpManager = null;\r\n\r\n  static readonly DEFAULT_HTTP_COMMUNICATION_TIMEOUT: number = 5 * 1000;\r\n  static readonly DEFAULT_OFFLINE_HTTP_COMMUNICATION_TIMEOUT: number = 2 * 1000;\r\n\r\n  private _httpCommunicationTimeoutMS: number = HttpManager.DEFAULT_HTTP_COMMUNICATION_TIMEOUT;\r\n  private _httpClientAsync: HttpClientAsync = null;\r\n\r\n  private getHttpClient(): HttpClientBase\r\n  {\r\n    // Creating a new instance of sync HttpClient because it will be created only once during the last request\r\n    if(this.IsAbortingMagicEngine)\r\n      return new HttpClientSync();\r\n\r\n    return this._httpClientAsync;\r\n  }\r\n\r\n  set HttpCommunicationTimeoutMS(value: number) {\r\n    this._httpCommunicationTimeoutMS = value;\r\n  }\r\n\r\n  private static _nativeHttpClient: HttpClient = null;\r\n  static setNativeHttpClient(httpClient: HttpClient)\r\n  {\r\n    HttpManager._nativeHttpClient = httpClient;\r\n  }\r\n\r\n  static GetInstance(): HttpManager {\r\n    if (HttpManager._instance === null) {\r\n      HttpManager._instance = new HttpManager();\r\n    }\r\n\r\n    return HttpManager._instance;\r\n  }\r\n\r\n  private _isAbortingMagicEngine: boolean = false;\r\n  get IsAbortingMagicEngine() { return this._isAbortingMagicEngine; }\r\n  set IsAbortingMagicEngine(isAbortingMagicEngine: boolean) { this._isAbortingMagicEngine = isAbortingMagicEngine; }\r\n\r\n  private constructor() {\r\n    this._httpClientAsync = new HttpClientAsync(HttpManager._nativeHttpClient);\r\n    this.RegisterBasicDelegates();\r\n  }\r\n\r\n  private RegisterBasicDelegates(): void {\r\n    HttpClientEvents.GetHttpCommunicationTimeout_Event = this.GetHttpCommunicationTimeoutMS.bind(this);\r\n  }\r\n\r\n  GetHttpCommunicationTimeoutMS(): number {\r\n    return this._httpCommunicationTimeoutMS;\r\n  }\r\n\r\n  SetCommunicationsFailureHandler(handler: ICommunicationsFailureHandler): void {\r\n    this.getHttpClient().CommunicationsFailureHandler = handler;\r\n  }\r\n\r\n  async GetContent(requestedURL: string, requestContent: string, useCache: boolean, isError: RefParam<boolean>): Promise<string> {\r\n    let response: string;\r\n    Debug.Assert(this.getHttpClient() != null);\r\n    // let startTime: number = Misc.getSystemMilliseconds();\r\n\r\n    try {\r\n      Logger.Instance.WriteServerToLog(\"*************************************************************************************************\");\r\n\r\n      isError.value = false;\r\n\r\n      Logger.Instance.WriteServerToLog(requestedURL);\r\n\r\n      HttpManager.LogAccessToServer(\"\", requestContent);\r\n      response = await this.getHttpClient().GetContent(requestedURL, requestContent, useCache);\r\n      Debug.Assert(response !== null);\r\n      let errorResponse: string = HttpManager.CheckAndGetErrorResponse(response);\r\n\r\n      if (errorResponse !== null) {\r\n        response = errorResponse;\r\n        isError.value = true;\r\n      }\r\n\r\n        return response;\r\n    }\r\n    catch (ex) {\r\n      // TODO: relative requestedURL doesn't work here.\r\n      let url: URL = new URL(requestedURL);\r\n      throw new ApplicationException(ex.Message + \"\\n\" + url.origin + url.pathname, ex);\r\n    }\r\n    finally {\r\n      // TODO: Implement in WebClient.\r\n      // How do we know if the contents were returned form browser cache?\r\n      // let elapsedTime: number = Misc.getSystemMilliseconds() - startTime;\r\n\r\n      // Logger.Instance.WriteServerToLog(\r\n      //               string.Format(\r\n      //                  \"Completed {0}: {1:N0} ms, accumulated: {2:N0} ms (server: {3:N0}), {4}{5}{6}**************************************************************************************************\",\r\n      //                  (cachingStrategy.FoundInCache\r\n      //                      ? \"\"\r\n      //                      : NString.Format(\"#{0:N0}\", Statistics.GetRequestsCnt())\r\n      //                  ),\r\n      //                  elapsedTime,\r\n      //                  Statistics.GetAccumulatedExternalTime(), Statistics.GetAccumulatedServerTime(),\r\n      //                  (cachingStrategy.FoundInCache\r\n      //                      ? \"\"\r\n      //                      : (response != null\r\n      //                            ? NString.Format(\"{0:N0} bytes downloaded\", response.length)\r\n      //                            : \"Null response!\")\r\n      //                  ),\r\n      //                  OSEnvironment.EolSeq, OSEnvironment.TabSeq)\r\n      //               );\r\n    }\r\n  }\r\n\r\n  /// <summary>Check if an HTTP response is an error response.\r\n  /// <param name=\"httpResponse\">response returned to an HTTP request.</param>\r\n  /// <returns>if the response contains the error indicator - the error indicator is truncated and the remaining is returned.\r\n  /// otherwise - null (indicating that the 'http Response' didn't contain an error).</returns>\r\n  private static CheckAndGetErrorResponse(httpResponse: string): string {\r\n    let errorResponse: string = null;\r\n\r\n    if (httpResponse.startsWith(ConstInterface.V24_RIA_ERROR_PREFIX))\r\n      errorResponse = httpResponse.substr(ConstInterface.V24_RIA_ERROR_PREFIX.length);\r\n\r\n    return errorResponse;\r\n  }\r\n\r\n  private static LogAccessToServer(msg: string, requestContent: string): void {\r\n    if (Logger.Instance.ShouldLogServerRelatedMessages()) {\r\n      if (!NString.IsNullOrEmpty(msg)) {\r\n        msg = msg + \"; accessing server ...\";\r\n      }\r\n\r\n      if (requestContent === null) {\r\n        if (!NString.IsNullOrEmpty(msg)) {\r\n          Logger.Instance.WriteServerToLog(msg);\r\n        }\r\n      }\r\n      else {\r\n        if (!NString.IsNullOrEmpty(msg)) {\r\n          msg = msg + \" \";\r\n        }\r\n\r\n        msg = msg + \"uploading \" + requestContent.length + \" bytes\";\r\n        Logger.Instance.WriteServerToLog(msg);\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,68 @@
1
+ import { HttpErrorResponse } from "@angular/common/http";
2
+ import { NString, Thread, WebException } from "@magic-xpa/mscorelib";
3
+ import { HttpClientBase, RequestMethod } from "./HttpClientBase";
4
+ import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
5
+ import { HttpClientEvents } from "./HttpClientEvents";
6
+ export class HttpClientAsync extends HttpClientBase {
7
+ httpClient;
8
+ constructor(httpClient) {
9
+ super();
10
+ this.httpClient = httpClient;
11
+ }
12
+ prepareRequest() {
13
+ }
14
+ addHeaders(urlString, useCache, httpHeaders, clientID) {
15
+ if (!urlString.startsWith("/"))
16
+ httpHeaders = httpHeaders.append("MgxpaRIAglobalUniqueSessionID", clientID);
17
+ if (!useCache)
18
+ httpHeaders = httpHeaders.append("Cache-Control", 'no-cache');
19
+ return httpHeaders;
20
+ }
21
+ async sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer) {
22
+ let httpResponse = await this.httpClient.request(RequestMethod[httpMethod], urlString, { headers: httpHeaders, responseType: "text", observe: "response", body: requestContent }).toPromise();
23
+ contentFromServer.value = httpResponse.body;
24
+ return httpResponse;
25
+ }
26
+ logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest) {
27
+ let statusCode = httpResponse['status'];
28
+ let responseTime = Misc.getSystemMilliseconds() - timeBeforeRequest;
29
+ if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)
30
+ Logger.Instance.WriteBasicToLog(Logger_MessageDirection.MessageEntering, HttpClientEvents.GetRuntimeCtxID(), HttpClientEvents.GetSessionCounter(), clientID, HttpClientEvents.ShouldDisplayGenericError() ? "-" : new URL(urlString).host, responseTime, statusCode.toString(), JSON.stringify(httpResponse.headers), contentFromServer.value.length);
31
+ }
32
+ handleHttpErrorException(ex, urlString) {
33
+ if (ex instanceof HttpErrorResponse) {
34
+ let statusCode = ex['status'];
35
+ if (statusCode === 404 || statusCode === 403)
36
+ throw new WebException(new Error("bad URL: " + urlString + " - StatusCode = " + statusCode));
37
+ }
38
+ }
39
+ async shouldRetry(httpCommunicationTimeoutMS, urlString, communicationsFailureHandler, ex, startTimeRef) {
40
+ let currentDelayMS = Math.floor(httpCommunicationTimeoutMS / 10);
41
+ let httpElapsedTimeMS = Misc.getSystemMilliseconds() - startTimeRef.value + currentDelayMS;
42
+ if (httpElapsedTimeMS <= httpCommunicationTimeoutMS) {
43
+ await Thread.Sleep(currentDelayMS);
44
+ Logger.Instance.WriteWarningToLogWithMsg(NString.Format("Retrying {0} : elapsed time {1:N0}ms out of {2:N0}ms", urlString, httpElapsedTimeMS, httpCommunicationTimeoutMS));
45
+ return true;
46
+ }
47
+ Logger.Instance.WriteWarningToLogWithMsg(NString.Format("{0} : http timeout {1:N0}ms expired", urlString, httpCommunicationTimeoutMS));
48
+ if (communicationsFailureHandler != null) {
49
+ communicationsFailureHandler.CommunicationFailed(urlString, ex);
50
+ if (communicationsFailureHandler.ShouldRetryLastRequest) {
51
+ Logger.Instance.WriteServerToLog(NString.Format("Retrying {0}, confirmed by user ...", urlString));
52
+ startTimeRef.value = Misc.getSystemMilliseconds();
53
+ return true;
54
+ }
55
+ }
56
+ return false;
57
+ }
58
+ logAndThrowException(ex) {
59
+ Logger.Instance.WriteWarningToLogWithMsg("Re-throwing ...");
60
+ Logger.Instance.WriteWarningToLog(ex);
61
+ throw new WebException(ex);
62
+ }
63
+ logExecutionAttempts(executionAttempts) {
64
+ if (executionAttempts > 1)
65
+ Logger.Instance.WriteServerToLog(NString.Format("Succeeded after {0} attempts ...", executionAttempts));
66
+ }
67
+ }
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"HttpClientAsync.js","sourceRoot":"","sources":["../../../../../../../projects/engine/src/http/client/HttpClientAsync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,iBAAiB,EAA4B,MAAM,sBAAsB,CAAC;AAC9F,OAAO,EAAC,OAAO,EAAY,MAAM,EAAE,YAAY,EAAC,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAC,cAAc,EAAE,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAC,MAAM,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAC;AACzF,OAAO,EAAC,gBAAgB,EAAC,MAAM,oBAAoB,CAAC;AAIpD,MAAM,OAAO,eAAgB,SAAQ,cAAc;IAC7B;IAApB,YAAoB,UAAsB;QACxC,KAAK,EAAE,CAAC;QADU,eAAU,GAAV,UAAU,CAAY;IAE1C,CAAC;IAED,cAAc;IAGd,CAAC;IAED,UAAU,CAAC,SAAiB,EAAE,QAAiB,EAAE,WAAwB,EAAE,QAAgB;QAEzF,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC;YAC5B,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,+BAA+B,EAAE,QAAQ,CAAC,CAAC;QAE9E,IAAI,CAAC,QAAQ;YACX,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QAEhE,OAAO,WAAW,CAAC;IACrB,CAAC;IAED,KAAK,CAAC,mBAAmB,CAAC,UAAyB,EAAE,SAAiB,EAAE,WAAwB,EAAE,cAAsB,EAAE,iBAAmC;QAC3J,IAAI,YAAY,GAAyB,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,SAAS,EACzG,EAAC,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,cAAc,EAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QAEvG,iBAAiB,CAAC,KAAK,GAAG,YAAY,CAAC,IAAW,CAAC;QAEnD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,YAAkC,EAAE,QAAgB,EAAE,SAAiB,EAAE,iBAAgC,EAAE,iBAAyB;QAE9I,IAAI,UAAU,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;QAExC,IAAI,YAAY,GAAW,IAAI,CAAC,qBAAqB,EAAE,GAAG,iBAAiB,CAAC;QAC5E,IAAI,MAAM,CAAC,QAAQ,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK;YACrD,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,uBAAuB,CAAC,eAAe,EACvC,gBAAgB,CAAC,eAAe,EAAE,EAClC,gBAAgB,CAAC,iBAAiB,EAAE,EACpC,QAAQ,EACR,gBAAgB,CAAC,yBAAyB,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC,IAAI,EAC5E,YAAY,EACZ,UAAU,CAAC,QAAQ,EAAE,EACrB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,CAAC,EACpC,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACpE,CAAC;IAED,wBAAwB,CAAC,EAAO,EAAE,SAAiB;QACjD,IAAI,EAAE,YAAY,iBAAiB,EACnC,CAAC;YACC,IAAI,UAAU,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC9B,IAAI,UAAU,KAAK,GAAG,IAAI,UAAU,KAAK,GAAG;gBAC1C,MAAM,IAAI,YAAY,CAAC,IAAI,KAAK,CAAC,WAAW,GAAG,SAAS,GAAG,kBAAkB,GAAG,UAAU,CAAC,CAAC,CAAC;QACjG,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,0BAAkC,EAAE,SAAiB,EAAE,4BAA2D,EAAE,EAAO,EAAE,YAA8B;QAG3K,IAAI,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,0BAA0B,GAAG,EAAE,CAAC,CAAC;QACjE,IAAI,iBAAiB,GAAW,IAAI,CAAC,qBAAqB,EAAE,GAAG,YAAY,CAAC,KAAK,GAAG,cAAc,CAAC;QAEnG,IAAI,iBAAiB,IAAI,0BAA0B,EACnD,CAAC;YACC,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACnC,MAAM,CAAC,QAAQ,CAAC,wBAAwB,CAAC,OAAO,CAAC,MAAM,CAAC,sDAAsD,EAC5G,SAAS,EAAE,iBAAiB,EAAE,0BAA0B,CAAC,CAAC,CAAC;YAC7D,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,CAAC,QAAQ,CAAC,wBAAwB,CAAC,OAAO,CAAC,MAAM,CAAC,qCAAqC,EAAE,SAAS,EAAE,0BAA0B,CAAC,CAAC,CAAC;QACvI,IAAI,4BAA4B,IAAI,IAAI,EACxC,CAAC;YACC,4BAA4B,CAAC,mBAAmB,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAChE,IAAI,4BAA4B,CAAC,sBAAsB,EACvD,CAAC;gBACC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAC,OAAO,CAAC,MAAM,CAAC,qCAAqC,EAAE,SAAS,CAAC,CAAC,CAAC;gBACnG,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAClD,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,oBAAoB,CAAC,EAAE;QAErB,MAAM,CAAC,QAAQ,CAAC,wBAAwB,CAAC,iBAAiB,CAAC,CAAC;QAC5D,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QACtC,MAAM,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,oBAAoB,CAAC,iBAAyB;QAE5C,IAAI,iBAAiB,GAAG,CAAC;YACvB,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAC,OAAO,CAAC,MAAM,CAAC,kCAAkC,EAAE,iBAAiB,CAAC,CAAC,CAAC;IAC5G,CAAC;CACF","sourcesContent":["import {HttpClient, HttpErrorResponse, HttpHeaders, HttpResponse} from \"@angular/common/http\";\r\nimport {NString, RefParam, Thread, WebException} from \"@magic-xpa/mscorelib\";\r\nimport {HttpClientBase, RequestMethod} from \"./HttpClientBase\";\r\nimport {Logger, Logger_LogLevels, Logger_MessageDirection, Misc} from \"@magic-xpa/utils\";\r\nimport {HttpClientEvents} from \"./HttpClientEvents\";\r\nimport {ICommunicationsFailureHandler} from \"./ICommunicationsFailureHandler\";\r\n\r\n// A class using Http Async Library\r\nexport class HttpClientAsync extends HttpClientBase {\r\n  constructor(private httpClient: HttpClient) {\r\n    super();\r\n  }\r\n\r\n  prepareRequest()\r\n  {\r\n    // No implementation needed\r\n  }\r\n\r\n  addHeaders(urlString: string, useCache: boolean, httpHeaders: HttpHeaders, clientID: string): HttpHeaders\r\n  {\r\n    if (!urlString.startsWith(\"/\"))\r\n      httpHeaders = httpHeaders.append(\"MgxpaRIAglobalUniqueSessionID\", clientID);\r\n\r\n    if (!useCache)\r\n      httpHeaders = httpHeaders.append(\"Cache-Control\", 'no-cache');\r\n\r\n    return httpHeaders;\r\n  }\r\n\r\n  async sendRequestToServer(httpMethod: RequestMethod, urlString: string, httpHeaders: HttpHeaders, requestContent: string, contentFromServer: RefParam<string>): Promise<any> {\r\n    let httpResponse: HttpResponse<string> = await this.httpClient.request(RequestMethod[httpMethod], urlString,\r\n      {headers: httpHeaders, responseType: \"text\", observe: \"response\", body: requestContent}).toPromise();\r\n\r\n    contentFromServer.value = httpResponse.body as any;\r\n\r\n    return httpResponse;\r\n  }\r\n\r\n  logResponse(httpResponse: HttpResponse<string>, clientID: string, urlString: string, contentFromServer: RefParam<any>, timeBeforeRequest: number)\r\n  {\r\n    let statusCode = httpResponse['status'];\r\n\r\n    let responseTime: number = Misc.getSystemMilliseconds() - timeBeforeRequest;\r\n    if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)\r\n      Logger.Instance.WriteBasicToLog(Logger_MessageDirection.MessageEntering,\r\n                                      HttpClientEvents.GetRuntimeCtxID(),\r\n                                      HttpClientEvents.GetSessionCounter(),\r\n                                      clientID,\r\n                                      HttpClientEvents.ShouldDisplayGenericError() ? \"-\" : new URL(urlString).host,\r\n                                      responseTime,\r\n                                      statusCode.toString(),\r\n                                      JSON.stringify(httpResponse.headers),\r\n                                      contentFromServer.value.length);\r\n  }\r\n\r\n  handleHttpErrorException(ex: any, urlString: string) {\r\n    if (ex instanceof HttpErrorResponse)\r\n    {\r\n      let statusCode = ex['status'];\r\n      if (statusCode === 404 || statusCode === 403)\r\n        throw new WebException(new Error(\"bad URL: \" + urlString + \" - StatusCode = \" + statusCode));\r\n    }\r\n  }\r\n\r\n  async shouldRetry(httpCommunicationTimeoutMS: number, urlString: string, communicationsFailureHandler: ICommunicationsFailureHandler, ex: any, startTimeRef: RefParam<number>): Promise<boolean>\r\n  {\r\n    // delay the total http timeout / 10.\r\n    let currentDelayMS = Math.floor(httpCommunicationTimeoutMS / 10); // ms\r\n    let httpElapsedTimeMS: number = Misc.getSystemMilliseconds() - startTimeRef.value + currentDelayMS;\r\n\r\n    if (httpElapsedTimeMS <= httpCommunicationTimeoutMS)\r\n    {\r\n      await Thread.Sleep(currentDelayMS);\r\n      Logger.Instance.WriteWarningToLogWithMsg(NString.Format(\"Retrying {0} : elapsed time {1:N0}ms out of {2:N0}ms\",\r\n        urlString, httpElapsedTimeMS, httpCommunicationTimeoutMS));\r\n      return true;\r\n    }\r\n\r\n    Logger.Instance.WriteWarningToLogWithMsg(NString.Format(\"{0} : http timeout {1:N0}ms expired\", urlString, httpCommunicationTimeoutMS));\r\n    if (communicationsFailureHandler != null)\r\n    {\r\n      communicationsFailureHandler.CommunicationFailed(urlString, ex);\r\n      if (communicationsFailureHandler.ShouldRetryLastRequest)\r\n      {\r\n        Logger.Instance.WriteServerToLog(NString.Format(\"Retrying {0}, confirmed by user ...\", urlString));\r\n        startTimeRef.value = Misc.getSystemMilliseconds();\r\n        return true;\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  logAndThrowException(ex)\r\n  {\r\n    Logger.Instance.WriteWarningToLogWithMsg(\"Re-throwing ...\");\r\n    Logger.Instance.WriteWarningToLog(ex);\r\n    throw new WebException(ex);\r\n  }\r\n\r\n  logExecutionAttempts(executionAttempts: number)\r\n  {\r\n    if (executionAttempts > 1)\r\n      Logger.Instance.WriteServerToLog(NString.Format(\"Succeeded after {0} attempts ...\", executionAttempts));\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,132 @@
1
+ import { NString, RefParam, StringBuilder, isNullOrUndefined } from "@magic-xpa/mscorelib";
2
+ import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
3
+ import { HttpClientEvents } from "./HttpClientEvents";
4
+ import { HttpHeaders } from "@angular/common/http";
5
+ export var RequestMethod;
6
+ (function (RequestMethod) {
7
+ RequestMethod[RequestMethod["Get"] = 0] = "Get";
8
+ RequestMethod[RequestMethod["Post"] = 1] = "Post";
9
+ RequestMethod[RequestMethod["Put"] = 2] = "Put";
10
+ RequestMethod[RequestMethod["Delete"] = 3] = "Delete";
11
+ RequestMethod[RequestMethod["Options"] = 4] = "Options";
12
+ RequestMethod[RequestMethod["Head"] = 5] = "Head";
13
+ RequestMethod[RequestMethod["Patch"] = 6] = "Patch";
14
+ })(RequestMethod || (RequestMethod = {}));
15
+ export class HttpClientBase {
16
+ _HTTPMaxURLLength = 2048;
17
+ CommunicationsFailureHandler = null;
18
+ constructor() {
19
+ this.CommunicationsFailureHandler = null;
20
+ }
21
+ DecideOnRequestMethod(requestContent, requestURL) {
22
+ let method = RequestMethod.Get;
23
+ if (requestContent === null) {
24
+ method = RequestMethod.Get;
25
+ }
26
+ else {
27
+ if (requestURL.value.length + 1 + requestContent.length <= this._HTTPMaxURLLength) {
28
+ requestURL.value = requestURL.value + "?" + requestContent;
29
+ method = RequestMethod.Get;
30
+ }
31
+ else {
32
+ method = RequestMethod.Post;
33
+ }
34
+ }
35
+ return method;
36
+ }
37
+ async GetContent(requestURL, requestContent, useCache) {
38
+ let contentFromServer = new RefParam(null);
39
+ let requestUrlRef = new RefParam(requestURL);
40
+ let httpMethod = this.DecideOnRequestMethod(requestContent, requestUrlRef);
41
+ requestURL = requestUrlRef.value;
42
+ try {
43
+ let response = await this.ExecuteHttpRequest(requestURL, requestContent, useCache, httpMethod, contentFromServer);
44
+ if (response != null) {
45
+ Logger.Instance.WriteServerToLog("Incoming Headers : " + HttpClientBase.HeadersToString(response.headers, true));
46
+ let nextSessionCounterString = response.headers.get("MgxpaNextSessionCounter".toLowerCase());
47
+ if (!isNullOrUndefined(nextSessionCounterString)) {
48
+ HttpClientEvents.CheckAndSetSessionCounter(+nextSessionCounterString);
49
+ }
50
+ }
51
+ }
52
+ catch (ex) {
53
+ Logger.Instance.WriteWarningToLog(ex);
54
+ throw ex;
55
+ }
56
+ return contentFromServer.value;
57
+ }
58
+ async ExecuteHttpRequest(urlString, requestContent, useCache, httpMethod, contentFromServer) {
59
+ let httpResponse = null;
60
+ this.prepareRequest();
61
+ let httpCommunicationTimeoutMS = HttpClientEvents.GetHttpCommunicationTimeout();
62
+ let clientID = HttpClientEvents.GetGlobalUniqueSessionID();
63
+ let executionAttempts = 0;
64
+ let startTime = Misc.getSystemMilliseconds();
65
+ while (true) {
66
+ executionAttempts++;
67
+ try {
68
+ let httpHeaders = new HttpHeaders();
69
+ httpHeaders = this.addHeaders(urlString, useCache, httpHeaders, clientID);
70
+ Logger.Instance.WriteServerToLog(NString.Format("Request Timeout set to {0} ms", httpCommunicationTimeoutMS));
71
+ if (Logger.Instance.LogLevel === Logger_LogLevels.Basic) {
72
+ let contentLength = 0;
73
+ if (httpMethod === RequestMethod.Get) {
74
+ let parts = urlString.split('?');
75
+ if (parts.length === 2)
76
+ contentLength = parts[1].length;
77
+ }
78
+ else
79
+ contentLength = requestContent.length;
80
+ Logger.Instance.WriteBasicToLog(Logger_MessageDirection.MessageLeaving, HttpClientEvents.GetRuntimeCtxID(), HttpClientEvents.GetSessionCounter(), clientID, HttpClientEvents.ShouldDisplayGenericError() ? "-" : new URL(urlString).host, 0, '-', JSON.stringify(httpHeaders), contentLength);
81
+ }
82
+ let timeBeforeRequest = Misc.getSystemMilliseconds();
83
+ Logger.Instance.WriteServerToLog(NString.Format("Accessing (method: '{0}'): '{1}'", httpMethod, urlString));
84
+ Logger.Instance.WriteServerToLog("Outgoing Headers : " + HttpClientBase.HeadersToString(httpHeaders, false));
85
+ if (httpMethod === RequestMethod.Post) {
86
+ }
87
+ let requestTime = Misc.getSystemMilliseconds();
88
+ this.LogRequestInfo(!isNullOrUndefined(requestContent) ? requestContent.length : 0, requestTime, false);
89
+ httpResponse = await this.sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer);
90
+ this.logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest);
91
+ this.LogRequestInfo(!isNullOrUndefined(requestContent) ? requestContent.length : 0, Misc.getSystemMilliseconds() - requestTime, true);
92
+ break;
93
+ }
94
+ catch (ex) {
95
+ if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)
96
+ Logger.Instance.WriteBasicErrorToLog();
97
+ else
98
+ Logger.Instance.WriteWarningToLog(ex);
99
+ this.handleHttpErrorException(ex, urlString);
100
+ let startTimeRef = new RefParam(startTime);
101
+ if (this.shouldRetry(httpCommunicationTimeoutMS, urlString, this.CommunicationsFailureHandler, ex, startTimeRef)) {
102
+ startTime = startTimeRef.value;
103
+ continue;
104
+ }
105
+ this.logAndThrowException(ex);
106
+ }
107
+ }
108
+ this.logExecutionAttempts(executionAttempts);
109
+ return httpResponse;
110
+ }
111
+ LogRequestInfo(contentLength, roundTrip, isLoggingResponse) {
112
+ if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo) {
113
+ HttpClientEvents.ComputeAndLogRequestInfo(contentLength, roundTrip, isLoggingResponse);
114
+ }
115
+ }
116
+ static HeadersToString(headers, bFilter) {
117
+ let headersStr = new StringBuilder();
118
+ let headerKeys = headers.keys();
119
+ for (let key in headerKeys) {
120
+ if (!bFilter || headerKeys[key].startsWith("Mg"))
121
+ headersStr.Append(NString.Format("{0}:{1} ", headerKeys[key], headers.get(headerKeys[key])));
122
+ }
123
+ return headersStr;
124
+ }
125
+ async sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer) {
126
+ return Promise.resolve();
127
+ }
128
+ async shouldRetry(httpCommunicationTimeoutMS, urlString, communicationsFailureHandler, ex, startTimeRef) {
129
+ return Promise.resolve(false);
130
+ }
131
+ }
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"HttpClientBase.js","sourceRoot":"","sources":["../../../../../../../projects/engine/src/http/client/HttpClientBase.ts"],"names":[],"mappings":"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","sourcesContent":["import {NString, RefParam, StringBuilder, isNullOrUndefined} from \"@magic-xpa/mscorelib\";\r\nimport {Logger, Logger_LogLevels, Logger_MessageDirection, Misc} from \"@magic-xpa/utils\";\r\nimport {ICommunicationsFailureHandler} from \"./ICommunicationsFailureHandler\";\r\nimport {HttpClientEvents} from \"./HttpClientEvents\";\r\nimport {HttpHeaders, HttpResponse} from \"@angular/common/http\";\r\n\r\n\r\nexport enum RequestMethod\r\n{\r\n  Get = 0,\r\n  Post = 1,\r\n  Put = 2,\r\n  Delete = 3,\r\n  Options = 4,\r\n  Head = 5,\r\n  Patch = 6\r\n}\r\n\r\n/// <summary>\r\n/// this class is responsible for:\r\n///    (i) deciding which method to use (GET/POST).\r\n///   (ii) handling communication failures.\r\n///  (iii) adding HTTP headers to requests.\r\n///  (iV) retrieving HTTP headers from responses.\r\n/// </summary>\r\n\r\nexport abstract class HttpClientBase {\r\n  private _HTTPMaxURLLength: number = 2048;\r\n\r\n  /// <summary>\r\n  /// Gets or sets a handler for communications failure. This property may be\r\n  /// set to null, in which case the HttpClientBase will automatically fail after\r\n  /// the first reconnection attempt.\r\n  /// </summary>\r\n  CommunicationsFailureHandler: ICommunicationsFailureHandler = null;\r\n\r\n  constructor() {\r\n    this.CommunicationsFailureHandler = null;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Returns the request method (POST or GET) based on its contents and length.\r\n  /// </summary>\r\n  /// <param name=\"requestURL\"></param>\r\n  /// <returns></returns>\r\n  private DecideOnRequestMethod(requestContent: string, requestURL: RefParam<string>): RequestMethod {\r\n    let method: RequestMethod = RequestMethod.Get;\r\n\r\n    if (requestContent === null) {\r\n      // requestContent (== content to be sent to server) is allowed only in POST requests. In case no content is required, opt for GET (for the aforementioned performance reason).\r\n      method = RequestMethod.Get;\r\n    }\r\n    else {\r\n      if (requestURL.value.length + 1 + requestContent.length <= this._HTTPMaxURLLength) {\r\n        // append the request content to the URL, and switch to using a GET request.\r\n        requestURL.value = requestURL.value + \"?\" + requestContent;\r\n        method = RequestMethod.Get;\r\n      }\r\n      else {\r\n        method = RequestMethod.Post;\r\n      }\r\n    }\r\n\r\n    return method;\r\n  }\r\n\r\n  /// <summary>Gets contents of a URL, using either GET or POST methods.\r\n  /// The method executes the HTTP request, reads the response and return the content.\r\n  /// </summary>\r\n  /// <param name=\"requestURL\">URL to be accessed.</param>\r\n  /// <param name=\"requestContent\">content to be sent to server (relevant only for POST method - is null for other methods).</param>\r\n  /// <returns>response (from the server).</returns>\r\n  async GetContent(requestURL: string, requestContent: any, useCache: boolean): Promise<string> {\r\n    let contentFromServer: RefParam<string> = new RefParam(null);\r\n    let requestUrlRef: RefParam<string> = new RefParam(requestURL);\r\n\r\n    let httpMethod: RequestMethod = this.DecideOnRequestMethod(requestContent, requestUrlRef);\r\n    requestURL = requestUrlRef.value;\r\n\r\n    try {\r\n      // Execute the http request\r\n      let response: HttpResponse<string> = await this.ExecuteHttpRequest(requestURL, requestContent, useCache, httpMethod, contentFromServer);\r\n\r\n      if(response != null) {\r\n        Logger.Instance.WriteServerToLog(\"Incoming Headers : \" + HttpClientBase.HeadersToString(response.headers, true));\r\n\r\n        // set the next session counter (which will be expected by the server in the next request).\r\n        let nextSessionCounterString: string = response.headers.get(\"MgxpaNextSessionCounter\".toLowerCase());\r\n        if (!isNullOrUndefined(nextSessionCounterString)) {\r\n          HttpClientEvents.CheckAndSetSessionCounter(+nextSessionCounterString);\r\n        }\r\n      }\r\n    }\r\n    catch (ex) {\r\n      Logger.Instance.WriteWarningToLog(ex);\r\n      throw ex;\r\n    }\r\n\r\n    return contentFromServer.value;\r\n  }\r\n\r\n  /// <summary>This function executes the HTTP request and make the response object. It can execute\r\n  ///   GET or POST request. In case of POST request the variables to server will contain the\r\n  ///   variables to be send to the server.\r\n  /// </summary>\r\n  /// <param name=\"urlString\">URL to be accessed.</param>\r\n  /// <param name=\"requestContent\">content to be sent to server (relevant only for POST method - is null for other methods).</param>\r\n  /// <param name=\"httpMethod\">enum RequestMethod to specify the method that will be used to execute the request.</param>\r\n  /// <param name=\"contentFromServer\">content received from the response. [OUT]</param>\r\n  /// <returns></returns>\r\n  private async ExecuteHttpRequest(urlString: string, requestContent: string, useCache: boolean, httpMethod: RequestMethod, contentFromServer: RefParam<any>): Promise<HttpResponse<string>>\r\n  {\r\n    let httpResponse: HttpResponse<string> = null;\r\n\r\n    this.prepareRequest();\r\n\r\n    let httpCommunicationTimeoutMS: number = HttpClientEvents.GetHttpCommunicationTimeout();\r\n    let clientID: string = HttpClientEvents.GetGlobalUniqueSessionID();\r\n\r\n    let executionAttempts: number = 0;  // for logging purpose only.\r\n\r\n    let startTime: number = Misc.getSystemMilliseconds();\r\n\r\n    // Retrying:\r\n    //    Is controlled by:\r\n    //       (I)  The method variable 'httpCommunicationTimeoutMS' (above),\r\n    //       (II) The class member 'CommunicationsFailureHandler' (above).\r\n    while (true) {\r\n      executionAttempts++;\r\n\r\n      try {\r\n        // TODO: implement TLS protocol.\r\n        // let useHighestSecurityProtocol: boolean = HttpClientBase.GetUseHighestSecurityProtocol();\r\n        // if (useHighestSecurityProtocol) {\r\n        //   ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;\r\n        // }\r\n\r\n        // Do not add MgxpaRIAglobalUniqueSessionID while getting execution properties\r\n        // TODO: headers should not be sent for cached file requests\r\n        let httpHeaders: HttpHeaders = new HttpHeaders();\r\n\r\n        httpHeaders = this.addHeaders(urlString, useCache, httpHeaders, clientID);\r\n\r\n        Logger.Instance.WriteServerToLog(NString.Format(\"Request Timeout set to {0} ms\", httpCommunicationTimeoutMS));\r\n\r\n        if (Logger.Instance.LogLevel === Logger_LogLevels.Basic) {\r\n          let contentLength: number = 0;\r\n          if (httpMethod === RequestMethod.Get) {\r\n            let parts: string[] = urlString.split('?');\r\n\r\n            if (parts.length === 2)\r\n              contentLength = parts[1].length;\r\n          }\r\n          else // (httpRequest.method === RequestMethod.Post)\r\n            contentLength = requestContent.length;\r\n\r\n          Logger.Instance.WriteBasicToLog(Logger_MessageDirection.MessageLeaving,\r\n            HttpClientEvents.GetRuntimeCtxID(),\r\n            HttpClientEvents.GetSessionCounter(),\r\n            clientID,\r\n            HttpClientEvents.ShouldDisplayGenericError() ? \"-\" : new URL(urlString).host,\r\n            0,\r\n            '-',\r\n            JSON.stringify(httpHeaders),\r\n            contentLength);\r\n        }\r\n\r\n        let timeBeforeRequest: number = Misc.getSystemMilliseconds();\r\n        Logger.Instance.WriteServerToLog(NString.Format(\"Accessing (method: '{0}'): '{1}'\", httpMethod, urlString));\r\n\r\n        Logger.Instance.WriteServerToLog(\"Outgoing Headers : \" + HttpClientBase.HeadersToString(httpHeaders, false));\r\n\r\n        if (httpMethod === RequestMethod.Post) {\r\n          // TODO: Handle Expect100Continue.\r\n          // httpWebRequest.ServicePoint.Expect100Continue = this.GetHTTPExpect100Continue();\r\n          // this.WriteContentToRequest(requestContent, httpWebRequest);\r\n        }\r\n\r\n        // =============================================================================================================\r\n        // send the request & get the response:\r\n        // =============================================================================================================\r\n        // TODO : Handle errors\r\n        // TODO: Handle timeout\r\n\r\n        let requestTime:number = Misc.getSystemMilliseconds();\r\n\r\n        this.LogRequestInfo(!isNullOrUndefined(requestContent) ? requestContent.length : 0, requestTime, false);\r\n\r\n        httpResponse = await this.sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer);\r\n\r\n        this.logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest);\r\n\r\n        this.LogRequestInfo(!isNullOrUndefined(requestContent) ? requestContent.length : 0, Misc.getSystemMilliseconds() - requestTime, true);\r\n\r\n        break;\r\n      }\r\n      catch (ex) {\r\n        if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)\r\n          Logger.Instance.WriteBasicErrorToLog();\r\n        else\r\n          Logger.Instance.WriteWarningToLog(ex);\r\n\r\n        this.handleHttpErrorException(ex, urlString);\r\n\r\n        let startTimeRef: RefParam<number> = new RefParam<number>(startTime);\r\n        if(this.shouldRetry(httpCommunicationTimeoutMS, urlString, this.CommunicationsFailureHandler, ex, startTimeRef))\r\n        {\r\n          startTime = startTimeRef.value;\r\n          continue;\r\n        }\r\n\r\n        this.logAndThrowException(ex);\r\n      }\r\n    }\r\n\r\n    this.logExecutionAttempts(executionAttempts);\r\n\r\n    return httpResponse;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Log the request info while sending request/after receiving response\r\n  /// </summary>\r\n  private LogRequestInfo(contentLength: number, roundTrip: number, isLoggingResponse: boolean) {\r\n    if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo) {\r\n      HttpClientEvents.ComputeAndLogRequestInfo(contentLength, roundTrip, isLoggingResponse);\r\n    }\r\n  }\r\n\r\n  /// <summary>Write Mg* prefixed headers to string in format \"HEADER1:VALUE1 HEADER2:VALUE2 ...\"</summary>\r\n  /// <param name=\"headers\"></param>\r\n  /// <param name=\"bFilter\">if true, list only headers prefixed with \"Mg\"</param>\r\n  private static HeadersToString(headers: HttpHeaders, bFilter: boolean): StringBuilder {\r\n    let headersStr: StringBuilder = new StringBuilder();\r\n    let headerKeys: string[] = headers.keys();\r\n\r\n    for (let key in headerKeys) {\r\n      // filter only headers that are prefixed with Mg* (sent from the Middleware and Server):\r\n      if (!bFilter || headerKeys[key].startsWith(\"Mg\"))\r\n        headersStr.Append(NString.Format(\"{0}:{1} \", headerKeys[key], headers.get(headerKeys[key])));\r\n    }\r\n\r\n    return headersStr;\r\n  }\r\n\r\n  // Abstract methods\r\n  abstract prepareRequest();\r\n  abstract addHeaders(urlString: string, useCache: boolean, httpHeaders: HttpHeaders, clientID: string): HttpHeaders;\r\n  async sendRequestToServer(httpMethod: RequestMethod, urlString: string, httpHeaders: HttpHeaders, requestContent: string, contentFromServer: RefParam<string>): Promise<any>{\r\n    return Promise.resolve();\r\n  }\r\n  abstract logResponse(httpResponse: HttpResponse<string>, clientID: string, urlString: string, contentFromServer: RefParam<any>, timeBeforeRequest: number);\r\n  abstract handleHttpErrorException(ex: any, urlString: string);\r\n  async shouldRetry(httpCommunicationTimeoutMS: number, urlString: string, communicationsFailureHandler: ICommunicationsFailureHandler, ex: any, startTimeRef: RefParam<number>): Promise<boolean>{\r\n    return Promise.resolve(false);\r\n  }\r\n  abstract logAndThrowException(ex: any);\r\n  abstract logExecutionAttempts(executionAttempts: number);\r\n}\r\n"]}
@@ -0,0 +1,39 @@
1
+ export class HttpClientEvents {
2
+ static GetHttpCommunicationTimeout_Event = null;
3
+ static GetExecutionProperty_Event = null;
4
+ static GetGlobalUniqueSessionID_Event = null;
5
+ static ShouldDisplayGenericError_Event = null;
6
+ static GetRuntimeCtxID_Event = null;
7
+ static GetSessionCounter_Event = null;
8
+ static CheckAndSetSessionCounter_Event = null;
9
+ static ComputeAndLogRequestInfo_Event = null;
10
+ static GetHttpCommunicationTimeout() {
11
+ return (HttpClientEvents.GetHttpCommunicationTimeout_Event !== null) ? HttpClientEvents.GetHttpCommunicationTimeout_Event() : 5000;
12
+ }
13
+ static GetExecutionProperty(propertyName) {
14
+ return (HttpClientEvents.GetExecutionProperty_Event !== null) ? HttpClientEvents.GetExecutionProperty_Event(propertyName) : null;
15
+ }
16
+ static GetGlobalUniqueSessionID() {
17
+ return (HttpClientEvents.GetGlobalUniqueSessionID_Event !== null) ? HttpClientEvents.GetGlobalUniqueSessionID_Event() : null;
18
+ }
19
+ static ShouldDisplayGenericError() {
20
+ return HttpClientEvents.ShouldDisplayGenericError_Event === null || HttpClientEvents.ShouldDisplayGenericError_Event();
21
+ }
22
+ static GetRuntimeCtxID() {
23
+ return (HttpClientEvents.GetRuntimeCtxID_Event !== null) ? HttpClientEvents.GetRuntimeCtxID_Event() : "";
24
+ }
25
+ static GetSessionCounter() {
26
+ return (HttpClientEvents.GetSessionCounter_Event !== null) ? HttpClientEvents.GetSessionCounter_Event() : 0;
27
+ }
28
+ static CheckAndSetSessionCounter(value) {
29
+ let flag = HttpClientEvents.CheckAndSetSessionCounter_Event !== null;
30
+ if (flag) {
31
+ HttpClientEvents.CheckAndSetSessionCounter_Event(value);
32
+ }
33
+ }
34
+ static ComputeAndLogRequestInfo(contentLength, roundTrip, isLoggingResponse) {
35
+ if (HttpClientEvents.ComputeAndLogRequestInfo_Event !== null)
36
+ HttpClientEvents.ComputeAndLogRequestInfo_Event(contentLength, roundTrip, isLoggingResponse);
37
+ }
38
+ }
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cENsaWVudEV2ZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VuZ2luZS9zcmMvaHR0cC9jbGllbnQvSHR0cENsaWVudEV2ZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLE1BQU0sQ0FBQyxpQ0FBaUMsR0FBaUIsSUFBSSxDQUFDO0lBQzlELE1BQU0sQ0FBQywwQkFBMEIsR0FBcUMsSUFBSSxDQUFDO0lBQzNFLE1BQU0sQ0FBQyw4QkFBOEIsR0FBaUIsSUFBSSxDQUFDO0lBQzNELE1BQU0sQ0FBQywrQkFBK0IsR0FBa0IsSUFBSSxDQUFDO0lBQzdELE1BQU0sQ0FBQyxxQkFBcUIsR0FBaUIsSUFBSSxDQUFDO0lBQ2xELE1BQU0sQ0FBQyx1QkFBdUIsR0FBaUIsSUFBSSxDQUFDO0lBQ3BELE1BQU0sQ0FBQywrQkFBK0IsR0FBNEIsSUFBSSxDQUFDO0lBQ3ZFLE1BQU0sQ0FBQyw4QkFBOEIsR0FBbUYsSUFBSSxDQUFDO0lBRTdILE1BQU0sQ0FBQywyQkFBMkI7UUFDaEMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLGlDQUFpQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxpQ0FBaUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDckksQ0FBQztJQUVELE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxZQUFvQjtRQUM5QyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsMEJBQTBCLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLDBCQUEwQixDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbkksQ0FBQztJQUVELE1BQU0sQ0FBQyx3QkFBd0I7UUFDN0IsT0FBTyxDQUFDLGdCQUFnQixDQUFDLDhCQUE4QixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyw4QkFBOEIsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDL0gsQ0FBQztJQUVELE1BQU0sQ0FBQyx5QkFBeUI7UUFDOUIsT0FBTyxnQkFBZ0IsQ0FBQywrQkFBK0IsS0FBSyxJQUFJLElBQUksZ0JBQWdCLENBQUMsK0JBQStCLEVBQUUsQ0FBQztJQUN6SCxDQUFDO0lBRUQsTUFBTSxDQUFDLGVBQWU7UUFDcEIsT0FBTyxDQUFDLGdCQUFnQixDQUFDLHFCQUFxQixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDM0csQ0FBQztJQUVELE1BQU0sQ0FBQyxpQkFBaUI7UUFDdEIsT0FBTyxDQUFDLGdCQUFnQixDQUFDLHVCQUF1QixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyx1QkFBdUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDOUcsQ0FBQztJQUVELE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxLQUFhO1FBQzVDLElBQUksSUFBSSxHQUFZLGdCQUFnQixDQUFDLCtCQUErQixLQUFLLElBQUksQ0FBQztRQUM5RSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ1QsZ0JBQWdCLENBQUMsK0JBQStCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUQsQ0FBQztJQUNILENBQUM7SUFFRCxNQUFNLENBQUMsd0JBQXdCLENBQUMsYUFBcUIsRUFBRSxTQUFpQixFQUFFLGlCQUEwQjtRQUNsRyxJQUFJLGdCQUFnQixDQUFDLDhCQUE4QixLQUFLLElBQUk7WUFDMUQsZ0JBQWdCLENBQUMsOEJBQThCLENBQUMsYUFBYSxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO0lBQ2pHLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgSHR0cENsaWVudEV2ZW50cyB7XHJcbiAgc3RhdGljIEdldEh0dHBDb21tdW5pY2F0aW9uVGltZW91dF9FdmVudDogKCkgPT4gbnVtYmVyID0gbnVsbDtcclxuICBzdGF0aWMgR2V0RXhlY3V0aW9uUHJvcGVydHlfRXZlbnQ6IChwcm9wZXJ0eU5hbWU6IHN0cmluZykgPT4gc3RyaW5nID0gbnVsbDtcclxuICBzdGF0aWMgR2V0R2xvYmFsVW5pcXVlU2Vzc2lvbklEX0V2ZW50OiAoKSA9PiBzdHJpbmcgPSBudWxsO1xyXG4gIHN0YXRpYyBTaG91bGREaXNwbGF5R2VuZXJpY0Vycm9yX0V2ZW50OiAoKSA9PiBib29sZWFuID0gbnVsbDtcclxuICBzdGF0aWMgR2V0UnVudGltZUN0eElEX0V2ZW50OiAoKSA9PiBzdHJpbmcgPSBudWxsO1xyXG4gIHN0YXRpYyBHZXRTZXNzaW9uQ291bnRlcl9FdmVudDogKCkgPT4gbnVtYmVyID0gbnVsbDtcclxuICBzdGF0aWMgQ2hlY2tBbmRTZXRTZXNzaW9uQ291bnRlcl9FdmVudDogKHZhbHVlOiBudW1iZXIpID0+IHZvaWQgPSBudWxsO1xyXG4gIHN0YXRpYyBDb21wdXRlQW5kTG9nUmVxdWVzdEluZm9fRXZlbnQ6IChjb250ZW50TGVuZ3RoOiBudW1iZXIsIHJvdW5kVHJpcDogbnVtYmVyLCBpc0xvZ2dpbmdSZXNwb25zZTogYm9vbGVhbikgPT4gdm9pZCA9IG51bGw7XHJcblxyXG4gIHN0YXRpYyBHZXRIdHRwQ29tbXVuaWNhdGlvblRpbWVvdXQoKTogbnVtYmVyIHtcclxuICAgIHJldHVybiAoSHR0cENsaWVudEV2ZW50cy5HZXRIdHRwQ29tbXVuaWNhdGlvblRpbWVvdXRfRXZlbnQgIT09IG51bGwpID8gSHR0cENsaWVudEV2ZW50cy5HZXRIdHRwQ29tbXVuaWNhdGlvblRpbWVvdXRfRXZlbnQoKSA6IDUwMDA7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgR2V0RXhlY3V0aW9uUHJvcGVydHkocHJvcGVydHlOYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIChIdHRwQ2xpZW50RXZlbnRzLkdldEV4ZWN1dGlvblByb3BlcnR5X0V2ZW50ICE9PSBudWxsKSA/IEh0dHBDbGllbnRFdmVudHMuR2V0RXhlY3V0aW9uUHJvcGVydHlfRXZlbnQocHJvcGVydHlOYW1lKSA6IG51bGw7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgR2V0R2xvYmFsVW5pcXVlU2Vzc2lvbklEKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gKEh0dHBDbGllbnRFdmVudHMuR2V0R2xvYmFsVW5pcXVlU2Vzc2lvbklEX0V2ZW50ICE9PSBudWxsKSA/IEh0dHBDbGllbnRFdmVudHMuR2V0R2xvYmFsVW5pcXVlU2Vzc2lvbklEX0V2ZW50KCkgOiBudWxsO1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIFNob3VsZERpc3BsYXlHZW5lcmljRXJyb3IoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gSHR0cENsaWVudEV2ZW50cy5TaG91bGREaXNwbGF5R2VuZXJpY0Vycm9yX0V2ZW50ID09PSBudWxsIHx8IEh0dHBDbGllbnRFdmVudHMuU2hvdWxkRGlzcGxheUdlbmVyaWNFcnJvcl9FdmVudCgpO1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIEdldFJ1bnRpbWVDdHhJRCgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIChIdHRwQ2xpZW50RXZlbnRzLkdldFJ1bnRpbWVDdHhJRF9FdmVudCAhPT0gbnVsbCkgPyBIdHRwQ2xpZW50RXZlbnRzLkdldFJ1bnRpbWVDdHhJRF9FdmVudCgpIDogXCJcIjtcclxuICB9XHJcblxyXG4gIHN0YXRpYyBHZXRTZXNzaW9uQ291bnRlcigpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIChIdHRwQ2xpZW50RXZlbnRzLkdldFNlc3Npb25Db3VudGVyX0V2ZW50ICE9PSBudWxsKSA/IEh0dHBDbGllbnRFdmVudHMuR2V0U2Vzc2lvbkNvdW50ZXJfRXZlbnQoKSA6IDA7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgQ2hlY2tBbmRTZXRTZXNzaW9uQ291bnRlcih2YWx1ZTogbnVtYmVyKTogdm9pZCB7XHJcbiAgICBsZXQgZmxhZzogYm9vbGVhbiA9IEh0dHBDbGllbnRFdmVudHMuQ2hlY2tBbmRTZXRTZXNzaW9uQ291bnRlcl9FdmVudCAhPT0gbnVsbDtcclxuICAgIGlmIChmbGFnKSB7XHJcbiAgICAgIEh0dHBDbGllbnRFdmVudHMuQ2hlY2tBbmRTZXRTZXNzaW9uQ291bnRlcl9FdmVudCh2YWx1ZSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgQ29tcHV0ZUFuZExvZ1JlcXVlc3RJbmZvKGNvbnRlbnRMZW5ndGg6IG51bWJlciwgcm91bmRUcmlwOiBudW1iZXIsIGlzTG9nZ2luZ1Jlc3BvbnNlOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICBpZiAoSHR0cENsaWVudEV2ZW50cy5Db21wdXRlQW5kTG9nUmVxdWVzdEluZm9fRXZlbnQgIT09IG51bGwpXHJcbiAgICAgIEh0dHBDbGllbnRFdmVudHMuQ29tcHV0ZUFuZExvZ1JlcXVlc3RJbmZvX0V2ZW50KGNvbnRlbnRMZW5ndGgsIHJvdW5kVHJpcCwgaXNMb2dnaW5nUmVzcG9uc2UpO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,42 @@
1
+ import { NString } from "@magic-xpa/mscorelib";
2
+ import { HttpClientBase } from "./HttpClientBase";
3
+ import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
4
+ import { HttpClientEvents } from "./HttpClientEvents";
5
+ export class HttpClientSync extends HttpClientBase {
6
+ httpRequest = null;
7
+ headers = new Headers();
8
+ constructor() {
9
+ super();
10
+ }
11
+ prepareRequest() {
12
+ }
13
+ addHeaders(urlString, useCache, httpHeaders, clientID) {
14
+ if (!urlString.startsWith("/")) {
15
+ this.headers.append("MgxpaRIAglobalUniqueSessionID", clientID);
16
+ }
17
+ if (!useCache) {
18
+ this.headers.append("Cache-Control", "no-cache");
19
+ }
20
+ return httpHeaders;
21
+ }
22
+ async sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer) {
23
+ await fetch(urlString, { method: 'POST', headers: this.headers, body: requestContent, keepalive: true });
24
+ return NString.Empty;
25
+ }
26
+ logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest) {
27
+ let responseTime = Misc.getSystemMilliseconds() - timeBeforeRequest;
28
+ if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)
29
+ Logger.Instance.WriteBasicToLog(Logger_MessageDirection.MessageEntering, HttpClientEvents.GetRuntimeCtxID(), HttpClientEvents.GetSessionCounter(), clientID, HttpClientEvents.ShouldDisplayGenericError() ? "-" : new URL(urlString).host, responseTime, this.httpRequest.status.toString(), JSON.stringify(this.httpRequest.getAllResponseHeaders()), contentFromServer.value.length);
30
+ }
31
+ handleHttpErrorException(ex, urlString) {
32
+ throw ex;
33
+ }
34
+ async shouldRetry(httpCommunicationTimeoutMS, urlString, communicationsFailureHandler, ex, startTimeRef) {
35
+ return Promise.resolve(false);
36
+ }
37
+ logAndThrowException(ex) {
38
+ }
39
+ logExecutionAttempts(executionAttempts) {
40
+ }
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cENsaWVudFN5bmMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL2h0dHAvY2xpZW50L0h0dHBDbGllbnRTeW5jLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxPQUFPLEVBQVcsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsY0FBYyxFQUFnQixNQUFNLGtCQUFrQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxNQUFNLEVBQUUsZ0JBQWdCLEVBQUUsdUJBQXVCLEVBQUUsSUFBSSxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDekYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sb0JBQW9CLENBQUM7QUFJcEQsTUFBTSxPQUFPLGNBQWUsU0FBUSxjQUFjO0lBRXhDLFdBQVcsR0FBbUIsSUFBSSxDQUFDO0lBQ25DLE9BQU8sR0FBWSxJQUFJLE9BQU8sRUFBRSxDQUFDO0lBRXpDO1FBRUUsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBRUQsY0FBYztJQUVkLENBQUM7SUFFRCxVQUFVLENBQUMsU0FBaUIsRUFBRSxRQUFpQixFQUFFLFdBQXdCLEVBQUUsUUFBZ0I7UUFFekYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEVBQzlCLENBQUM7WUFDQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQywrQkFBK0IsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUNqRSxDQUFDO1FBRUQsSUFBSSxDQUFDLFFBQVEsRUFDYixDQUFDO1lBQ0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsZUFBZSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ25ELENBQUM7UUFFRCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRUQsS0FBSyxDQUFDLG1CQUFtQixDQUFDLFVBQXlCLEVBQUUsU0FBaUIsRUFBRSxXQUF3QixFQUFFLGNBQXNCLEVBQUUsaUJBQW1DO1FBRzNKLE1BQU0sS0FBSyxDQUFDLFNBQVMsRUFBRSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLGNBQWMsRUFBRSxTQUFTLEVBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUV4RyxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUM7SUFDdkIsQ0FBQztJQUVELFdBQVcsQ0FBQyxZQUFrQyxFQUFFLFFBQWdCLEVBQUUsU0FBaUIsRUFBRSxpQkFBZ0MsRUFBRSxpQkFBeUI7UUFFOUksSUFBSSxZQUFZLEdBQVcsSUFBSSxDQUFDLHFCQUFxQixFQUFFLEdBQUcsaUJBQWlCLENBQUM7UUFFNUUsSUFBSSxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsS0FBSyxnQkFBZ0IsQ0FBQyxLQUFLO1lBQ3JELE1BQU0sQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLGVBQWUsRUFDdkMsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLEVBQ2xDLGdCQUFnQixDQUFDLGlCQUFpQixFQUFFLEVBQ3BDLFFBQVEsRUFDUixnQkFBZ0IsQ0FBQyx5QkFBeUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksRUFDNUUsWUFBWSxFQUNaLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxFQUNsQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxFQUN4RCxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVELHdCQUF3QixDQUFDLEVBQU8sRUFBRSxTQUFpQjtRQUdqRCxNQUFNLEVBQUUsQ0FBQztJQUNYLENBQUM7SUFFRCxLQUFLLENBQUMsV0FBVyxDQUFDLDBCQUFrQyxFQUFFLFNBQWlCLEVBQUUsNEJBQTJELEVBQUUsRUFBTyxFQUFFLFlBQThCO1FBRzNLLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRUQsb0JBQW9CLENBQUMsRUFBRTtJQUd2QixDQUFDO0lBRUQsb0JBQW9CLENBQUMsaUJBQXlCO0lBRzlDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SHR0cEhlYWRlcnMsIEh0dHBSZXNwb25zZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7TlN0cmluZywgUmVmUGFyYW19IGZyb20gXCJAbWFnaWMteHBhL21zY29yZWxpYlwiO1xyXG5pbXBvcnQge0h0dHBDbGllbnRCYXNlLCBSZXF1ZXN0TWV0aG9kfSBmcm9tIFwiLi9IdHRwQ2xpZW50QmFzZVwiO1xyXG5pbXBvcnQge0xvZ2dlciwgTG9nZ2VyX0xvZ0xldmVscywgTG9nZ2VyX01lc3NhZ2VEaXJlY3Rpb24sIE1pc2N9IGZyb20gXCJAbWFnaWMteHBhL3V0aWxzXCI7XHJcbmltcG9ydCB7SHR0cENsaWVudEV2ZW50c30gZnJvbSBcIi4vSHR0cENsaWVudEV2ZW50c1wiO1xyXG5pbXBvcnQge0lDb21tdW5pY2F0aW9uc0ZhaWx1cmVIYW5kbGVyfSBmcm9tIFwiLi9JQ29tbXVuaWNhdGlvbnNGYWlsdXJlSGFuZGxlclwiO1xyXG5cclxuLy8gQSBjbGFzcyB1c2luZyBIdHRwIFN5bmMgTGlicmFyeVxyXG5leHBvcnQgY2xhc3MgSHR0cENsaWVudFN5bmMgZXh0ZW5kcyBIdHRwQ2xpZW50QmFzZVxyXG57XHJcbiAgcHJpdmF0ZSBodHRwUmVxdWVzdDogWE1MSHR0cFJlcXVlc3QgPSBudWxsO1xyXG4gIHByaXZhdGUgaGVhZGVyczogSGVhZGVycyA9IG5ldyBIZWFkZXJzKCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKClcclxuICB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgcHJlcGFyZVJlcXVlc3QoKVxyXG4gIHtcclxuICB9XHJcblxyXG4gIGFkZEhlYWRlcnModXJsU3RyaW5nOiBzdHJpbmcsIHVzZUNhY2hlOiBib29sZWFuLCBodHRwSGVhZGVyczogSHR0cEhlYWRlcnMsIGNsaWVudElEOiBzdHJpbmcpOiBIdHRwSGVhZGVyc1xyXG4gIHtcclxuICAgIGlmICghdXJsU3RyaW5nLnN0YXJ0c1dpdGgoXCIvXCIpKVxyXG4gICAge1xyXG4gICAgICB0aGlzLmhlYWRlcnMuYXBwZW5kKFwiTWd4cGFSSUFnbG9iYWxVbmlxdWVTZXNzaW9uSURcIiwgY2xpZW50SUQpO1xyXG4gICAgfVxyXG5cclxuICAgIGlmICghdXNlQ2FjaGUpXHJcbiAgICB7XHJcbiAgICAgIHRoaXMuaGVhZGVycy5hcHBlbmQoXCJDYWNoZS1Db250cm9sXCIsIFwibm8tY2FjaGVcIik7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGh0dHBIZWFkZXJzO1xyXG4gIH1cclxuXHJcbiAgYXN5bmMgc2VuZFJlcXVlc3RUb1NlcnZlcihodHRwTWV0aG9kOiBSZXF1ZXN0TWV0aG9kLCB1cmxTdHJpbmc6IHN0cmluZywgaHR0cEhlYWRlcnM6IEh0dHBIZWFkZXJzLCByZXF1ZXN0Q29udGVudDogc3RyaW5nLCBjb250ZW50RnJvbVNlcnZlcjogUmVmUGFyYW08c3RyaW5nPik6IFByb21pc2U8YW55PlxyXG4gIHtcclxuICAgIC8vIFNlbmQgdGhlIGVuZ2luZSB0ZXJtaW5hdGlvbiByZXF1ZXN0IHRvIHNlcnZlci5cclxuICAgIGF3YWl0IGZldGNoKHVybFN0cmluZywgeyBtZXRob2Q6ICdQT1NUJywgaGVhZGVyczogdGhpcy5oZWFkZXJzLCBib2R5OiByZXF1ZXN0Q29udGVudCwga2VlcGFsaXZlOnRydWUgfSk7XHJcblxyXG4gICAgcmV0dXJuIE5TdHJpbmcuRW1wdHk7XHJcbiAgfVxyXG5cclxuICBsb2dSZXNwb25zZShodHRwUmVzcG9uc2U6IEh0dHBSZXNwb25zZTxzdHJpbmc+LCBjbGllbnRJRDogc3RyaW5nLCB1cmxTdHJpbmc6IHN0cmluZywgY29udGVudEZyb21TZXJ2ZXI6IFJlZlBhcmFtPGFueT4sIHRpbWVCZWZvcmVSZXF1ZXN0OiBudW1iZXIpXHJcbiAge1xyXG4gICAgbGV0IHJlc3BvbnNlVGltZTogbnVtYmVyID0gTWlzYy5nZXRTeXN0ZW1NaWxsaXNlY29uZHMoKSAtIHRpbWVCZWZvcmVSZXF1ZXN0O1xyXG5cclxuICAgIGlmIChMb2dnZXIuSW5zdGFuY2UuTG9nTGV2ZWwgPT09IExvZ2dlcl9Mb2dMZXZlbHMuQmFzaWMpXHJcbiAgICAgIExvZ2dlci5JbnN0YW5jZS5Xcml0ZUJhc2ljVG9Mb2coTG9nZ2VyX01lc3NhZ2VEaXJlY3Rpb24uTWVzc2FnZUVudGVyaW5nLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEh0dHBDbGllbnRFdmVudHMuR2V0UnVudGltZUN0eElEKCksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSHR0cENsaWVudEV2ZW50cy5HZXRTZXNzaW9uQ291bnRlcigpLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsaWVudElELFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEh0dHBDbGllbnRFdmVudHMuU2hvdWxkRGlzcGxheUdlbmVyaWNFcnJvcigpID8gXCItXCIgOiBuZXcgVVJMKHVybFN0cmluZykuaG9zdCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByZXNwb25zZVRpbWUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5odHRwUmVxdWVzdC5zdGF0dXMudG9TdHJpbmcoKSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBKU09OLnN0cmluZ2lmeSh0aGlzLmh0dHBSZXF1ZXN0LmdldEFsbFJlc3BvbnNlSGVhZGVycygpKSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb250ZW50RnJvbVNlcnZlci52YWx1ZS5sZW5ndGgpO1xyXG4gIH1cclxuXHJcbiAgaGFuZGxlSHR0cEVycm9yRXhjZXB0aW9uKGV4OiBhbnksIHVybFN0cmluZzogc3RyaW5nKVxyXG4gIHtcclxuICAgIC8vIE5vIGV4Y2VwdGlvbiBoYW5kbGluZyBmb3IgbGFzdCByZXF1ZXN0IGFuZCBoZW5jZSBqdXN0IHRocm93IHRoZSBleGNlcHRpb25cclxuICAgIHRocm93IGV4O1xyXG4gIH1cclxuXHJcbiAgYXN5bmMgc2hvdWxkUmV0cnkoaHR0cENvbW11bmljYXRpb25UaW1lb3V0TVM6IG51bWJlciwgdXJsU3RyaW5nOiBzdHJpbmcsIGNvbW11bmljYXRpb25zRmFpbHVyZUhhbmRsZXI6IElDb21tdW5pY2F0aW9uc0ZhaWx1cmVIYW5kbGVyLCBleDogYW55LCBzdGFydFRpbWVSZWY6IFJlZlBhcmFtPG51bWJlcj4pOiBQcm9taXNlPGJvb2xlYW4+XHJcbiAge1xyXG4gICAgLy8gTm8gcmV0cnkgc3VwcG9ydGVkIG9uIGxhc3QgcmVxdWVzdFxyXG4gICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShmYWxzZSk7XHJcbiAgfVxyXG5cclxuICBsb2dBbmRUaHJvd0V4Y2VwdGlvbihleClcclxuICB7XHJcbiAgICAvLyBOLkEuXHJcbiAgfVxyXG5cclxuICBsb2dFeGVjdXRpb25BdHRlbXB0cyhleGVjdXRpb25BdHRlbXB0czogbnVtYmVyKVxyXG4gIHtcclxuICAgIC8vIE4uQS5cclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,84 @@
1
+ import { Encoding, NString } from "@magic-xpa/mscorelib";
2
+ import { Logger } from "@magic-xpa/utils";
3
+ export class HttpUtility {
4
+ static EncodingEnabled = true;
5
+ static ASCIIGetString(bytes) {
6
+ return Encoding.ASCII.GetString(bytes, 0, bytes.length);
7
+ }
8
+ static IntToHexCharCode(n) {
9
+ if (n <= 9)
10
+ return n + 0x30;
11
+ return (n - 10) + 0X61;
12
+ }
13
+ static IsSafe(ch) {
14
+ if ((ch >= 'a' && ch <= 'z') ||
15
+ (ch >= 'A' && ch <= 'Z') ||
16
+ (ch >= '0' && ch <= '9'))
17
+ return true;
18
+ switch (ch) {
19
+ case '\'':
20
+ case '(':
21
+ case ')':
22
+ case '*':
23
+ case '-':
24
+ case '.':
25
+ case '_':
26
+ case '!':
27
+ return true;
28
+ }
29
+ return false;
30
+ }
31
+ static UrlEncode(str, e) {
32
+ let encodedStr = null;
33
+ if (str !== null) {
34
+ encodedStr = HttpUtility.ASCIIGetString(HttpUtility.UrlEncodeToBytes(str, e));
35
+ Logger.Instance.WriteServerMessagesToLog(NString.Format("\n String: {0} \n UrlEncoded by: {1} \n To: {2}", str, e, encodedStr));
36
+ }
37
+ return encodedStr;
38
+ }
39
+ static UrlEncodeToBytes(str, e) {
40
+ if (str === null) {
41
+ return null;
42
+ }
43
+ let bytes = e.GetBytes(str);
44
+ return HttpUtility.UrlEncodeBytesToBytesInternal(bytes, 0, bytes.length);
45
+ }
46
+ static UrlEncodeBytesToBytesInternal(bytes, offset, count) {
47
+ if (!HttpUtility.EncodingEnabled) {
48
+ return bytes;
49
+ }
50
+ let num = 0;
51
+ let num2 = 0;
52
+ for (let i = 0; i < count; i++) {
53
+ let ch = String.fromCharCode(bytes[offset + i]);
54
+ if (ch === ' ') {
55
+ num = num++;
56
+ }
57
+ else if (!HttpUtility.IsSafe(ch)) {
58
+ num2 = num2 + 1;
59
+ }
60
+ }
61
+ if (num === 0 && num2 === 0) {
62
+ return bytes;
63
+ }
64
+ let buffer = new Uint8Array(count + num2 * 2);
65
+ let num4 = 0;
66
+ for (let j = 0; j < count; j++) {
67
+ let num6 = bytes[offset + j];
68
+ let ch = String.fromCharCode(num6);
69
+ if (HttpUtility.IsSafe(ch)) {
70
+ buffer[num4++] = num6;
71
+ }
72
+ else if (ch === ' ') {
73
+ buffer[num4++] = 0X2b;
74
+ }
75
+ else {
76
+ buffer[num4++] = 0X25;
77
+ buffer[num4++] = HttpUtility.IntToHexCharCode(num6 >> 4 & 15);
78
+ buffer[num4++] = HttpUtility.IntToHexCharCode(num6 & 15);
79
+ }
80
+ }
81
+ return buffer;
82
+ }
83
+ }
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"HttpUtility.js","sourceRoot":"","sources":["../../../../../../../projects/engine/src/http/client/HttpUtility.ts"],"names":[],"mappings":"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","sourcesContent":["import {Encoding, NString} from \"@magic-xpa/mscorelib\";\r\nimport {Logger} from \"@magic-xpa/utils\";\r\n\r\n/// <summary>Provides methods for encoding URLs when processing Web requests.\r\n///   This class cannot be inherited.\r\n/// </summary>\r\nexport class HttpUtility {\r\n  static EncodingEnabled: boolean = true;\r\n\r\n  /// <summary>Decodes all the bytes in the specified byte array into a string.</summary>\r\n  /// <remarks>Replace the method \"System.Text.Encoding.ASCII.GetString(byte[] bytes);\" in .Net Framework.</remarks>\r\n  /// <param name = \"bytes\">The byte array containing the sequence of bytes to decode.</param>\r\n  /// <returns>A String containing the results of decoding the specified sequence of bytes.</returns>\r\n  private static ASCIIGetString(bytes: Uint8Array): string {\r\n    return Encoding.ASCII.GetString(bytes, 0, bytes.length);\r\n  }\r\n\r\n  private static IntToHexCharCode(n: number): number {\r\n    if (n <= 9)\r\n      return n + 0x30;\r\n\r\n    return (n - 10) + 0X61;\r\n  }\r\n\r\n  private static IsSafe(ch: string): boolean {\r\n    if ((ch >= 'a' && ch <= 'z') ||\r\n        (ch >= 'A' && ch <= 'Z') ||\r\n        (ch >= '0' && ch <= '9'))\r\n      return true;\r\n\r\n    switch (ch) {\r\n      case '\\'':\r\n      case '(':\r\n      case ')':\r\n      case '*':\r\n      case '-':\r\n      case '.':\r\n      case '_':\r\n      case '!':\r\n        return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  /// <summary>Encodes a URL string using the specified encoding object.</summary>\r\n  /// <returns>An encoded string.</returns>\r\n  /// <param name = \"e\">The <see cref = \"T:System.Text.Encoding\"></see> object that specifies the encoding scheme. </param>\r\n  /// <param name = \"str\">The text to encode. </param>\r\n  static UrlEncode(str: string, e: Encoding): string {\r\n    let encodedStr: string = null;\r\n\r\n    if (str !== null) {\r\n      encodedStr = HttpUtility.ASCIIGetString(HttpUtility.UrlEncodeToBytes(str, e));\r\n      Logger.Instance.WriteServerMessagesToLog(NString.Format(\"\\n String: {0} \\n UrlEncoded by: {1} \\n To: {2}\", str, e, encodedStr));\r\n    }\r\n\r\n    return encodedStr;\r\n  }\r\n\r\n  /// <summary>Converts a string into a URL-encoded array of bytes using the specified encoding object.</summary>\r\n  /// <returns>An encoded array of bytes.</returns>\r\n  /// <param name = \"e\">The <see cref = \"T:System.Text.Encoding\"></see> that specifies the encoding scheme. </param>\r\n  /// <param name = \"str\">The string to encode </param>\r\n  private static UrlEncodeToBytes(str: string, e: Encoding): Uint8Array {\r\n    if (str === null) {\r\n      return null;\r\n    }\r\n\r\n    let bytes: Uint8Array = e.GetBytes(str);\r\n    return HttpUtility.UrlEncodeBytesToBytesInternal(bytes, 0, bytes.length);\r\n  }\r\n\r\n  private static UrlEncodeBytesToBytesInternal(bytes: Uint8Array, offset: number, count: number): Uint8Array {\r\n    if (!HttpUtility.EncodingEnabled) {\r\n      return bytes;\r\n    }\r\n\r\n    let num: number = 0;\r\n    let num2: number = 0;\r\n    for (let i: number = 0; i < count; i++) {\r\n      let ch: string = String.fromCharCode(bytes[offset + i]);\r\n      if (ch === ' ') {\r\n        num = num++;\r\n      }\r\n      else if (!HttpUtility.IsSafe(ch)) {\r\n        num2 = num2 + 1;\r\n      }\r\n    }\r\n    if (num === 0 && num2 === 0) {\r\n      return bytes;\r\n    }\r\n\r\n    let buffer: Uint8Array = new Uint8Array(count + num2 * 2);\r\n    let num4: number = 0;\r\n    for (let j: number = 0; j < count; j++) {\r\n      let num6: number = bytes[offset + j];\r\n      // TODO: Consider sending number instead of creating a new string for each byte.\r\n      let ch: string = String.fromCharCode(num6);\r\n      if (HttpUtility.IsSafe(ch)) {\r\n        buffer[num4++] = num6;\r\n      }\r\n      else if (ch === ' ') {\r\n          buffer[num4++] = 0X2b;\r\n      }\r\n      else {\r\n        buffer[num4++] = 0X25;\r\n        buffer[num4++] = HttpUtility.IntToHexCharCode(num6 >> 4 & 15);\r\n        buffer[num4++] = HttpUtility.IntToHexCharCode(num6 & 15);\r\n      }\r\n    }\r\n\r\n    return buffer;\r\n  }\r\n}\r\n"]}
@@ -1,2 +1,2 @@
1
- export {};
1
+ export {};
2
2
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUNvbW11bmljYXRpb25zRmFpbHVyZUhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL2h0dHAvY2xpZW50L0lDb21tdW5pY2F0aW9uc0ZhaWx1cmVIYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuZXhwb3J0IGludGVyZmFjZSBJQ29tbXVuaWNhdGlvbnNGYWlsdXJlSGFuZGxlciB7XHJcbiAgLy8vIDxzdW1tYXJ5PlxyXG4gIC8vLyBHZXRzIGEgdmFsdWUgZGV0ZXJtaW5pbmcgd2hldGhlciB0aGUgY2FsbGVyIHNob3VsZCByZXRyeSBleGVjdXRpbmcgdGhlXHJcbiAgLy8vIGNvbW11bmljYXRpb25zIHJlcXVlc3QsIHdoaWNoIHdhcyBzZW50IHdoZW4gdGhlIGZhaWx1cmUgb2NjdXJyZWQuXHJcbiAgLy8vIDwvc3VtbWFyeT5cclxuICBTaG91bGRSZXRyeUxhc3RSZXF1ZXN0OiBib29sZWFuO1xyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIEdldHMgYSB2YWx1ZSBkZXRlcm1pbmluZyB3aGV0aGVyIHRoZSBjYWxsZXIgc2hvdWxkIHNob3cgdGhlXHJcbiAgLy8vIGNvbW11bmljYXRpb25zIGVycm9ycy5cclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIFNob3dDb21tdW5pY2F0aW9uRXJyb3JzOiBib29sZWFuO1xyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIFRoaXMgbWV0aG9kIGlzIHVzZWQgdG8gbm90aWZ5IHRoZSBpbXBsZW1lbnRpbmcgY2xhc3MgdGhhdCB0aGUgY29ubmVjdGlvbiBmYWlsZWQuXHJcbiAgLy8vIFRoZSBzcGVjaWZpYyBtZXRob2QgaW1wbGVtZW50YXRpb24gaXMgbm93IGZyZWUgdG8gZG8gd2hhdGV2ZXIgaXMgbmVlZGVkIGF0IHRoaXNcclxuICAvLy8gcG9pbnQsIHN1Y2ggYXMgZGlzcGxheWluZyBhIG5vdGlmaWNhdGlvbiBtZXNzYWdlIHRvIHRoZSB1c2VyLCBvciBkZXRlcm1pbmluZ1xyXG4gIC8vLyBuZXh0IGFjdGlvbnMgYXV0b21hdGljYWxseS5cclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIC8vLyA8cGFyYW0gbmFtZT1cInVybFwiPlRoZSBmYWlsaW5nIFVSTC48L3BhcmFtPlxyXG4gIC8vLyA8cGFyYW0gbmFtZT1cImZhaWx1cmVFeGNlcHRpb25cIj5UaGUgZXhjZXB0aW9uIHJhaXNlZCB3aGVuIHRoZSBmYWlsdXJlIHdhcyBkZXRlY3RlZC48L3BhcmFtPlxyXG4gIENvbW11bmljYXRpb25GYWlsZWQodXJsOiBzdHJpbmcsIGZhaWx1cmVFeGNlcHRpb246IEVycm9yKTogdm9pZDtcclxufVxyXG4iXX0=