@contrast/agent 4.4.1 → 4.6.0

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 (156) hide show
  1. package/bin/VERSION +1 -1
  2. package/bin/linux/contrast-service +0 -0
  3. package/bin/mac/contrast-service +0 -0
  4. package/bin/windows/contrast-service.exe +0 -0
  5. package/lib/assess/hapi/route-coverage.js +3 -3
  6. package/lib/assess/membrane/index.js +2 -8
  7. package/lib/assess/membrane/source-membrane.js +3 -4
  8. package/lib/assess/models/base-event.js +2 -2
  9. package/lib/assess/models/call-context.js +0 -3
  10. package/lib/assess/policy/propagators.json +20 -0
  11. package/lib/assess/policy/signatures.json +103 -0
  12. package/lib/assess/propagators/path/common.js +165 -36
  13. package/lib/assess/propagators/path/join.js +5 -1
  14. package/lib/assess/propagators/path/normalize.js +5 -1
  15. package/lib/assess/propagators/path/resolve.js +11 -2
  16. package/lib/assess/response-scanning/autocomplete-missing.js +0 -2
  17. package/lib/assess/response-scanning/parameter-pollution.js +0 -2
  18. package/lib/core/arch-components/dynamodb.js +1 -2
  19. package/lib/core/arch-components/dynamodbv3.js +44 -0
  20. package/lib/core/arch-components/index.js +1 -0
  21. package/lib/core/async-storage/hooks/bluebird.js +20 -0
  22. package/lib/core/config/options.js +3 -2
  23. package/lib/core/express/utils.js +1 -1
  24. package/lib/core/logger/debug-logger.js +15 -17
  25. package/lib/core/stacktrace.js +3 -4
  26. package/lib/feature-set.js +2 -1
  27. package/lib/hooks/encoding.js +1 -1
  28. package/lib/hooks/frameworks/base.js +8 -2
  29. package/lib/hooks/frameworks/http.js +23 -16
  30. package/lib/hooks/frameworks/http2.js +73 -0
  31. package/lib/hooks/frameworks/index.js +8 -3
  32. package/lib/hooks/http.js +112 -128
  33. package/lib/hooks/patcher.js +10 -12
  34. package/lib/hooks/require.js +16 -22
  35. package/lib/instrumentation.js +0 -3
  36. package/lib/protect/analysis/aho-corasick.js +13 -30
  37. package/lib/protect/rules/cmd-injection-command-backdoors/backdoor-detector.js +3 -3
  38. package/lib/protect/rules/signatures/reflected-xss/helpers/function-call.js +1 -1
  39. package/lib/protect/rules/xss/helpers/function-call.js +1 -1
  40. package/lib/util/clean-stack.js +1 -1
  41. package/lib/util/clean-string/brackets.js +3 -3
  42. package/lib/util/clean-string/concatenations.js +1 -1
  43. package/lib/util/clean-string/util.js +1 -2
  44. package/lib/util/ip-analyzer.js +1 -1
  45. package/lib/util/some.js +27 -0
  46. package/lib/util/xml-analyzer/external-entity-finder.js +1 -1
  47. package/package.json +14 -15
  48. package/lib/hooks/frameworks/https.js +0 -42
  49. package/node_modules/bindings/LICENSE.md +0 -22
  50. package/node_modules/bindings/README.md +0 -98
  51. package/node_modules/bindings/bindings.js +0 -221
  52. package/node_modules/bindings/package.json +0 -32
  53. package/node_modules/file-uri-to-path/.npmignore +0 -1
  54. package/node_modules/file-uri-to-path/.travis.yml +0 -30
  55. package/node_modules/file-uri-to-path/History.md +0 -21
  56. package/node_modules/file-uri-to-path/LICENSE +0 -20
  57. package/node_modules/file-uri-to-path/README.md +0 -74
  58. package/node_modules/file-uri-to-path/index.d.ts +0 -2
  59. package/node_modules/file-uri-to-path/index.js +0 -66
  60. package/node_modules/file-uri-to-path/package.json +0 -36
  61. package/node_modules/file-uri-to-path/test/test.js +0 -24
  62. package/node_modules/file-uri-to-path/test/tests.json +0 -13
  63. package/node_modules/glossy/LICENSE +0 -19
  64. package/node_modules/glossy/README.md +0 -129
  65. package/node_modules/glossy/index.js +0 -12
  66. package/node_modules/glossy/lib/glossy/parse.js +0 -520
  67. package/node_modules/glossy/lib/glossy/produce.js +0 -459
  68. package/node_modules/glossy/package.json +0 -47
  69. package/node_modules/glossy/test/decide.js +0 -7
  70. package/node_modules/glossy/test/decode_pri.js +0 -24
  71. package/node_modules/glossy/test/parse_3164.js +0 -104
  72. package/node_modules/glossy/test/parse_5424.js +0 -106
  73. package/node_modules/glossy/test/parse_5848.js +0 -40
  74. package/node_modules/glossy/test/parse_8601.js +0 -14
  75. package/node_modules/glossy/test/parse_rfc3339.js +0 -9
  76. package/node_modules/glossy/test/produce.js +0 -162
  77. package/node_modules/glossy/test/runner.js +0 -40
  78. package/node_modules/glossy/test/structure_data.js +0 -24
  79. package/node_modules/nan/CHANGELOG.md +0 -537
  80. package/node_modules/nan/LICENSE.md +0 -13
  81. package/node_modules/nan/README.md +0 -455
  82. package/node_modules/nan/doc/asyncworker.md +0 -146
  83. package/node_modules/nan/doc/buffers.md +0 -54
  84. package/node_modules/nan/doc/callback.md +0 -76
  85. package/node_modules/nan/doc/converters.md +0 -41
  86. package/node_modules/nan/doc/errors.md +0 -226
  87. package/node_modules/nan/doc/json.md +0 -62
  88. package/node_modules/nan/doc/maybe_types.md +0 -583
  89. package/node_modules/nan/doc/methods.md +0 -664
  90. package/node_modules/nan/doc/new.md +0 -147
  91. package/node_modules/nan/doc/node_misc.md +0 -123
  92. package/node_modules/nan/doc/object_wrappers.md +0 -263
  93. package/node_modules/nan/doc/persistent.md +0 -296
  94. package/node_modules/nan/doc/scopes.md +0 -73
  95. package/node_modules/nan/doc/script.md +0 -38
  96. package/node_modules/nan/doc/string_bytes.md +0 -62
  97. package/node_modules/nan/doc/v8_internals.md +0 -199
  98. package/node_modules/nan/doc/v8_misc.md +0 -85
  99. package/node_modules/nan/include_dirs.js +0 -1
  100. package/node_modules/nan/nan.h +0 -2898
  101. package/node_modules/nan/nan_callbacks.h +0 -88
  102. package/node_modules/nan/nan_callbacks_12_inl.h +0 -514
  103. package/node_modules/nan/nan_callbacks_pre_12_inl.h +0 -520
  104. package/node_modules/nan/nan_converters.h +0 -72
  105. package/node_modules/nan/nan_converters_43_inl.h +0 -68
  106. package/node_modules/nan/nan_converters_pre_43_inl.h +0 -42
  107. package/node_modules/nan/nan_define_own_property_helper.h +0 -29
  108. package/node_modules/nan/nan_implementation_12_inl.h +0 -430
  109. package/node_modules/nan/nan_implementation_pre_12_inl.h +0 -263
  110. package/node_modules/nan/nan_json.h +0 -166
  111. package/node_modules/nan/nan_maybe_43_inl.h +0 -356
  112. package/node_modules/nan/nan_maybe_pre_43_inl.h +0 -268
  113. package/node_modules/nan/nan_new.h +0 -340
  114. package/node_modules/nan/nan_object_wrap.h +0 -156
  115. package/node_modules/nan/nan_persistent_12_inl.h +0 -132
  116. package/node_modules/nan/nan_persistent_pre_12_inl.h +0 -242
  117. package/node_modules/nan/nan_private.h +0 -73
  118. package/node_modules/nan/nan_string_bytes.h +0 -305
  119. package/node_modules/nan/nan_typedarray_contents.h +0 -96
  120. package/node_modules/nan/nan_weak.h +0 -437
  121. package/node_modules/nan/package.json +0 -41
  122. package/node_modules/nan/tools/1to2.js +0 -412
  123. package/node_modules/nan/tools/README.md +0 -14
  124. package/node_modules/nan/tools/package.json +0 -19
  125. package/node_modules/unix-dgram/LICENSE +0 -13
  126. package/node_modules/unix-dgram/README.md +0 -107
  127. package/node_modules/unix-dgram/binding.gyp +0 -20
  128. package/node_modules/unix-dgram/build/Makefile +0 -324
  129. package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram/src/unix_dgram.o.d +0 -58
  130. package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram.node.d +0 -1
  131. package/node_modules/unix-dgram/build/Release/.deps/Release/unix_dgram.node.d +0 -1
  132. package/node_modules/unix-dgram/build/Release/obj.target/unix_dgram/src/unix_dgram.o +0 -0
  133. package/node_modules/unix-dgram/build/Release/obj.target/unix_dgram.node +0 -0
  134. package/node_modules/unix-dgram/build/Release/unix_dgram.node +0 -0
  135. package/node_modules/unix-dgram/build/binding.Makefile +0 -6
  136. package/node_modules/unix-dgram/build/config.gypi +0 -213
  137. package/node_modules/unix-dgram/build/unix_dgram.target.mk +0 -159
  138. package/node_modules/unix-dgram/lib/unix_dgram.js +0 -168
  139. package/node_modules/unix-dgram/package.json +0 -36
  140. package/node_modules/unix-dgram/src/unix_dgram.cc +0 -404
  141. package/node_modules/unix-dgram/src/win_dummy.cc +0 -7
  142. package/node_modules/unix-dgram/test/test-connect-callback.js +0 -68
  143. package/node_modules/unix-dgram/test/test-connect.js +0 -53
  144. package/node_modules/unix-dgram/test/test-dgram-unix.js +0 -58
  145. package/node_modules/unix-dgram/test/test-send-error.js +0 -26
  146. package/node_modules/winston-syslog/.eslintrc +0 -7
  147. package/node_modules/winston-syslog/.travis.yml +0 -14
  148. package/node_modules/winston-syslog/CHANGELOG.md +0 -9
  149. package/node_modules/winston-syslog/LICENSE +0 -20
  150. package/node_modules/winston-syslog/README.md +0 -135
  151. package/node_modules/winston-syslog/lib/utils.js +0 -26
  152. package/node_modules/winston-syslog/lib/winston-syslog.js +0 -385
  153. package/node_modules/winston-syslog/package.json +0 -56
  154. package/node_modules/winston-syslog/test/format-test.js +0 -122
  155. package/node_modules/winston-syslog/test/syslog-test.js +0 -95
  156. package/node_modules/winston-syslog/test/unix-connect-test.js +0 -133
@@ -1,106 +0,0 @@
1
- var syslogParser = require('../lib/glossy/parse.js'),
2
- assert = require('assert');
3
-
4
- assert.ok(syslogParser, 'parser loaded');
5
- var withPrecisionTime = "<165>1 2003-08-24T05:14:15.000003-07:00 192.0.2.1 myproc 8710 - - %% It's time to make the do-nuts.";
6
- syslogParser.parse(withPrecisionTime, function(parsedMessage){
7
- var expectedData = {
8
- originalMessage: withPrecisionTime,
9
- prival: 165,
10
- facilityID: 20,
11
- severityID: 5,
12
- facility: 'local4',
13
- severity: 'notice',
14
- type: 'RFC5424',
15
- host: '192.0.2.1',
16
- appName: 'myproc',
17
- pid: '8710',
18
- msgID: null,
19
- message: "%% It's time to make the do-nuts." };
20
-
21
- delete parsedMessage.time;
22
- assert.deepEqual(parsedMessage, expectedData);
23
-
24
- });
25
-
26
- // FIXME 3 minute offset from UTC?!
27
- var with8601 = "<34>1 2003-10-11T22:14:15.003Z mymachine.example.com su - ID47 - BOM'su root' failed for lonvick on /dev/pts/8";
28
- syslogParser.parse(with8601, function(parsedMessage){
29
- var expectedData = {
30
- originalMessage: with8601,
31
- prival: 34,
32
- facilityID: 4,
33
- severityID: 2,
34
- facility: 'auth',
35
- severity: 'crit',
36
- type: 'RFC5424',
37
- time: new Date('2003-10-11T22:14:15.003Z'),
38
- host: 'mymachine.example.com',
39
- appName: 'su',
40
- pid: null,
41
- msgID: 'ID47',
42
- message: "BOM'su root' failed for lonvick on /dev/pts/8" };
43
-
44
- assert.deepEqual(parsedMessage, expectedData);
45
- });
46
-
47
- // FIXME 3 minute offset from UTC?!
48
- var withSD = '<165>1 2003-10-11T22:14:15.003Z mymachine.example.com evntslog - ID47 [exampleSDID@32473 iut="3" eventSource="Application" eventID="1011"] BOMAn application event log entry...';
49
- syslogParser.parse(withSD, function(parsedMessage){
50
- var expectedData = {
51
- originalMessage: withSD,
52
- prival: 165,
53
- facilityID: 20,
54
- severityID: 5,
55
- facility: 'local4',
56
- severity: 'notice',
57
- type: 'RFC5424',
58
- time: new Date('2003-10-11T22:14:15.003Z'),
59
- host: 'mymachine.example.com',
60
- appName: 'evntslog',
61
- pid: null,
62
- msgID: 'ID47',
63
- structuredData: {
64
- 'exampleSDID@32473': {
65
- iut: '3',
66
- eventSource: 'Application',
67
- eventID: '1011'
68
- }
69
- },
70
- message: 'BOMAn application event log entry...' };
71
-
72
- assert.deepEqual(parsedMessage, expectedData);
73
- });
74
-
75
- // FIXME 3 minute offset from UTC?!
76
- var withDoubleSD = '<165>1 2003-10-11T22:14:15.003Z mymachine.example.com evntslog - ID47 [exampleSDID@32473 iut="3" eventSource="Application" eventID="1011"][examplePriority@32473 class="high"]';
77
- syslogParser.parse(withDoubleSD, function(parsedMessage){
78
- var expectedStructuredData = {
79
- 'exampleSDID@32473': {
80
- iut: '3',
81
- eventSource: 'Application',
82
- eventID: '1011'
83
- },
84
- 'examplePriority@32473': {
85
- 'class': 'high'
86
- }
87
- };
88
-
89
- var expectedData = {
90
- originalMessage: withDoubleSD,
91
- prival: 165,
92
- facilityID: 20,
93
- severityID: 5,
94
- facility: 'local4',
95
- severity: 'notice',
96
- type: 'RFC5424',
97
- time: new Date('2003-10-11T22:14:15.003Z'),
98
- host: 'mymachine.example.com',
99
- appName: 'evntslog',
100
- pid: null,
101
- msgID: 'ID47',
102
- structuredData: expectedStructuredData, //FIXME Both sets should be there
103
- message: '' };
104
- assert.deepEqual(parsedMessage, expectedData);
105
- });
106
-
@@ -1,40 +0,0 @@
1
- var syslogParser = require('../lib/glossy/parse.js'),
2
- assert = require('assert');
3
-
4
- assert.ok(syslogParser, 'parser loaded');
5
-
6
- var fullySigned = '<110>1 2009-05-03T14:00:39.519307+02:00 host.example.org syslogd 2138 - [ssign-cert VER="0111" RSID="1" SG="0" SPRI="0" TPBL="587" INDEX="1" FLEN="587" FRAG="2009-05-03T14:00:39.519005+02:00 K BACsLMZ NCV2NUAwe4RAeAnSQuvv2KS51SnHFAaWJNU2XVDYvW1LjmJgg4vKvQPo3HEOD+2hEkt1zcXADe03u5pmHoWy5FGiyCbglYxJkUJJrQqlTSS6vID9yhsmEnh07w3pOsxmb4qYo0uWQrAAenBweVMlBgV3ZA5IMA8xq8l+i8wCgkWJjCjfLar7s+0X3HVrRroyARv8EAIYoxofh9m N8n821BTTuQnz5hp40d6Z3UudKePu2di5Mx3GFelwnV0Qh5mSs0YkuHJg0mcXyUAoeYry5X6482fUxbm+gOHVmYSDtBmZEB8PTEt8Os8aedWgKEt/E4dT+Hmod4omECLteLXxtScTMgDXyC+bSBMjRRCaeWhHrYYdYBACCWMdTc12hRLJTn8LX99kv1I7qwgieyna8GCJv/rEgC ssS9E1qARM+h19KovIUOhl4VzBw3rK7v8Dlw/CJyYDd5kwSvCwjhO21LiReeS90VPYuZFRC1B82Sub152zOqIcAWsgd4myCCiZbWBsuJ8P0gtarFIpleNacCc6OV3i2Rg==" SIGN="AKAQEUiQptgpd0lKcXbuggGXH/dCdQCgdysrTBLUlbeGAQ4vwrnLOqSL7+c="]';
7
-
8
- var fullySignedSD = syslogParser.parseStructure(fullySigned);
9
- assert.deepEqual(fullySignedSD, {
10
- 'ssign-cert': {
11
- VER: '0111',
12
- RSID: '1',
13
- SG: '0',
14
- SPRI: '0',
15
- TPBL: '587',
16
- INDEX: '1',
17
- FLEN: '587',
18
- FRAG: '2009-05-03T14:00:39.519005+02:00 K BACsLMZ NCV2NUAwe4RAeAnSQuvv2KS51SnHFAaWJNU2XVDYvW1LjmJgg4vKvQPo3HEOD+2hEkt1zcXADe03u5pmHoWy5FGiyCbglYxJkUJJrQqlTSS6vID9yhsmEnh07w3pOsxmb4qYo0uWQrAAenBweVMlBgV3ZA5IMA8xq8l+i8wCgkWJjCjfLar7s+0X3HVrRroyARv8EAIYoxofh9m N8n821BTTuQnz5hp40d6Z3UudKePu2di5Mx3GFelwnV0Qh5mSs0YkuHJg0mcXyUAoeYry5X6482fUxbm+gOHVmYSDtBmZEB8PTEt8Os8aedWgKEt/E4dT+Hmod4omECLteLXxtScTMgDXyC+bSBMjRRCaeWhHrYYdYBACCWMdTc12hRLJTn8LX99kv1I7qwgieyna8GCJv/rEgC ssS9E1qARM+h19KovIUOhl4VzBw3rK7v8Dlw/CJyYDd5kwSvCwjhO21LiReeS90VPYuZFRC1B82Sub152zOqIcAWsgd4myCCiZbWBsuJ8P0gtarFIpleNacCc6OV3i2Rg==',
19
- SIGN: 'AKAQEUiQptgpd0lKcXbuggGXH/dCdQCgdysrTBLUlbeGAQ4vwrnLOqSL7+c='
20
- }
21
- });
22
-
23
- assert.deepEqual(syslogParser.parseSignedCertificate(fullySignedSD['ssign-cert']), {
24
- version: '01',
25
- hashAlgorithm: 1,
26
- hashAlgoString: 'SHA1',
27
- sigScheme: 1,
28
- rebootSessionID: 1,
29
- signatureGroup: 0,
30
- signaturePriority: 0,
31
- totalPayloadLength: 587,
32
- payloadIndex: 1,
33
- fragmentLength: 587,
34
- payloadTimestamp: new Date('2009-05-03T14:00:39.519005+02:00'),
35
- payloadType: 'K',
36
- payloadName: 'Public Key',
37
- keyBlob: new Buffer(fullySignedSD['ssign-cert']['FRAG'].split(/\s/)[2], encoding='base64'),
38
- thisSignature: new Buffer(fullySignedSD['ssign-cert']['SIGN'], encoding='base64')
39
- });
40
-
@@ -1,14 +0,0 @@
1
- var syslogParser = require('../lib/glossy/parse.js'),
2
- assert = require('assert');
3
-
4
- assert.ok(syslogParser, 'parser loaded');
5
-
6
- assert.deepEqual(
7
- syslogParser.parse8601('2011-10-10T14:48:00'),
8
- new Date(Date.parse('2011-10-10T14:48:00'))
9
- );
10
-
11
- assert.equal(
12
- syslogParser.parse8601('foo'),
13
- undefined
14
- );
@@ -1,9 +0,0 @@
1
- var syslogParser = require('../lib/glossy/parse.js'),
2
- assert = require('assert');
3
-
4
- assert.ok(syslogParser, 'parser loaded');
5
-
6
- assert.deepEqual(
7
- syslogParser.parseRfc3339("1985-04-12T23:20:50.52Z"),
8
- new Date(482196050000)
9
- );
@@ -1,162 +0,0 @@
1
- var assert = require('assert');
2
- var producer = require('../lib/glossy/produce.js');
3
-
4
- assert.ok(producer, 'producer loaded');
5
-
6
- var syslogProducer = new producer();
7
- assert.ok(syslogProducer, 'new SyslogProducer object created');
8
- assert.equal(syslogProducer.type, 'RFC5424', 'Syslog Producer set correctly');
9
-
10
- var BSDProducer = new producer({ type: 'BSD'});
11
- assert.ok(BSDProducer, 'new BSDProducer object created');
12
- assert.equal(BSDProducer.type, 'RFC3164', 'BSD Producer set correctly');
13
-
14
- var presetProducer = new producer({
15
- type: 'bsd',
16
- facility: 'ntp',
17
- host: 'localhost',
18
- appName: 'kill'
19
- });
20
-
21
- var invalidProducer = new producer({
22
- type: 'invalid',
23
- facility: 'invalid',
24
- });
25
- assert.notEqual(invalidProducer, 'invalid producer is null');
26
-
27
- var msg = syslogProducer.produce({
28
- facility: 'local4',
29
- severity: 'error',
30
- host: 'localhost',
31
- appName: 'sudo',
32
- pid: '123',
33
- date: new Date(1234567890000),
34
- message: 'Test Message'
35
- });
36
- assert.equal(msg, "<163>1 2009-02-13T23:31:30.00+01:00 localhost sudo 123 - - Test Message",'Valid message returned');
37
-
38
- syslogProducer.produce({
39
- facility: 'audit',
40
- severity: 'error',
41
- host: '127.0.0.1',
42
- appName: 'sudo',
43
- pid: '419',
44
- date: new Date(1234567890000),
45
- message: 'Test Message'
46
- }, function(cbMsg) {
47
- assert.equal(cbMsg, '<107>1 2009-02-13T23:31:30.00+01:00 127.0.0.1 sudo 419 - - Test Message', 'Valid message in callback returned');
48
- });
49
-
50
- BSDProducer.produce({
51
- facility: 'audit',
52
- severity: 'error',
53
- host: '127.0.0.1',
54
- appName: 'sudo',
55
- pid: '419',
56
- date: new Date(1234567890000),
57
- message: 'Test Message'
58
- }, function(cbMsg){
59
- assert.equal(cbMsg, '<107>Feb 14 00:31:30 127.0.0.1 sudo[419]: Test Message');
60
- });
61
-
62
- var debugMsg = presetProducer.debug({
63
- facility: 'local2',
64
- message: 'Debug Message',
65
- date: new Date(1234567890000),
66
- pid: 91
67
- });
68
- assert.ok(debugMsg);
69
- assert.equal(debugMsg, '<151>Feb 14 00:31:30 localhost kill[91]: Debug Message');
70
-
71
- var infoMsg = presetProducer.info({
72
- facility: 'ntp',
73
- message: 'Info Message',
74
- pid: 42,
75
- date: new Date(1234567890000)
76
- });
77
- assert.ok(infoMsg);
78
- assert.equal(infoMsg, '<102>Feb 14 00:31:30 localhost kill[42]: Info Message');
79
-
80
- var noticeMsg = presetProducer.debug({
81
- facility: 'local2',
82
- message: 'Notice Message',
83
- pid: 16,
84
- date: new Date(1234567890000)
85
- });
86
- assert.ok(noticeMsg);
87
- assert.equal(noticeMsg, '<151>Feb 14 00:31:30 localhost kill[16]: Notice Message');
88
-
89
- var warnMsg = presetProducer.debug({
90
- facility: 'local4',
91
- message: 'Warning Message',
92
- pid: 91,
93
- date: new Date(1234567890000)
94
- });
95
- assert.ok(warnMsg);
96
- assert.equal(warnMsg, '<167>Feb 14 00:31:30 localhost kill[91]: Warning Message');
97
-
98
- var errorMsg = presetProducer.debug({
99
- facility: 'clock',
100
- message: 'Error Message',
101
- pid: 91,
102
- date: new Date(1234567890000)
103
- });
104
- assert.ok(errorMsg);
105
- assert.equal(errorMsg, '<79>Feb 14 00:31:30 localhost kill[91]: Error Message');
106
-
107
- var criticalMsg = presetProducer.crit({
108
- facility: 'local0',
109
- message: 'Critical Message',
110
- pid: 91,
111
- date: new Date(1234567890000)
112
- });
113
- assert.ok(criticalMsg);
114
- assert.equal(criticalMsg, '<130>Feb 14 00:31:30 localhost kill[91]: Critical Message');
115
-
116
- var alertMsg = presetProducer.alert({
117
- facility: 'clock',
118
- message: 'Alert Message',
119
- pid: 91,
120
- date: new Date(1234567890000)
121
- });
122
- assert.ok(alertMsg);
123
- assert.equal(alertMsg, '<73>Feb 14 00:31:30 localhost kill[91]: Alert Message');
124
-
125
- var emergencyMsg = presetProducer.emergency({
126
- facility: 'news',
127
- message: 'Emergency Message',
128
- pid: 91,
129
- date: new Date(1234567890000)
130
- });
131
- assert.ok(emergencyMsg);
132
- assert.equal(emergencyMsg, '<56>Feb 14 00:31:30 localhost kill[91]: Emergency Message');
133
-
134
- var structuredMsg = syslogProducer.produce({
135
- facility: 'local4',
136
- severity: 'error',
137
- host: 'mymachine.example.com',
138
- appName: 'evntslog',
139
- msgID: 'ID47',
140
- date: new Date(1234567890000),
141
- structuredData: {
142
- 'exampleSDID@32473': {
143
- 'iut': "3",
144
- 'eventSource': "Application",
145
- 'eventID': "1011",
146
- 'seqNo': "1"
147
- }
148
- },
149
- message: 'BOMAn application event log entry...'
150
- });
151
-
152
- assert.ok(structuredMsg);
153
- assert.equal(structuredMsg, '<163>1 2009-02-13T23:31:30.00+01:00 mymachine.example.com evntslog - ID47 [exampleSDID@32473 iut="3" eventSource="Application" eventID="1011" seqNo="1"] BOMAn application event log entry...');
154
-
155
- var messageWithOneDigitDate = presetProducer.emergency({
156
- facility: 'news',
157
- message: 'Emergency Message',
158
- pid: 91,
159
- date: new Date(1233531090000)
160
- });
161
- assert.ok(messageWithOneDigitDate);
162
- assert.equal(messageWithOneDigitDate, '<56>Feb 2 00:31:30 localhost kill[91]: Emergency Message');
@@ -1,40 +0,0 @@
1
- // set timezone to CET for tests
2
- process.env.TZ='CET';
3
-
4
- var spawn = require('child_process').spawn,
5
- fs = require('fs'),
6
- exitCode = 0,
7
- timeout = 10000;
8
-
9
- fs.readdir(__dirname, function (e, files) {
10
- if(e) throw e;
11
-
12
- var tests = files.filter(function (f) {return f.substr(-2) === 'js' && f != 'runner.js'});
13
-
14
- var next = function () {
15
- if(tests.length === 0) process.exit(exitCode);
16
-
17
- var file = tests.shift();
18
- var proc = spawn('node', [ 'test/' + file ]);
19
-
20
- var killed = false;
21
- var t = setTimeout(function () {
22
- proc.kill();
23
- exitCode += 1;
24
- console.error(file + ' timeout');
25
- killed = true;
26
- }, timeout)
27
-
28
- proc.stdout.pipe(process.stdout);
29
- proc.stderr.pipe(process.stderr);
30
- proc.on('exit', function (code) {
31
- if (code && !killed) console.error(file + ' failed');
32
- exitCode += code || 0;
33
- clearTimeout(t);
34
- next();
35
- })
36
- }
37
- next();
38
- })
39
-
40
-
@@ -1,24 +0,0 @@
1
- var syslogParser = require('../lib/glossy/parse.js'),
2
- assert = require('assert');
3
-
4
- assert.ok(syslogParser, 'parser loaded');
5
- var singleStructure = '[exampleSDID@32473 iut="3" eventSource="Application" eventID="1011"]';
6
- assert.deepEqual(syslogParser.parseStructure(singleStructure), {
7
- 'exampleSDID@32473': {
8
- iut: '3',
9
- eventSource: 'Application',
10
- eventID: '1011'
11
- }
12
- });
13
-
14
- var doubleStructure = '[exampleSDID@32473 iut="3" eventSource="Application" eventID="1011"][examplePriority@32473 class="high"] ';
15
- assert.deepEqual(syslogParser.parseStructure(doubleStructure), {
16
- 'exampleSDID@32473': {
17
- iut: '3',
18
- eventID: '1011',
19
- eventSource: 'Application'
20
- },
21
- 'examplePriority@32473': {
22
- 'class': 'high'
23
- }
24
- });