@hpcc-js/comms 2.102.2 → 2.102.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/LICENSE +43 -43
  2. package/README.md +50 -50
  3. package/dist/index.es6.js +2 -2
  4. package/dist/index.es6.js.map +1 -1
  5. package/dist/index.js +2 -2
  6. package/dist/index.js.map +1 -1
  7. package/dist/index.min.js +1 -1
  8. package/dist/index.min.js.map +1 -1
  9. package/dist/index.node.js +2 -2
  10. package/dist/index.node.js.map +1 -1
  11. package/dist/index.node.min.js +1 -1
  12. package/dist/index.node.min.js.map +1 -1
  13. package/lib-es6/__package__.js +2 -2
  14. package/lib-es6/__package__.js.map +1 -1
  15. package/package.json +5 -5
  16. package/src/__package__.ts +3 -3
  17. package/src/__tests__/dfuXRef.ts +22 -22
  18. package/src/__tests__/https.ts +69 -69
  19. package/src/__tests__/workunit.ts +35 -35
  20. package/src/clienttools/eclMeta.ts +506 -506
  21. package/src/clienttools/eclcc.ts +628 -628
  22. package/src/connection.ts +295 -295
  23. package/src/ecl/activity.ts +82 -82
  24. package/src/ecl/dfuWorkunit.ts +363 -363
  25. package/src/ecl/graph.ts +196 -196
  26. package/src/ecl/logicalFile.ts +195 -195
  27. package/src/ecl/machine.ts +63 -63
  28. package/src/ecl/query.ts +252 -252
  29. package/src/ecl/queryGraph.ts +813 -813
  30. package/src/ecl/resource.ts +39 -39
  31. package/src/ecl/result.ts +236 -236
  32. package/src/ecl/scope.ts +192 -192
  33. package/src/ecl/sourceFile.ts +34 -34
  34. package/src/ecl/store.ts +154 -154
  35. package/src/ecl/targetCluster.ts +149 -149
  36. package/src/ecl/timer.ts +42 -42
  37. package/src/ecl/topology.ts +131 -131
  38. package/src/ecl/workunit.ts +1314 -1314
  39. package/src/ecl/xsdParser.ts +268 -268
  40. package/src/espConnection.ts +172 -172
  41. package/src/index-common.ts +41 -41
  42. package/src/index.node.ts +68 -68
  43. package/src/index.ts +3 -3
  44. package/src/pem/trustwave.ts +909 -909
  45. package/src/services/fileSpray.ts +48 -48
  46. package/src/services/wsAccess.ts +8 -8
  47. package/src/services/wsAccount.ts +27 -27
  48. package/src/services/wsCloud.ts +73 -73
  49. package/src/services/wsCodesign.ts +94 -94
  50. package/src/services/wsDFU.ts +34 -34
  51. package/src/services/wsDFUXRef.ts +308 -308
  52. package/src/services/wsDali.ts +40 -40
  53. package/src/services/wsEcl.ts +123 -123
  54. package/src/services/wsElk.ts +8 -8
  55. package/src/services/wsLogaccess.ts +263 -263
  56. package/src/services/wsMachine.ts +89 -89
  57. package/src/services/wsPackageProcess.ts +8 -8
  58. package/src/services/wsResources.ts +8 -8
  59. package/src/services/wsSMC.ts +24 -24
  60. package/src/services/wsSasha.ts +7 -7
  61. package/src/services/wsStore.ts +230 -230
  62. package/src/services/wsTopology.ts +45 -45
  63. package/src/services/wsWorkunits.ts +160 -160
  64. package/src/services/wsdl/FileSpray/v1.23/FileSpray.ts +1008 -1008
  65. package/src/services/wsdl/FileSpray/v1.25/FileSpray.ts +1040 -1040
  66. package/src/services/wsdl/FileSpray/v1.26/FileSpray.ts +929 -929
  67. package/src/services/wsdl/WsCloud/v1/WsCloud.ts +38 -38
  68. package/src/services/wsdl/WsCloud/v1.02/WsCloud.ts +77 -77
  69. package/src/services/wsdl/WsDFUXRef/v1.02/WsDFUXRef.ts +224 -224
  70. package/src/services/wsdl/WsDali/v1.04/WsDali.ts +216 -216
  71. package/src/services/wsdl/WsDfu/v1.62/WsDfu.ts +1455 -1455
  72. package/src/services/wsdl/WsDfu/v1.63/WsDfu.ts +1465 -1465
  73. package/src/services/wsdl/WsDfu/v1.65/WsDfu.ts +1244 -1244
  74. package/src/services/wsdl/WsFileIO/v1.01/WsFileIO.ts +107 -107
  75. package/src/services/wsdl/WsPackageProcess/v1.04/WsPackageProcess.ts +519 -519
  76. package/src/services/wsdl/WsResources/v1.01/WsResources.ts +119 -119
  77. package/src/services/wsdl/WsSMC/v1.24/WsSMC.ts +665 -665
  78. package/src/services/wsdl/WsSMC/v1.27/WsSMC.ts +670 -670
  79. package/src/services/wsdl/WsTopology/v1.31/WsTopology.ts +856 -856
  80. package/src/services/wsdl/WsTopology/v1.32/WsTopology.ts +885 -885
  81. package/src/services/wsdl/WsWorkunits/v1.88/WsWorkunits.ts +2944 -2944
  82. package/src/services/wsdl/WsWorkunits/v1.94/WsWorkunits.ts +3072 -3072
  83. package/src/services/wsdl/WsWorkunits/v1.95/WsWorkunits.ts +3073 -3073
  84. package/src/services/wsdl/WsWorkunits/v1.97/WsWorkunits.ts +3134 -3134
  85. package/src/services/wsdl/WsWorkunits/v1.98/WsWorkunits.ts +3182 -3182
  86. package/src/services/wsdl/WsWorkunits/v1.99/WsWorkunits.ts +3162 -3162
  87. package/src/services/wsdl/WsWorkunits/v2/WsWorkunits.ts +3153 -3153
  88. package/src/services/wsdl/WsWorkunits/v2.02/WsWorkunits.ts +3157 -3157
  89. package/src/services/wsdl/ws_access/v1.16/ws_access.ts +1086 -1086
  90. package/src/services/wsdl/ws_access/v1.17/ws_access.ts +1023 -1023
  91. package/src/services/wsdl/ws_account/v1.05/ws_account.ts +111 -111
  92. package/src/services/wsdl/ws_account/v1.06/ws_account.ts +109 -109
  93. package/src/services/wsdl/ws_codesign/v1.1/ws_codesign.ts +100 -100
  94. package/src/services/wsdl/ws_elk/v1/ws_elk.ts +47 -47
  95. package/src/services/wsdl/ws_logaccess/v1/ws_logaccess.ts +83 -83
  96. package/src/services/wsdl/ws_logaccess/v1.02/ws_logaccess.ts +161 -161
  97. package/src/services/wsdl/ws_logaccess/v1.03/ws_logaccess.ts +190 -190
  98. package/src/services/wsdl/ws_logaccess/v1.04/ws_logaccess.ts +215 -215
  99. package/src/services/wsdl/ws_logaccess/v1.05/ws_logaccess.ts +219 -219
  100. package/src/services/wsdl/ws_logaccess/v1.08/ws_logaccess.ts +267 -267
  101. package/src/services/wsdl/ws_machine/v1.17/ws_machine.ts +567 -567
  102. package/src/services/wsdl/wsstore/v1.02/wsstore.ts +250 -250
  103. package/types/__package__.d.ts +2 -2
  104. package/types/__package__.d.ts.map +1 -1
  105. package/types-3.4/__package__.d.ts +2 -2
@@ -1,263 +1,263 @@
1
- import { scopedLogger } from "@hpcc-js/util";
2
- import { LogaccessServiceBase, WsLogaccess } from "./wsdl/ws_logaccess/v1.08/ws_logaccess";
3
-
4
- const logger = scopedLogger("@hpcc-js/comms/services/wsLogaccess.ts");
5
-
6
- export {
7
- WsLogaccess
8
- };
9
-
10
- export interface GetLogsExRequest {
11
- audience?: string;
12
- class?: string[];
13
- workunits?: string;
14
- message?: string;
15
- processid?: string;
16
- logid?: string;
17
- threadid?: string;
18
- timestamp?: string;
19
- components?: string;
20
- instance?: string;
21
- StartDate?: Date;
22
- EndDate?: Date;
23
- LogLineStartFrom: number,
24
- LogLineLimit: number
25
- }
26
-
27
- export const enum LogType {
28
- Disaster = "DIS",
29
- Error = "ERR",
30
- Warning = "WRN",
31
- Information = "INF",
32
- Progress = "PRO",
33
- Metric = "MET"
34
- }
35
-
36
- export const enum TargetAudience {
37
- Operator = "OPR",
38
- User = "USR",
39
- Programmer = "PRO",
40
- Audit = "ADT"
41
- }
42
-
43
- //properties here are "LogType" values in Ws_logaccess.GetLogAccessInfo
44
- export interface LogLine {
45
- audience?: string;
46
- class?: string;
47
- workunits?: string;
48
- message?: string;
49
- processid?: number;
50
- logid?: string;
51
- threadid?: number;
52
- timestamp?: string;
53
- components?: string;
54
- instance?: string;
55
- }
56
-
57
- export interface GetLogsExResponse {
58
- lines: LogLine[],
59
- total: number,
60
- }
61
-
62
- export class LogaccessService extends LogaccessServiceBase {
63
-
64
- protected _logAccessInfo: Promise<WsLogaccess.GetLogAccessInfoResponse>;
65
-
66
- GetLogAccessInfo(request: WsLogaccess.GetLogAccessInfoRequest = {}): Promise<WsLogaccess.GetLogAccessInfoResponse> {
67
- if (!this._logAccessInfo) {
68
- this._logAccessInfo = super.GetLogAccessInfo(request);
69
- }
70
- return this._logAccessInfo;
71
- }
72
-
73
- GetLogs(request: WsLogaccess.GetLogsRequest): Promise<WsLogaccess.GetLogsResponse> {
74
- return super.GetLogs(request);
75
- }
76
-
77
- async GetLogsEx(request: GetLogsExRequest): Promise<GetLogsExResponse> {
78
- const logInfo = await this.GetLogAccessInfo();
79
- const columnMap = {};
80
- logInfo.Columns.Column.forEach(column => columnMap[column.LogType] = column.Name);
81
-
82
- const convertLogLine = (line: any) => {
83
- const retVal: LogLine = {};
84
- for (const key in columnMap) {
85
- if (line?.fields) {
86
- retVal[key] = Object.assign({}, ...line.fields)[columnMap[key]] ?? "";
87
- } else {
88
- retVal[key] = "";
89
- }
90
- }
91
- return retVal;
92
- };
93
-
94
- const getLogsRequest: WsLogaccess.GetLogsRequest = {
95
- Filter: {
96
- leftBinaryFilter: {
97
- BinaryLogFilter: [{
98
- leftFilter: {
99
- LogCategory: WsLogaccess.LogAccessType.All,
100
- },
101
- } as WsLogaccess.BinaryLogFilter]
102
- }
103
- },
104
- Range: {
105
- StartDate: new Date(0).toISOString(),
106
- },
107
- LogLineStartFrom: request.LogLineStartFrom ?? 0,
108
- LogLineLimit: request.LogLineLimit ?? 100,
109
- SelectColumnMode: WsLogaccess.LogSelectColumnMode.DEFAULT,
110
- Format: "JSON",
111
- SortBy: {
112
- SortCondition: [{
113
- BySortType: WsLogaccess.SortColumType.ByDate,
114
- ColumnName: "",
115
- Direction: 0
116
- }]
117
- }
118
- };
119
-
120
- const filters: WsLogaccess.leftFilter[] = [];
121
- for (const key in request) {
122
- let searchField;
123
- if (key in columnMap) {
124
- if (Object.values(WsLogaccess.LogColumnType).includes(key as WsLogaccess.LogColumnType)) {
125
- searchField = key;
126
- } else {
127
- searchField = columnMap[key];
128
- }
129
- }
130
- let logCategory;
131
- if (searchField) {
132
- switch (searchField) {
133
- case WsLogaccess.LogColumnType.workunits:
134
- case "hpcc.log.jobid":
135
- logCategory = WsLogaccess.LogAccessType.ByJobID;
136
- break;
137
- case WsLogaccess.LogColumnType.audience:
138
- case "hpcc.log.audience":
139
- logCategory = WsLogaccess.LogAccessType.ByTargetAudience;
140
- break;
141
- case WsLogaccess.LogColumnType.class:
142
- case "hpcc.log.class":
143
- logCategory = WsLogaccess.LogAccessType.ByLogType;
144
- break;
145
- case WsLogaccess.LogColumnType.components:
146
- case "kubernetes.container.name":
147
- logCategory = WsLogaccess.LogAccessType.ByComponent;
148
- break;
149
- default:
150
- logCategory = WsLogaccess.LogAccessType.ByFieldName;
151
- searchField = columnMap[key];
152
- }
153
- if (Array.isArray(request[key])) {
154
- request[key].forEach(value => {
155
- if (logCategory === WsLogaccess.LogAccessType.ByComponent) {
156
- value += "*";
157
- }
158
- filters.push({
159
- LogCategory: logCategory,
160
- SearchField: searchField,
161
- SearchByValue: value
162
- });
163
- });
164
- } else {
165
- let value = request[key];
166
- if (logCategory === WsLogaccess.LogAccessType.ByComponent) {
167
- // append wildcard to end of search value to include ephemeral
168
- // containers that aren't listed in ECL Watch's filters
169
- value += "*";
170
- }
171
- filters.push({
172
- LogCategory: logCategory,
173
- SearchField: searchField,
174
- SearchByValue: value
175
- });
176
- }
177
- }
178
- }
179
-
180
- if (filters.length > 2) {
181
- let binaryLogFilter = getLogsRequest.Filter.leftBinaryFilter.BinaryLogFilter[0];
182
- filters.forEach((filter, i) => {
183
- let operator = WsLogaccess.LogAccessFilterOperator.AND;
184
- if (i > 0) {
185
- if (filters[i - 1].SearchField === filter.SearchField) {
186
- operator = WsLogaccess.LogAccessFilterOperator.OR;
187
- }
188
- if (i === filters.length - 1) {
189
- binaryLogFilter.Operator = operator;
190
- binaryLogFilter.rightFilter = filter as WsLogaccess.rightFilter;
191
- } else {
192
- binaryLogFilter.Operator = operator;
193
- binaryLogFilter.rightBinaryFilter = {
194
- BinaryLogFilter: [{
195
- leftFilter: filter
196
- } as WsLogaccess.BinaryLogFilter]
197
- };
198
- binaryLogFilter = binaryLogFilter.rightBinaryFilter.BinaryLogFilter[0];
199
- }
200
- } else {
201
- binaryLogFilter.leftFilter = filter as WsLogaccess.leftFilter;
202
- }
203
- });
204
- } else {
205
- delete getLogsRequest.Filter.leftBinaryFilter;
206
- getLogsRequest.Filter.leftFilter = {
207
- LogCategory: WsLogaccess.LogAccessType.All
208
- } as WsLogaccess.leftFilter;
209
- if (filters[0]?.SearchField) {
210
- getLogsRequest.Filter.leftFilter = {
211
- LogCategory: filters[0]?.LogCategory,
212
- SearchField: filters[0]?.SearchField,
213
- SearchByValue: filters[0]?.SearchByValue
214
- };
215
- }
216
- if (filters[1]?.SearchField) {
217
- getLogsRequest.Filter.Operator = WsLogaccess.LogAccessFilterOperator.AND;
218
- if (filters[0].SearchField === filters[1].SearchField) {
219
- getLogsRequest.Filter.Operator = WsLogaccess.LogAccessFilterOperator.OR;
220
- }
221
- getLogsRequest.Filter.rightFilter = {
222
- LogCategory: filters[1]?.LogCategory,
223
- SearchField: filters[1]?.SearchField,
224
- SearchByValue: filters[1]?.SearchByValue
225
- };
226
- }
227
- }
228
-
229
- if (request.StartDate) {
230
- getLogsRequest.Range.StartDate = request.StartDate.toISOString();
231
- }
232
- if (request.EndDate) {
233
- getLogsRequest.Range.EndDate = request.EndDate.toISOString();
234
- }
235
-
236
- return this.GetLogs(getLogsRequest).then(response => {
237
- try {
238
- const logLines = JSON.parse(response.LogLines);
239
- let lines = [];
240
- switch (logInfo.RemoteLogManagerType) {
241
- case "azureloganalyticscurl":
242
- case "elasticstack":
243
- case "grafanacurl":
244
- lines = logLines.lines?.map(convertLogLine) ?? [];
245
- break;
246
- default:
247
- logger.warning(`Unknown RemoteLogManagerType: ${logInfo.RemoteLogManagerType}`);
248
- lines = [];
249
- }
250
- return {
251
- lines: lines,
252
- total: response.TotalLogLinesAvailable ?? 10000
253
- };
254
- } catch (e) {
255
- logger.error(e);
256
- }
257
- return {
258
- lines: [],
259
- total: 0
260
- };
261
- });
262
- }
263
- }
1
+ import { scopedLogger } from "@hpcc-js/util";
2
+ import { LogaccessServiceBase, WsLogaccess } from "./wsdl/ws_logaccess/v1.08/ws_logaccess";
3
+
4
+ const logger = scopedLogger("@hpcc-js/comms/services/wsLogaccess.ts");
5
+
6
+ export {
7
+ WsLogaccess
8
+ };
9
+
10
+ export interface GetLogsExRequest {
11
+ audience?: string;
12
+ class?: string[];
13
+ workunits?: string;
14
+ message?: string;
15
+ processid?: string;
16
+ logid?: string;
17
+ threadid?: string;
18
+ timestamp?: string;
19
+ components?: string;
20
+ instance?: string;
21
+ StartDate?: Date;
22
+ EndDate?: Date;
23
+ LogLineStartFrom: number,
24
+ LogLineLimit: number
25
+ }
26
+
27
+ export const enum LogType {
28
+ Disaster = "DIS",
29
+ Error = "ERR",
30
+ Warning = "WRN",
31
+ Information = "INF",
32
+ Progress = "PRO",
33
+ Metric = "MET"
34
+ }
35
+
36
+ export const enum TargetAudience {
37
+ Operator = "OPR",
38
+ User = "USR",
39
+ Programmer = "PRO",
40
+ Audit = "ADT"
41
+ }
42
+
43
+ //properties here are "LogType" values in Ws_logaccess.GetLogAccessInfo
44
+ export interface LogLine {
45
+ audience?: string;
46
+ class?: string;
47
+ workunits?: string;
48
+ message?: string;
49
+ processid?: number;
50
+ logid?: string;
51
+ threadid?: number;
52
+ timestamp?: string;
53
+ components?: string;
54
+ instance?: string;
55
+ }
56
+
57
+ export interface GetLogsExResponse {
58
+ lines: LogLine[],
59
+ total: number,
60
+ }
61
+
62
+ export class LogaccessService extends LogaccessServiceBase {
63
+
64
+ protected _logAccessInfo: Promise<WsLogaccess.GetLogAccessInfoResponse>;
65
+
66
+ GetLogAccessInfo(request: WsLogaccess.GetLogAccessInfoRequest = {}): Promise<WsLogaccess.GetLogAccessInfoResponse> {
67
+ if (!this._logAccessInfo) {
68
+ this._logAccessInfo = super.GetLogAccessInfo(request);
69
+ }
70
+ return this._logAccessInfo;
71
+ }
72
+
73
+ GetLogs(request: WsLogaccess.GetLogsRequest): Promise<WsLogaccess.GetLogsResponse> {
74
+ return super.GetLogs(request);
75
+ }
76
+
77
+ async GetLogsEx(request: GetLogsExRequest): Promise<GetLogsExResponse> {
78
+ const logInfo = await this.GetLogAccessInfo();
79
+ const columnMap = {};
80
+ logInfo.Columns.Column.forEach(column => columnMap[column.LogType] = column.Name);
81
+
82
+ const convertLogLine = (line: any) => {
83
+ const retVal: LogLine = {};
84
+ for (const key in columnMap) {
85
+ if (line?.fields) {
86
+ retVal[key] = Object.assign({}, ...line.fields)[columnMap[key]] ?? "";
87
+ } else {
88
+ retVal[key] = "";
89
+ }
90
+ }
91
+ return retVal;
92
+ };
93
+
94
+ const getLogsRequest: WsLogaccess.GetLogsRequest = {
95
+ Filter: {
96
+ leftBinaryFilter: {
97
+ BinaryLogFilter: [{
98
+ leftFilter: {
99
+ LogCategory: WsLogaccess.LogAccessType.All,
100
+ },
101
+ } as WsLogaccess.BinaryLogFilter]
102
+ }
103
+ },
104
+ Range: {
105
+ StartDate: new Date(0).toISOString(),
106
+ },
107
+ LogLineStartFrom: request.LogLineStartFrom ?? 0,
108
+ LogLineLimit: request.LogLineLimit ?? 100,
109
+ SelectColumnMode: WsLogaccess.LogSelectColumnMode.DEFAULT,
110
+ Format: "JSON",
111
+ SortBy: {
112
+ SortCondition: [{
113
+ BySortType: WsLogaccess.SortColumType.ByDate,
114
+ ColumnName: "",
115
+ Direction: 0
116
+ }]
117
+ }
118
+ };
119
+
120
+ const filters: WsLogaccess.leftFilter[] = [];
121
+ for (const key in request) {
122
+ let searchField;
123
+ if (key in columnMap) {
124
+ if (Object.values(WsLogaccess.LogColumnType).includes(key as WsLogaccess.LogColumnType)) {
125
+ searchField = key;
126
+ } else {
127
+ searchField = columnMap[key];
128
+ }
129
+ }
130
+ let logCategory;
131
+ if (searchField) {
132
+ switch (searchField) {
133
+ case WsLogaccess.LogColumnType.workunits:
134
+ case "hpcc.log.jobid":
135
+ logCategory = WsLogaccess.LogAccessType.ByJobID;
136
+ break;
137
+ case WsLogaccess.LogColumnType.audience:
138
+ case "hpcc.log.audience":
139
+ logCategory = WsLogaccess.LogAccessType.ByTargetAudience;
140
+ break;
141
+ case WsLogaccess.LogColumnType.class:
142
+ case "hpcc.log.class":
143
+ logCategory = WsLogaccess.LogAccessType.ByLogType;
144
+ break;
145
+ case WsLogaccess.LogColumnType.components:
146
+ case "kubernetes.container.name":
147
+ logCategory = WsLogaccess.LogAccessType.ByComponent;
148
+ break;
149
+ default:
150
+ logCategory = WsLogaccess.LogAccessType.ByFieldName;
151
+ searchField = columnMap[key];
152
+ }
153
+ if (Array.isArray(request[key])) {
154
+ request[key].forEach(value => {
155
+ if (logCategory === WsLogaccess.LogAccessType.ByComponent) {
156
+ value += "*";
157
+ }
158
+ filters.push({
159
+ LogCategory: logCategory,
160
+ SearchField: searchField,
161
+ SearchByValue: value
162
+ });
163
+ });
164
+ } else {
165
+ let value = request[key];
166
+ if (logCategory === WsLogaccess.LogAccessType.ByComponent) {
167
+ // append wildcard to end of search value to include ephemeral
168
+ // containers that aren't listed in ECL Watch's filters
169
+ value += "*";
170
+ }
171
+ filters.push({
172
+ LogCategory: logCategory,
173
+ SearchField: searchField,
174
+ SearchByValue: value
175
+ });
176
+ }
177
+ }
178
+ }
179
+
180
+ if (filters.length > 2) {
181
+ let binaryLogFilter = getLogsRequest.Filter.leftBinaryFilter.BinaryLogFilter[0];
182
+ filters.forEach((filter, i) => {
183
+ let operator = WsLogaccess.LogAccessFilterOperator.AND;
184
+ if (i > 0) {
185
+ if (filters[i - 1].SearchField === filter.SearchField) {
186
+ operator = WsLogaccess.LogAccessFilterOperator.OR;
187
+ }
188
+ if (i === filters.length - 1) {
189
+ binaryLogFilter.Operator = operator;
190
+ binaryLogFilter.rightFilter = filter as WsLogaccess.rightFilter;
191
+ } else {
192
+ binaryLogFilter.Operator = operator;
193
+ binaryLogFilter.rightBinaryFilter = {
194
+ BinaryLogFilter: [{
195
+ leftFilter: filter
196
+ } as WsLogaccess.BinaryLogFilter]
197
+ };
198
+ binaryLogFilter = binaryLogFilter.rightBinaryFilter.BinaryLogFilter[0];
199
+ }
200
+ } else {
201
+ binaryLogFilter.leftFilter = filter as WsLogaccess.leftFilter;
202
+ }
203
+ });
204
+ } else {
205
+ delete getLogsRequest.Filter.leftBinaryFilter;
206
+ getLogsRequest.Filter.leftFilter = {
207
+ LogCategory: WsLogaccess.LogAccessType.All
208
+ } as WsLogaccess.leftFilter;
209
+ if (filters[0]?.SearchField) {
210
+ getLogsRequest.Filter.leftFilter = {
211
+ LogCategory: filters[0]?.LogCategory,
212
+ SearchField: filters[0]?.SearchField,
213
+ SearchByValue: filters[0]?.SearchByValue
214
+ };
215
+ }
216
+ if (filters[1]?.SearchField) {
217
+ getLogsRequest.Filter.Operator = WsLogaccess.LogAccessFilterOperator.AND;
218
+ if (filters[0].SearchField === filters[1].SearchField) {
219
+ getLogsRequest.Filter.Operator = WsLogaccess.LogAccessFilterOperator.OR;
220
+ }
221
+ getLogsRequest.Filter.rightFilter = {
222
+ LogCategory: filters[1]?.LogCategory,
223
+ SearchField: filters[1]?.SearchField,
224
+ SearchByValue: filters[1]?.SearchByValue
225
+ };
226
+ }
227
+ }
228
+
229
+ if (request.StartDate) {
230
+ getLogsRequest.Range.StartDate = request.StartDate.toISOString();
231
+ }
232
+ if (request.EndDate) {
233
+ getLogsRequest.Range.EndDate = request.EndDate.toISOString();
234
+ }
235
+
236
+ return this.GetLogs(getLogsRequest).then(response => {
237
+ try {
238
+ const logLines = JSON.parse(response.LogLines);
239
+ let lines = [];
240
+ switch (logInfo.RemoteLogManagerType) {
241
+ case "azureloganalyticscurl":
242
+ case "elasticstack":
243
+ case "grafanacurl":
244
+ lines = logLines.lines?.map(convertLogLine) ?? [];
245
+ break;
246
+ default:
247
+ logger.warning(`Unknown RemoteLogManagerType: ${logInfo.RemoteLogManagerType}`);
248
+ lines = [];
249
+ }
250
+ return {
251
+ lines: lines,
252
+ total: response.TotalLogLinesAvailable ?? 10000
253
+ };
254
+ } catch (e) {
255
+ logger.error(e);
256
+ }
257
+ return {
258
+ lines: [],
259
+ total: 0
260
+ };
261
+ });
262
+ }
263
+ }