@hpcc-js/comms 2.102.1 → 2.102.2

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 (95) hide show
  1. package/LICENSE +43 -43
  2. package/README.md +50 -50
  3. package/dist/index.es6.js.map +1 -1
  4. package/dist/index.js.map +1 -1
  5. package/dist/index.min.js.map +1 -1
  6. package/dist/index.node.js.map +1 -1
  7. package/dist/index.node.min.js.map +1 -1
  8. package/package.json +5 -5
  9. package/src/__package__.ts +3 -3
  10. package/src/__tests__/dfuXRef.ts +22 -22
  11. package/src/__tests__/https.ts +69 -69
  12. package/src/__tests__/workunit.ts +35 -35
  13. package/src/clienttools/eclMeta.ts +506 -506
  14. package/src/clienttools/eclcc.ts +628 -628
  15. package/src/connection.ts +295 -295
  16. package/src/ecl/activity.ts +82 -82
  17. package/src/ecl/dfuWorkunit.ts +363 -363
  18. package/src/ecl/graph.ts +196 -196
  19. package/src/ecl/logicalFile.ts +195 -195
  20. package/src/ecl/machine.ts +63 -63
  21. package/src/ecl/query.ts +252 -252
  22. package/src/ecl/queryGraph.ts +813 -813
  23. package/src/ecl/resource.ts +39 -39
  24. package/src/ecl/result.ts +236 -236
  25. package/src/ecl/scope.ts +192 -192
  26. package/src/ecl/sourceFile.ts +34 -34
  27. package/src/ecl/store.ts +154 -154
  28. package/src/ecl/targetCluster.ts +149 -149
  29. package/src/ecl/timer.ts +42 -42
  30. package/src/ecl/topology.ts +131 -131
  31. package/src/ecl/workunit.ts +1314 -1314
  32. package/src/ecl/xsdParser.ts +268 -268
  33. package/src/espConnection.ts +172 -172
  34. package/src/index-common.ts +41 -41
  35. package/src/index.node.ts +68 -68
  36. package/src/index.ts +3 -3
  37. package/src/pem/trustwave.ts +909 -909
  38. package/src/services/fileSpray.ts +48 -48
  39. package/src/services/wsAccess.ts +8 -8
  40. package/src/services/wsAccount.ts +27 -27
  41. package/src/services/wsCloud.ts +73 -73
  42. package/src/services/wsCodesign.ts +94 -94
  43. package/src/services/wsDFU.ts +34 -34
  44. package/src/services/wsDFUXRef.ts +308 -308
  45. package/src/services/wsDali.ts +40 -40
  46. package/src/services/wsEcl.ts +123 -123
  47. package/src/services/wsElk.ts +8 -8
  48. package/src/services/wsLogaccess.ts +263 -263
  49. package/src/services/wsMachine.ts +89 -89
  50. package/src/services/wsPackageProcess.ts +8 -8
  51. package/src/services/wsResources.ts +8 -8
  52. package/src/services/wsSMC.ts +24 -24
  53. package/src/services/wsSasha.ts +7 -7
  54. package/src/services/wsStore.ts +230 -230
  55. package/src/services/wsTopology.ts +45 -45
  56. package/src/services/wsWorkunits.ts +160 -160
  57. package/src/services/wsdl/FileSpray/v1.23/FileSpray.ts +1008 -1008
  58. package/src/services/wsdl/FileSpray/v1.25/FileSpray.ts +1040 -1040
  59. package/src/services/wsdl/FileSpray/v1.26/FileSpray.ts +929 -929
  60. package/src/services/wsdl/WsCloud/v1/WsCloud.ts +38 -38
  61. package/src/services/wsdl/WsCloud/v1.02/WsCloud.ts +77 -77
  62. package/src/services/wsdl/WsDFUXRef/v1.02/WsDFUXRef.ts +224 -224
  63. package/src/services/wsdl/WsDali/v1.04/WsDali.ts +216 -216
  64. package/src/services/wsdl/WsDfu/v1.62/WsDfu.ts +1455 -1455
  65. package/src/services/wsdl/WsDfu/v1.63/WsDfu.ts +1465 -1465
  66. package/src/services/wsdl/WsDfu/v1.65/WsDfu.ts +1244 -1244
  67. package/src/services/wsdl/WsFileIO/v1.01/WsFileIO.ts +107 -107
  68. package/src/services/wsdl/WsPackageProcess/v1.04/WsPackageProcess.ts +519 -519
  69. package/src/services/wsdl/WsResources/v1.01/WsResources.ts +119 -119
  70. package/src/services/wsdl/WsSMC/v1.24/WsSMC.ts +665 -665
  71. package/src/services/wsdl/WsSMC/v1.27/WsSMC.ts +670 -670
  72. package/src/services/wsdl/WsTopology/v1.31/WsTopology.ts +856 -856
  73. package/src/services/wsdl/WsTopology/v1.32/WsTopology.ts +885 -885
  74. package/src/services/wsdl/WsWorkunits/v1.88/WsWorkunits.ts +2944 -2944
  75. package/src/services/wsdl/WsWorkunits/v1.94/WsWorkunits.ts +3072 -3072
  76. package/src/services/wsdl/WsWorkunits/v1.95/WsWorkunits.ts +3073 -3073
  77. package/src/services/wsdl/WsWorkunits/v1.97/WsWorkunits.ts +3134 -3134
  78. package/src/services/wsdl/WsWorkunits/v1.98/WsWorkunits.ts +3182 -3182
  79. package/src/services/wsdl/WsWorkunits/v1.99/WsWorkunits.ts +3162 -3162
  80. package/src/services/wsdl/WsWorkunits/v2/WsWorkunits.ts +3153 -3153
  81. package/src/services/wsdl/WsWorkunits/v2.02/WsWorkunits.ts +3157 -3157
  82. package/src/services/wsdl/ws_access/v1.16/ws_access.ts +1086 -1086
  83. package/src/services/wsdl/ws_access/v1.17/ws_access.ts +1023 -1023
  84. package/src/services/wsdl/ws_account/v1.05/ws_account.ts +111 -111
  85. package/src/services/wsdl/ws_account/v1.06/ws_account.ts +109 -109
  86. package/src/services/wsdl/ws_codesign/v1.1/ws_codesign.ts +100 -100
  87. package/src/services/wsdl/ws_elk/v1/ws_elk.ts +47 -47
  88. package/src/services/wsdl/ws_logaccess/v1/ws_logaccess.ts +83 -83
  89. package/src/services/wsdl/ws_logaccess/v1.02/ws_logaccess.ts +161 -161
  90. package/src/services/wsdl/ws_logaccess/v1.03/ws_logaccess.ts +190 -190
  91. package/src/services/wsdl/ws_logaccess/v1.04/ws_logaccess.ts +215 -215
  92. package/src/services/wsdl/ws_logaccess/v1.05/ws_logaccess.ts +219 -219
  93. package/src/services/wsdl/ws_logaccess/v1.08/ws_logaccess.ts +267 -267
  94. package/src/services/wsdl/ws_machine/v1.17/ws_machine.ts +567 -567
  95. package/src/services/wsdl/wsstore/v1.02/wsstore.ts +250 -250
@@ -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
+ }