@magic-xpa/engine 4.801.0-dev481.242 → 4.801.0-dev481.243
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.
- package/bundles/magic-xpa-engine.umd.js +45 -45
- package/bundles/magic-xpa-engine.umd.js.map +1 -1
- package/bundles/magic-xpa-engine.umd.min.js +2 -2
- package/bundles/magic-xpa-engine.umd.min.js.map +1 -1
- package/esm2015/src/CommandsProcessorBase.js +2 -2
- package/esm2015/src/CurrentClientVersion.js +2 -2
- package/esm2015/src/commands/ClientToServer/BrowserEscEventCommand.js +2 -3
- package/esm2015/src/data/DataView.js +2 -3
- package/esm2015/src/data/Field.js +2 -3
- package/esm2015/src/data/Record.js +2 -3
- package/esm2015/src/env/LanguageData.js +2 -3
- package/esm2015/src/event/EventHandler.js +2 -3
- package/esm2015/src/event/EventHandlerPosition.js +2 -2
- package/esm2015/src/event/EventsManager.js +2 -3
- package/esm2015/src/exp/ExpressionEvaluator.js +2 -3
- package/esm2015/src/gui/MgForm.js +2 -3
- package/esm2015/src/http/client/HttpClientBase.js +2 -3
- package/esm2015/src/remote/RemoteCommandsProcessor.js +2 -3
- package/esm2015/src/remote/ServerError.js +2 -3
- package/esm2015/src/rt/DataviewHeadersSaxHandler.js +2 -3
- package/esm2015/src/tasks/Task.js +2 -3
- package/fesm2015/magic-xpa-engine.js +2 -3
- package/fesm2015/magic-xpa-engine.js.map +1 -1
- package/package.json +4 -4
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { NString, RefParam, StringBuilder } from "@magic-xpa/mscorelib";
|
|
2
|
+
import { NString, RefParam, StringBuilder, isNullOrUndefined } from "@magic-xpa/mscorelib";
|
|
3
3
|
import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
|
|
4
|
-
import { isNullOrUndefined } from "util";
|
|
5
4
|
import { HttpClientEvents } from "./HttpClientEvents";
|
|
6
5
|
import { HttpHeaders } from "@angular/common/http";
|
|
7
6
|
const HTTP_EXPECT100CONTINUE = "Expect100Continue";
|
|
@@ -145,4 +144,4 @@ export class HttpClientBase {
|
|
|
145
144
|
return result;
|
|
146
145
|
}
|
|
147
146
|
}
|
|
148
|
-
//# 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} from \"@magic-xpa/mscorelib\";\r\nimport {Logger, Logger_LogLevels, Logger_MessageDirection, Misc} from \"@magic-xpa/utils\";\r\nimport {ICommunicationsFailureHandler} from \"./ICommunicationsFailureHandler\";\r\nimport {isNullOrUndefined} from \"util\";\r\nimport {HttpClientEvents} from \"./HttpClientEvents\";\r\nimport {HttpHeaders, HttpResponse} from \"@angular/common/http\";\r\n\r\n// execution properties\r\nconst HTTP_EXPECT100CONTINUE: string = \"Expect100Continue\"; // Add HTTP header \"Expect:100Continue\"\r\nconst USE_HIGHEST_SECURITY_PROTOCOL: string = \"UseHighestSecurityProtocol\"; // This property decides to use TLS v1.2 (implemented at .NET v4.5) or TLS v1.0\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  /// <summary>Return the property which decide whether to set HTTP header \"Expect:100Continue\"</summary>\r\n  /// <returns>bool</returns>\r\n  private static GetHTTPExpect100Continue(): boolean {\r\n    let result: boolean = true;\r\n    let executionProperty: string = HttpClientEvents.GetExecutionProperty(HTTP_EXPECT100CONTINUE);\r\n\r\n    // In case the property is not given in the execution properties, it should default to true\r\n    if (!NString.IsNullOrEmpty(executionProperty))\r\n      result = (executionProperty.toUpperCase() === \"Y\");\r\n\r\n    return result;\r\n  }\r\n\r\n  /// <summary>Return the property which allows to use TLS v1.2 (implemented at .NET v4.5) as a highest TLS protocol version.\r\n  /// Otherwise use TLS v1.0 as a highest TLS protocol version</summary>\r\n  /// <returns>bool</returns>\r\n  private static GetUseHighestSecurityProtocol(): boolean {\r\n    let result: boolean = false;\r\n    let executionProperty: string = HttpClientEvents.GetExecutionProperty(USE_HIGHEST_SECURITY_PROTOCOL);\r\n\r\n    // In case the property is not given in the execution properties, it should default to false (a highest TLS protocol version is v1.0)\r\n    if (!NString.IsNullOrEmpty(executionProperty))\r\n      result = (executionProperty.toUpperCase() === \"Y\");\r\n\r\n    return result;\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  abstract async sendRequestToServer(httpMethod: RequestMethod, urlString: string, httpHeaders: HttpHeaders, requestContent: string, contentFromServer: RefParam<string>): Promise<any>;\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  abstract async shouldRetry(httpCommunicationTimeoutMS: number, urlString: string, communicationsFailureHandler: ICommunicationsFailureHandler, ex: any, startTimeRef: RefParam<number>);\r\n  abstract logAndThrowException(ex: any);\r\n  abstract logExecutionAttempts(executionAttempts: number);\r\n}\r\n"]}
|
|
147
|
+
//# 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// execution properties\r\nconst HTTP_EXPECT100CONTINUE: string = \"Expect100Continue\"; // Add HTTP header \"Expect:100Continue\"\r\nconst USE_HIGHEST_SECURITY_PROTOCOL: string = \"UseHighestSecurityProtocol\"; // This property decides to use TLS v1.2 (implemented at .NET v4.5) or TLS v1.0\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  /// <summary>Return the property which decide whether to set HTTP header \"Expect:100Continue\"</summary>\r\n  /// <returns>bool</returns>\r\n  private static GetHTTPExpect100Continue(): boolean {\r\n    let result: boolean = true;\r\n    let executionProperty: string = HttpClientEvents.GetExecutionProperty(HTTP_EXPECT100CONTINUE);\r\n\r\n    // In case the property is not given in the execution properties, it should default to true\r\n    if (!NString.IsNullOrEmpty(executionProperty))\r\n      result = (executionProperty.toUpperCase() === \"Y\");\r\n\r\n    return result;\r\n  }\r\n\r\n  /// <summary>Return the property which allows to use TLS v1.2 (implemented at .NET v4.5) as a highest TLS protocol version.\r\n  /// Otherwise use TLS v1.0 as a highest TLS protocol version</summary>\r\n  /// <returns>bool</returns>\r\n  private static GetUseHighestSecurityProtocol(): boolean {\r\n    let result: boolean = false;\r\n    let executionProperty: string = HttpClientEvents.GetExecutionProperty(USE_HIGHEST_SECURITY_PROTOCOL);\r\n\r\n    // In case the property is not given in the execution properties, it should default to false (a highest TLS protocol version is v1.0)\r\n    if (!NString.IsNullOrEmpty(executionProperty))\r\n      result = (executionProperty.toUpperCase() === \"Y\");\r\n\r\n    return result;\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  abstract async sendRequestToServer(httpMethod: RequestMethod, urlString: string, httpHeaders: HttpHeaders, requestContent: string, contentFromServer: RefParam<string>): Promise<any>;\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  abstract async shouldRetry(httpCommunicationTimeoutMS: number, urlString: string, communicationsFailureHandler: ICommunicationsFailureHandler, ex: any, startTimeRef: RefParam<number>);\r\n  abstract logAndThrowException(ex: any);\r\n  abstract logExecutionAttempts(executionAttempts: number);\r\n}\r\n"]}
|