@magic-xpa/engine 4.1200.0-dev4120.1 → 4.1200.0-dev4120.102

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (205) hide show
  1. package/fesm2022/magic-xpa-engine.mjs +11008 -1259
  2. package/fesm2022/magic-xpa-engine.mjs.map +1 -1
  3. package/index.d.ts +3 -0
  4. package/package.json +5 -7
  5. package/src/ClientManager.d.ts +1 -0
  6. package/src/CommandsProcessorBase.d.ts +1 -1
  7. package/src/CommandsProcessorManager.d.ts +1 -1
  8. package/src/ConstInterface.d.ts +1 -0
  9. package/src/bridge/MagicBridge.d.ts +1 -0
  10. package/src/event/EventsManager.d.ts +4 -0
  11. package/src/http/HttpManager.d.ts +1 -1
  12. package/src/http/client/HttpClientAsync.d.ts +2 -2
  13. package/src/http/client/HttpClientBase.d.ts +2 -2
  14. package/src/http/client/HttpClientSync.d.ts +1 -1
  15. package/src/remote/RemoteCommandsProcessor.d.ts +3 -1
  16. package/src/util/ParamParseResult.d.ts +3 -3
  17. package/esm2022/index.mjs +0 -188
  18. package/esm2022/magic-xpa-engine.mjs +0 -2
  19. package/esm2022/src/AccessHelper.mjs +0 -15
  20. package/esm2022/src/ClientManager.mjs +0 -420
  21. package/esm2022/src/CommandsProcessorBase.mjs +0 -56
  22. package/esm2022/src/CommandsProcessorManager.mjs +0 -26
  23. package/esm2022/src/CommandsTable.mjs +0 -162
  24. package/esm2022/src/ConstInterface.mjs +0 -517
  25. package/esm2022/src/CurrentClientVersion.mjs +0 -2
  26. package/esm2022/src/FlowMonitorInterface.mjs +0 -16
  27. package/esm2022/src/GUIManager.mjs +0 -62
  28. package/esm2022/src/GlobalCommandsManager.mjs +0 -34
  29. package/esm2022/src/GuiEventsProcessor.mjs +0 -156
  30. package/esm2022/src/ICommandsTable.mjs +0 -2
  31. package/esm2022/src/ServerConfig.mjs +0 -122
  32. package/esm2022/src/bridge/IGuiEvent.mjs +0 -20
  33. package/esm2022/src/bridge/MagicBridge.mjs +0 -41
  34. package/esm2022/src/commands/ClientOriginatedCommandTaskTag.mjs +0 -12
  35. package/esm2022/src/commands/ClientToServer/AddUserLocateDataViewCommand.mjs +0 -9
  36. package/esm2022/src/commands/ClientToServer/AddUserRangeDataviewCommand.mjs +0 -9
  37. package/esm2022/src/commands/ClientToServer/AddUserSortDataViewCommand.mjs +0 -9
  38. package/esm2022/src/commands/ClientToServer/BrowserEscEventCommand.mjs +0 -26
  39. package/esm2022/src/commands/ClientToServer/ClientOriginatedCommand.mjs +0 -15
  40. package/esm2022/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs +0 -60
  41. package/esm2022/src/commands/ClientToServer/ColumnSortEventCommand.mjs +0 -29
  42. package/esm2022/src/commands/ClientToServer/CommandFactory.mjs +0 -261
  43. package/esm2022/src/commands/ClientToServer/CommandSerializationHelper.mjs +0 -67
  44. package/esm2022/src/commands/ClientToServer/ComputeEventCommand.mjs +0 -26
  45. package/esm2022/src/commands/ClientToServer/ContextTerminationEventCommand.mjs +0 -24
  46. package/esm2022/src/commands/ClientToServer/ContextTimeoutResetCommand.mjs +0 -23
  47. package/esm2022/src/commands/ClientToServer/ControlItemsRefreshCommand.mjs +0 -8
  48. package/esm2022/src/commands/ClientToServer/DataViewOutputCommand.mjs +0 -13
  49. package/esm2022/src/commands/ClientToServer/DataviewCommand.mjs +0 -44
  50. package/esm2022/src/commands/ClientToServer/EvaluateCommand.mjs +0 -40
  51. package/esm2022/src/commands/ClientToServer/EventCommand.mjs +0 -43
  52. package/esm2022/src/commands/ClientToServer/ExecOperCommand.mjs +0 -70
  53. package/esm2022/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +0 -25
  54. package/esm2022/src/commands/ClientToServer/GlobalParamsQueryCommand.mjs +0 -11
  55. package/esm2022/src/commands/ClientToServer/ICommandTaskTag.mjs +0 -2
  56. package/esm2022/src/commands/ClientToServer/IndexChangeEventCommand.mjs +0 -24
  57. package/esm2022/src/commands/ClientToServer/IniputForceWriteCommand.mjs +0 -26
  58. package/esm2022/src/commands/ClientToServer/NonReversibleExitEventCommand.mjs +0 -26
  59. package/esm2022/src/commands/ClientToServer/QueryCommand.mjs +0 -21
  60. package/esm2022/src/commands/ClientToServer/RecomputeCommand.mjs +0 -30
  61. package/esm2022/src/commands/ClientToServer/RefreshEventCommand.mjs +0 -30
  62. package/esm2022/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +0 -27
  63. package/esm2022/src/commands/ClientToServer/RollbackEventCommand.mjs +0 -43
  64. package/esm2022/src/commands/ClientToServer/SelectProgramCommand.mjs +0 -19
  65. package/esm2022/src/commands/ClientToServer/SetTransactionStateDataviewCommand.mjs +0 -9
  66. package/esm2022/src/commands/ClientToServer/SubformOpenEventCommand.mjs +0 -24
  67. package/esm2022/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +0 -27
  68. package/esm2022/src/commands/ClientToServer/TransactionCommand.mjs +0 -34
  69. package/esm2022/src/commands/ClientToServer/UnloadCommand.mjs +0 -18
  70. package/esm2022/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +0 -18
  71. package/esm2022/src/commands/DataViewCommandBase.mjs +0 -8
  72. package/esm2022/src/commands/IClientCommand.mjs +0 -2
  73. package/esm2022/src/commands/IClientTargetedCommand.mjs +0 -13
  74. package/esm2022/src/commands/IClientToServerCommandInfo.mjs +0 -2
  75. package/esm2022/src/commands/ServerToClient/AbortCommand.mjs +0 -65
  76. package/esm2022/src/commands/ServerToClient/AddLocateCommand.mjs +0 -22
  77. package/esm2022/src/commands/ServerToClient/AddRangeCommand.mjs +0 -62
  78. package/esm2022/src/commands/ServerToClient/AddSortCommand.mjs +0 -33
  79. package/esm2022/src/commands/ServerToClient/ClientRefreshCommand.mjs +0 -25
  80. package/esm2022/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +0 -24
  81. package/esm2022/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +0 -45
  82. package/esm2022/src/commands/ServerToClient/OpenURLCommand.mjs +0 -221
  83. package/esm2022/src/commands/ServerToClient/ResetLocateCommand.mjs +0 -15
  84. package/esm2022/src/commands/ServerToClient/ResetRangeCommand.mjs +0 -15
  85. package/esm2022/src/commands/ServerToClient/ResetSortCommand.mjs +0 -15
  86. package/esm2022/src/commands/ServerToClient/ResultCommand.mjs +0 -37
  87. package/esm2022/src/commands/ServerToClient/VerifyCommand.mjs +0 -83
  88. package/esm2022/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs +0 -132
  89. package/esm2022/src/communications/IConnectionStateManager.mjs +0 -2
  90. package/esm2022/src/communications/InteractiveCommunicationsFailureHandler.mjs +0 -15
  91. package/esm2022/src/data/DataSourceIdKey.mjs +0 -3
  92. package/esm2022/src/data/DataView.mjs +0 -1613
  93. package/esm2022/src/data/DataViewBase.mjs +0 -4
  94. package/esm2022/src/data/DataviewManager.mjs +0 -28
  95. package/esm2022/src/data/DataviewManagerBase.mjs +0 -15
  96. package/esm2022/src/data/DvCache.mjs +0 -67
  97. package/esm2022/src/data/Field.mjs +0 -646
  98. package/esm2022/src/data/FieldBase.mjs +0 -15
  99. package/esm2022/src/data/FieldsTable.mjs +0 -103
  100. package/esm2022/src/data/IRecordsTable.mjs +0 -2
  101. package/esm2022/src/data/Key.mjs +0 -88
  102. package/esm2022/src/data/Record.mjs +0 -880
  103. package/esm2022/src/data/RecordOutOfDataViewException.mjs +0 -16
  104. package/esm2022/src/data/RecordsTable.mjs +0 -267
  105. package/esm2022/src/data/TaskTransactionManager.mjs +0 -107
  106. package/esm2022/src/data/XMLBasedDcValuesBuilder.mjs +0 -74
  107. package/esm2022/src/enums.mjs +0 -24
  108. package/esm2022/src/env/EnvVariablesTable.mjs +0 -340
  109. package/esm2022/src/env/Environment.mjs +0 -487
  110. package/esm2022/src/env/ILanguageData.mjs +0 -2
  111. package/esm2022/src/env/LanguageData.mjs +0 -227
  112. package/esm2022/src/env/MirrorString.mjs +0 -67
  113. package/esm2022/src/event/ActionManager.mjs +0 -91
  114. package/esm2022/src/event/Event.mjs +0 -1333
  115. package/esm2022/src/event/EventHandler.mjs +0 -766
  116. package/esm2022/src/event/EventHandlerPosition.mjs +0 -204
  117. package/esm2022/src/event/EventsManager.mjs +0 -2988
  118. package/esm2022/src/event/IEventsManager.mjs +0 -7
  119. package/esm2022/src/event/RunTimeEvent.mjs +0 -399
  120. package/esm2022/src/event/RunTimeEventBase.mjs +0 -4
  121. package/esm2022/src/event/UserEventsTable.mjs +0 -47
  122. package/esm2022/src/exp/ExpTable.mjs +0 -57
  123. package/esm2022/src/exp/Expression.mjs +0 -200
  124. package/esm2022/src/exp/ExpressionDict.mjs +0 -727
  125. package/esm2022/src/exp/ExpressionEvaluator.mjs +0 -4206
  126. package/esm2022/src/exp/ExpressionLocalJpn.mjs +0 -314
  127. package/esm2022/src/exp/GlobalParamsTable.mjs +0 -85
  128. package/esm2022/src/exp/YesNoExp.mjs +0 -36
  129. package/esm2022/src/gui/CreatedFormVector.mjs +0 -23
  130. package/esm2022/src/gui/FormsTable.mjs +0 -66
  131. package/esm2022/src/gui/MgControl.mjs +0 -363
  132. package/esm2022/src/gui/MgForm.mjs +0 -1224
  133. package/esm2022/src/http/HttpManager.mjs +0 -97
  134. package/esm2022/src/http/client/HttpClientAsync.mjs +0 -68
  135. package/esm2022/src/http/client/HttpClientBase.mjs +0 -132
  136. package/esm2022/src/http/client/HttpClientEvents.mjs +0 -39
  137. package/esm2022/src/http/client/HttpClientSync.mjs +0 -42
  138. package/esm2022/src/http/client/HttpUtility.mjs +0 -84
  139. package/esm2022/src/http/client/ICommunicationsFailureHandler.mjs +0 -2
  140. package/esm2022/src/remote/AddUserLocateRemoteDataViewCommand.mjs +0 -18
  141. package/esm2022/src/remote/AddUserRangeRemoteDataViewCommand.mjs +0 -18
  142. package/esm2022/src/remote/AddUserSortRemoteDataViewCommand.mjs +0 -18
  143. package/esm2022/src/remote/RemoteCommandsProcessor.mjs +0 -883
  144. package/esm2022/src/remote/RemoteControlItemsRefreshCommand.mjs +0 -25
  145. package/esm2022/src/remote/RemoteDataViewCommandBase.mjs +0 -24
  146. package/esm2022/src/remote/RemoteDataViewCommandFactory.mjs +0 -61
  147. package/esm2022/src/remote/RemoteDataViewCommandUpdateNonModifiable.mjs +0 -16
  148. package/esm2022/src/remote/RemoteDataviewManager.mjs +0 -17
  149. package/esm2022/src/remote/RemoteInitDataViewCommand.mjs +0 -11
  150. package/esm2022/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +0 -17
  151. package/esm2022/src/remote/ResetUserRangeRemoteDataviewCommand.mjs +0 -13
  152. package/esm2022/src/remote/ResetUserSortRemoteDataviewCommand.mjs +0 -16
  153. package/esm2022/src/remote/ServerError.mjs +0 -40
  154. package/esm2022/src/remote/SetTransactionStateRemoteDataViewCommand.mjs +0 -20
  155. package/esm2022/src/rt/Argument.mjs +0 -265
  156. package/esm2022/src/rt/ArgumentsList.mjs +0 -103
  157. package/esm2022/src/rt/Boundary.mjs +0 -152
  158. package/esm2022/src/rt/CompMainPrgTable.mjs +0 -63
  159. package/esm2022/src/rt/DataviewHeaderBase.mjs +0 -98
  160. package/esm2022/src/rt/DataviewHeaderFactory.mjs +0 -7
  161. package/esm2022/src/rt/DataviewHeaders.mjs +0 -53
  162. package/esm2022/src/rt/DataviewHeadersSaxHandler.mjs +0 -38
  163. package/esm2022/src/rt/ExecutionStack.mjs +0 -94
  164. package/esm2022/src/rt/ExecutionStackEntry.mjs +0 -17
  165. package/esm2022/src/rt/HandlersTable.mjs +0 -96
  166. package/esm2022/src/rt/IDataSourceViewDefinition.mjs +0 -2
  167. package/esm2022/src/rt/IDataviewHeader.mjs +0 -2
  168. package/esm2022/src/rt/IResultValue.mjs +0 -2
  169. package/esm2022/src/rt/LastFocusedManager.mjs +0 -65
  170. package/esm2022/src/rt/Operation.mjs +0 -735
  171. package/esm2022/src/rt/OperationTable.mjs +0 -67
  172. package/esm2022/src/rt/Recompute.mjs +0 -355
  173. package/esm2022/src/rt/RecomputeTable.mjs +0 -63
  174. package/esm2022/src/rt/RemoteDataviewHeader.mjs +0 -108
  175. package/esm2022/src/rt/ResultValue.mjs +0 -10
  176. package/esm2022/src/rt/TableCache.mjs +0 -177
  177. package/esm2022/src/rt/TableCacheManager.mjs +0 -67
  178. package/esm2022/src/rt/Transaction.mjs +0 -53
  179. package/esm2022/src/security/UserDetails.mjs +0 -71
  180. package/esm2022/src/tasks/IMGDataCollection.mjs +0 -2
  181. package/esm2022/src/tasks/MGData.mjs +0 -552
  182. package/esm2022/src/tasks/MGDataCollection.mjs +0 -252
  183. package/esm2022/src/tasks/RCTimer.mjs +0 -63
  184. package/esm2022/src/tasks/RemoteTaskService.mjs +0 -45
  185. package/esm2022/src/tasks/Task.mjs +0 -2499
  186. package/esm2022/src/tasks/TaskBase.mjs +0 -83
  187. package/esm2022/src/tasks/TaskServiceBase.mjs +0 -25
  188. package/esm2022/src/tasks/TasksTable.mjs +0 -80
  189. package/esm2022/src/tasks/sort/Sort.mjs +0 -5
  190. package/esm2022/src/tasks/sort/SortCollection.mjs +0 -67
  191. package/esm2022/src/util/ConstUtils.mjs +0 -14
  192. package/esm2022/src/util/FlowMonitorQueue.mjs +0 -451
  193. package/esm2022/src/util/HeapSort.mjs +0 -70
  194. package/esm2022/src/util/IMirrorXML.mjs +0 -2
  195. package/esm2022/src/util/IServerConfig.mjs +0 -2
  196. package/esm2022/src/util/MgBlockingQueue.mjs +0 -2
  197. package/esm2022/src/util/MgPriorityBlockingQueue.mjs +0 -74
  198. package/esm2022/src/util/MgPriorityQueue.mjs +0 -66
  199. package/esm2022/src/util/ParamParseResult.mjs +0 -8
  200. package/esm2022/src/util/PrmMap.mjs +0 -153
  201. package/esm2022/src/util/ReturnResult.mjs +0 -46
  202. package/esm2022/src/util/ReturnResultBase.mjs +0 -18
  203. package/esm2022/src/util/Scrambler.mjs +0 -89
  204. package/esm2022/src/util/UniqueIDUtils.mjs +0 -13
  205. package/esm2022/src/util/cookie.service.mjs +0 -92
@@ -1,97 +0,0 @@
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"]}
@@ -1,68 +0,0 @@
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":"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","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"]}
@@ -1,132 +0,0 @@
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"]}
@@ -1,39 +0,0 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cENsaWVudEV2ZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VuZ2luZS9zcmMvaHR0cC9jbGllbnQvSHR0cENsaWVudEV2ZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLE1BQU0sQ0FBQyxpQ0FBaUMsR0FBaUIsSUFBSSxDQUFDO0lBQzlELE1BQU0sQ0FBQywwQkFBMEIsR0FBcUMsSUFBSSxDQUFDO0lBQzNFLE1BQU0sQ0FBQyw4QkFBOEIsR0FBaUIsSUFBSSxDQUFDO0lBQzNELE1BQU0sQ0FBQywrQkFBK0IsR0FBa0IsSUFBSSxDQUFDO0lBQzdELE1BQU0sQ0FBQyxxQkFBcUIsR0FBaUIsSUFBSSxDQUFDO0lBQ2xELE1BQU0sQ0FBQyx1QkFBdUIsR0FBaUIsSUFBSSxDQUFDO0lBQ3BELE1BQU0sQ0FBQywrQkFBK0IsR0FBNEIsSUFBSSxDQUFDO0lBQ3ZFLE1BQU0sQ0FBQyw4QkFBOEIsR0FBbUYsSUFBSSxDQUFDO0lBRTdILE1BQU0sQ0FBQywyQkFBMkI7UUFDaEMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLGlDQUFpQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxpQ0FBaUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDckksQ0FBQztJQUVELE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxZQUFvQjtRQUM5QyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsMEJBQTBCLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLDBCQUEwQixDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbkksQ0FBQztJQUVELE1BQU0sQ0FBQyx3QkFBd0I7UUFDN0IsT0FBTyxDQUFDLGdCQUFnQixDQUFDLDhCQUE4QixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyw4QkFBOEIsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDL0gsQ0FBQztJQUVELE1BQU0sQ0FBQyx5QkFBeUI7UUFDOUIsT0FBTyxnQkFBZ0IsQ0FBQywrQkFBK0IsS0FBSyxJQUFJLElBQUksZ0JBQWdCLENBQUMsK0JBQStCLEVBQUUsQ0FBQztJQUN6SCxDQUFDO0lBRUQsTUFBTSxDQUFDLGVBQWU7UUFDcEIsT0FBTyxDQUFDLGdCQUFnQixDQUFDLHFCQUFxQixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDM0csQ0FBQztJQUVELE1BQU0sQ0FBQyxpQkFBaUI7UUFDdEIsT0FBTyxDQUFDLGdCQUFnQixDQUFDLHVCQUF1QixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyx1QkFBdUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDOUcsQ0FBQztJQUVELE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxLQUFhO1FBQzVDLElBQUksSUFBSSxHQUFZLGdCQUFnQixDQUFDLCtCQUErQixLQUFLLElBQUksQ0FBQztRQUM5RSxJQUFJLElBQUksRUFBRTtZQUNSLGdCQUFnQixDQUFDLCtCQUErQixDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3pEO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxhQUFxQixFQUFFLFNBQWlCLEVBQUUsaUJBQTBCO1FBQ2xHLElBQUksZ0JBQWdCLENBQUMsOEJBQThCLEtBQUssSUFBSTtZQUMxRCxnQkFBZ0IsQ0FBQyw4QkFBOEIsQ0FBQyxhQUFhLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixDQUFDLENBQUM7SUFDakcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBIdHRwQ2xpZW50RXZlbnRzIHtcclxuICBzdGF0aWMgR2V0SHR0cENvbW11bmljYXRpb25UaW1lb3V0X0V2ZW50OiAoKSA9PiBudW1iZXIgPSBudWxsO1xyXG4gIHN0YXRpYyBHZXRFeGVjdXRpb25Qcm9wZXJ0eV9FdmVudDogKHByb3BlcnR5TmFtZTogc3RyaW5nKSA9PiBzdHJpbmcgPSBudWxsO1xyXG4gIHN0YXRpYyBHZXRHbG9iYWxVbmlxdWVTZXNzaW9uSURfRXZlbnQ6ICgpID0+IHN0cmluZyA9IG51bGw7XHJcbiAgc3RhdGljIFNob3VsZERpc3BsYXlHZW5lcmljRXJyb3JfRXZlbnQ6ICgpID0+IGJvb2xlYW4gPSBudWxsO1xyXG4gIHN0YXRpYyBHZXRSdW50aW1lQ3R4SURfRXZlbnQ6ICgpID0+IHN0cmluZyA9IG51bGw7XHJcbiAgc3RhdGljIEdldFNlc3Npb25Db3VudGVyX0V2ZW50OiAoKSA9PiBudW1iZXIgPSBudWxsO1xyXG4gIHN0YXRpYyBDaGVja0FuZFNldFNlc3Npb25Db3VudGVyX0V2ZW50OiAodmFsdWU6IG51bWJlcikgPT4gdm9pZCA9IG51bGw7XHJcbiAgc3RhdGljIENvbXB1dGVBbmRMb2dSZXF1ZXN0SW5mb19FdmVudDogKGNvbnRlbnRMZW5ndGg6IG51bWJlciwgcm91bmRUcmlwOiBudW1iZXIsIGlzTG9nZ2luZ1Jlc3BvbnNlOiBib29sZWFuKSA9PiB2b2lkID0gbnVsbDtcclxuXHJcbiAgc3RhdGljIEdldEh0dHBDb21tdW5pY2F0aW9uVGltZW91dCgpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIChIdHRwQ2xpZW50RXZlbnRzLkdldEh0dHBDb21tdW5pY2F0aW9uVGltZW91dF9FdmVudCAhPT0gbnVsbCkgPyBIdHRwQ2xpZW50RXZlbnRzLkdldEh0dHBDb21tdW5pY2F0aW9uVGltZW91dF9FdmVudCgpIDogNTAwMDtcclxuICB9XHJcblxyXG4gIHN0YXRpYyBHZXRFeGVjdXRpb25Qcm9wZXJ0eShwcm9wZXJ0eU5hbWU6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gKEh0dHBDbGllbnRFdmVudHMuR2V0RXhlY3V0aW9uUHJvcGVydHlfRXZlbnQgIT09IG51bGwpID8gSHR0cENsaWVudEV2ZW50cy5HZXRFeGVjdXRpb25Qcm9wZXJ0eV9FdmVudChwcm9wZXJ0eU5hbWUpIDogbnVsbDtcclxuICB9XHJcblxyXG4gIHN0YXRpYyBHZXRHbG9iYWxVbmlxdWVTZXNzaW9uSUQoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiAoSHR0cENsaWVudEV2ZW50cy5HZXRHbG9iYWxVbmlxdWVTZXNzaW9uSURfRXZlbnQgIT09IG51bGwpID8gSHR0cENsaWVudEV2ZW50cy5HZXRHbG9iYWxVbmlxdWVTZXNzaW9uSURfRXZlbnQoKSA6IG51bGw7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgU2hvdWxkRGlzcGxheUdlbmVyaWNFcnJvcigpOiBib29sZWFuIHtcclxuICAgIHJldHVybiBIdHRwQ2xpZW50RXZlbnRzLlNob3VsZERpc3BsYXlHZW5lcmljRXJyb3JfRXZlbnQgPT09IG51bGwgfHwgSHR0cENsaWVudEV2ZW50cy5TaG91bGREaXNwbGF5R2VuZXJpY0Vycm9yX0V2ZW50KCk7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgR2V0UnVudGltZUN0eElEKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gKEh0dHBDbGllbnRFdmVudHMuR2V0UnVudGltZUN0eElEX0V2ZW50ICE9PSBudWxsKSA/IEh0dHBDbGllbnRFdmVudHMuR2V0UnVudGltZUN0eElEX0V2ZW50KCkgOiBcIlwiO1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIEdldFNlc3Npb25Db3VudGVyKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gKEh0dHBDbGllbnRFdmVudHMuR2V0U2Vzc2lvbkNvdW50ZXJfRXZlbnQgIT09IG51bGwpID8gSHR0cENsaWVudEV2ZW50cy5HZXRTZXNzaW9uQ291bnRlcl9FdmVudCgpIDogMDtcclxuICB9XHJcblxyXG4gIHN0YXRpYyBDaGVja0FuZFNldFNlc3Npb25Db3VudGVyKHZhbHVlOiBudW1iZXIpOiB2b2lkIHtcclxuICAgIGxldCBmbGFnOiBib29sZWFuID0gSHR0cENsaWVudEV2ZW50cy5DaGVja0FuZFNldFNlc3Npb25Db3VudGVyX0V2ZW50ICE9PSBudWxsO1xyXG4gICAgaWYgKGZsYWcpIHtcclxuICAgICAgSHR0cENsaWVudEV2ZW50cy5DaGVja0FuZFNldFNlc3Npb25Db3VudGVyX0V2ZW50KHZhbHVlKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHN0YXRpYyBDb21wdXRlQW5kTG9nUmVxdWVzdEluZm8oY29udGVudExlbmd0aDogbnVtYmVyLCByb3VuZFRyaXA6IG51bWJlciwgaXNMb2dnaW5nUmVzcG9uc2U6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIGlmIChIdHRwQ2xpZW50RXZlbnRzLkNvbXB1dGVBbmRMb2dSZXF1ZXN0SW5mb19FdmVudCAhPT0gbnVsbClcclxuICAgICAgSHR0cENsaWVudEV2ZW50cy5Db21wdXRlQW5kTG9nUmVxdWVzdEluZm9fRXZlbnQoY29udGVudExlbmd0aCwgcm91bmRUcmlwLCBpc0xvZ2dpbmdSZXNwb25zZSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -1,42 +0,0 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cENsaWVudFN5bmMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL2h0dHAvY2xpZW50L0h0dHBDbGllbnRTeW5jLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxPQUFPLEVBQVcsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsY0FBYyxFQUFnQixNQUFNLGtCQUFrQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxNQUFNLEVBQUUsZ0JBQWdCLEVBQUUsdUJBQXVCLEVBQUUsSUFBSSxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDekYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sb0JBQW9CLENBQUM7QUFJcEQsTUFBTSxPQUFPLGNBQWUsU0FBUSxjQUFjO0lBRXhDLFdBQVcsR0FBbUIsSUFBSSxDQUFDO0lBQ25DLE9BQU8sR0FBWSxJQUFJLE9BQU8sRUFBRSxDQUFDO0lBRXpDO1FBRUUsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBRUQsY0FBYztJQUVkLENBQUM7SUFFRCxVQUFVLENBQUMsU0FBaUIsRUFBRSxRQUFpQixFQUFFLFdBQXdCLEVBQUUsUUFBZ0I7UUFFekYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEVBQzlCO1lBQ0UsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsK0JBQStCLEVBQUUsUUFBUSxDQUFDLENBQUM7U0FDaEU7UUFFRCxJQUFJLENBQUMsUUFBUSxFQUNiO1lBQ0UsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsZUFBZSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQ2xEO1FBRUQsT0FBTyxXQUFXLENBQUM7SUFDckIsQ0FBQztJQUVELEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxVQUF5QixFQUFFLFNBQWlCLEVBQUUsV0FBd0IsRUFBRSxjQUFzQixFQUFFLGlCQUFtQztRQUczSixNQUFNLEtBQUssQ0FBQyxTQUFTLEVBQUUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxjQUFjLEVBQUUsU0FBUyxFQUFDLElBQUksRUFBRSxDQUFDLENBQUM7UUFFeEcsT0FBTyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxXQUFXLENBQUMsWUFBa0MsRUFBRSxRQUFnQixFQUFFLFNBQWlCLEVBQUUsaUJBQWdDLEVBQUUsaUJBQXlCO1FBRTlJLElBQUksWUFBWSxHQUFXLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxHQUFHLGlCQUFpQixDQUFDO1FBRTVFLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEtBQUssZ0JBQWdCLENBQUMsS0FBSztZQUNyRCxNQUFNLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyx1QkFBdUIsQ0FBQyxlQUFlLEVBQ3ZDLGdCQUFnQixDQUFDLGVBQWUsRUFBRSxFQUNsQyxnQkFBZ0IsQ0FBQyxpQkFBaUIsRUFBRSxFQUNwQyxRQUFRLEVBQ1IsZ0JBQWdCLENBQUMseUJBQXlCLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLEVBQzVFLFlBQVksRUFDWixJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsRUFDbEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLHFCQUFxQixFQUFFLENBQUMsRUFDeEQsaUJBQWlCLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3BFLENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxFQUFPLEVBQUUsU0FBaUI7UUFHakQsTUFBTSxFQUFFLENBQUM7SUFDWCxDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQVcsQ0FBQywwQkFBa0MsRUFBRSxTQUFpQixFQUFFLDRCQUEyRCxFQUFFLEVBQU8sRUFBRSxZQUE4QjtRQUczSyxPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVELG9CQUFvQixDQUFDLEVBQUU7SUFHdkIsQ0FBQztJQUVELG9CQUFvQixDQUFDLGlCQUF5QjtJQUc5QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0h0dHBIZWFkZXJzLCBIdHRwUmVzcG9uc2V9IGZyb20gXCJAYW5ndWxhci9jb21tb24vaHR0cFwiO1xyXG5pbXBvcnQge05TdHJpbmcsIFJlZlBhcmFtfSBmcm9tIFwiQG1hZ2ljLXhwYS9tc2NvcmVsaWJcIjtcclxuaW1wb3J0IHtIdHRwQ2xpZW50QmFzZSwgUmVxdWVzdE1ldGhvZH0gZnJvbSBcIi4vSHR0cENsaWVudEJhc2VcIjtcclxuaW1wb3J0IHtMb2dnZXIsIExvZ2dlcl9Mb2dMZXZlbHMsIExvZ2dlcl9NZXNzYWdlRGlyZWN0aW9uLCBNaXNjfSBmcm9tIFwiQG1hZ2ljLXhwYS91dGlsc1wiO1xyXG5pbXBvcnQge0h0dHBDbGllbnRFdmVudHN9IGZyb20gXCIuL0h0dHBDbGllbnRFdmVudHNcIjtcclxuaW1wb3J0IHtJQ29tbXVuaWNhdGlvbnNGYWlsdXJlSGFuZGxlcn0gZnJvbSBcIi4vSUNvbW11bmljYXRpb25zRmFpbHVyZUhhbmRsZXJcIjtcclxuXHJcbi8vIEEgY2xhc3MgdXNpbmcgSHR0cCBTeW5jIExpYnJhcnlcclxuZXhwb3J0IGNsYXNzIEh0dHBDbGllbnRTeW5jIGV4dGVuZHMgSHR0cENsaWVudEJhc2Vcclxue1xyXG4gIHByaXZhdGUgaHR0cFJlcXVlc3Q6IFhNTEh0dHBSZXF1ZXN0ID0gbnVsbDtcclxuICBwcml2YXRlIGhlYWRlcnM6IEhlYWRlcnMgPSBuZXcgSGVhZGVycygpO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpXHJcbiAge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcblxyXG4gIHByZXBhcmVSZXF1ZXN0KClcclxuICB7XHJcbiAgfVxyXG5cclxuICBhZGRIZWFkZXJzKHVybFN0cmluZzogc3RyaW5nLCB1c2VDYWNoZTogYm9vbGVhbiwgaHR0cEhlYWRlcnM6IEh0dHBIZWFkZXJzLCBjbGllbnRJRDogc3RyaW5nKTogSHR0cEhlYWRlcnNcclxuICB7XHJcbiAgICBpZiAoIXVybFN0cmluZy5zdGFydHNXaXRoKFwiL1wiKSlcclxuICAgIHtcclxuICAgICAgdGhpcy5oZWFkZXJzLmFwcGVuZChcIk1neHBhUklBZ2xvYmFsVW5pcXVlU2Vzc2lvbklEXCIsIGNsaWVudElEKTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAoIXVzZUNhY2hlKVxyXG4gICAge1xyXG4gICAgICB0aGlzLmhlYWRlcnMuYXBwZW5kKFwiQ2FjaGUtQ29udHJvbFwiLCBcIm5vLWNhY2hlXCIpO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBodHRwSGVhZGVycztcclxuICB9XHJcblxyXG4gIGFzeW5jIHNlbmRSZXF1ZXN0VG9TZXJ2ZXIoaHR0cE1ldGhvZDogUmVxdWVzdE1ldGhvZCwgdXJsU3RyaW5nOiBzdHJpbmcsIGh0dHBIZWFkZXJzOiBIdHRwSGVhZGVycywgcmVxdWVzdENvbnRlbnQ6IHN0cmluZywgY29udGVudEZyb21TZXJ2ZXI6IFJlZlBhcmFtPHN0cmluZz4pOiBQcm9taXNlPGFueT5cclxuICB7XHJcbiAgICAvLyBTZW5kIHRoZSBlbmdpbmUgdGVybWluYXRpb24gcmVxdWVzdCB0byBzZXJ2ZXIuXHJcbiAgICBhd2FpdCBmZXRjaCh1cmxTdHJpbmcsIHsgbWV0aG9kOiAnUE9TVCcsIGhlYWRlcnM6IHRoaXMuaGVhZGVycywgYm9keTogcmVxdWVzdENvbnRlbnQsIGtlZXBhbGl2ZTp0cnVlIH0pO1xyXG5cclxuICAgIHJldHVybiBOU3RyaW5nLkVtcHR5O1xyXG4gIH1cclxuXHJcbiAgbG9nUmVzcG9uc2UoaHR0cFJlc3BvbnNlOiBIdHRwUmVzcG9uc2U8c3RyaW5nPiwgY2xpZW50SUQ6IHN0cmluZywgdXJsU3RyaW5nOiBzdHJpbmcsIGNvbnRlbnRGcm9tU2VydmVyOiBSZWZQYXJhbTxhbnk+LCB0aW1lQmVmb3JlUmVxdWVzdDogbnVtYmVyKVxyXG4gIHtcclxuICAgIGxldCByZXNwb25zZVRpbWU6IG51bWJlciA9IE1pc2MuZ2V0U3lzdGVtTWlsbGlzZWNvbmRzKCkgLSB0aW1lQmVmb3JlUmVxdWVzdDtcclxuXHJcbiAgICBpZiAoTG9nZ2VyLkluc3RhbmNlLkxvZ0xldmVsID09PSBMb2dnZXJfTG9nTGV2ZWxzLkJhc2ljKVxyXG4gICAgICBMb2dnZXIuSW5zdGFuY2UuV3JpdGVCYXNpY1RvTG9nKExvZ2dlcl9NZXNzYWdlRGlyZWN0aW9uLk1lc3NhZ2VFbnRlcmluZyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBIdHRwQ2xpZW50RXZlbnRzLkdldFJ1bnRpbWVDdHhJRCgpLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEh0dHBDbGllbnRFdmVudHMuR2V0U2Vzc2lvbkNvdW50ZXIoKSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjbGllbnRJRCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBIdHRwQ2xpZW50RXZlbnRzLlNob3VsZERpc3BsYXlHZW5lcmljRXJyb3IoKSA/IFwiLVwiIDogbmV3IFVSTCh1cmxTdHJpbmcpLmhvc3QsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmVzcG9uc2VUaW1lLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuaHR0cFJlcXVlc3Quc3RhdHVzLnRvU3RyaW5nKCksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSlNPTi5zdHJpbmdpZnkodGhpcy5odHRwUmVxdWVzdC5nZXRBbGxSZXNwb25zZUhlYWRlcnMoKSksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29udGVudEZyb21TZXJ2ZXIudmFsdWUubGVuZ3RoKTtcclxuICB9XHJcblxyXG4gIGhhbmRsZUh0dHBFcnJvckV4Y2VwdGlvbihleDogYW55LCB1cmxTdHJpbmc6IHN0cmluZylcclxuICB7XHJcbiAgICAvLyBObyBleGNlcHRpb24gaGFuZGxpbmcgZm9yIGxhc3QgcmVxdWVzdCBhbmQgaGVuY2UganVzdCB0aHJvdyB0aGUgZXhjZXB0aW9uXHJcbiAgICB0aHJvdyBleDtcclxuICB9XHJcblxyXG4gIGFzeW5jIHNob3VsZFJldHJ5KGh0dHBDb21tdW5pY2F0aW9uVGltZW91dE1TOiBudW1iZXIsIHVybFN0cmluZzogc3RyaW5nLCBjb21tdW5pY2F0aW9uc0ZhaWx1cmVIYW5kbGVyOiBJQ29tbXVuaWNhdGlvbnNGYWlsdXJlSGFuZGxlciwgZXg6IGFueSwgc3RhcnRUaW1lUmVmOiBSZWZQYXJhbTxudW1iZXI+KTogUHJvbWlzZTxib29sZWFuPlxyXG4gIHtcclxuICAgIC8vIE5vIHJldHJ5IHN1cHBvcnRlZCBvbiBsYXN0IHJlcXVlc3RcclxuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoZmFsc2UpO1xyXG4gIH1cclxuXHJcbiAgbG9nQW5kVGhyb3dFeGNlcHRpb24oZXgpXHJcbiAge1xyXG4gICAgLy8gTi5BLlxyXG4gIH1cclxuXHJcbiAgbG9nRXhlY3V0aW9uQXR0ZW1wdHMoZXhlY3V0aW9uQXR0ZW1wdHM6IG51bWJlcilcclxuICB7XHJcbiAgICAvLyBOLkEuXHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -1,84 +0,0 @@
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 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUNvbW11bmljYXRpb25zRmFpbHVyZUhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL2h0dHAvY2xpZW50L0lDb21tdW5pY2F0aW9uc0ZhaWx1cmVIYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuZXhwb3J0IGludGVyZmFjZSBJQ29tbXVuaWNhdGlvbnNGYWlsdXJlSGFuZGxlciB7XHJcbiAgLy8vIDxzdW1tYXJ5PlxyXG4gIC8vLyBHZXRzIGEgdmFsdWUgZGV0ZXJtaW5pbmcgd2hldGhlciB0aGUgY2FsbGVyIHNob3VsZCByZXRyeSBleGVjdXRpbmcgdGhlXHJcbiAgLy8vIGNvbW11bmljYXRpb25zIHJlcXVlc3QsIHdoaWNoIHdhcyBzZW50IHdoZW4gdGhlIGZhaWx1cmUgb2NjdXJyZWQuXHJcbiAgLy8vIDwvc3VtbWFyeT5cclxuICBTaG91bGRSZXRyeUxhc3RSZXF1ZXN0OiBib29sZWFuO1xyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIEdldHMgYSB2YWx1ZSBkZXRlcm1pbmluZyB3aGV0aGVyIHRoZSBjYWxsZXIgc2hvdWxkIHNob3cgdGhlXHJcbiAgLy8vIGNvbW11bmljYXRpb25zIGVycm9ycy5cclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIFNob3dDb21tdW5pY2F0aW9uRXJyb3JzOiBib29sZWFuO1xyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIFRoaXMgbWV0aG9kIGlzIHVzZWQgdG8gbm90aWZ5IHRoZSBpbXBsZW1lbnRpbmcgY2xhc3MgdGhhdCB0aGUgY29ubmVjdGlvbiBmYWlsZWQuXHJcbiAgLy8vIFRoZSBzcGVjaWZpYyBtZXRob2QgaW1wbGVtZW50YXRpb24gaXMgbm93IGZyZWUgdG8gZG8gd2hhdGV2ZXIgaXMgbmVlZGVkIGF0IHRoaXNcclxuICAvLy8gcG9pbnQsIHN1Y2ggYXMgZGlzcGxheWluZyBhIG5vdGlmaWNhdGlvbiBtZXNzYWdlIHRvIHRoZSB1c2VyLCBvciBkZXRlcm1pbmluZ1xyXG4gIC8vLyBuZXh0IGFjdGlvbnMgYXV0b21hdGljYWxseS5cclxuICAvLy8gPC9zdW1tYXJ5PlxyXG4gIC8vLyA8cGFyYW0gbmFtZT1cInVybFwiPlRoZSBmYWlsaW5nIFVSTC48L3BhcmFtPlxyXG4gIC8vLyA8cGFyYW0gbmFtZT1cImZhaWx1cmVFeGNlcHRpb25cIj5UaGUgZXhjZXB0aW9uIHJhaXNlZCB3aGVuIHRoZSBmYWlsdXJlIHdhcyBkZXRlY3RlZC48L3BhcmFtPlxyXG4gIENvbW11bmljYXRpb25GYWlsZWQodXJsOiBzdHJpbmcsIGZhaWx1cmVFeGNlcHRpb246IEVycm9yKTogdm9pZDtcclxufVxyXG4iXX0=