forked from alertlogic/al-collector-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparse.js
95 lines (85 loc) · 2.71 KB
/
parse.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/* -----------------------------------------------------------------------------
* @copyright (C) 2019, Alert Logic, Inc
* @doc
*
* Message parse utilities common for collector functions.
* Message timestamp and type property paths are based on Azure event schema definitions
* https://docs.microsoft.com/en-us/azure/azure-monitor/platform/activity-log-schema#mapping-to-diagnostic-logs-schema
* https://docs.microsoft.com/en-us/azure/azure-monitor/platform/tutorial-dashboards
*
* @end
* -----------------------------------------------------------------------------
*/
/*
* For the ISO8601 timestamp, '2018-12-19T08:18:21.1834546Z'
*/
const ISO8601_MICROSEC_OFFSET = 20;
var getProp = function(path, obj, defaultVal = null) {
var reduceFun = function(xs, x) {
return (xs && xs[x]) ? xs[x] : defaultVal;
};
return path.reduce(reduceFun, obj);
};
var defaultTs = function() {
return {
sec: Math.floor(Date.now() / 1000),
usec: null
};
};
var parseTs = function(ts) {
var milli = Date.parse(ts);
if (isNaN(milli)) {
return defaultTs();
} else {
var micro = parseTsUsec(ts);
return {
sec: Math.floor(milli / 1000),
usec: micro
};
}
};
var parseTsUsec = function(ts) {
var micro = null;
try {
// extracts microseconds from ISO8601 timestamp, like '2018-12-19T08:18:21.1834546Z'
if (ts.length > ISO8601_MICROSEC_OFFSET) {
var microStr = ts.slice(ISO8601_MICROSEC_OFFSET, ISO8601_MICROSEC_OFFSET + 6).replace(/Z|\+.*$/g, '');
while (microStr && microStr.length > 0 && microStr.length < 6) {
microStr += '0';
}
micro = Number.parseInt(microStr);
micro = Number.isInteger(micro) ? micro : null;
}
return micro;
} catch (err) {
// Unable to get microseconds from a timestamp. Do nothing.
return null;
}
};
var iteratePropPaths = function(paths, msg) {
return paths.reduce(function(acc, v) {
if (acc) {
return acc;
} else {
const propVal = getProp(v.path, msg);
if (v.override) {
return propVal ? v.override : propVal;
} else {
return propVal;
}
}
}, null);
};
var getMsgTs = function(msg, tsPaths) {
var msgTs = iteratePropPaths(tsPaths, msg);
return msgTs ? parseTs(msgTs) : defaultTs();
};
var getMsgTypeId = function(msg, typeIdPaths, defaultVal = null) {
var msgType = iteratePropPaths(typeIdPaths, msg);
return msgType ? msgType : defaultVal;
};
module.exports = {
iteratePropPaths: iteratePropPaths,
getMsgTs: getMsgTs,
getMsgTypeId: getMsgTypeId
};