@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.
- package/LICENSE +43 -43
- package/README.md +50 -50
- package/dist/browser/index.js +1 -1
- package/dist/browser/index.js.map +1 -1
- package/dist/browser/index.umd.cjs +1 -1
- package/dist/browser/index.umd.cjs.map +1 -1
- package/dist/node/index.cjs +6 -6
- package/dist/node/index.cjs.map +4 -4
- package/dist/node/index.js +6 -6
- package/dist/node/index.js.map +4 -4
- package/package.json +5 -5
- package/src/__package__.ts +3 -3
- package/src/clienttools/eclMeta.ts +506 -506
- package/src/clienttools/eclcc.ts +628 -628
- package/src/connection.ts +288 -288
- package/src/ecl/activity.ts +82 -82
- package/src/ecl/dfuWorkunit.ts +363 -363
- package/src/ecl/graph.ts +196 -196
- package/src/ecl/logicalFile.ts +196 -196
- package/src/ecl/machine.ts +63 -63
- package/src/ecl/query.ts +265 -265
- package/src/ecl/queryGraph.ts +813 -813
- package/src/ecl/resource.ts +39 -39
- package/src/ecl/result.ts +245 -245
- package/src/ecl/scope.ts +188 -188
- package/src/ecl/sourceFile.ts +34 -34
- package/src/ecl/store.ts +154 -154
- package/src/ecl/targetCluster.ts +149 -149
- package/src/ecl/timer.ts +42 -42
- package/src/ecl/topology.ts +131 -131
- package/src/ecl/workunit.ts +1340 -1340
- package/src/ecl/xsdParser.ts +267 -267
- package/src/espConnection.ts +164 -164
- package/src/index.browser.ts +1 -1
- package/src/index.common.ts +40 -40
- package/src/index.node.ts +48 -48
- package/src/pem/trustwave.ts +909 -909
- package/src/services/fileSpray.ts +48 -48
- package/src/services/wsAccess.ts +8 -8
- package/src/services/wsAccount.ts +27 -27
- package/src/services/wsCloud.ts +73 -73
- package/src/services/wsCodesign.ts +18 -18
- package/src/services/wsDFU.ts +34 -34
- package/src/services/wsDFUXRef.ts +121 -121
- package/src/services/wsDali.ts +8 -8
- package/src/services/wsEcl.ts +123 -123
- package/src/services/wsElk.ts +8 -8
- package/src/services/wsLogaccess.ts +267 -263
- package/src/services/wsMachine.ts +89 -89
- package/src/services/wsPackageProcess.ts +8 -8
- package/src/services/wsResources.ts +8 -8
- package/src/services/wsSMC.ts +80 -80
- package/src/services/wsSasha.ts +7 -7
- package/src/services/wsStore.ts +32 -32
- package/src/services/wsTopology.ts +45 -45
- package/src/services/wsWorkunits.ts +151 -151
- package/src/services/wsdl/FileSpray/v1.23/FileSpray.ts +1008 -1008
- package/src/services/wsdl/FileSpray/v1.25/FileSpray.ts +1040 -1040
- package/src/services/wsdl/FileSpray/v1.26/FileSpray.ts +929 -929
- package/src/services/wsdl/FileSpray/v1.27/FileSpray.ts +930 -930
- package/src/services/wsdl/WsCloud/v1/WsCloud.ts +38 -38
- package/src/services/wsdl/WsCloud/v1.02/WsCloud.ts +77 -77
- package/src/services/wsdl/WsDFUXRef/v1.02/WsDFUXRef.ts +224 -224
- package/src/services/wsdl/WsDFUXRef/v1.04/WsDFUXRef.ts +227 -227
- package/src/services/wsdl/WsDali/v1.04/WsDali.ts +216 -216
- package/src/services/wsdl/WsDfu/v1.62/WsDfu.ts +1455 -1455
- package/src/services/wsdl/WsDfu/v1.63/WsDfu.ts +1465 -1465
- package/src/services/wsdl/WsDfu/v1.65/WsDfu.ts +1244 -1244
- package/src/services/wsdl/WsDfu/v1.66/WsDfu.ts +1267 -1267
- package/src/services/wsdl/WsDfu/v1.67/WsDfu.ts +1268 -1268
- package/src/services/wsdl/WsFileIO/v1.01/WsFileIO.ts +104 -104
- package/src/services/wsdl/WsPackageProcess/v1.04/WsPackageProcess.ts +519 -519
- package/src/services/wsdl/WsPackageProcess/v1.07/WsPackageProcess.ts +500 -500
- package/src/services/wsdl/WsResources/v1.01/WsResources.ts +119 -119
- package/src/services/wsdl/WsSMC/v1.24/WsSMC.ts +665 -665
- package/src/services/wsdl/WsSMC/v1.27/WsSMC.ts +591 -591
- package/src/services/wsdl/WsSMC/v1.28/WsSMC.ts +645 -645
- package/src/services/wsdl/WsSMC/v1.29/WsSMC.ts +660 -660
- package/src/services/wsdl/WsTopology/v1.31/WsTopology.ts +856 -856
- package/src/services/wsdl/WsTopology/v1.32/WsTopology.ts +786 -786
- package/src/services/wsdl/WsTopology/v1.33/WsTopology.ts +835 -835
- package/src/services/wsdl/WsWorkunits/v1.88/WsWorkunits.ts +2944 -2944
- package/src/services/wsdl/WsWorkunits/v1.94/WsWorkunits.ts +3072 -3072
- package/src/services/wsdl/WsWorkunits/v1.95/WsWorkunits.ts +3073 -3073
- package/src/services/wsdl/WsWorkunits/v1.97/WsWorkunits.ts +3134 -3134
- package/src/services/wsdl/WsWorkunits/v1.98/WsWorkunits.ts +3182 -3182
- package/src/services/wsdl/WsWorkunits/v1.99/WsWorkunits.ts +3162 -3162
- package/src/services/wsdl/WsWorkunits/v2/WsWorkunits.ts +3153 -3153
- package/src/services/wsdl/WsWorkunits/v2.02/WsWorkunits.ts +3162 -3162
- package/src/services/wsdl/WsWorkunits/v2.03/WsWorkunits.ts +3164 -3164
- package/src/services/wsdl/WsWorkunits/v2.04/WsWorkunits.ts +3171 -0
- package/src/services/wsdl/ws_access/v1.16/ws_access.ts +1086 -1086
- package/src/services/wsdl/ws_access/v1.17/ws_access.ts +1023 -1023
- package/src/services/wsdl/ws_account/v1.05/ws_account.ts +111 -111
- package/src/services/wsdl/ws_account/v1.06/ws_account.ts +109 -109
- package/src/services/wsdl/ws_account/v1.07/ws_account.ts +114 -114
- package/src/services/wsdl/ws_codesign/v1.1/ws_codesign.ts +95 -95
- package/src/services/wsdl/ws_elk/v1/ws_elk.ts +47 -47
- package/src/services/wsdl/ws_logaccess/v1/ws_logaccess.ts +83 -83
- package/src/services/wsdl/ws_logaccess/v1.02/ws_logaccess.ts +161 -161
- package/src/services/wsdl/ws_logaccess/v1.03/ws_logaccess.ts +190 -190
- package/src/services/wsdl/ws_logaccess/v1.04/ws_logaccess.ts +215 -215
- package/src/services/wsdl/ws_logaccess/v1.05/ws_logaccess.ts +219 -219
- package/src/services/wsdl/ws_logaccess/v1.08/ws_logaccess.ts +267 -267
- package/src/services/wsdl/ws_machine/v1.17/ws_machine.ts +567 -567
- package/src/services/wsdl/ws_machine/v1.18/ws_machine.ts +497 -497
- package/src/services/wsdl/ws_machine/v1.19/ws_machine.ts +497 -497
- package/src/services/wsdl/wsstore/v1.02/wsstore.ts +239 -239
- package/types/services/wsWorkunits.d.ts +1 -1
- 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
|
-
|
|
122
|
-
|
|
123
|
-
if (key
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
case WsLogaccess.LogColumnType.
|
|
138
|
-
case "hpcc.log.
|
|
139
|
-
logCategory = WsLogaccess.LogAccessType.
|
|
140
|
-
break;
|
|
141
|
-
case WsLogaccess.LogColumnType.
|
|
142
|
-
case "hpcc.log.
|
|
143
|
-
logCategory = WsLogaccess.LogAccessType.
|
|
144
|
-
break;
|
|
145
|
-
case WsLogaccess.LogColumnType.
|
|
146
|
-
case "
|
|
147
|
-
logCategory = WsLogaccess.LogAccessType.
|
|
148
|
-
break;
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
binaryLogFilter.
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
getLogsRequest.Filter.
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
lines = [];
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
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
|
+
}
|