@hpcc-js/comms 3.14.1 → 3.14.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 (110) hide show
  1. package/LICENSE +43 -43
  2. package/README.md +50 -50
  3. package/dist/browser/index.js +1 -1
  4. package/dist/browser/index.js.map +1 -1
  5. package/dist/browser/index.umd.cjs +1 -1
  6. package/dist/browser/index.umd.cjs.map +1 -1
  7. package/dist/node/index.cjs +6 -6
  8. package/dist/node/index.cjs.map +4 -4
  9. package/dist/node/index.js +6 -6
  10. package/dist/node/index.js.map +4 -4
  11. package/package.json +5 -5
  12. package/src/__package__.ts +3 -3
  13. package/src/clienttools/eclMeta.ts +506 -506
  14. package/src/clienttools/eclcc.ts +628 -628
  15. package/src/connection.ts +288 -288
  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 +196 -196
  20. package/src/ecl/machine.ts +63 -63
  21. package/src/ecl/query.ts +265 -265
  22. package/src/ecl/queryGraph.ts +813 -813
  23. package/src/ecl/resource.ts +39 -39
  24. package/src/ecl/result.ts +245 -245
  25. package/src/ecl/scope.ts +188 -188
  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 +1340 -1340
  32. package/src/ecl/xsdParser.ts +267 -267
  33. package/src/espConnection.ts +164 -164
  34. package/src/index.browser.ts +1 -1
  35. package/src/index.common.ts +40 -40
  36. package/src/index.node.ts +48 -48
  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 +18 -18
  43. package/src/services/wsDFU.ts +34 -34
  44. package/src/services/wsDFUXRef.ts +121 -121
  45. package/src/services/wsDali.ts +8 -8
  46. package/src/services/wsEcl.ts +123 -123
  47. package/src/services/wsElk.ts +8 -8
  48. package/src/services/wsLogaccess.ts +267 -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 +80 -80
  53. package/src/services/wsSasha.ts +7 -7
  54. package/src/services/wsStore.ts +32 -32
  55. package/src/services/wsTopology.ts +45 -45
  56. package/src/services/wsWorkunits.ts +151 -151
  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/FileSpray/v1.27/FileSpray.ts +930 -930
  61. package/src/services/wsdl/WsCloud/v1/WsCloud.ts +38 -38
  62. package/src/services/wsdl/WsCloud/v1.02/WsCloud.ts +77 -77
  63. package/src/services/wsdl/WsDFUXRef/v1.02/WsDFUXRef.ts +224 -224
  64. package/src/services/wsdl/WsDFUXRef/v1.04/WsDFUXRef.ts +227 -227
  65. package/src/services/wsdl/WsDali/v1.04/WsDali.ts +216 -216
  66. package/src/services/wsdl/WsDfu/v1.62/WsDfu.ts +1455 -1455
  67. package/src/services/wsdl/WsDfu/v1.63/WsDfu.ts +1465 -1465
  68. package/src/services/wsdl/WsDfu/v1.65/WsDfu.ts +1244 -1244
  69. package/src/services/wsdl/WsDfu/v1.66/WsDfu.ts +1267 -1267
  70. package/src/services/wsdl/WsDfu/v1.67/WsDfu.ts +1268 -1268
  71. package/src/services/wsdl/WsFileIO/v1.01/WsFileIO.ts +104 -104
  72. package/src/services/wsdl/WsPackageProcess/v1.04/WsPackageProcess.ts +519 -519
  73. package/src/services/wsdl/WsPackageProcess/v1.07/WsPackageProcess.ts +500 -500
  74. package/src/services/wsdl/WsResources/v1.01/WsResources.ts +119 -119
  75. package/src/services/wsdl/WsSMC/v1.24/WsSMC.ts +665 -665
  76. package/src/services/wsdl/WsSMC/v1.27/WsSMC.ts +591 -591
  77. package/src/services/wsdl/WsSMC/v1.28/WsSMC.ts +645 -645
  78. package/src/services/wsdl/WsSMC/v1.29/WsSMC.ts +660 -660
  79. package/src/services/wsdl/WsTopology/v1.31/WsTopology.ts +856 -856
  80. package/src/services/wsdl/WsTopology/v1.32/WsTopology.ts +786 -786
  81. package/src/services/wsdl/WsTopology/v1.33/WsTopology.ts +835 -835
  82. package/src/services/wsdl/WsWorkunits/v1.88/WsWorkunits.ts +2944 -2944
  83. package/src/services/wsdl/WsWorkunits/v1.94/WsWorkunits.ts +3072 -3072
  84. package/src/services/wsdl/WsWorkunits/v1.95/WsWorkunits.ts +3073 -3073
  85. package/src/services/wsdl/WsWorkunits/v1.97/WsWorkunits.ts +3134 -3134
  86. package/src/services/wsdl/WsWorkunits/v1.98/WsWorkunits.ts +3182 -3182
  87. package/src/services/wsdl/WsWorkunits/v1.99/WsWorkunits.ts +3162 -3162
  88. package/src/services/wsdl/WsWorkunits/v2/WsWorkunits.ts +3153 -3153
  89. package/src/services/wsdl/WsWorkunits/v2.02/WsWorkunits.ts +3162 -3162
  90. package/src/services/wsdl/WsWorkunits/v2.03/WsWorkunits.ts +3164 -3164
  91. package/src/services/wsdl/WsWorkunits/v2.04/WsWorkunits.ts +3171 -0
  92. package/src/services/wsdl/ws_access/v1.16/ws_access.ts +1086 -1086
  93. package/src/services/wsdl/ws_access/v1.17/ws_access.ts +1023 -1023
  94. package/src/services/wsdl/ws_account/v1.05/ws_account.ts +111 -111
  95. package/src/services/wsdl/ws_account/v1.06/ws_account.ts +109 -109
  96. package/src/services/wsdl/ws_account/v1.07/ws_account.ts +114 -114
  97. package/src/services/wsdl/ws_codesign/v1.1/ws_codesign.ts +95 -95
  98. package/src/services/wsdl/ws_elk/v1/ws_elk.ts +47 -47
  99. package/src/services/wsdl/ws_logaccess/v1/ws_logaccess.ts +83 -83
  100. package/src/services/wsdl/ws_logaccess/v1.02/ws_logaccess.ts +161 -161
  101. package/src/services/wsdl/ws_logaccess/v1.03/ws_logaccess.ts +190 -190
  102. package/src/services/wsdl/ws_logaccess/v1.04/ws_logaccess.ts +215 -215
  103. package/src/services/wsdl/ws_logaccess/v1.05/ws_logaccess.ts +219 -219
  104. package/src/services/wsdl/ws_logaccess/v1.08/ws_logaccess.ts +267 -267
  105. package/src/services/wsdl/ws_machine/v1.17/ws_machine.ts +567 -567
  106. package/src/services/wsdl/ws_machine/v1.18/ws_machine.ts +497 -497
  107. package/src/services/wsdl/ws_machine/v1.19/ws_machine.ts +497 -497
  108. package/src/services/wsdl/wsstore/v1.02/wsstore.ts +239 -239
  109. package/types/services/wsWorkunits.d.ts +1 -1
  110. package/types/services/wsdl/WsWorkunits/{v2.03 → v2.04}/WsWorkunits.d.ts +9 -3
@@ -1,263 +1,267 @@
1
- import { scopedLogger } from "@hpcc-js/util";
2
- import { LogaccessServiceBase, WsLogaccess } from "./wsdl/ws_logaccess/v1.08/ws_logaccess.ts";
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: any) {
255
- logger.error(e.message ?? 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.ts";
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
+ const logTypes = Object.values(WsLogaccess.LogColumnType);
122
+ for (const key in request) {
123
+ if (request[key] == null || request[key] === "" || (Array.isArray(request[key]) && request[key].length === 0)) {
124
+ continue;
125
+ }
126
+ let searchField;
127
+ if (key in columnMap) {
128
+ if (logTypes.includes(key as WsLogaccess.LogColumnType)) {
129
+ searchField = key;
130
+ } else {
131
+ searchField = columnMap[key];
132
+ }
133
+ }
134
+ let logCategory;
135
+ if (searchField) {
136
+ switch (searchField) {
137
+ case WsLogaccess.LogColumnType.workunits:
138
+ case "hpcc.log.jobid":
139
+ logCategory = WsLogaccess.LogAccessType.ByJobID;
140
+ break;
141
+ case WsLogaccess.LogColumnType.audience:
142
+ case "hpcc.log.audience":
143
+ logCategory = WsLogaccess.LogAccessType.ByTargetAudience;
144
+ break;
145
+ case WsLogaccess.LogColumnType.class:
146
+ case "hpcc.log.class":
147
+ logCategory = WsLogaccess.LogAccessType.ByLogType;
148
+ break;
149
+ case WsLogaccess.LogColumnType.components:
150
+ case "kubernetes.container.name":
151
+ logCategory = WsLogaccess.LogAccessType.ByComponent;
152
+ break;
153
+ default:
154
+ logCategory = WsLogaccess.LogAccessType.ByFieldName;
155
+ searchField = columnMap[key];
156
+ }
157
+ if (Array.isArray(request[key])) {
158
+ request[key].forEach(value => {
159
+ if (logCategory === WsLogaccess.LogAccessType.ByComponent) {
160
+ value += "*";
161
+ }
162
+ filters.push({
163
+ LogCategory: logCategory,
164
+ SearchField: searchField,
165
+ SearchByValue: value
166
+ });
167
+ });
168
+ } else {
169
+ let value = request[key];
170
+ if (logCategory === WsLogaccess.LogAccessType.ByComponent) {
171
+ // append wildcard to end of search value to include ephemeral
172
+ // containers that aren't listed in ECL Watch's filters
173
+ value += "*";
174
+ }
175
+ filters.push({
176
+ LogCategory: logCategory,
177
+ SearchField: searchField,
178
+ SearchByValue: value
179
+ });
180
+ }
181
+ }
182
+ }
183
+
184
+ if (filters.length > 2) {
185
+ let binaryLogFilter = getLogsRequest.Filter.leftBinaryFilter.BinaryLogFilter[0];
186
+ filters.forEach((filter, i) => {
187
+ let operator = WsLogaccess.LogAccessFilterOperator.AND;
188
+ if (i > 0) {
189
+ if (filters[i - 1].SearchField === filter.SearchField) {
190
+ operator = WsLogaccess.LogAccessFilterOperator.OR;
191
+ }
192
+ if (i === filters.length - 1) {
193
+ binaryLogFilter.Operator = operator;
194
+ binaryLogFilter.rightFilter = filter as WsLogaccess.rightFilter;
195
+ } else {
196
+ binaryLogFilter.Operator = operator;
197
+ binaryLogFilter.rightBinaryFilter = {
198
+ BinaryLogFilter: [{
199
+ leftFilter: filter
200
+ } as WsLogaccess.BinaryLogFilter]
201
+ };
202
+ binaryLogFilter = binaryLogFilter.rightBinaryFilter.BinaryLogFilter[0];
203
+ }
204
+ } else {
205
+ binaryLogFilter.leftFilter = filter as WsLogaccess.leftFilter;
206
+ }
207
+ });
208
+ } else {
209
+ delete getLogsRequest.Filter.leftBinaryFilter;
210
+ getLogsRequest.Filter.leftFilter = {
211
+ LogCategory: WsLogaccess.LogAccessType.All
212
+ } as WsLogaccess.leftFilter;
213
+ if (filters[0]?.SearchField) {
214
+ getLogsRequest.Filter.leftFilter = {
215
+ LogCategory: filters[0]?.LogCategory,
216
+ SearchField: filters[0]?.SearchField,
217
+ SearchByValue: filters[0]?.SearchByValue
218
+ };
219
+ }
220
+ if (filters[1]?.SearchField) {
221
+ getLogsRequest.Filter.Operator = WsLogaccess.LogAccessFilterOperator.AND;
222
+ if (filters[0].SearchField === filters[1].SearchField) {
223
+ getLogsRequest.Filter.Operator = WsLogaccess.LogAccessFilterOperator.OR;
224
+ }
225
+ getLogsRequest.Filter.rightFilter = {
226
+ LogCategory: filters[1]?.LogCategory,
227
+ SearchField: filters[1]?.SearchField,
228
+ SearchByValue: filters[1]?.SearchByValue
229
+ };
230
+ }
231
+ }
232
+
233
+ if (request.StartDate) {
234
+ getLogsRequest.Range.StartDate = request.StartDate.toISOString();
235
+ }
236
+ if (request.EndDate) {
237
+ getLogsRequest.Range.EndDate = request.EndDate.toISOString();
238
+ }
239
+
240
+ return this.GetLogs(getLogsRequest).then(response => {
241
+ try {
242
+ const logLines = JSON.parse(response.LogLines);
243
+ let lines = [];
244
+ switch (logInfo.RemoteLogManagerType) {
245
+ case "azureloganalyticscurl":
246
+ case "elasticstack":
247
+ case "grafanacurl":
248
+ lines = logLines.lines?.map(convertLogLine) ?? [];
249
+ break;
250
+ default:
251
+ logger.warning(`Unknown RemoteLogManagerType: ${logInfo.RemoteLogManagerType}`);
252
+ lines = [];
253
+ }
254
+ return {
255
+ lines: lines,
256
+ total: response.TotalLogLinesAvailable ?? 10000
257
+ };
258
+ } catch (e: any) {
259
+ logger.error(e.message ?? e);
260
+ }
261
+ return {
262
+ lines: [],
263
+ total: 0
264
+ };
265
+ });
266
+ }
267
+ }