@magic-xpa/engine 4.801.0-dev481.245 → 4.801.0-dev481.253
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/{esm2015/index.js → esm2020/index.mjs} +0 -0
- package/{esm2015/magic-xpa-engine.js → esm2020/magic-xpa-engine.mjs} +0 -0
- package/{esm2015/src/AccessHelper.js → esm2020/src/AccessHelper.mjs} +0 -0
- package/esm2020/src/ClientManager.mjs +403 -0
- package/esm2020/src/CommandsProcessorBase.mjs +58 -0
- package/esm2020/src/CommandsProcessorManager.mjs +26 -0
- package/esm2020/src/CommandsTable.mjs +163 -0
- package/{esm2015/src/ConstInterface.js → esm2020/src/ConstInterface.mjs} +0 -0
- package/{esm2015/src/CurrentClientVersion.js → esm2020/src/CurrentClientVersion.mjs} +2 -2
- package/{esm2015/src/FlowMonitorInterface.js → esm2020/src/FlowMonitorInterface.mjs} +0 -0
- package/esm2020/src/GUIManager.mjs +63 -0
- package/{esm2015/src/GlobalCommandsManager.js → esm2020/src/GlobalCommandsManager.mjs} +0 -0
- package/{esm2015/src/GuiEventsProcessor.js → esm2020/src/GuiEventsProcessor.mjs} +0 -0
- package/{esm2015/src/ICommandsTable.js → esm2020/src/ICommandsTable.mjs} +1 -0
- package/{esm2015/src/ServerConfig.js → esm2020/src/ServerConfig.mjs} +0 -0
- package/{esm2015/src/bridge/IGuiEvent.js → esm2020/src/bridge/IGuiEvent.mjs} +0 -0
- package/esm2020/src/bridge/MagicBridge.mjs +41 -0
- package/{esm2015/src/commands/ClientOriginatedCommandTaskTag.js → esm2020/src/commands/ClientOriginatedCommandTaskTag.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/AddUserLocateDataViewCommand.js → esm2020/src/commands/ClientToServer/AddUserLocateDataViewCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/AddUserRangeDataviewCommand.js → esm2020/src/commands/ClientToServer/AddUserRangeDataviewCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/AddUserSortDataViewCommand.js → esm2020/src/commands/ClientToServer/AddUserSortDataViewCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/BrowserEscEventCommand.js → esm2020/src/commands/ClientToServer/BrowserEscEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ClientOriginatedCommand.js → esm2020/src/commands/ClientToServer/ClientOriginatedCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ClientOriginatedCommandSerializer.js → esm2020/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ColumnSortEventCommand.js → esm2020/src/commands/ClientToServer/ColumnSortEventCommand.mjs} +0 -0
- package/esm2020/src/commands/ClientToServer/CommandFactory.mjs +278 -0
- package/{esm2015/src/commands/ClientToServer/CommandSerializationHelper.js → esm2020/src/commands/ClientToServer/CommandSerializationHelper.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ComputeEventCommand.js → esm2020/src/commands/ClientToServer/ComputeEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ContextTerminationEventCommand.js → esm2020/src/commands/ClientToServer/ContextTerminationEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ContextTimeoutResetCommand.js → esm2020/src/commands/ClientToServer/ContextTimeoutResetCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ControlItemsRefreshCommand.js → esm2020/src/commands/ClientToServer/ControlItemsRefreshCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/DataViewOutputCommand.js → esm2020/src/commands/ClientToServer/DataViewOutputCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/DataviewCommand.js → esm2020/src/commands/ClientToServer/DataviewCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/EvaluateCommand.js → esm2020/src/commands/ClientToServer/EvaluateCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/EventCommand.js → esm2020/src/commands/ClientToServer/EventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ExecOperCommand.js → esm2020/src/commands/ClientToServer/ExecOperCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/FetchDataControlValuesEventCommand.js → esm2020/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/GlobalParamsQueryCommand.js → esm2020/src/commands/ClientToServer/GlobalParamsQueryCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/ICommandTaskTag.js → esm2020/src/commands/ClientToServer/ICommandTaskTag.mjs} +1 -0
- package/{esm2015/src/commands/ClientToServer/IndexChangeEventCommand.js → esm2020/src/commands/ClientToServer/IndexChangeEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/IniputForceWriteCommand.js → esm2020/src/commands/ClientToServer/IniputForceWriteCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/NonReversibleExitEventCommand.js → esm2020/src/commands/ClientToServer/NonReversibleExitEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/QueryCommand.js → esm2020/src/commands/ClientToServer/QueryCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/RecomputeCommand.js → esm2020/src/commands/ClientToServer/RecomputeCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/RefreshEventCommand.js → esm2020/src/commands/ClientToServer/RefreshEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/RefreshScreenEventCommand.js → esm2020/src/commands/ClientToServer/RefreshScreenEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/RollbackEventCommand.js → esm2020/src/commands/ClientToServer/RollbackEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/SelectProgramCommand.js → esm2020/src/commands/ClientToServer/SelectProgramCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/SetTransactionStateDataviewCommand.js → esm2020/src/commands/ClientToServer/SetTransactionStateDataviewCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/SubformOpenEventCommand.js → esm2020/src/commands/ClientToServer/SubformOpenEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/SubformRefreshEventCommand.js → esm2020/src/commands/ClientToServer/SubformRefreshEventCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/TransactionCommand.js → esm2020/src/commands/ClientToServer/TransactionCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/UnloadCommand.js → esm2020/src/commands/ClientToServer/UnloadCommand.mjs} +0 -0
- package/{esm2015/src/commands/ClientToServer/WriteMessageToServerLogCommand.js → esm2020/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs} +0 -0
- package/esm2020/src/commands/DataViewCommandBase.mjs +10 -0
- package/{esm2015/src/commands/IClientCommand.js → esm2020/src/commands/IClientCommand.mjs} +1 -0
- package/esm2020/src/commands/IClientTargetedCommand.mjs +9 -0
- package/{esm2015/src/commands/IClientToServerCommandInfo.js → esm2020/src/commands/IClientToServerCommandInfo.mjs} +1 -0
- package/esm2020/src/commands/ServerToClient/AbortCommand.mjs +65 -0
- package/esm2020/src/commands/ServerToClient/AddLocateCommand.mjs +22 -0
- package/esm2020/src/commands/ServerToClient/AddRangeCommand.mjs +62 -0
- package/esm2020/src/commands/ServerToClient/AddSortCommand.mjs +33 -0
- package/{esm2015/src/commands/ServerToClient/ClientRefreshCommand.js → esm2020/src/commands/ServerToClient/ClientRefreshCommand.mjs} +14 -17
- package/esm2020/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +27 -0
- package/esm2020/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +45 -0
- package/esm2020/src/commands/ServerToClient/OpenURLCommand.mjs +222 -0
- package/esm2020/src/commands/ServerToClient/ResetLocateCommand.mjs +15 -0
- package/esm2020/src/commands/ServerToClient/ResetRangeCommand.mjs +15 -0
- package/esm2020/src/commands/ServerToClient/ResetSortCommand.mjs +15 -0
- package/esm2020/src/commands/ServerToClient/ResultCommand.mjs +37 -0
- package/esm2020/src/commands/ServerToClient/VerifyCommand.mjs +85 -0
- package/{esm2015/src/commands/ServerToClient/XMLBasedCommandBuilder.js → esm2020/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs} +0 -0
- package/{esm2015/src/communications/IConnectionStateManager.js → esm2020/src/communications/IConnectionStateManager.mjs} +1 -0
- package/esm2020/src/communications/InteractiveCommunicationsFailureHandler.mjs +17 -0
- package/{esm2015/src/data/DataSourceIdKey.js → esm2020/src/data/DataSourceIdKey.mjs} +0 -0
- package/esm2020/src/data/DataView.mjs +1634 -0
- package/{esm2015/src/data/DataViewBase.js → esm2020/src/data/DataViewBase.mjs} +0 -0
- package/esm2020/src/data/DataviewManager.mjs +28 -0
- package/esm2020/src/data/DataviewManagerBase.mjs +15 -0
- package/{esm2015/src/data/DvCache.js → esm2020/src/data/DvCache.mjs} +0 -0
- package/esm2020/src/data/Field.mjs +645 -0
- package/esm2020/src/data/FieldBase.mjs +18 -0
- package/{esm2015/src/data/FieldsTable.js → esm2020/src/data/FieldsTable.mjs} +0 -0
- package/{esm2015/src/data/IRecordsTable.js → esm2020/src/data/IRecordsTable.mjs} +1 -0
- package/{esm2015/src/data/Key.js → esm2020/src/data/Key.mjs} +0 -0
- package/{esm2015/src/data/Record.js → esm2020/src/data/Record.mjs} +0 -0
- package/{esm2015/src/data/RecordOutOfDataViewException.js → esm2020/src/data/RecordOutOfDataViewException.mjs} +0 -0
- package/{esm2015/src/data/RecordsTable.js → esm2020/src/data/RecordsTable.mjs} +0 -0
- package/esm2020/src/data/TaskTransactionManager.mjs +103 -0
- package/{esm2015/src/data/XMLBasedDcValuesBuilder.js → esm2020/src/data/XMLBasedDcValuesBuilder.mjs} +0 -0
- package/{esm2015/src/enums.js → esm2020/src/enums.mjs} +0 -0
- package/esm2020/src/env/EnvVariablesTable.mjs +340 -0
- package/esm2020/src/env/Environment.mjs +554 -0
- package/{esm2015/src/env/ILanguageData.js → esm2020/src/env/ILanguageData.mjs} +1 -0
- package/esm2020/src/env/LanguageData.mjs +222 -0
- package/{esm2015/src/env/MirrorString.js → esm2020/src/env/MirrorString.mjs} +0 -0
- package/{esm2015/src/event/ActionManager.js → esm2020/src/event/ActionManager.mjs} +0 -0
- package/esm2020/src/event/Event.mjs +1436 -0
- package/esm2020/src/event/EventHandler.mjs +773 -0
- package/{esm2015/src/event/EventHandlerPosition.js → esm2020/src/event/EventHandlerPosition.mjs} +0 -0
- package/esm2020/src/event/EventsManager.mjs +2983 -0
- package/{esm2015/src/event/IEventsManager.js → esm2020/src/event/IEventsManager.mjs} +0 -0
- package/{esm2015/src/event/RunTimeEvent.js → esm2020/src/event/RunTimeEvent.mjs} +0 -0
- package/{esm2015/src/event/RunTimeEventBase.js → esm2020/src/event/RunTimeEventBase.mjs} +0 -0
- package/{esm2015/src/event/UserEventsTable.js → esm2020/src/event/UserEventsTable.mjs} +0 -0
- package/{esm2015/src/exp/ExpTable.js → esm2020/src/exp/ExpTable.mjs} +0 -0
- package/esm2020/src/exp/Expression.mjs +200 -0
- package/{esm2015/src/exp/ExpressionDict.js → esm2020/src/exp/ExpressionDict.mjs} +0 -0
- package/esm2020/src/exp/ExpressionEvaluator.mjs +4373 -0
- package/{esm2015/src/exp/ExpressionLocalJpn.js → esm2020/src/exp/ExpressionLocalJpn.mjs} +0 -0
- package/{esm2015/src/exp/GlobalParamsTable.js → esm2020/src/exp/GlobalParamsTable.mjs} +0 -0
- package/esm2020/src/exp/YesNoExp.mjs +41 -0
- package/{esm2015/src/gui/CreatedFormVector.js → esm2020/src/gui/CreatedFormVector.mjs} +0 -0
- package/esm2020/src/gui/FormsTable.mjs +66 -0
- package/esm2020/src/gui/MgControl.mjs +357 -0
- package/esm2020/src/gui/MgForm.mjs +1195 -0
- package/esm2020/src/http/HttpManager.mjs +97 -0
- package/esm2020/src/http/client/HttpClientAsync.mjs +67 -0
- package/esm2020/src/http/client/HttpClientBase.mjs +148 -0
- package/{esm2015/src/http/client/HttpClientEvents.js → esm2020/src/http/client/HttpClientEvents.mjs} +0 -0
- package/esm2020/src/http/client/HttpClientSync.mjs +42 -0
- package/{esm2015/src/http/client/HttpUtility.js → esm2020/src/http/client/HttpUtility.mjs} +0 -0
- package/{esm2015/src/http/client/ICommunicationsFailureHandler.js → esm2020/src/http/client/ICommunicationsFailureHandler.mjs} +1 -0
- package/esm2020/src/remote/AddUserLocateRemoteDataViewCommand.mjs +18 -0
- package/esm2020/src/remote/AddUserRangeRemoteDataViewCommand.mjs +18 -0
- package/esm2020/src/remote/AddUserSortRemoteDataViewCommand.mjs +18 -0
- package/esm2020/src/remote/RemoteCommandsProcessor.mjs +872 -0
- package/esm2020/src/remote/RemoteControlItemsRefreshCommand.mjs +25 -0
- package/esm2020/src/remote/RemoteDataViewCommandBase.mjs +24 -0
- package/{esm2015/src/remote/RemoteDataViewCommandFactory.js → esm2020/src/remote/RemoteDataViewCommandFactory.mjs} +0 -0
- package/esm2020/src/remote/RemoteDataViewCommandUpdateNonModifiable.mjs +16 -0
- package/esm2020/src/remote/RemoteDataviewManager.mjs +17 -0
- package/esm2020/src/remote/RemoteInitDataViewCommand.mjs +11 -0
- package/esm2020/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +17 -0
- package/esm2020/src/remote/ResetUserRangeRemoteDataviewCommand.mjs +13 -0
- package/esm2020/src/remote/ResetUserSortRemoteDataviewCommand.mjs +16 -0
- package/{esm2015/src/remote/ServerError.js → esm2020/src/remote/ServerError.mjs} +0 -0
- package/{esm2015/src/remote/SetTransactionStateRemoteDataViewCommand.js → esm2020/src/remote/SetTransactionStateRemoteDataViewCommand.mjs} +8 -11
- package/esm2020/src/rt/Argument.mjs +274 -0
- package/esm2020/src/rt/ArgumentsList.mjs +103 -0
- package/esm2020/src/rt/Boundary.mjs +158 -0
- package/{esm2015/src/rt/CompMainPrgTable.js → esm2020/src/rt/CompMainPrgTable.mjs} +0 -0
- package/esm2020/src/rt/DataviewHeaderBase.mjs +96 -0
- package/{esm2015/src/rt/DataviewHeaderFactory.js → esm2020/src/rt/DataviewHeaderFactory.mjs} +0 -0
- package/{esm2015/src/rt/DataviewHeaders.js → esm2020/src/rt/DataviewHeaders.mjs} +0 -0
- package/{esm2015/src/rt/DataviewHeadersSaxHandler.js → esm2020/src/rt/DataviewHeadersSaxHandler.mjs} +0 -0
- package/{esm2015/src/rt/ExecutionStack.js → esm2020/src/rt/ExecutionStack.mjs} +0 -0
- package/{esm2015/src/rt/ExecutionStackEntry.js → esm2020/src/rt/ExecutionStackEntry.mjs} +0 -0
- package/{esm2015/src/rt/HandlersTable.js → esm2020/src/rt/HandlersTable.mjs} +0 -0
- package/{esm2015/src/rt/IDataSourceViewDefinition.js → esm2020/src/rt/IDataSourceViewDefinition.mjs} +1 -0
- package/{esm2015/src/rt/IDataviewHeader.js → esm2020/src/rt/IDataviewHeader.mjs} +1 -0
- package/{esm2015/src/rt/IResultValue.js → esm2020/src/rt/IResultValue.mjs} +1 -0
- package/{esm2015/src/rt/LastFocusedManager.js → esm2020/src/rt/LastFocusedManager.mjs} +0 -0
- package/esm2020/src/rt/Operation.mjs +745 -0
- package/{esm2015/src/rt/OperationTable.js → esm2020/src/rt/OperationTable.mjs} +0 -0
- package/esm2020/src/rt/Recompute.mjs +355 -0
- package/{esm2015/src/rt/RecomputeTable.js → esm2020/src/rt/RecomputeTable.mjs} +0 -0
- package/esm2020/src/rt/RemoteDataviewHeader.mjs +105 -0
- package/{esm2015/src/rt/ResultValue.js → esm2020/src/rt/ResultValue.mjs} +0 -0
- package/esm2020/src/rt/TableCache.mjs +177 -0
- package/esm2020/src/rt/TableCacheManager.mjs +67 -0
- package/{esm2015/src/rt/Transaction.js → esm2020/src/rt/Transaction.mjs} +0 -0
- package/{esm2015/src/security/UserDetails.js → esm2020/src/security/UserDetails.mjs} +0 -0
- package/{esm2015/src/tasks/IMGDataCollection.js → esm2020/src/tasks/IMGDataCollection.mjs} +1 -0
- package/esm2020/src/tasks/MGData.mjs +552 -0
- package/esm2020/src/tasks/MGDataCollection.mjs +259 -0
- package/{esm2015/src/tasks/MenusDeserializer.js → esm2020/src/tasks/MenusDeserializer.mjs} +0 -0
- package/{esm2015/src/tasks/RCTimer.js → esm2020/src/tasks/RCTimer.mjs} +0 -0
- package/{esm2015/src/tasks/RemoteTaskService.js → esm2020/src/tasks/RemoteTaskService.mjs} +0 -0
- package/esm2020/src/tasks/Task.mjs +2501 -0
- package/{esm2015/src/tasks/TaskBase.js → esm2020/src/tasks/TaskBase.mjs} +22 -1
- package/esm2020/src/tasks/TaskServiceBase.mjs +25 -0
- package/esm2020/src/tasks/TasksTable.mjs +80 -0
- package/{esm2015/src/tasks/sort/Sort.js → esm2020/src/tasks/sort/Sort.mjs} +0 -0
- package/{esm2015/src/tasks/sort/SortCollection.js → esm2020/src/tasks/sort/SortCollection.mjs} +0 -0
- package/{esm2015/src/util/ConstUtils.js → esm2020/src/util/ConstUtils.mjs} +0 -0
- package/esm2020/src/util/FlowMonitorQueue.mjs +361 -0
- package/{esm2015/src/util/HeapSort.js → esm2020/src/util/HeapSort.mjs} +0 -0
- package/{esm2015/src/util/IMirrorXML.js → esm2020/src/util/IMirrorXML.mjs} +1 -0
- package/{esm2015/src/util/IServerConfig.js → esm2020/src/util/IServerConfig.mjs} +1 -0
- package/{esm2015/src/util/MgBlockingQueue.js → esm2020/src/util/MgBlockingQueue.mjs} +1 -0
- package/esm2020/src/util/MgPriorityBlockingQueue.mjs +76 -0
- package/{esm2015/src/util/MgPriorityQueue.js → esm2020/src/util/MgPriorityQueue.mjs} +0 -0
- package/{esm2015/src/util/ParamParseResult.js → esm2020/src/util/ParamParseResult.mjs} +0 -0
- package/{esm2015/src/util/PrmMap.js → esm2020/src/util/PrmMap.mjs} +0 -0
- package/{esm2015/src/util/Process.js → esm2020/src/util/Process.mjs} +0 -0
- package/{esm2015/src/util/ReturnResult.js → esm2020/src/util/ReturnResult.mjs} +0 -0
- package/{esm2015/src/util/ReturnResultBase.js → esm2020/src/util/ReturnResultBase.mjs} +0 -0
- package/{esm2015/src/util/Scrambler.js → esm2020/src/util/Scrambler.mjs} +0 -0
- package/{esm2015/src/util/UniqueIDUtils.js → esm2020/src/util/UniqueIDUtils.mjs} +0 -0
- package/{esm2015/src/util/cookie.service.js → esm2020/src/util/cookie.service.mjs} +0 -0
- package/fesm2015/{magic-xpa-engine.js → magic-xpa-engine.mjs} +98 -3
- package/fesm2015/magic-xpa-engine.mjs.map +1 -0
- package/fesm2020/magic-xpa-engine.mjs +30705 -0
- package/fesm2020/magic-xpa-engine.mjs.map +1 -0
- package/package.json +24 -12
- package/src/CommandsProcessorBase.d.ts +3 -3
- package/src/commands/DataViewCommandBase.d.ts +2 -2
- package/src/commands/IClientTargetedCommand.d.ts +1 -1
- package/src/commands/ServerToClient/ClientTargetedCommandBase.d.ts +1 -1
- package/src/data/FieldBase.d.ts +3 -3
- package/src/http/client/HttpClientBase.d.ts +2 -2
- package/src/rt/DataviewHeaderBase.d.ts +1 -1
- package/src/tasks/TaskBase.d.ts +7 -7
- package/bundles/magic-xpa-engine.umd.js +0 -37985
- package/bundles/magic-xpa-engine.umd.js.map +0 -1
- package/bundles/magic-xpa-engine.umd.min.js +0 -16
- package/bundles/magic-xpa-engine.umd.min.js.map +0 -1
- package/esm2015/src/ClientManager.js +0 -412
- package/esm2015/src/CommandsProcessorBase.js +0 -54
- package/esm2015/src/CommandsProcessorManager.js +0 -31
- package/esm2015/src/CommandsTable.js +0 -166
- package/esm2015/src/GUIManager.js +0 -72
- package/esm2015/src/bridge/MagicBridge.js +0 -44
- package/esm2015/src/commands/ClientToServer/CommandFactory.js +0 -283
- package/esm2015/src/commands/DataViewCommandBase.js +0 -6
- package/esm2015/src/commands/IClientTargetedCommand.js +0 -6
- package/esm2015/src/commands/ServerToClient/AbortCommand.js +0 -68
- package/esm2015/src/commands/ServerToClient/AddLocateCommand.js +0 -25
- package/esm2015/src/commands/ServerToClient/AddRangeCommand.js +0 -65
- package/esm2015/src/commands/ServerToClient/AddSortCommand.js +0 -36
- package/esm2015/src/commands/ServerToClient/ClientTargetedCommandBase.js +0 -24
- package/esm2015/src/commands/ServerToClient/EnhancedVerifyCommand.js +0 -48
- package/esm2015/src/commands/ServerToClient/OpenURLCommand.js +0 -225
- package/esm2015/src/commands/ServerToClient/ResetLocateCommand.js +0 -18
- package/esm2015/src/commands/ServerToClient/ResetRangeCommand.js +0 -18
- package/esm2015/src/commands/ServerToClient/ResetSortCommand.js +0 -18
- package/esm2015/src/commands/ServerToClient/ResultCommand.js +0 -40
- package/esm2015/src/commands/ServerToClient/VerifyCommand.js +0 -88
- package/esm2015/src/communications/InteractiveCommunicationsFailureHandler.js +0 -20
- package/esm2015/src/data/DataView.js +0 -1692
- package/esm2015/src/data/DataviewManager.js +0 -31
- package/esm2015/src/data/DataviewManagerBase.js +0 -18
- package/esm2015/src/data/Field.js +0 -671
- package/esm2015/src/data/FieldBase.js +0 -9
- package/esm2015/src/data/TaskTransactionManager.js +0 -110
- package/esm2015/src/env/EnvVariablesTable.js +0 -347
- package/esm2015/src/env/Environment.js +0 -557
- package/esm2015/src/env/LanguageData.js +0 -229
- package/esm2015/src/event/Event.js +0 -1441
- package/esm2015/src/event/EventHandler.js +0 -786
- package/esm2015/src/event/EventsManager.js +0 -3106
- package/esm2015/src/exp/Expression.js +0 -209
- package/esm2015/src/exp/ExpressionEvaluator.js +0 -4440
- package/esm2015/src/exp/YesNoExp.js +0 -44
- package/esm2015/src/gui/FormsTable.js +0 -73
- package/esm2015/src/gui/MgControl.js +0 -424
- package/esm2015/src/gui/MgForm.js +0 -1291
- package/esm2015/src/http/HttpManager.js +0 -100
- package/esm2015/src/http/client/HttpClientAsync.js +0 -72
- package/esm2015/src/http/client/HttpClientBase.js +0 -147
- package/esm2015/src/http/client/HttpClientSync.js +0 -47
- package/esm2015/src/remote/AddUserLocateRemoteDataViewCommand.js +0 -21
- package/esm2015/src/remote/AddUserRangeRemoteDataViewCommand.js +0 -21
- package/esm2015/src/remote/AddUserSortRemoteDataViewCommand.js +0 -21
- package/esm2015/src/remote/RemoteCommandsProcessor.js +0 -901
- package/esm2015/src/remote/RemoteControlItemsRefreshCommand.js +0 -28
- package/esm2015/src/remote/RemoteDataViewCommandBase.js +0 -27
- package/esm2015/src/remote/RemoteDataViewCommandUpdateNonModifiable.js +0 -19
- package/esm2015/src/remote/RemoteDataviewManager.js +0 -23
- package/esm2015/src/remote/RemoteInitDataViewCommand.js +0 -14
- package/esm2015/src/remote/ResetUserLocateRemoteDataviewCommand.js +0 -20
- package/esm2015/src/remote/ResetUserRangeRemoteDataviewCommand.js +0 -16
- package/esm2015/src/remote/ResetUserSortRemoteDataviewCommand.js +0 -19
- package/esm2015/src/rt/Argument.js +0 -281
- package/esm2015/src/rt/ArgumentsList.js +0 -108
- package/esm2015/src/rt/Boundary.js +0 -161
- package/esm2015/src/rt/DataviewHeaderBase.js +0 -96
- package/esm2015/src/rt/Operation.js +0 -772
- package/esm2015/src/rt/Recompute.js +0 -372
- package/esm2015/src/rt/RemoteDataviewHeader.js +0 -114
- package/esm2015/src/rt/TableCache.js +0 -182
- package/esm2015/src/rt/TableCacheManager.js +0 -70
- package/esm2015/src/tasks/MGData.js +0 -561
- package/esm2015/src/tasks/MGDataCollection.js +0 -270
- package/esm2015/src/tasks/Task.js +0 -2601
- package/esm2015/src/tasks/TaskServiceBase.js +0 -30
- package/esm2015/src/tasks/TasksTable.js +0 -87
- package/esm2015/src/util/FlowMonitorQueue.js +0 -364
- package/esm2015/src/util/MgPriorityBlockingQueue.js +0 -79
- package/fesm2015/magic-xpa-engine.js.map +0 -1
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { ApplicationException, Debug, NString } from "@magic-xpa/mscorelib";
|
|
3
|
-
import { Logger } from "@magic-xpa/utils";
|
|
4
|
-
import { ConstInterface } from "../ConstInterface";
|
|
5
|
-
import { HttpClientEvents } from "./client/HttpClientEvents";
|
|
6
|
-
import { HttpClientSync } from "./client/HttpClientSync";
|
|
7
|
-
import { HttpClientAsync } from "./client/HttpClientAsync";
|
|
8
|
-
export class HttpManager {
|
|
9
|
-
constructor() {
|
|
10
|
-
this._httpCommunicationTimeoutMS = HttpManager.DEFAULT_HTTP_COMMUNICATION_TIMEOUT;
|
|
11
|
-
this._httpClientAsync = null;
|
|
12
|
-
this._isAbortingMagicEngine = false;
|
|
13
|
-
this._httpClientAsync = new HttpClientAsync(HttpManager._nativeHttpClient);
|
|
14
|
-
this.RegisterBasicDelegates();
|
|
15
|
-
}
|
|
16
|
-
getHttpClient() {
|
|
17
|
-
if (this.IsAbortingMagicEngine)
|
|
18
|
-
return new HttpClientSync();
|
|
19
|
-
return this._httpClientAsync;
|
|
20
|
-
}
|
|
21
|
-
set HttpCommunicationTimeoutMS(value) {
|
|
22
|
-
this._httpCommunicationTimeoutMS = value;
|
|
23
|
-
}
|
|
24
|
-
static setNativeHttpClient(httpClient) {
|
|
25
|
-
HttpManager._nativeHttpClient = httpClient;
|
|
26
|
-
}
|
|
27
|
-
static GetInstance() {
|
|
28
|
-
if (HttpManager._instance === null) {
|
|
29
|
-
HttpManager._instance = new HttpManager();
|
|
30
|
-
}
|
|
31
|
-
return HttpManager._instance;
|
|
32
|
-
}
|
|
33
|
-
get IsAbortingMagicEngine() { return this._isAbortingMagicEngine; }
|
|
34
|
-
set IsAbortingMagicEngine(isAbortingMagicEngine) { this._isAbortingMagicEngine = isAbortingMagicEngine; }
|
|
35
|
-
RegisterBasicDelegates() {
|
|
36
|
-
HttpClientEvents.GetHttpCommunicationTimeout_Event = this.GetHttpCommunicationTimeoutMS.bind(this);
|
|
37
|
-
}
|
|
38
|
-
GetHttpCommunicationTimeoutMS() {
|
|
39
|
-
return this._httpCommunicationTimeoutMS;
|
|
40
|
-
}
|
|
41
|
-
SetCommunicationsFailureHandler(handler) {
|
|
42
|
-
this.getHttpClient().CommunicationsFailureHandler = handler;
|
|
43
|
-
}
|
|
44
|
-
GetContent(requestedURL, requestContent, useCache, isError) {
|
|
45
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
-
let response;
|
|
47
|
-
Debug.Assert(this.getHttpClient() != null);
|
|
48
|
-
try {
|
|
49
|
-
Logger.Instance.WriteServerToLog("*************************************************************************************************");
|
|
50
|
-
isError.value = false;
|
|
51
|
-
Logger.Instance.WriteServerToLog(requestedURL);
|
|
52
|
-
HttpManager.LogAccessToServer("", requestContent);
|
|
53
|
-
response = yield this.getHttpClient().GetContent(requestedURL, requestContent, useCache);
|
|
54
|
-
Debug.Assert(response !== null);
|
|
55
|
-
let errorResponse = HttpManager.CheckAndGetErrorResponse(response);
|
|
56
|
-
if (errorResponse !== null) {
|
|
57
|
-
response = errorResponse;
|
|
58
|
-
isError.value = true;
|
|
59
|
-
}
|
|
60
|
-
return response;
|
|
61
|
-
}
|
|
62
|
-
catch (ex) {
|
|
63
|
-
let url = new URL(requestedURL);
|
|
64
|
-
throw new ApplicationException(ex.Message + "\n" + url.origin + url.pathname, ex);
|
|
65
|
-
}
|
|
66
|
-
finally {
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
static CheckAndGetErrorResponse(httpResponse) {
|
|
71
|
-
let errorResponse = null;
|
|
72
|
-
if (httpResponse.startsWith(ConstInterface.V24_RIA_ERROR_PREFIX))
|
|
73
|
-
errorResponse = httpResponse.substr(ConstInterface.V24_RIA_ERROR_PREFIX.length);
|
|
74
|
-
return errorResponse;
|
|
75
|
-
}
|
|
76
|
-
static LogAccessToServer(msg, requestContent) {
|
|
77
|
-
if (Logger.Instance.ShouldLogServerRelatedMessages()) {
|
|
78
|
-
if (!NString.IsNullOrEmpty(msg)) {
|
|
79
|
-
msg = msg + "; accessing server ...";
|
|
80
|
-
}
|
|
81
|
-
if (requestContent === null) {
|
|
82
|
-
if (!NString.IsNullOrEmpty(msg)) {
|
|
83
|
-
Logger.Instance.WriteServerToLog(msg);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
if (!NString.IsNullOrEmpty(msg)) {
|
|
88
|
-
msg = msg + " ";
|
|
89
|
-
}
|
|
90
|
-
msg = msg + "uploading " + requestContent.length + " bytes";
|
|
91
|
-
Logger.Instance.WriteServerToLog(msg);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
HttpManager._instance = null;
|
|
97
|
-
HttpManager.DEFAULT_HTTP_COMMUNICATION_TIMEOUT = 5 * 1000;
|
|
98
|
-
HttpManager.DEFAULT_OFFLINE_HTTP_COMMUNICATION_TIMEOUT = 2 * 1000;
|
|
99
|
-
HttpManager._nativeHttpClient = null;
|
|
100
|
-
//# 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,72 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { HttpErrorResponse } from "@angular/common/http";
|
|
3
|
-
import { NString, Thread, WebException } from "@magic-xpa/mscorelib";
|
|
4
|
-
import { HttpClientBase, RequestMethod } from "./HttpClientBase";
|
|
5
|
-
import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
|
|
6
|
-
import { HttpClientEvents } from "./HttpClientEvents";
|
|
7
|
-
export class HttpClientAsync extends HttpClientBase {
|
|
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
|
-
sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer) {
|
|
22
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
let httpResponse = yield this.httpClient.request(RequestMethod[httpMethod], urlString, { headers: httpHeaders, responseType: "text", observe: "response", body: requestContent }).toPromise();
|
|
24
|
-
contentFromServer.value = httpResponse.body;
|
|
25
|
-
return httpResponse;
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest) {
|
|
29
|
-
let statusCode = httpResponse['status'];
|
|
30
|
-
let responseTime = Misc.getSystemMilliseconds() - timeBeforeRequest;
|
|
31
|
-
if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)
|
|
32
|
-
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);
|
|
33
|
-
}
|
|
34
|
-
handleHttpErrorException(ex, urlString) {
|
|
35
|
-
if (ex instanceof HttpErrorResponse) {
|
|
36
|
-
let statusCode = ex['status'];
|
|
37
|
-
if (statusCode === 404 || statusCode === 403)
|
|
38
|
-
throw new WebException(new Error("bad URL: " + urlString + " - StatusCode = " + statusCode));
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
shouldRetry(httpCommunicationTimeoutMS, urlString, communicationsFailureHandler, ex, startTimeRef) {
|
|
42
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
43
|
-
let currentDelayMS = Math.floor(httpCommunicationTimeoutMS / 10);
|
|
44
|
-
let httpElapsedTimeMS = Misc.getSystemMilliseconds() - startTimeRef.value + currentDelayMS;
|
|
45
|
-
if (httpElapsedTimeMS <= httpCommunicationTimeoutMS) {
|
|
46
|
-
yield Thread.Sleep(currentDelayMS);
|
|
47
|
-
Logger.Instance.WriteWarningToLogWithMsg(NString.Format("Retrying {0} : elapsed time {1:N0}ms out of {2:N0}ms", urlString, httpElapsedTimeMS, httpCommunicationTimeoutMS));
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
Logger.Instance.WriteWarningToLogWithMsg(NString.Format("{0} : http timeout {1:N0}ms expired", urlString, httpCommunicationTimeoutMS));
|
|
51
|
-
if (communicationsFailureHandler != null) {
|
|
52
|
-
communicationsFailureHandler.CommunicationFailed(urlString, ex);
|
|
53
|
-
if (communicationsFailureHandler.ShouldRetryLastRequest) {
|
|
54
|
-
Logger.Instance.WriteServerToLog(NString.Format("Retrying {0}, confirmed by user ...", urlString));
|
|
55
|
-
startTimeRef.value = Misc.getSystemMilliseconds();
|
|
56
|
-
return true;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
return false;
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
logAndThrowException(ex) {
|
|
63
|
-
Logger.Instance.WriteWarningToLogWithMsg("Re-throwing ...");
|
|
64
|
-
Logger.Instance.WriteWarningToLog(ex);
|
|
65
|
-
throw new WebException(ex);
|
|
66
|
-
}
|
|
67
|
-
logExecutionAttempts(executionAttempts) {
|
|
68
|
-
if (executionAttempts > 1)
|
|
69
|
-
Logger.Instance.WriteServerToLog(NString.Format("Succeeded after {0} attempts ...", executionAttempts));
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
//# 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>)\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,147 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { NString, RefParam, StringBuilder, isNullOrUndefined } from "@magic-xpa/mscorelib";
|
|
3
|
-
import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
|
|
4
|
-
import { HttpClientEvents } from "./HttpClientEvents";
|
|
5
|
-
import { HttpHeaders } from "@angular/common/http";
|
|
6
|
-
const HTTP_EXPECT100CONTINUE = "Expect100Continue";
|
|
7
|
-
const USE_HIGHEST_SECURITY_PROTOCOL = "UseHighestSecurityProtocol";
|
|
8
|
-
export var RequestMethod;
|
|
9
|
-
(function (RequestMethod) {
|
|
10
|
-
RequestMethod[RequestMethod["Get"] = 0] = "Get";
|
|
11
|
-
RequestMethod[RequestMethod["Post"] = 1] = "Post";
|
|
12
|
-
RequestMethod[RequestMethod["Put"] = 2] = "Put";
|
|
13
|
-
RequestMethod[RequestMethod["Delete"] = 3] = "Delete";
|
|
14
|
-
RequestMethod[RequestMethod["Options"] = 4] = "Options";
|
|
15
|
-
RequestMethod[RequestMethod["Head"] = 5] = "Head";
|
|
16
|
-
RequestMethod[RequestMethod["Patch"] = 6] = "Patch";
|
|
17
|
-
})(RequestMethod || (RequestMethod = {}));
|
|
18
|
-
export class HttpClientBase {
|
|
19
|
-
constructor() {
|
|
20
|
-
this._HTTPMaxURLLength = 2048;
|
|
21
|
-
this.CommunicationsFailureHandler = null;
|
|
22
|
-
this.CommunicationsFailureHandler = null;
|
|
23
|
-
}
|
|
24
|
-
DecideOnRequestMethod(requestContent, requestURL) {
|
|
25
|
-
let method = RequestMethod.Get;
|
|
26
|
-
if (requestContent === null) {
|
|
27
|
-
method = RequestMethod.Get;
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
if (requestURL.value.length + 1 + requestContent.length <= this._HTTPMaxURLLength) {
|
|
31
|
-
requestURL.value = requestURL.value + "?" + requestContent;
|
|
32
|
-
method = RequestMethod.Get;
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
method = RequestMethod.Post;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
return method;
|
|
39
|
-
}
|
|
40
|
-
GetContent(requestURL, requestContent, useCache) {
|
|
41
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
-
let contentFromServer = new RefParam(null);
|
|
43
|
-
let requestUrlRef = new RefParam(requestURL);
|
|
44
|
-
let httpMethod = this.DecideOnRequestMethod(requestContent, requestUrlRef);
|
|
45
|
-
requestURL = requestUrlRef.value;
|
|
46
|
-
try {
|
|
47
|
-
let response = yield this.ExecuteHttpRequest(requestURL, requestContent, useCache, httpMethod, contentFromServer);
|
|
48
|
-
if (response != null) {
|
|
49
|
-
Logger.Instance.WriteServerToLog("Incoming Headers : " + HttpClientBase.HeadersToString(response.headers, true));
|
|
50
|
-
let nextSessionCounterString = response.headers.get("MgxpaNextSessionCounter".toLowerCase());
|
|
51
|
-
if (!isNullOrUndefined(nextSessionCounterString)) {
|
|
52
|
-
HttpClientEvents.CheckAndSetSessionCounter(+nextSessionCounterString);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
catch (ex) {
|
|
57
|
-
Logger.Instance.WriteWarningToLog(ex);
|
|
58
|
-
throw ex;
|
|
59
|
-
}
|
|
60
|
-
return contentFromServer.value;
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
ExecuteHttpRequest(urlString, requestContent, useCache, httpMethod, contentFromServer) {
|
|
64
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
65
|
-
let httpResponse = null;
|
|
66
|
-
this.prepareRequest();
|
|
67
|
-
let httpCommunicationTimeoutMS = HttpClientEvents.GetHttpCommunicationTimeout();
|
|
68
|
-
let clientID = HttpClientEvents.GetGlobalUniqueSessionID();
|
|
69
|
-
let executionAttempts = 0;
|
|
70
|
-
let startTime = Misc.getSystemMilliseconds();
|
|
71
|
-
while (true) {
|
|
72
|
-
executionAttempts++;
|
|
73
|
-
try {
|
|
74
|
-
let httpHeaders = new HttpHeaders();
|
|
75
|
-
httpHeaders = this.addHeaders(urlString, useCache, httpHeaders, clientID);
|
|
76
|
-
Logger.Instance.WriteServerToLog(NString.Format("Request Timeout set to {0} ms", httpCommunicationTimeoutMS));
|
|
77
|
-
if (Logger.Instance.LogLevel === Logger_LogLevels.Basic) {
|
|
78
|
-
let contentLength = 0;
|
|
79
|
-
if (httpMethod === RequestMethod.Get) {
|
|
80
|
-
let parts = urlString.split('?');
|
|
81
|
-
if (parts.length === 2)
|
|
82
|
-
contentLength = parts[1].length;
|
|
83
|
-
}
|
|
84
|
-
else
|
|
85
|
-
contentLength = requestContent.length;
|
|
86
|
-
Logger.Instance.WriteBasicToLog(Logger_MessageDirection.MessageLeaving, HttpClientEvents.GetRuntimeCtxID(), HttpClientEvents.GetSessionCounter(), clientID, HttpClientEvents.ShouldDisplayGenericError() ? "-" : new URL(urlString).host, 0, '-', JSON.stringify(httpHeaders), contentLength);
|
|
87
|
-
}
|
|
88
|
-
let timeBeforeRequest = Misc.getSystemMilliseconds();
|
|
89
|
-
Logger.Instance.WriteServerToLog(NString.Format("Accessing (method: '{0}'): '{1}'", httpMethod, urlString));
|
|
90
|
-
Logger.Instance.WriteServerToLog("Outgoing Headers : " + HttpClientBase.HeadersToString(httpHeaders, false));
|
|
91
|
-
if (httpMethod === RequestMethod.Post) {
|
|
92
|
-
}
|
|
93
|
-
let requestTime = Misc.getSystemMilliseconds();
|
|
94
|
-
this.LogRequestInfo(!isNullOrUndefined(requestContent) ? requestContent.length : 0, requestTime, false);
|
|
95
|
-
httpResponse = yield this.sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer);
|
|
96
|
-
this.logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest);
|
|
97
|
-
this.LogRequestInfo(!isNullOrUndefined(requestContent) ? requestContent.length : 0, Misc.getSystemMilliseconds() - requestTime, true);
|
|
98
|
-
break;
|
|
99
|
-
}
|
|
100
|
-
catch (ex) {
|
|
101
|
-
if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)
|
|
102
|
-
Logger.Instance.WriteBasicErrorToLog();
|
|
103
|
-
else
|
|
104
|
-
Logger.Instance.WriteWarningToLog(ex);
|
|
105
|
-
this.handleHttpErrorException(ex, urlString);
|
|
106
|
-
let startTimeRef = new RefParam(startTime);
|
|
107
|
-
if (this.shouldRetry(httpCommunicationTimeoutMS, urlString, this.CommunicationsFailureHandler, ex, startTimeRef)) {
|
|
108
|
-
startTime = startTimeRef.value;
|
|
109
|
-
continue;
|
|
110
|
-
}
|
|
111
|
-
this.logAndThrowException(ex);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
this.logExecutionAttempts(executionAttempts);
|
|
115
|
-
return httpResponse;
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
LogRequestInfo(contentLength, roundTrip, isLoggingResponse) {
|
|
119
|
-
if (Logger.Instance.LogLevel == Logger_LogLevels.RequestInfo) {
|
|
120
|
-
HttpClientEvents.ComputeAndLogRequestInfo(contentLength, roundTrip, isLoggingResponse);
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
static HeadersToString(headers, bFilter) {
|
|
124
|
-
let headersStr = new StringBuilder();
|
|
125
|
-
let headerKeys = headers.keys();
|
|
126
|
-
for (let key in headerKeys) {
|
|
127
|
-
if (!bFilter || headerKeys[key].startsWith("Mg"))
|
|
128
|
-
headersStr.Append(NString.Format("{0}:{1} ", headerKeys[key], headers.get(headerKeys[key])));
|
|
129
|
-
}
|
|
130
|
-
return headersStr;
|
|
131
|
-
}
|
|
132
|
-
static GetHTTPExpect100Continue() {
|
|
133
|
-
let result = true;
|
|
134
|
-
let executionProperty = HttpClientEvents.GetExecutionProperty(HTTP_EXPECT100CONTINUE);
|
|
135
|
-
if (!NString.IsNullOrEmpty(executionProperty))
|
|
136
|
-
result = (executionProperty.toUpperCase() === "Y");
|
|
137
|
-
return result;
|
|
138
|
-
}
|
|
139
|
-
static GetUseHighestSecurityProtocol() {
|
|
140
|
-
let result = false;
|
|
141
|
-
let executionProperty = HttpClientEvents.GetExecutionProperty(USE_HIGHEST_SECURITY_PROTOCOL);
|
|
142
|
-
if (!NString.IsNullOrEmpty(executionProperty))
|
|
143
|
-
result = (executionProperty.toUpperCase() === "Y");
|
|
144
|
-
return result;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
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"]}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { NString } from "@magic-xpa/mscorelib";
|
|
3
|
-
import { HttpClientBase } from "./HttpClientBase";
|
|
4
|
-
import { Logger, Logger_LogLevels, Logger_MessageDirection, Misc } from "@magic-xpa/utils";
|
|
5
|
-
import { HttpClientEvents } from "./HttpClientEvents";
|
|
6
|
-
export class HttpClientSync extends HttpClientBase {
|
|
7
|
-
constructor() {
|
|
8
|
-
super();
|
|
9
|
-
this.httpRequest = null;
|
|
10
|
-
this.headers = new Headers();
|
|
11
|
-
}
|
|
12
|
-
prepareRequest() {
|
|
13
|
-
}
|
|
14
|
-
addHeaders(urlString, useCache, httpHeaders, clientID) {
|
|
15
|
-
if (!urlString.startsWith("/")) {
|
|
16
|
-
this.headers.append("MgxpaRIAglobalUniqueSessionID", clientID);
|
|
17
|
-
}
|
|
18
|
-
if (!useCache) {
|
|
19
|
-
this.headers.append("Cache-Control", "no-cache");
|
|
20
|
-
}
|
|
21
|
-
return httpHeaders;
|
|
22
|
-
}
|
|
23
|
-
sendRequestToServer(httpMethod, urlString, httpHeaders, requestContent, contentFromServer) {
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
yield fetch(urlString, { method: 'POST', headers: this.headers, body: requestContent, keepalive: true });
|
|
26
|
-
return NString.Empty;
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
logResponse(httpResponse, clientID, urlString, contentFromServer, timeBeforeRequest) {
|
|
30
|
-
let responseTime = Misc.getSystemMilliseconds() - timeBeforeRequest;
|
|
31
|
-
if (Logger.Instance.LogLevel === Logger_LogLevels.Basic)
|
|
32
|
-
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);
|
|
33
|
-
}
|
|
34
|
-
handleHttpErrorException(ex, urlString) {
|
|
35
|
-
throw ex;
|
|
36
|
-
}
|
|
37
|
-
shouldRetry(httpCommunicationTimeoutMS, urlString, communicationsFailureHandler, ex, startTimeRef) {
|
|
38
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
-
return false;
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
logAndThrowException(ex) {
|
|
43
|
-
}
|
|
44
|
-
logExecutionAttempts(executionAttempts) {
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cENsaWVudFN5bmMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL2h0dHAvY2xpZW50L0h0dHBDbGllbnRTeW5jLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUMsT0FBTyxFQUFXLE1BQU0sc0JBQXNCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGNBQWMsRUFBZ0IsTUFBTSxrQkFBa0IsQ0FBQztBQUMvRCxPQUFPLEVBQUMsTUFBTSxFQUFFLGdCQUFnQixFQUFFLHVCQUF1QixFQUFFLElBQUksRUFBQyxNQUFNLGtCQUFrQixDQUFDO0FBQ3pGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBSXBELE1BQU0sT0FBTyxjQUFlLFNBQVEsY0FBYztJQUtoRDtRQUVFLEtBQUssRUFBRSxDQUFDO1FBTEYsZ0JBQVcsR0FBbUIsSUFBSSxDQUFDO1FBQ25DLFlBQU8sR0FBWSxJQUFJLE9BQU8sRUFBRSxDQUFDO0lBS3pDLENBQUM7SUFFRCxjQUFjO0lBRWQsQ0FBQztJQUVELFVBQVUsQ0FBQyxTQUFpQixFQUFFLFFBQWlCLEVBQUUsV0FBd0IsRUFBRSxRQUFnQjtRQUV6RixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFDOUI7WUFDRSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQywrQkFBK0IsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUNoRTtRQUVELElBQUksQ0FBQyxRQUFRLEVBQ2I7WUFDRSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxlQUFlLEVBQUUsVUFBVSxDQUFDLENBQUM7U0FDbEQ7UUFFRCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRUssbUJBQW1CLENBQUMsVUFBeUIsRUFBRSxTQUFpQixFQUFFLFdBQXdCLEVBQUUsY0FBc0IsRUFBRSxpQkFBbUM7O1lBRzNKLE1BQU0sS0FBSyxDQUFDLFNBQVMsRUFBRSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLGNBQWMsRUFBRSxTQUFTLEVBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztZQUV4RyxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUM7UUFDdkIsQ0FBQztLQUFBO0lBRUQsV0FBVyxDQUFDLFlBQWtDLEVBQUUsUUFBZ0IsRUFBRSxTQUFpQixFQUFFLGlCQUFnQyxFQUFFLGlCQUF5QjtRQUU5SSxJQUFJLFlBQVksR0FBVyxJQUFJLENBQUMscUJBQXFCLEVBQUUsR0FBRyxpQkFBaUIsQ0FBQztRQUU1RSxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxLQUFLLGdCQUFnQixDQUFDLEtBQUs7WUFDckQsTUFBTSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsdUJBQXVCLENBQUMsZUFBZSxFQUN2QyxnQkFBZ0IsQ0FBQyxlQUFlLEVBQUUsRUFDbEMsZ0JBQWdCLENBQUMsaUJBQWlCLEVBQUUsRUFDcEMsUUFBUSxFQUNSLGdCQUFnQixDQUFDLHlCQUF5QixFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUM1RSxZQUFZLEVBQ1osSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQ2xDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLEVBQ3hELGlCQUFpQixDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBRUQsd0JBQXdCLENBQUMsRUFBTyxFQUFFLFNBQWlCO1FBR2pELE1BQU0sRUFBRSxDQUFDO0lBQ1gsQ0FBQztJQUVLLFdBQVcsQ0FBQywwQkFBa0MsRUFBRSxTQUFpQixFQUFFLDRCQUEyRCxFQUFFLEVBQU8sRUFBRSxZQUE4Qjs7WUFHM0ssT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO0tBQUE7SUFFRCxvQkFBb0IsQ0FBQyxFQUFFO0lBR3ZCLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxpQkFBeUI7SUFHOUMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtIdHRwSGVhZGVycywgSHR0cFJlc3BvbnNlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcclxuaW1wb3J0IHtOU3RyaW5nLCBSZWZQYXJhbX0gZnJvbSBcIkBtYWdpYy14cGEvbXNjb3JlbGliXCI7XHJcbmltcG9ydCB7SHR0cENsaWVudEJhc2UsIFJlcXVlc3RNZXRob2R9IGZyb20gXCIuL0h0dHBDbGllbnRCYXNlXCI7XHJcbmltcG9ydCB7TG9nZ2VyLCBMb2dnZXJfTG9nTGV2ZWxzLCBMb2dnZXJfTWVzc2FnZURpcmVjdGlvbiwgTWlzY30gZnJvbSBcIkBtYWdpYy14cGEvdXRpbHNcIjtcclxuaW1wb3J0IHtIdHRwQ2xpZW50RXZlbnRzfSBmcm9tIFwiLi9IdHRwQ2xpZW50RXZlbnRzXCI7XHJcbmltcG9ydCB7SUNvbW11bmljYXRpb25zRmFpbHVyZUhhbmRsZXJ9IGZyb20gXCIuL0lDb21tdW5pY2F0aW9uc0ZhaWx1cmVIYW5kbGVyXCI7XHJcblxyXG4vLyBBIGNsYXNzIHVzaW5nIEh0dHAgU3luYyBMaWJyYXJ5XHJcbmV4cG9ydCBjbGFzcyBIdHRwQ2xpZW50U3luYyBleHRlbmRzIEh0dHBDbGllbnRCYXNlXHJcbntcclxuICBwcml2YXRlIGh0dHBSZXF1ZXN0OiBYTUxIdHRwUmVxdWVzdCA9IG51bGw7XHJcbiAgcHJpdmF0ZSBoZWFkZXJzOiBIZWFkZXJzID0gbmV3IEhlYWRlcnMoKTtcclxuXHJcbiAgY29uc3RydWN0b3IoKVxyXG4gIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgfVxyXG5cclxuICBwcmVwYXJlUmVxdWVzdCgpXHJcbiAge1xyXG4gIH1cclxuXHJcbiAgYWRkSGVhZGVycyh1cmxTdHJpbmc6IHN0cmluZywgdXNlQ2FjaGU6IGJvb2xlYW4sIGh0dHBIZWFkZXJzOiBIdHRwSGVhZGVycywgY2xpZW50SUQ6IHN0cmluZyk6IEh0dHBIZWFkZXJzXHJcbiAge1xyXG4gICAgaWYgKCF1cmxTdHJpbmcuc3RhcnRzV2l0aChcIi9cIikpXHJcbiAgICB7XHJcbiAgICAgIHRoaXMuaGVhZGVycy5hcHBlbmQoXCJNZ3hwYVJJQWdsb2JhbFVuaXF1ZVNlc3Npb25JRFwiLCBjbGllbnRJRCk7XHJcbiAgICB9XHJcblxyXG4gICAgaWYgKCF1c2VDYWNoZSlcclxuICAgIHtcclxuICAgICAgdGhpcy5oZWFkZXJzLmFwcGVuZChcIkNhY2hlLUNvbnRyb2xcIiwgXCJuby1jYWNoZVwiKTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gaHR0cEhlYWRlcnM7XHJcbiAgfVxyXG5cclxuICBhc3luYyBzZW5kUmVxdWVzdFRvU2VydmVyKGh0dHBNZXRob2Q6IFJlcXVlc3RNZXRob2QsIHVybFN0cmluZzogc3RyaW5nLCBodHRwSGVhZGVyczogSHR0cEhlYWRlcnMsIHJlcXVlc3RDb250ZW50OiBzdHJpbmcsIGNvbnRlbnRGcm9tU2VydmVyOiBSZWZQYXJhbTxzdHJpbmc+KTogUHJvbWlzZTxhbnk+XHJcbiAge1xyXG4gICAgLy8gU2VuZCB0aGUgZW5naW5lIHRlcm1pbmF0aW9uIHJlcXVlc3QgdG8gc2VydmVyLlxyXG4gICAgYXdhaXQgZmV0Y2godXJsU3RyaW5nLCB7IG1ldGhvZDogJ1BPU1QnLCBoZWFkZXJzOiB0aGlzLmhlYWRlcnMsIGJvZHk6IHJlcXVlc3RDb250ZW50LCBrZWVwYWxpdmU6dHJ1ZSB9KTtcclxuXHJcbiAgICByZXR1cm4gTlN0cmluZy5FbXB0eTtcclxuICB9XHJcblxyXG4gIGxvZ1Jlc3BvbnNlKGh0dHBSZXNwb25zZTogSHR0cFJlc3BvbnNlPHN0cmluZz4sIGNsaWVudElEOiBzdHJpbmcsIHVybFN0cmluZzogc3RyaW5nLCBjb250ZW50RnJvbVNlcnZlcjogUmVmUGFyYW08YW55PiwgdGltZUJlZm9yZVJlcXVlc3Q6IG51bWJlcilcclxuICB7XHJcbiAgICBsZXQgcmVzcG9uc2VUaW1lOiBudW1iZXIgPSBNaXNjLmdldFN5c3RlbU1pbGxpc2Vjb25kcygpIC0gdGltZUJlZm9yZVJlcXVlc3Q7XHJcblxyXG4gICAgaWYgKExvZ2dlci5JbnN0YW5jZS5Mb2dMZXZlbCA9PT0gTG9nZ2VyX0xvZ0xldmVscy5CYXNpYylcclxuICAgICAgTG9nZ2VyLkluc3RhbmNlLldyaXRlQmFzaWNUb0xvZyhMb2dnZXJfTWVzc2FnZURpcmVjdGlvbi5NZXNzYWdlRW50ZXJpbmcsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSHR0cENsaWVudEV2ZW50cy5HZXRSdW50aW1lQ3R4SUQoKSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBIdHRwQ2xpZW50RXZlbnRzLkdldFNlc3Npb25Db3VudGVyKCksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2xpZW50SUQsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSHR0cENsaWVudEV2ZW50cy5TaG91bGREaXNwbGF5R2VuZXJpY0Vycm9yKCkgPyBcIi1cIiA6IG5ldyBVUkwodXJsU3RyaW5nKS5ob3N0LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJlc3BvbnNlVGltZSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmh0dHBSZXF1ZXN0LnN0YXR1cy50b1N0cmluZygpLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEpTT04uc3RyaW5naWZ5KHRoaXMuaHR0cFJlcXVlc3QuZ2V0QWxsUmVzcG9uc2VIZWFkZXJzKCkpLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbnRlbnRGcm9tU2VydmVyLnZhbHVlLmxlbmd0aCk7XHJcbiAgfVxyXG5cclxuICBoYW5kbGVIdHRwRXJyb3JFeGNlcHRpb24oZXg6IGFueSwgdXJsU3RyaW5nOiBzdHJpbmcpXHJcbiAge1xyXG4gICAgLy8gTm8gZXhjZXB0aW9uIGhhbmRsaW5nIGZvciBsYXN0IHJlcXVlc3QgYW5kIGhlbmNlIGp1c3QgdGhyb3cgdGhlIGV4Y2VwdGlvblxyXG4gICAgdGhyb3cgZXg7XHJcbiAgfVxyXG5cclxuICBhc3luYyBzaG91bGRSZXRyeShodHRwQ29tbXVuaWNhdGlvblRpbWVvdXRNUzogbnVtYmVyLCB1cmxTdHJpbmc6IHN0cmluZywgY29tbXVuaWNhdGlvbnNGYWlsdXJlSGFuZGxlcjogSUNvbW11bmljYXRpb25zRmFpbHVyZUhhbmRsZXIsIGV4OiBhbnksIHN0YXJ0VGltZVJlZjogUmVmUGFyYW08bnVtYmVyPilcclxuICB7XHJcbiAgICAvLyBObyByZXRyeSBzdXBwb3J0ZWQgb24gbGFzdCByZXF1ZXN0XHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBsb2dBbmRUaHJvd0V4Y2VwdGlvbihleClcclxuICB7XHJcbiAgICAvLyBOLkEuXHJcbiAgfVxyXG5cclxuICBsb2dFeGVjdXRpb25BdHRlbXB0cyhleGVjdXRpb25BdHRlbXB0czogbnVtYmVyKVxyXG4gIHtcclxuICAgIC8vIE4uQS5cclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { RemoteDataViewCommandBase } from "./RemoteDataViewCommandBase";
|
|
3
|
-
import { List } from "@magic-xpa/mscorelib";
|
|
4
|
-
import { ReturnResult } from "../util/ReturnResult";
|
|
5
|
-
export class AddUserLocateRemoteDataViewCommand extends RemoteDataViewCommandBase {
|
|
6
|
-
constructor(command) {
|
|
7
|
-
super(command);
|
|
8
|
-
this.userRange = null;
|
|
9
|
-
this.userRange = command.Range;
|
|
10
|
-
}
|
|
11
|
-
Execute() {
|
|
12
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
13
|
-
if (this.Task.UserLocs === null) {
|
|
14
|
-
this.Task.UserLocs = new List();
|
|
15
|
-
}
|
|
16
|
-
this.Task.UserLocs.push(this.userRange);
|
|
17
|
-
return new ReturnResult();
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWRkVXNlckxvY2F0ZVJlbW90ZURhdGFWaWV3Q29tbWFuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VuZ2luZS9zcmMvcmVtb3RlL0FkZFVzZXJMb2NhdGVSZW1vdGVEYXRhVmlld0NvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBR3RFLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxQyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFNbEQsTUFBTSxPQUFPLGtDQUFtQyxTQUFRLHlCQUF5QjtJQUcvRSxZQUFZLE9BQXFDO1FBQy9DLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUhULGNBQVMsR0FBYyxJQUFJLENBQUM7UUFJbEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQ2pDLENBQUM7SUFNSyxPQUFPOztZQUNYLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEtBQUssSUFBSSxFQUFFO2dCQUMvQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLElBQUksRUFBYSxDQUFDO2FBQzVDO1lBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUN4QyxPQUFPLElBQUksWUFBWSxFQUFFLENBQUM7UUFDNUIsQ0FBQztLQUFBO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JlbW90ZURhdGFWaWV3Q29tbWFuZEJhc2V9IGZyb20gXCIuL1JlbW90ZURhdGFWaWV3Q29tbWFuZEJhc2VcIjtcclxuaW1wb3J0IHtBZGRVc2VyTG9jYXRlRGF0YVZpZXdDb21tYW5kfSBmcm9tIFwiLi4vY29tbWFuZHMvQ2xpZW50VG9TZXJ2ZXIvQWRkVXNlckxvY2F0ZURhdGFWaWV3Q29tbWFuZFwiO1xyXG5pbXBvcnQge1JldHVyblJlc3VsdEJhc2V9IGZyb20gXCIuLi91dGlsL1JldHVyblJlc3VsdEJhc2VcIjtcclxuaW1wb3J0IHtMaXN0fSBmcm9tIFwiQG1hZ2ljLXhwYS9tc2NvcmVsaWJcIjtcclxuaW1wb3J0IHtSZXR1cm5SZXN1bHR9IGZyb20gXCIuLi91dGlsL1JldHVyblJlc3VsdFwiO1xyXG5pbXBvcnQge1VzZXJSYW5nZX0gZnJvbSBcIi4uL3Rhc2tzL1Rhc2tCYXNlXCI7XHJcblxyXG4vLy8gPHN1bW1hcnk+XHJcbi8vLyBSZW1vdGUgRGF0YVZpZXcgQ29tbWFuZCBmb3IgQWRkIFVzZXIgTG9jYXRlcy5cclxuLy8vIDwvc3VtbWFyeT5cclxuZXhwb3J0IGNsYXNzIEFkZFVzZXJMb2NhdGVSZW1vdGVEYXRhVmlld0NvbW1hbmQgZXh0ZW5kcyBSZW1vdGVEYXRhVmlld0NvbW1hbmRCYXNlIHtcclxuICBwcml2YXRlIHVzZXJSYW5nZTogVXNlclJhbmdlID0gbnVsbDtcclxuXHJcbiAgY29uc3RydWN0b3IoY29tbWFuZDogQWRkVXNlckxvY2F0ZURhdGFWaWV3Q29tbWFuZCkge1xyXG4gICAgc3VwZXIoY29tbWFuZCk7XHJcbiAgICB0aGlzLnVzZXJSYW5nZSA9IGNvbW1hbmQuUmFuZ2U7XHJcbiAgfVxyXG5cclxuICAvLy8gPHN1bW1hcnk+XHJcbiAgLy8vIEFkZCBsb2NhdGUgdmFsdWVzIGludG8gdGhlIHRhc2ssIHNvIHRoYXQgdmlldyByZWZyZXNoIGNvbW1hbmQgd2lsbCB1c2UgdGhpcyB2YWx1ZXMgdG8gbG9jYXRlIHRoZSByZWNvcmRzLlxyXG4gIC8vLyA8L3N1bW1hcnk+XHJcbiAgLy8vIDxyZXR1cm5zPjwvcmV0dXJucz5cclxuICBhc3luYyBFeGVjdXRlKCk6IFByb21pc2U8UmV0dXJuUmVzdWx0QmFzZT4ge1xyXG4gICAgaWYgKHRoaXMuVGFzay5Vc2VyTG9jcyA9PT0gbnVsbCkge1xyXG4gICAgICB0aGlzLlRhc2suVXNlckxvY3MgPSBuZXcgTGlzdDxVc2VyUmFuZ2U+KCk7XHJcbiAgICB9XHJcbiAgICB0aGlzLlRhc2suVXNlckxvY3MucHVzaCh0aGlzLnVzZXJSYW5nZSk7XHJcbiAgICByZXR1cm4gbmV3IFJldHVyblJlc3VsdCgpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { RemoteDataViewCommandBase } from "./RemoteDataViewCommandBase";
|
|
3
|
-
import { List } from "@magic-xpa/mscorelib";
|
|
4
|
-
import { ReturnResult } from "../util/ReturnResult";
|
|
5
|
-
export class AddUserRangeRemoteDataViewCommand extends RemoteDataViewCommandBase {
|
|
6
|
-
constructor(command) {
|
|
7
|
-
super(command);
|
|
8
|
-
this.userRange = null;
|
|
9
|
-
this.userRange = command.Range;
|
|
10
|
-
}
|
|
11
|
-
Execute() {
|
|
12
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
13
|
-
if (this.Task.UserRngs === null) {
|
|
14
|
-
this.Task.UserRngs = new List();
|
|
15
|
-
}
|
|
16
|
-
this.Task.UserRngs.push(this.userRange);
|
|
17
|
-
return new ReturnResult();
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWRkVXNlclJhbmdlUmVtb3RlRGF0YVZpZXdDb21tYW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZW5naW5lL3NyYy9yZW1vdGUvQWRkVXNlclJhbmdlUmVtb3RlRGF0YVZpZXdDb21tYW5kLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUl0RSxPQUFPLEVBQUMsSUFBSSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDMUMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBS2xELE1BQU0sT0FBTyxpQ0FBa0MsU0FBUSx5QkFBeUI7SUFHOUUsWUFBWSxPQUFvQztRQUM5QyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFIVCxjQUFTLEdBQWMsSUFBSSxDQUFDO1FBSWxDLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQztJQUNqQyxDQUFDO0lBRUssT0FBTzs7WUFDWCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxLQUFLLElBQUksRUFBRTtnQkFDL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxJQUFJLEVBQWEsQ0FBQzthQUM1QztZQUNELElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDeEMsT0FBTyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQzVCLENBQUM7S0FBQTtDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtSZW1vdGVEYXRhVmlld0NvbW1hbmRCYXNlfSBmcm9tIFwiLi9SZW1vdGVEYXRhVmlld0NvbW1hbmRCYXNlXCI7XHJcbmltcG9ydCB7VXNlclJhbmdlfSBmcm9tIFwiLi4vdGFza3MvVGFza0Jhc2VcIjtcclxuaW1wb3J0IHtBZGRVc2VyUmFuZ2VEYXRhdmlld0NvbW1hbmR9IGZyb20gXCIuLi9jb21tYW5kcy9DbGllbnRUb1NlcnZlci9BZGRVc2VyUmFuZ2VEYXRhdmlld0NvbW1hbmRcIjtcclxuaW1wb3J0IHtSZXR1cm5SZXN1bHRCYXNlfSBmcm9tIFwiLi4vdXRpbC9SZXR1cm5SZXN1bHRCYXNlXCI7XHJcbmltcG9ydCB7TGlzdH0gZnJvbSBcIkBtYWdpYy14cGEvbXNjb3JlbGliXCI7XHJcbmltcG9ydCB7UmV0dXJuUmVzdWx0fSBmcm9tIFwiLi4vdXRpbC9SZXR1cm5SZXN1bHRcIjtcclxuXHJcbi8vLyA8c3VtbWFyeT5cclxuLy8vIGNvbW1hbmQgdG8gYWRkIHRoZSB1c2VyIHJhbmdlLCBmcm9tIFJhbmdlQWRkLCB0byB0aGUgcmVtb3RlIGRhdGEgdmlld1xyXG4vLy8gPC9zdW1tYXJ5PlxyXG5leHBvcnQgY2xhc3MgQWRkVXNlclJhbmdlUmVtb3RlRGF0YVZpZXdDb21tYW5kIGV4dGVuZHMgUmVtb3RlRGF0YVZpZXdDb21tYW5kQmFzZSB7XHJcbiAgcHJpdmF0ZSB1c2VyUmFuZ2U6IFVzZXJSYW5nZSA9IG51bGw7XHJcblxyXG4gIGNvbnN0cnVjdG9yKGNvbW1hbmQ6IEFkZFVzZXJSYW5nZURhdGF2aWV3Q29tbWFuZCkge1xyXG4gICAgc3VwZXIoY29tbWFuZCk7XHJcbiAgICB0aGlzLnVzZXJSYW5nZSA9IGNvbW1hbmQuUmFuZ2U7XHJcbiAgfVxyXG5cclxuICBhc3luYyBFeGVjdXRlKCk6IFByb21pc2U8UmV0dXJuUmVzdWx0QmFzZT4ge1xyXG4gICAgaWYgKHRoaXMuVGFzay5Vc2VyUm5ncyA9PT0gbnVsbCkge1xyXG4gICAgICB0aGlzLlRhc2suVXNlclJuZ3MgPSBuZXcgTGlzdDxVc2VyUmFuZ2U+KCk7XHJcbiAgICB9XHJcbiAgICB0aGlzLlRhc2suVXNlclJuZ3MucHVzaCh0aGlzLnVzZXJSYW5nZSk7XHJcbiAgICByZXR1cm4gbmV3IFJldHVyblJlc3VsdCgpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { RemoteDataViewCommandBase } from "./RemoteDataViewCommandBase";
|
|
3
|
-
import { List } from "@magic-xpa/mscorelib";
|
|
4
|
-
import { ReturnResult } from "../util/ReturnResult";
|
|
5
|
-
export class AddUserSortRemoteDataViewCommand extends RemoteDataViewCommandBase {
|
|
6
|
-
constructor(command) {
|
|
7
|
-
super(command);
|
|
8
|
-
this.sort = null;
|
|
9
|
-
this.sort = command.Sort;
|
|
10
|
-
}
|
|
11
|
-
Execute() {
|
|
12
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
13
|
-
if (this.Task.UserSorts === null) {
|
|
14
|
-
this.Task.UserSorts = new List();
|
|
15
|
-
}
|
|
16
|
-
this.Task.UserSorts.push(this.sort);
|
|
17
|
-
return new ReturnResult();
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWRkVXNlclNvcnRSZW1vdGVEYXRhVmlld0NvbW1hbmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL3JlbW90ZS9BZGRVc2VyU29ydFJlbW90ZURhdGFWaWV3Q29tbWFuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFJdEUsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQzFDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUtsRCxNQUFNLE9BQU8sZ0NBQWlDLFNBQVEseUJBQXlCO0lBRzdFLFlBQVksT0FBbUM7UUFDN0MsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBSFQsU0FBSSxHQUFTLElBQUksQ0FBQztRQUl4QixJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUM7SUFDM0IsQ0FBQztJQU1LLE9BQU87O1lBQ1gsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsS0FBSyxJQUFJLEVBQUU7Z0JBQ2hDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksSUFBSSxFQUFRLENBQUM7YUFDeEM7WUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3BDLE9BQU8sSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUM1QixDQUFDO0tBQUE7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7UmVtb3RlRGF0YVZpZXdDb21tYW5kQmFzZX0gZnJvbSBcIi4vUmVtb3RlRGF0YVZpZXdDb21tYW5kQmFzZVwiO1xyXG5pbXBvcnQge1NvcnR9IGZyb20gXCIuLi90YXNrcy9zb3J0L1NvcnRcIjtcclxuaW1wb3J0IHtBZGRVc2VyU29ydERhdGFWaWV3Q29tbWFuZH0gZnJvbSBcIi4uL2NvbW1hbmRzL0NsaWVudFRvU2VydmVyL0FkZFVzZXJTb3J0RGF0YVZpZXdDb21tYW5kXCI7XHJcbmltcG9ydCB7UmV0dXJuUmVzdWx0QmFzZX0gZnJvbSBcIi4uL3V0aWwvUmV0dXJuUmVzdWx0QmFzZVwiO1xyXG5pbXBvcnQge0xpc3R9IGZyb20gXCJAbWFnaWMteHBhL21zY29yZWxpYlwiO1xyXG5pbXBvcnQge1JldHVyblJlc3VsdH0gZnJvbSBcIi4uL3V0aWwvUmV0dXJuUmVzdWx0XCI7XHJcblxyXG4vLy8gPHN1bW1hcnk+XHJcbi8vLyBSZW1vdGUgRGF0YVZpZXcgQ29tbWFuZCBmb3IgQWRkIHVzZXIgc29ydC5cclxuLy8vIDwvc3VtbWFyeT5cclxuZXhwb3J0IGNsYXNzIEFkZFVzZXJTb3J0UmVtb3RlRGF0YVZpZXdDb21tYW5kIGV4dGVuZHMgUmVtb3RlRGF0YVZpZXdDb21tYW5kQmFzZSB7XHJcbiAgcHJpdmF0ZSBzb3J0OiBTb3J0ID0gbnVsbDtcclxuXHJcbiAgY29uc3RydWN0b3IoY29tbWFuZDogQWRkVXNlclNvcnREYXRhVmlld0NvbW1hbmQpIHtcclxuICAgIHN1cGVyKGNvbW1hbmQpO1xyXG4gICAgdGhpcy5zb3J0ID0gY29tbWFuZC5Tb3J0O1xyXG4gIH1cclxuXHJcbiAgLy8vIDxzdW1tYXJ5PlxyXG4gIC8vLyBUaGlzIHdpbGwgYWRkIHVzZXIgc29ydHMgb24gdGFzayBzbyB0aGF0IHZpZXcgcmVmcmVzaCBjb21tYW5kIHdpbGwgYXBwbHkgdGhpcyBzb3J0LlxyXG4gIC8vLyA8L3N1bW1hcnk+XHJcbiAgLy8vIDxyZXR1cm5zPjwvcmV0dXJucz5cclxuICBhc3luYyBFeGVjdXRlKCk6IFByb21pc2U8UmV0dXJuUmVzdWx0QmFzZT4ge1xyXG4gICAgaWYgKHRoaXMuVGFzay5Vc2VyU29ydHMgPT09IG51bGwpIHtcclxuICAgICAgdGhpcy5UYXNrLlVzZXJTb3J0cyA9IG5ldyBMaXN0PFNvcnQ+KCk7XHJcbiAgICB9XHJcbiAgICB0aGlzLlRhc2suVXNlclNvcnRzLnB1c2godGhpcy5zb3J0KTtcclxuICAgIHJldHVybiBuZXcgUmV0dXJuUmVzdWx0KCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|