@contrast/agent 4.5.2 → 4.8.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.
- package/LICENSE +1 -1
- package/agent-loader.js +1 -1
- package/bin/VERSION +1 -1
- package/bin/linux/contrast-service +0 -0
- package/bin/mac/contrast-service +0 -0
- package/bin/windows/contrast-service.exe +0 -0
- package/bootstrap.js +1 -1
- package/cli-rewriter.js +1 -1
- package/cli.js +1 -1
- package/esm.mjs +1 -1
- package/lib/agent-emitter.js +1 -1
- package/lib/agent.js +1 -1
- package/lib/app-info.js +1 -1
- package/lib/assess/deadzones/index.js +1 -1
- package/lib/assess/deadzones/rewrite.js +1 -1
- package/lib/assess/express/index.js +1 -1
- package/lib/assess/express/route-coverage.js +1 -1
- package/lib/assess/express/sinks/index.js +1 -1
- package/lib/assess/express/sinks/xss.js +1 -1
- package/lib/assess/express/sources.js +1 -1
- package/lib/assess/fastify/index.js +1 -1
- package/lib/assess/fastify/route-coverage.js +1 -1
- package/lib/assess/fastify/sinks/index.js +1 -1
- package/lib/assess/fastify/sinks/response-scanning.js +1 -1
- package/lib/assess/fastify/sinks/unvalidated-redirect.js +1 -1
- package/lib/assess/fastify/sinks/xss.js +1 -1
- package/lib/assess/fastify/sources.js +1 -1
- package/lib/assess/hapi/index.js +1 -1
- package/lib/assess/hapi/route-coverage.js +1 -1
- package/lib/assess/hapi/sinks/index.js +1 -1
- package/lib/assess/hapi/sinks/response-scanning.js +1 -1
- package/lib/assess/hapi/sinks/session.js +1 -1
- package/lib/assess/hapi/sinks/unvalidated-redirect.js +1 -1
- package/lib/assess/hapi/sinks/xss.js +1 -1
- package/lib/assess/hapi/sources.js +1 -1
- package/lib/assess/index.js +1 -1
- package/lib/assess/koa/index.js +1 -1
- package/lib/assess/koa/route-coverage.js +1 -1
- package/lib/assess/koa/sinks/index.js +1 -1
- package/lib/assess/koa/sinks/response-scanning.js +1 -1
- package/lib/assess/koa/sinks/unvalidated-redirect.js +1 -1
- package/lib/assess/koa/sinks/xss.js +1 -1
- package/lib/assess/koa/sources.js +1 -1
- package/lib/assess/loopback4/index.js +1 -1
- package/lib/assess/loopback4/route-coverage.js +1 -1
- package/lib/assess/loopback4/sinks/index.js +1 -1
- package/lib/assess/loopback4/sinks/response-scanning.js +1 -1
- package/lib/assess/loopback4/sinks/xss.js +1 -1
- package/lib/assess/loopback4/sources.js +1 -1
- package/lib/assess/membrane/debraner.js +1 -1
- package/lib/assess/membrane/deserialization-membrane.js +5 -6
- package/lib/assess/membrane/index.js +1 -1
- package/lib/assess/membrane/source-membrane.js +17 -34
- package/lib/assess/models/base-event.js +1 -1
- package/lib/assess/models/call-context.js +2 -2
- package/lib/assess/models/index.js +1 -1
- package/lib/assess/models/propagation-event.js +1 -1
- package/lib/assess/models/signature.js +1 -1
- package/lib/assess/models/sink-event.js +1 -1
- package/lib/assess/models/source-event.js +1 -1
- package/lib/assess/models/tag-range/index.js +1 -1
- package/lib/assess/models/tag-range/relationships.js +1 -1
- package/lib/assess/models/tag-range/util.js +1 -1
- package/lib/assess/policy/index.js +1 -1
- package/lib/assess/policy/init.js +1 -1
- package/lib/assess/policy/propagators.json +19 -21
- package/lib/assess/policy/rules.json +7 -2
- package/lib/assess/policy/signatures.json +42 -6
- package/lib/assess/policy/util.js +3 -2
- package/lib/assess/propagators/JSON/parse.js +2 -2
- package/lib/assess/propagators/JSON/stringify.js +4 -4
- package/lib/assess/propagators/ajv/conditionals.js +1 -1
- package/lib/assess/propagators/ajv/evaluator-shim.js +1 -1
- package/lib/assess/propagators/ajv/index.js +1 -1
- package/lib/assess/propagators/ajv/json-schema-type-evaluators.js +1 -1
- package/lib/assess/propagators/ajv/object-walk.js +1 -1
- package/lib/assess/propagators/ajv/refs.js +1 -1
- package/lib/assess/propagators/ajv/schema-context.js +1 -1
- package/lib/assess/propagators/array-prototype-join.js +8 -9
- package/lib/assess/propagators/common.js +8 -6
- package/lib/assess/propagators/dustjs/escape-html.js +22 -0
- package/lib/assess/propagators/dustjs/escape-js.js +22 -0
- package/lib/assess/propagators/ejs-template-generate-source.js +1 -1
- package/lib/assess/propagators/encode-uri/encode-uri-component.js +22 -0
- package/lib/assess/propagators/encode-uri/encode-uri.js +22 -0
- package/lib/assess/propagators/handlebars-compile.js +1 -1
- package/lib/assess/propagators/handlebars-escape-expresssion.js +2 -2
- package/lib/assess/propagators/index.js +1 -3
- package/lib/assess/propagators/joi/boolean.js +2 -2
- package/lib/assess/propagators/joi/expression.js +2 -2
- package/lib/assess/propagators/joi/index.js +1 -1
- package/lib/assess/propagators/joi/number.js +2 -2
- package/lib/assess/propagators/joi/string-base.js +2 -2
- package/lib/assess/propagators/joi/string-schema.js +13 -14
- package/lib/assess/propagators/joi/values.js +38 -23
- package/lib/assess/propagators/manager.js +13 -11
- package/lib/assess/propagators/mongoose/helpers.js +20 -0
- package/lib/assess/propagators/mongoose/index.js +18 -0
- package/lib/assess/propagators/mongoose/map.js +74 -0
- package/lib/assess/propagators/mongoose/string.js +104 -0
- package/lib/assess/propagators/mustache/escape.js +22 -0
- package/lib/assess/propagators/number.js +54 -0
- package/lib/assess/propagators/object.js +7 -8
- package/lib/assess/propagators/path/basename.js +15 -14
- package/lib/assess/propagators/path/common.js +2 -2
- package/lib/assess/propagators/path/dirname.js +15 -14
- package/lib/assess/propagators/path/extname.js +15 -14
- package/lib/assess/propagators/path/format.js +1 -1
- package/lib/assess/propagators/path/join.js +1 -1
- package/lib/assess/propagators/path/normalize.js +1 -1
- package/lib/assess/propagators/path/parse.js +2 -2
- package/lib/assess/propagators/path/relative.js +8 -6
- package/lib/assess/propagators/path/resolve.js +1 -1
- package/lib/assess/propagators/path/to-namespaced-path.js +1 -1
- package/lib/assess/propagators/pug-compile.js +1 -1
- package/lib/assess/propagators/querystring/escape.js +21 -19
- package/lib/assess/propagators/querystring/parse.js +8 -6
- package/lib/assess/propagators/querystring/stringify.js +26 -25
- package/lib/assess/propagators/querystring/unescape.js +21 -19
- package/lib/assess/propagators/querystring/utils.js +1 -1
- package/lib/assess/propagators/sequelize/sql-string-escape.js +2 -2
- package/lib/assess/propagators/sequelize/sql-string-format-named-parameters.js +2 -2
- package/lib/assess/propagators/sequelize/sql-string-format.js +4 -4
- package/lib/assess/propagators/sequelize/utils.js +3 -3
- package/lib/assess/propagators/string-prototype-replace.js +31 -29
- package/lib/assess/propagators/string-prototype-split.js +37 -37
- package/lib/assess/propagators/string-prototype-trim.js +16 -18
- package/lib/assess/propagators/string.js +13 -17
- package/lib/assess/propagators/template-escape.js +87 -0
- package/lib/assess/propagators/templates.js +11 -12
- package/lib/assess/propagators/url/url-prototype-parse.js +6 -7
- package/lib/assess/propagators/url/url-url.js +52 -44
- package/lib/assess/propagators/url/utils.js +1 -1
- package/lib/assess/propagators/util/format.js +2 -2
- package/lib/assess/propagators/utils.js +1 -1
- package/lib/assess/propagators/v8/init-hooks.js +4 -4
- package/lib/assess/propagators/validator/init-hooks.js +23 -23
- package/lib/assess/propagators/validator/validator-methods.js +1 -2
- package/lib/assess/response-scanning/app-activity.js +1 -1
- package/lib/assess/response-scanning/autocomplete-missing.js +1 -1
- package/lib/assess/response-scanning/cache-controls-missing.js +1 -1
- package/lib/assess/response-scanning/clickjacking-control-missing.js +1 -1
- package/lib/assess/response-scanning/common.js +1 -1
- package/lib/assess/response-scanning/cookies/common.js +1 -1
- package/lib/assess/response-scanning/cookies/events.js +1 -1
- package/lib/assess/response-scanning/cookies/httponly.js +1 -1
- package/lib/assess/response-scanning/cookies/secure-flag-missing.js +1 -1
- package/lib/assess/response-scanning/headers/csp-header-insecure.js +1 -1
- package/lib/assess/response-scanning/headers/csp-header-missing.js +1 -1
- package/lib/assess/response-scanning/headers/csp-utils.js +1 -1
- package/lib/assess/response-scanning/headers/hsts-header-missing.js +1 -1
- package/lib/assess/response-scanning/headers/powered-by.js +1 -1
- package/lib/assess/response-scanning/headers/xcontenttype-header-missing.js +1 -1
- package/lib/assess/response-scanning/headers/xxssprotection-header-disabled.js +1 -1
- package/lib/assess/response-scanning/parameter-pollution.js +1 -1
- package/lib/assess/response-scanning/parseable-response-emitter.js +1 -1
- package/lib/assess/restify/index.js +1 -1
- package/lib/assess/restify/route-coverage.js +1 -1
- package/lib/assess/restify/session.js +1 -1
- package/lib/assess/restify/sinks/index.js +1 -1
- package/lib/assess/restify/sinks/response-scanning.js +1 -1
- package/lib/assess/restify/sinks/unvalidated-redirect.js +1 -1
- package/lib/assess/restify/sinks/xss.js +1 -1
- package/lib/assess/restify/sources.js +1 -1
- package/lib/assess/sinks/common.js +11 -6
- package/lib/assess/sinks/dustjs-linkedin-xss.js +131 -0
- package/lib/assess/sinks/dynamo.js +1 -1
- package/lib/assess/sinks/hapi-16-xss.js +1 -1
- package/lib/assess/sinks/index.js +1 -1
- package/lib/assess/sinks/libxmljs-xxe.js +2 -2
- package/lib/assess/sinks/mongodb.js +3 -2
- package/lib/assess/sinks/ssrf-url.js +2 -2
- package/lib/assess/sources/formidable.js +1 -1
- package/lib/assess/sources/index.js +1 -1
- package/lib/assess/static/hardcoded.js +1 -1
- package/lib/assess/technologies/index.js +1 -1
- package/lib/assess/utils.js +1 -1
- package/lib/cli-rewriter/index.js +1 -1
- package/lib/constants.js +5 -2
- package/lib/contrast.js +1 -1
- package/lib/core/arch-components/dynamodb.js +1 -1
- package/lib/core/arch-components/dynamodbv3.js +1 -1
- package/lib/core/arch-components/index.js +1 -1
- package/lib/core/arch-components/mongodb.js +1 -1
- package/lib/core/arch-components/mysql.js +1 -1
- package/lib/core/arch-components/postgres.js +1 -1
- package/lib/core/arch-components/rethinkdb.js +53 -0
- package/lib/core/arch-components/sqlite3.js +1 -1
- package/lib/core/async-storage/context.js +1 -1
- package/lib/core/async-storage/hooks/bluebird.js +1 -1
- package/lib/core/async-storage/hooks/mongodb-core.js +1 -1
- package/lib/core/async-storage/hooks/mysql.js +1 -1
- package/lib/core/async-storage/hooks/redis.js +1 -1
- package/lib/core/async-storage/hooks/utils.js +1 -1
- package/lib/core/async-storage/index.js +1 -1
- package/lib/core/async-storage/scopes/index.js +1 -1
- package/lib/core/common/formidable.js +1 -1
- package/lib/core/common/index.js +1 -1
- package/lib/core/config/options.js +4 -3
- package/lib/core/config/util.js +1 -1
- package/lib/core/exclusions/exclusion-factory.js +1 -1
- package/lib/core/exclusions/exclusion.js +1 -1
- package/lib/core/exclusions/input.js +1 -1
- package/lib/core/exclusions/url.js +1 -1
- package/lib/core/express/index.js +1 -1
- package/lib/core/express/utils.js +1 -1
- package/lib/core/fastify/index.js +1 -1
- package/lib/core/fastify/utils.js +1 -1
- package/lib/core/hapi/index.js +1 -1
- package/lib/core/hapi/utils.js +1 -1
- package/lib/core/index.js +1 -1
- package/lib/core/koa/index.js +1 -1
- package/lib/core/koa/utils.js +1 -1
- package/lib/core/logger/daily-rotate-file.js +1 -1
- package/lib/core/logger/dataflow-monitor.js +1 -1
- package/lib/core/logger/debug-logger.js +1 -1
- package/lib/core/logger/index.js +1 -1
- package/lib/core/logger/perf-logger.js +1 -1
- package/lib/core/logger/umbrella-logger.js +1 -1
- package/lib/core/loopback4/index.js +1 -1
- package/lib/core/metrics/index.js +1 -1
- package/lib/core/restify/index.js +1 -1
- package/lib/core/restify/utils.js +1 -1
- package/lib/core/rewrite/assignment-expression.js +1 -1
- package/lib/core/rewrite/binary-expression.js +1 -1
- package/lib/core/rewrite/call-expression.js +1 -1
- package/lib/core/rewrite/callees.js +1 -1
- package/lib/core/rewrite/catch-clause.js +1 -1
- package/lib/core/rewrite/function-wrap.js +1 -1
- package/lib/core/rewrite/index.js +1 -1
- package/lib/core/rewrite/injections.js +9 -1
- package/lib/core/rewrite/is-contrast-method.js +1 -1
- package/lib/core/rewrite/log.js +1 -1
- package/lib/core/rewrite/member-expression.js +1 -1
- package/lib/core/rewrite/object-property.js +1 -1
- package/lib/core/rewrite/prepend-globals.js +1 -1
- package/lib/core/rewrite/rewrite-log.js +1 -1
- package/lib/core/rewrite/switch-statement.js +1 -1
- package/lib/core/rewrite/template-literal.js +1 -1
- package/lib/core/stacktrace.js +3 -2
- package/lib/coverage.js +1 -1
- package/lib/feature-set.js +2 -2
- package/lib/generator-function.js +1 -1
- package/lib/hooks/array.js +1 -1
- package/lib/hooks/cluster.js +1 -1
- package/lib/hooks/dataflow-monitor.js +1 -1
- package/lib/hooks/encoding.js +1 -1
- package/lib/hooks/express-fileupload.js +1 -1
- package/lib/hooks/express-session.js +1 -1
- package/lib/hooks/fn-to-string.js +1 -1
- package/lib/hooks/frameworks/base.js +9 -3
- package/lib/hooks/frameworks/common.js +1 -1
- package/lib/hooks/frameworks/hapi16.js +1 -1
- package/lib/hooks/frameworks/http.js +24 -17
- package/lib/hooks/frameworks/http2.js +73 -0
- package/lib/hooks/frameworks/index.js +9 -4
- package/lib/hooks/hapi-16-reply.js +1 -1
- package/lib/hooks/hapi-16-session.js +1 -1
- package/lib/hooks/http.js +113 -129
- package/lib/hooks/module/extensions.js +1 -1
- package/lib/hooks/module/helpers.js +1 -1
- package/lib/hooks/module/index.js +1 -1
- package/lib/hooks/newrelic.js +1 -1
- package/lib/hooks/object-is.js +1 -1
- package/lib/hooks/object-to-primitive.js +7 -8
- package/lib/hooks/patcher.js +62 -39
- package/lib/hooks/require.js +17 -23
- package/lib/hooks/stealthy-require.js +1 -1
- package/lib/instrumentation.js +1 -4
- package/lib/libraries.js +1 -1
- package/lib/library-usage.js +1 -1
- package/lib/list-installed.js +1 -1
- package/lib/protect/analysis/aho-corasick.js +1 -1
- package/lib/protect/analysis/dfsa-analyzer.js +1 -1
- package/lib/protect/errors/handler.js +1 -1
- package/lib/protect/errors/security-exception.js +1 -1
- package/lib/protect/express/index.js +1 -1
- package/lib/protect/express/sinks.js +1 -1
- package/lib/protect/express/sources.js +1 -1
- package/lib/protect/fastify/index.js +1 -1
- package/lib/protect/fastify/sinks.js +1 -1
- package/lib/protect/fastify/sources.js +1 -1
- package/lib/protect/hapi/error-handler.js +1 -1
- package/lib/protect/hapi/index.js +1 -1
- package/lib/protect/hapi/sinks.js +1 -1
- package/lib/protect/hapi/sources.js +1 -1
- package/lib/protect/index.js +1 -1
- package/lib/protect/input-analysis.js +1 -1
- package/lib/protect/koa/index.js +1 -1
- package/lib/protect/koa/sinks.js +1 -1
- package/lib/protect/koa/sources.js +1 -1
- package/lib/protect/listeners.js +1 -1
- package/lib/protect/loopback4/index.js +1 -1
- package/lib/protect/loopback4/sources.js +1 -1
- package/lib/protect/models/application-context.js +1 -1
- package/lib/protect/models/sink-event.js +1 -1
- package/lib/protect/models/source-event.js +1 -1
- package/lib/protect/restify/index.js +1 -1
- package/lib/protect/restify/sinks.js +1 -1
- package/lib/protect/restify/sources.js +1 -1
- package/lib/protect/rules/assessment.js +1 -1
- package/lib/protect/rules/attack-patterns.js +1 -1
- package/lib/protect/rules/base-scanner/index.js +1 -1
- package/lib/protect/rules/base-scanner/java-script-scanner.js +1 -1
- package/lib/protect/rules/base-scanner/postgresqlscanner.js +1 -1
- package/lib/protect/rules/base-scanner/scan-state.js +1 -1
- package/lib/protect/rules/base-scanner/substring-finder.js +1 -1
- package/lib/protect/rules/base-scanner/token-sequence.js +1 -1
- package/lib/protect/rules/bot-blocker/bot-blocker-rule.js +1 -1
- package/lib/protect/rules/bot-blocker/index.js +1 -1
- package/lib/protect/rules/cmd-injection/cmdinjection-rule.js +1 -1
- package/lib/protect/rules/cmd-injection-command-backdoors/backdoor-detector.js +1 -1
- package/lib/protect/rules/cmd-injection-command-backdoors/cmd-injection-command-backdoors-rule.js +1 -1
- package/lib/protect/rules/cmd-injection-semantic-chained-commands/chained-command-scanner.js +1 -1
- package/lib/protect/rules/cmd-injection-semantic-chained-commands/cmd-injection-semantic-chained-commands-rule.js +1 -1
- package/lib/protect/rules/cmd-injection-semantic-dangerous-paths/cmd-injection-semantic-dangerous-paths-rule.js +1 -1
- package/lib/protect/rules/cmd-injection-semantic-dangerous-paths/dangerous-paths-scanner.js +1 -1
- package/lib/protect/rules/common.js +1 -1
- package/lib/protect/rules/index.js +1 -1
- package/lib/protect/rules/ip-denylist/ip-denylist-rule.js +1 -1
- package/lib/protect/rules/method-tampering/evaluator.js +1 -1
- package/lib/protect/rules/method-tampering/method-tampering-rule.js +1 -1
- package/lib/protect/rules/nosqli/nosql-injection-rule.js +228 -0
- package/lib/protect/rules/nosqli/nosql-scanner/index.js +1 -1
- package/lib/protect/rules/nosqli/nosql-scanner/mongodbscanner.js +1 -1
- package/lib/protect/rules/path-traversal/path-traversal-rule.js +1 -1
- package/lib/protect/rules/rule-factory.js +3 -3
- package/lib/protect/rules/signatures/cmd-injection/custom-searchers/chained-command-searcher.js +1 -1
- package/lib/protect/rules/signatures/cmd-injection/custom-searchers/index.js +1 -1
- package/lib/protect/rules/signatures/cmd-injection/index.js +1 -1
- package/lib/protect/rules/signatures/evaluator.js +1 -1
- package/lib/protect/rules/signatures/index.js +1 -1
- package/lib/protect/rules/signatures/nosql-injection/custom-searchers/index.js +1 -1
- package/lib/protect/rules/signatures/nosql-injection/custom-searchers/nosql-comment-searcher.js +1 -1
- package/lib/protect/rules/signatures/nosql-injection/custom-searchers/simple-or-searcher.js +1 -1
- package/lib/protect/rules/signatures/nosql-injection/index.js +1 -1
- package/lib/protect/rules/signatures/path-traversal/index.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/behavior-url-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/function-definition-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/immediate-function-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/index.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/link-and-src-target-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/location-set-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/map-access-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/native-function-execution-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/no-alnum-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/redefined-function-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/style-url-injection-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/variable-assignment-searcher.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/helpers/function-call.js +1 -1
- package/lib/protect/rules/signatures/reflected-xss/index.js +1 -1
- package/lib/protect/rules/signatures/signature.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/if-else-drop-searcher.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/index.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/simple-or-searcher.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/sql-comment-searcher.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/time-function-searcher.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/tsql-exec-searcher.js +1 -1
- package/lib/protect/rules/signatures/sql-injection/index.js +1 -1
- package/lib/protect/rules/signatures/ssjs-injection/index.js +1 -1
- package/lib/protect/rules/signatures/unsafe-file-upload/index.js +1 -1
- package/lib/protect/rules/signatures/untrusted-deserialization/index.js +1 -1
- package/lib/protect/rules/sqli/generic-complicated.js +1 -1
- package/lib/protect/rules/sqli/sql-injection-rule.js +1 -1
- package/lib/protect/rules/sqli/sql-scanner/index.js +1 -1
- package/lib/protect/rules/sqli/sql-scanner/mysql-scanner.js +1 -1
- package/lib/protect/rules/ssjs-injection/evaluator.js +1 -1
- package/lib/protect/rules/ssjs-injection/ssjsinjection-rule.js +1 -1
- package/lib/protect/rules/unsafe-file-upload/unsafe-file-upload-rule.js +1 -1
- package/lib/protect/rules/untrusted-deserialization/untrusted-deserialization-rule.js +1 -1
- package/lib/protect/rules/virtual-patch/index.js +1 -1
- package/lib/protect/rules/virtual-patch/utils.js +1 -1
- package/lib/protect/rules/virtual-patch/virtual-patch-rule.js +1 -1
- package/lib/protect/rules/xss/helpers/function-call.js +1 -1
- package/lib/protect/rules/xss/reflected-xss-rule.js +1 -1
- package/lib/protect/rules/xxe/xxerule.js +1 -1
- package/lib/protect/sample-aggregator.js +1 -1
- package/lib/protect/samples.js +1 -1
- package/lib/protect/service.js +24 -12
- package/lib/protect/sinks/child-process.js +1 -1
- package/lib/protect/sinks/eval.js +1 -1
- package/lib/protect/sinks/fs.js +1 -1
- package/lib/protect/sinks/function.js +1 -1
- package/lib/protect/sinks/index.js +1 -1
- package/lib/protect/sinks/libxmljs.js +1 -1
- package/lib/protect/sinks/mongodb.js +57 -56
- package/lib/protect/sinks/mysql.js +1 -1
- package/lib/protect/sinks/node-serialize.js +1 -1
- package/lib/protect/sinks/postgres.js +1 -1
- package/lib/protect/sinks/sequelize.js +1 -1
- package/lib/protect/sinks/sqlite3.js +1 -1
- package/lib/protect/sinks/vm.js +1 -1
- package/lib/protect/sources/busboy.js +1 -1
- package/lib/protect/sources/formidable.js +1 -1
- package/lib/protect/sources/index.js +1 -1
- package/lib/protect/validators/authorization.js +1 -1
- package/lib/protect/validators/common.js +1 -1
- package/lib/protect/validators/connection.js +1 -1
- package/lib/protect/validators/content-length.js +1 -1
- package/lib/protect/validators/host.js +1 -1
- package/lib/protect/validators/if-none-match.js +1 -1
- package/lib/protect/validators/index.js +1 -1
- package/lib/protect/validators/origin.js +1 -1
- package/lib/reporter/app-activity-queue.js +1 -1
- package/lib/reporter/grpc-client.js +1 -1
- package/lib/reporter/messages/speedracer/activity.js +1 -1
- package/lib/reporter/messages/speedracer/application-create.js +1 -1
- package/lib/reporter/messages/speedracer/application-update.js +1 -1
- package/lib/reporter/messages/speedracer/base.js +1 -1
- package/lib/reporter/messages/speedracer/index.js +1 -1
- package/lib/reporter/messages/speedracer/observed-route.js +1 -1
- package/lib/reporter/messages/speedracer/poll.js +1 -1
- package/lib/reporter/messages/speedracer/request.js +1 -1
- package/lib/reporter/messages/speedracer/startup.js +1 -1
- package/lib/reporter/messaging-router.js +1 -1
- package/lib/reporter/models/app-activity/app-activity.js +1 -1
- package/lib/reporter/models/app-activity/attacker-activity.js +1 -1
- package/lib/reporter/models/app-activity/defend.js +1 -1
- package/lib/reporter/models/app-activity/inventory.js +1 -1
- package/lib/reporter/models/app-activity/protection-rule-activity.js +1 -1
- package/lib/reporter/models/app-activity/rule-events.js +1 -1
- package/lib/reporter/models/app-activity/sample.js +1 -1
- package/lib/reporter/models/app-activity/source.js +1 -1
- package/lib/reporter/models/app-activity/user-input.js +1 -1
- package/lib/reporter/models/app-create.js +1 -1
- package/lib/reporter/models/app-update/index.js +1 -1
- package/lib/reporter/models/app-update/library-manifest.js +1 -1
- package/lib/reporter/models/app-update/library-usage.js +1 -1
- package/lib/reporter/models/app-update/library.js +1 -1
- package/lib/reporter/models/event-tag.js +1 -1
- package/lib/reporter/models/finding/event.js +1 -1
- package/lib/reporter/models/finding/finding.js +1 -1
- package/lib/reporter/models/frameworks/express-request.js +1 -1
- package/lib/reporter/models/frameworks/fastify-request.js +1 -1
- package/lib/reporter/models/frameworks/hapi-request.js +1 -1
- package/lib/reporter/models/frameworks/index.js +1 -1
- package/lib/reporter/models/frameworks/koa-request.js +1 -1
- package/lib/reporter/models/frameworks/restify-request.js +1 -1
- package/lib/reporter/models/observed-route.js +1 -1
- package/lib/reporter/models/request.js +1 -1
- package/lib/reporter/models/route-coverage.js +1 -1
- package/lib/reporter/models/startup.js +1 -1
- package/lib/reporter/models/trace-event-source.js +1 -1
- package/lib/reporter/models/utils/request-factory.js +1 -1
- package/lib/reporter/models/utils/user-input-factory.js +1 -1
- package/lib/reporter/models/utils/user-input-kit.js +1 -1
- package/lib/reporter/mq-client.js +1 -1
- package/lib/reporter/server-activity-queue.js +1 -1
- package/lib/reporter/socket-client.js +1 -1
- package/lib/reporter/speedracer/base-connection-state.js +1 -1
- package/lib/reporter/speedracer/constants.js +1 -1
- package/lib/reporter/speedracer/failure-connection-state.js +1 -1
- package/lib/reporter/speedracer/index.js +1 -1
- package/lib/reporter/speedracer/success-connection-state.js +1 -1
- package/lib/reporter/speedracer/unknown-connection-state.js +1 -1
- package/lib/reporter/translations/enums.js +1 -1
- package/lib/reporter/translations/helpers.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/activity.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/address.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/agent-startup.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/application-create.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/application-update.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/architecture-component.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/attack-result.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/bot-blocker-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/cmd-injection-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/cmd-injection-semantic-analysis-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/finding.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/http-method-tampering-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/http-request.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/index.js +2 -2
- package/lib/reporter/translations/to-protobuf/dtm/ip-denylist-details.js +2 -2
- package/lib/reporter/translations/to-protobuf/dtm/library-usage-update.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/no-sql-injection-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/observed-route.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/pair.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/path-traversal-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/poll.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/rasp-rule-sample.js +2 -2
- package/lib/reporter/translations/to-protobuf/dtm/raw-request.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/route-coverage.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/simple-pair.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/sql-injection-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/ssjs-injection-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/stack-trace-element.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/action.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/index.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/parent-object-id.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-event-object.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-event-signature.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-event-source.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-stack.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-taint-range.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/type.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/untrusted-deserialization-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/user-input.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/virtual-patch-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/xss-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/xxe-details.js +1 -1
- package/lib/reporter/translations/to-protobuf/index.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/application-settings.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/assess-features.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/auth.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/bot-blocker.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/custom-rule-feature.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/defend-features.js +9 -7
- package/lib/reporter/translations/to-protobuf/settings/exclusions.js +6 -5
- package/lib/reporter/translations/to-protobuf/settings/index.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/input-analysis-result.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/inventory-features.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/ip-filter.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/log-enhancer.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/protection-rule.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/reaction.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/rule-definition.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/sampling.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/server-features.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/syslog.js +1 -1
- package/lib/reporter/translations/to-protobuf/settings/virtual-patch.js +1 -1
- package/lib/reporter/ts-reporter.js +1 -1
- package/lib/tracker.js +14 -66
- package/lib/util/base64.js +1 -1
- package/lib/util/bitset.js +1 -1
- package/lib/util/block-request.js +1 -1
- package/lib/util/callback-resolver.js +1 -1
- package/lib/util/clean-stack.js +1 -1
- package/lib/util/clean-string/brackets.js +1 -1
- package/lib/util/clean-string/clean-string-base.js +1 -1
- package/lib/util/clean-string/comments.js +1 -1
- package/lib/util/clean-string/concatenations.js +1 -1
- package/lib/util/clean-string/jsclean-string.js +1 -1
- package/lib/util/clean-string/placeholders.js +1 -1
- package/lib/util/clean-string/util.js +1 -1
- package/lib/util/colors.js +1 -1
- package/lib/util/file-finder.js +1 -1
- package/lib/util/heap-dump.js +1 -1
- package/lib/util/html-util.js +1 -1
- package/lib/util/ip-analyzer.js +1 -1
- package/lib/util/is-agent-path.js +1 -1
- package/lib/util/is-contrast-error.js +1 -1
- package/lib/util/is-piped-to-dev.js +1 -1
- package/lib/util/is-string.js +1 -1
- package/lib/util/partial.js +1 -1
- package/lib/util/pkg-name.js +1 -1
- package/lib/util/request-util.js +1 -1
- package/lib/util/resolve-obj.js +1 -1
- package/lib/util/route-info.js +1 -1
- package/lib/util/some.js +1 -1
- package/lib/util/source-map.js +2 -2
- package/lib/util/static-rules.js +1 -1
- package/lib/util/trace-util.js +1 -1
- package/lib/util/traverse.js +1 -1
- package/lib/util/user-input-evaluator.js +1 -1
- package/lib/util/xml-analyzer/external-entity-finder.js +1 -1
- package/package.json +14 -16
- package/perf-logs.js +1 -1
- package/lib/hooks/frameworks/https.js +0 -42
- package/lib/protect/rules/nosqli/no-sql-injection-rule.js +0 -109
- package/node_modules/bindings/LICENSE.md +0 -22
- package/node_modules/bindings/README.md +0 -98
- package/node_modules/bindings/bindings.js +0 -221
- package/node_modules/bindings/package.json +0 -32
- package/node_modules/file-uri-to-path/.npmignore +0 -1
- package/node_modules/file-uri-to-path/.travis.yml +0 -30
- package/node_modules/file-uri-to-path/History.md +0 -21
- package/node_modules/file-uri-to-path/LICENSE +0 -20
- package/node_modules/file-uri-to-path/README.md +0 -74
- package/node_modules/file-uri-to-path/index.d.ts +0 -2
- package/node_modules/file-uri-to-path/index.js +0 -66
- package/node_modules/file-uri-to-path/package.json +0 -36
- package/node_modules/file-uri-to-path/test/test.js +0 -24
- package/node_modules/file-uri-to-path/test/tests.json +0 -13
- package/node_modules/glossy/LICENSE +0 -19
- package/node_modules/glossy/README.md +0 -129
- package/node_modules/glossy/index.js +0 -12
- package/node_modules/glossy/lib/glossy/parse.js +0 -520
- package/node_modules/glossy/lib/glossy/produce.js +0 -459
- package/node_modules/glossy/package.json +0 -47
- package/node_modules/glossy/test/decide.js +0 -7
- package/node_modules/glossy/test/decode_pri.js +0 -24
- package/node_modules/glossy/test/parse_3164.js +0 -104
- package/node_modules/glossy/test/parse_5424.js +0 -106
- package/node_modules/glossy/test/parse_5848.js +0 -40
- package/node_modules/glossy/test/parse_8601.js +0 -14
- package/node_modules/glossy/test/parse_rfc3339.js +0 -9
- package/node_modules/glossy/test/produce.js +0 -162
- package/node_modules/glossy/test/runner.js +0 -40
- package/node_modules/glossy/test/structure_data.js +0 -24
- package/node_modules/nan/CHANGELOG.md +0 -537
- package/node_modules/nan/LICENSE.md +0 -13
- package/node_modules/nan/README.md +0 -455
- package/node_modules/nan/doc/asyncworker.md +0 -146
- package/node_modules/nan/doc/buffers.md +0 -54
- package/node_modules/nan/doc/callback.md +0 -76
- package/node_modules/nan/doc/converters.md +0 -41
- package/node_modules/nan/doc/errors.md +0 -226
- package/node_modules/nan/doc/json.md +0 -62
- package/node_modules/nan/doc/maybe_types.md +0 -583
- package/node_modules/nan/doc/methods.md +0 -664
- package/node_modules/nan/doc/new.md +0 -147
- package/node_modules/nan/doc/node_misc.md +0 -123
- package/node_modules/nan/doc/object_wrappers.md +0 -263
- package/node_modules/nan/doc/persistent.md +0 -296
- package/node_modules/nan/doc/scopes.md +0 -73
- package/node_modules/nan/doc/script.md +0 -38
- package/node_modules/nan/doc/string_bytes.md +0 -62
- package/node_modules/nan/doc/v8_internals.md +0 -199
- package/node_modules/nan/doc/v8_misc.md +0 -85
- package/node_modules/nan/include_dirs.js +0 -1
- package/node_modules/nan/nan.h +0 -2898
- package/node_modules/nan/nan_callbacks.h +0 -88
- package/node_modules/nan/nan_callbacks_12_inl.h +0 -514
- package/node_modules/nan/nan_callbacks_pre_12_inl.h +0 -520
- package/node_modules/nan/nan_converters.h +0 -72
- package/node_modules/nan/nan_converters_43_inl.h +0 -68
- package/node_modules/nan/nan_converters_pre_43_inl.h +0 -42
- package/node_modules/nan/nan_define_own_property_helper.h +0 -29
- package/node_modules/nan/nan_implementation_12_inl.h +0 -430
- package/node_modules/nan/nan_implementation_pre_12_inl.h +0 -263
- package/node_modules/nan/nan_json.h +0 -166
- package/node_modules/nan/nan_maybe_43_inl.h +0 -356
- package/node_modules/nan/nan_maybe_pre_43_inl.h +0 -268
- package/node_modules/nan/nan_new.h +0 -340
- package/node_modules/nan/nan_object_wrap.h +0 -156
- package/node_modules/nan/nan_persistent_12_inl.h +0 -132
- package/node_modules/nan/nan_persistent_pre_12_inl.h +0 -242
- package/node_modules/nan/nan_private.h +0 -73
- package/node_modules/nan/nan_string_bytes.h +0 -305
- package/node_modules/nan/nan_typedarray_contents.h +0 -96
- package/node_modules/nan/nan_weak.h +0 -437
- package/node_modules/nan/package.json +0 -41
- package/node_modules/nan/tools/1to2.js +0 -412
- package/node_modules/nan/tools/README.md +0 -14
- package/node_modules/nan/tools/package.json +0 -19
- package/node_modules/unix-dgram/LICENSE +0 -13
- package/node_modules/unix-dgram/README.md +0 -107
- package/node_modules/unix-dgram/binding.gyp +0 -20
- package/node_modules/unix-dgram/build/Makefile +0 -324
- package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram/src/unix_dgram.o.d +0 -58
- package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram.node.d +0 -1
- package/node_modules/unix-dgram/build/Release/.deps/Release/unix_dgram.node.d +0 -1
- package/node_modules/unix-dgram/build/Release/obj.target/unix_dgram/src/unix_dgram.o +0 -0
- package/node_modules/unix-dgram/build/Release/obj.target/unix_dgram.node +0 -0
- package/node_modules/unix-dgram/build/Release/unix_dgram.node +0 -0
- package/node_modules/unix-dgram/build/binding.Makefile +0 -6
- package/node_modules/unix-dgram/build/config.gypi +0 -213
- package/node_modules/unix-dgram/build/unix_dgram.target.mk +0 -159
- package/node_modules/unix-dgram/lib/unix_dgram.js +0 -168
- package/node_modules/unix-dgram/package.json +0 -36
- package/node_modules/unix-dgram/src/unix_dgram.cc +0 -404
- package/node_modules/unix-dgram/src/win_dummy.cc +0 -7
- package/node_modules/unix-dgram/test/test-connect-callback.js +0 -68
- package/node_modules/unix-dgram/test/test-connect.js +0 -53
- package/node_modules/unix-dgram/test/test-dgram-unix.js +0 -58
- package/node_modules/unix-dgram/test/test-send-error.js +0 -26
- package/node_modules/winston-syslog/.eslintrc +0 -7
- package/node_modules/winston-syslog/.travis.yml +0 -14
- package/node_modules/winston-syslog/CHANGELOG.md +0 -9
- package/node_modules/winston-syslog/LICENSE +0 -20
- package/node_modules/winston-syslog/README.md +0 -135
- package/node_modules/winston-syslog/lib/utils.js +0 -26
- package/node_modules/winston-syslog/lib/winston-syslog.js +0 -385
- package/node_modules/winston-syslog/package.json +0 -56
- package/node_modules/winston-syslog/test/format-test.js +0 -122
- package/node_modules/winston-syslog/test/syslog-test.js +0 -95
- package/node_modules/winston-syslog/test/unix-connect-test.js +0 -133
|
@@ -1,459 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Glossy Producer - Generate valid syslog messages
|
|
3
|
-
*
|
|
4
|
-
* Copyright Squeeks <privacymyass@gmail.com>.
|
|
5
|
-
* This is free software licensed under the MIT License -
|
|
6
|
-
* see the LICENSE file that should be included with this package.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
/*
|
|
10
|
-
* These values replace the integers in message that define the facility.
|
|
11
|
-
*/
|
|
12
|
-
var FacilityIndex = {
|
|
13
|
-
'kern': 0, // kernel messages
|
|
14
|
-
'user': 1, // user-level messages
|
|
15
|
-
'mail': 2, // mail system
|
|
16
|
-
'daemon': 3, // system daemons
|
|
17
|
-
'auth': 4, // security/authorization messages
|
|
18
|
-
'syslog': 5, // messages generated internally by syslogd
|
|
19
|
-
'lpr': 6, // line printer subsystem
|
|
20
|
-
'news': 7, // network news subsystem
|
|
21
|
-
'uucp': 8, // UUCP subsystem
|
|
22
|
-
'clock': 9, // clock daemon
|
|
23
|
-
'sec': 10, // security/authorization messages
|
|
24
|
-
'ftp': 11, // FTP daemon
|
|
25
|
-
'ntp': 12, // NTP subsystem
|
|
26
|
-
'audit': 13, // log audit
|
|
27
|
-
'alert': 14, // log alert
|
|
28
|
-
// 'clock': 15, // clock daemon (note 2)
|
|
29
|
-
'local0': 16, // local use 0 (local0)
|
|
30
|
-
'local1': 17, // local use 1 (local1)
|
|
31
|
-
'local2': 18, // local use 2 (local2)
|
|
32
|
-
'local3': 19, // local use 3 (local3)
|
|
33
|
-
'local4': 20, // local use 4 (local4)
|
|
34
|
-
'local5': 21, // local use 5 (local5)
|
|
35
|
-
'local6': 22, // local use 6 (local6)
|
|
36
|
-
'local7': 23 // local use 7 (local7)
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
// Note 1 - Various operating systems have been found to utilize
|
|
40
|
-
// Facilities 4, 10, 13 and 14 for security/authorization,
|
|
41
|
-
// audit, and alert messages which seem to be similar.
|
|
42
|
-
|
|
43
|
-
// Note 2 - Various operating systems have been found to utilize
|
|
44
|
-
// both Facilities 9 and 15 for clock (cron/at) messages.
|
|
45
|
-
|
|
46
|
-
/*
|
|
47
|
-
* These values replace the integers in message that define the severity.
|
|
48
|
-
*/
|
|
49
|
-
var SeverityIndex = {
|
|
50
|
-
'emerg': 0, // Emergency: system is unusable
|
|
51
|
-
'emergency': 0,
|
|
52
|
-
|
|
53
|
-
'alert': 1, // Alert: action must be taken immediately
|
|
54
|
-
|
|
55
|
-
'crit': 2, // Critical: critical conditions
|
|
56
|
-
'critical': 2,
|
|
57
|
-
|
|
58
|
-
'err': 3, // Error: error conditions
|
|
59
|
-
'error': 3,
|
|
60
|
-
|
|
61
|
-
'warn': 4, // Warning: warning conditions
|
|
62
|
-
'warning': 4,
|
|
63
|
-
|
|
64
|
-
'notice': 5, // Notice: normal but significant condition
|
|
65
|
-
|
|
66
|
-
'info': 6 , // Informational: informational messages
|
|
67
|
-
'information': 6,
|
|
68
|
-
'informational': 6,
|
|
69
|
-
|
|
70
|
-
'debug': 7 // Debug: debug-level messages
|
|
71
|
-
};
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
/*
|
|
75
|
-
* Defines the range matching BSD style months to integers.
|
|
76
|
-
*/
|
|
77
|
-
var BSDDateIndex = [
|
|
78
|
-
'Jan',
|
|
79
|
-
'Feb',
|
|
80
|
-
'Mar',
|
|
81
|
-
'Apr',
|
|
82
|
-
'May',
|
|
83
|
-
'Jun',
|
|
84
|
-
'Jul',
|
|
85
|
-
'Aug',
|
|
86
|
-
'Sep',
|
|
87
|
-
'Oct',
|
|
88
|
-
'Nov',
|
|
89
|
-
'Dec'
|
|
90
|
-
];
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
/*
|
|
94
|
-
* GlossyProducer class
|
|
95
|
-
* @param {Object} provides persistent details of all messages:
|
|
96
|
-
* facility: The facility index
|
|
97
|
-
* severity: Severity index
|
|
98
|
-
* host: Host address, either name or IP
|
|
99
|
-
* appName: Application/Process name
|
|
100
|
-
* pid: Process ID
|
|
101
|
-
* msgID: Message ID (RFC5424 only)
|
|
102
|
-
* type: RFC3164/RFC5424 message type
|
|
103
|
-
* @return {Object} GlossyProducer object
|
|
104
|
-
*/
|
|
105
|
-
var GlossyProducer = function(options) {
|
|
106
|
-
if(options && typeof options =='object' && options.type) {
|
|
107
|
-
this.type = options.type.match(/bsd|3164/i) ? "RFC3164" : "RFC5424";
|
|
108
|
-
} else if(options && typeof options == 'string') {
|
|
109
|
-
this.type = options.match(/bsd|3164/i) ? "RFC3164" : "RFC5424";
|
|
110
|
-
} else {
|
|
111
|
-
this.type = "RFC5424";
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
if(options && options.facility && FacilityIndex[options.facility]) {
|
|
115
|
-
this.facility = options.facility;
|
|
116
|
-
}
|
|
117
|
-
if(options && options.pid && parseInt(options.pid, 10)) {
|
|
118
|
-
this.pid = options.pid;
|
|
119
|
-
}
|
|
120
|
-
if(options && options.host) this.host = options.host.replace(/\s+/g, '');
|
|
121
|
-
if(options && options.appName) this.appName = options.appName.replace(/\s+/g, '');
|
|
122
|
-
if(options && options.msgID) this.msgID = options.msgID.replace(/\s+/g, '');
|
|
123
|
-
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
/*
|
|
128
|
-
* @param {Object} options object containing details of the message:
|
|
129
|
-
* facility: The facility index
|
|
130
|
-
* severity: Severity index
|
|
131
|
-
* prival: RFC5424 PRIVAL field - will override facility/severity if in valid [0-191] range and both provided
|
|
132
|
-
* see ABNF at: (http://tools.ietf.org/html/rfc5424#section-6)
|
|
133
|
-
* host: Host address, either name or IP
|
|
134
|
-
* appName: Application ID
|
|
135
|
-
* pid: Process ID
|
|
136
|
-
* date: Timestamp to be applied, uses current GMT by default
|
|
137
|
-
* time: Optional Date() argument may be used in lieu of 'date' - allows parse() output to be used for produce args
|
|
138
|
-
* msgID: Message ID (RFC5424 only)
|
|
139
|
-
* structuredData: Object of structured data (RFC5424 only)
|
|
140
|
-
* message: The message to be sent
|
|
141
|
-
*
|
|
142
|
-
* @param {Function} callback a callback run once the message is built
|
|
143
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
144
|
-
*/
|
|
145
|
-
GlossyProducer.prototype.produce = function(options, callback) {
|
|
146
|
-
// TODO: next breaking api change make key output from parse() consistent with produce input options
|
|
147
|
-
if(options.time instanceof Date && !options.date) options.date = options.time;
|
|
148
|
-
|
|
149
|
-
var msgData = [];
|
|
150
|
-
if(!options.date instanceof Date) {
|
|
151
|
-
options.date = new Date(Date());
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
if(!options.facility) options.facility = this.facility;
|
|
155
|
-
|
|
156
|
-
if(this.type == 'RFC5424') {
|
|
157
|
-
if(options.hasOwnProperty('prival') && options.prival >= 0 && options.prival <= 191) {
|
|
158
|
-
var prival = '<' + options.prival + '>1';
|
|
159
|
-
}
|
|
160
|
-
else {
|
|
161
|
-
var prival = calculatePrival({
|
|
162
|
-
facility: options.facility,
|
|
163
|
-
severity: options.severity,
|
|
164
|
-
version: 1
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
if(prival === false) return false;
|
|
169
|
-
|
|
170
|
-
msgData.push(prival);
|
|
171
|
-
msgData.push(generateDate(options.date));
|
|
172
|
-
|
|
173
|
-
msgData.push(options.host || this.host || '-');
|
|
174
|
-
msgData.push(options.appName || this.appName || '-');
|
|
175
|
-
msgData.push(options.pid || this.pid || '-');
|
|
176
|
-
msgData.push(options.msgID || this.msgID || '-');
|
|
177
|
-
if(options.structuredData) {
|
|
178
|
-
msgData.push(generateStructuredData(options.structuredData) || '-');
|
|
179
|
-
} else {
|
|
180
|
-
msgData.push('-');
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
if(!options.message) options.message = '-';
|
|
184
|
-
|
|
185
|
-
} else {
|
|
186
|
-
options.timestamp = generateBSDDate(options.date);
|
|
187
|
-
msgData.push(
|
|
188
|
-
calculatePrival({
|
|
189
|
-
facility: options.facility,
|
|
190
|
-
severity: options.severity
|
|
191
|
-
}) + options.timestamp
|
|
192
|
-
);
|
|
193
|
-
|
|
194
|
-
msgData.push(options.host || this.host);
|
|
195
|
-
msgData.push();
|
|
196
|
-
if(options.appName || this.appName) {
|
|
197
|
-
var app = options.appName || this.appName;
|
|
198
|
-
var pid = options.pid || this.pid;
|
|
199
|
-
|
|
200
|
-
if(parseInt(pid, 10)) {
|
|
201
|
-
msgData.push(app + '[' + pid + ']:');
|
|
202
|
-
} else {
|
|
203
|
-
msgData.push(app + ':');
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
var compiledMessage = msgData.filter(function (messageElement) {
|
|
209
|
-
// Filter null/ undefined values
|
|
210
|
-
return messageElement;
|
|
211
|
-
}).map(function (messageElement) {
|
|
212
|
-
// Trim messages to remove successive whitespace
|
|
213
|
-
return String(messageElement).trim();
|
|
214
|
-
}).join(' ');
|
|
215
|
-
compiledMessage += ' ' + options.message || '';
|
|
216
|
-
msgData.push(compiledMessage);
|
|
217
|
-
|
|
218
|
-
if(callback) {
|
|
219
|
-
return callback(compiledMessage);
|
|
220
|
-
} else {
|
|
221
|
-
return compiledMessage;
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
};
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
/*
|
|
228
|
-
* @param {Object} options object containing details of the message with
|
|
229
|
-
* the severity as 'debug'
|
|
230
|
-
* @param {Function} callback a callback run once the message is built
|
|
231
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
232
|
-
*/
|
|
233
|
-
GlossyProducer.prototype.debug = function(options, callback) {
|
|
234
|
-
options.severity = 'debug';
|
|
235
|
-
return this.produce(options, callback);
|
|
236
|
-
};
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
/*
|
|
240
|
-
* @param {Object} options object containing details of the message with
|
|
241
|
-
* the severity as 'info'
|
|
242
|
-
* @param {Function} callback a callback run once the message is built
|
|
243
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
244
|
-
*/
|
|
245
|
-
GlossyProducer.prototype.info = function(options, callback) {
|
|
246
|
-
options.severity = 'info';
|
|
247
|
-
return this.produce(options, callback);
|
|
248
|
-
};
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
/*
|
|
252
|
-
* @param {Object} options object containing details of the message with
|
|
253
|
-
* the severity as 'notice'
|
|
254
|
-
* @param {Function} callback a callback run once the message is built
|
|
255
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
256
|
-
*/
|
|
257
|
-
GlossyProducer.prototype.notice = function(options, callback) {
|
|
258
|
-
options.severity = 'notice';
|
|
259
|
-
return this.produce(options, callback);
|
|
260
|
-
};
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
/*
|
|
264
|
-
* @param {Object} options object containing details of the message with
|
|
265
|
-
* the severity as 'warn'
|
|
266
|
-
* @param {Function} callback a callback run once the message is built
|
|
267
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
268
|
-
*/
|
|
269
|
-
GlossyProducer.prototype.warn = function(options, callback) {
|
|
270
|
-
options.severity = 'warn';
|
|
271
|
-
return this.produce(options, callback);
|
|
272
|
-
};
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
/*
|
|
276
|
-
* @param {Object} options object containing details of the message with
|
|
277
|
-
* the severity as 'crit'
|
|
278
|
-
* @param {Function} callback a callback run once the message is built
|
|
279
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
280
|
-
*/
|
|
281
|
-
GlossyProducer.prototype.crit = function(options, callback) {
|
|
282
|
-
options.severity = 'crit';
|
|
283
|
-
return this.produce(options, callback);
|
|
284
|
-
};
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
/*
|
|
288
|
-
* @param {Object} options object containing details of the message with
|
|
289
|
-
* the severity as 'alert'
|
|
290
|
-
* @param {Function} callback a callback run once the message is built
|
|
291
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
292
|
-
*/
|
|
293
|
-
GlossyProducer.prototype.alert = function(options, callback) {
|
|
294
|
-
options.severity = 'alert';
|
|
295
|
-
return this.produce(options, callback);
|
|
296
|
-
};
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
/*
|
|
300
|
-
* @param {Object} options object containing details of the message with
|
|
301
|
-
* the severity as 'emergency'
|
|
302
|
-
* @param {Function} callback a callback run once the message is built
|
|
303
|
-
* @return {String} compiledMessage on completion, false on failure
|
|
304
|
-
*/
|
|
305
|
-
GlossyProducer.prototype.emergency = function(options, callback) {
|
|
306
|
-
options.severity = 'emergency';
|
|
307
|
-
return this.produce(options, callback);
|
|
308
|
-
};
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
/*
|
|
312
|
-
* Prepend a zero to a number less than 10
|
|
313
|
-
* @param {Number} n
|
|
314
|
-
* @return {String}
|
|
315
|
-
*
|
|
316
|
-
* Where's sprintf when you need it?
|
|
317
|
-
*/
|
|
318
|
-
function leadZero(n) {
|
|
319
|
-
if(typeof n != 'number') return n;
|
|
320
|
-
n = n < 10 ? '0' + n : n ;
|
|
321
|
-
return n;
|
|
322
|
-
}
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
/*
|
|
326
|
-
* Get current date in RFC 3164 format. If no date is supplied, the default
|
|
327
|
-
* is the current time in GMT + 0.
|
|
328
|
-
* @param {Date} dateObject optional Date object
|
|
329
|
-
* @returns {String}
|
|
330
|
-
*
|
|
331
|
-
* Features code taken from https://github.com/akaspin/ain
|
|
332
|
-
*/
|
|
333
|
-
function generateBSDDate(dateObject) {
|
|
334
|
-
if(!(dateObject instanceof Date)) dateObject = new Date(Date());
|
|
335
|
-
var hours = leadZero(dateObject.getHours());
|
|
336
|
-
var minutes = leadZero(dateObject.getMinutes());
|
|
337
|
-
var seconds = leadZero(dateObject.getSeconds());
|
|
338
|
-
var month = dateObject.getMonth();
|
|
339
|
-
var day = dateObject.getDate();
|
|
340
|
-
if(day < 10) (day = ' ' + day);
|
|
341
|
-
return BSDDateIndex[month] + " " + day + " " + hours + ":" + minutes + ":" + seconds;
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
/*
|
|
346
|
-
* Generate date in RFC 3339 format. If no date is supplied, the default is
|
|
347
|
-
* the current time in GMT + 0.
|
|
348
|
-
* @param {Date} dateObject optional Date object
|
|
349
|
-
* @returns {String} formatted date
|
|
350
|
-
*/
|
|
351
|
-
function generateDate(dateObject) {
|
|
352
|
-
if(!(dateObject instanceof Date)) dateObject = new Date(Date());
|
|
353
|
-
|
|
354
|
-
// Calcutate the offset
|
|
355
|
-
var timeOffset;
|
|
356
|
-
var minutes = Math.abs(dateObject.getTimezoneOffset());
|
|
357
|
-
var hours = 0;
|
|
358
|
-
while(minutes >= 60) {
|
|
359
|
-
hours++;
|
|
360
|
-
minutes -= 60;
|
|
361
|
-
}
|
|
362
|
-
|
|
363
|
-
if(dateObject.getTimezoneOffset() < 0) {
|
|
364
|
-
// Ahead of UTC
|
|
365
|
-
timeOffset = '+' + leadZero(hours) + '' + ':' + leadZero(minutes);
|
|
366
|
-
} else if(dateObject.getTimezoneOffset() > 0) {
|
|
367
|
-
// Behind UTC
|
|
368
|
-
timeOffset = '-' + leadZero(hours) + '' + ':' + leadZero(minutes);
|
|
369
|
-
} else {
|
|
370
|
-
// UTC
|
|
371
|
-
timeOffset = 'Z';
|
|
372
|
-
}
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
// Date
|
|
376
|
-
formattedDate = dateObject.getUTCFullYear() + '-' +
|
|
377
|
-
// N.B. Javascript Date objects return months of the year indexed from
|
|
378
|
-
// zero, while the RFC 5424 syslog standard expects months indexed from
|
|
379
|
-
// one.
|
|
380
|
-
leadZero(dateObject.getUTCMonth() + 1) + '-' +
|
|
381
|
-
// N.B. Javascript Date objects return days of the month indexed from one
|
|
382
|
-
// (unlike months of year), so this does not need any correction.
|
|
383
|
-
leadZero(dateObject.getUTCDate()) + 'T' +
|
|
384
|
-
// Time
|
|
385
|
-
leadZero(dateObject.getUTCHours()) + ':' +
|
|
386
|
-
leadZero(dateObject.getUTCMinutes()) + ':' +
|
|
387
|
-
leadZero(dateObject.getUTCSeconds()) + '.' +
|
|
388
|
-
leadZero(dateObject.getUTCMilliseconds()) +
|
|
389
|
-
timeOffset;
|
|
390
|
-
|
|
391
|
-
return formattedDate;
|
|
392
|
-
|
|
393
|
-
}
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
/*
|
|
397
|
-
* Calculate the PRIVAL for a given facility
|
|
398
|
-
* @param {Object} values Contains the three key arguments
|
|
399
|
-
* facility {Number}/{String} the Facility Index
|
|
400
|
-
* severity {Number}
|
|
401
|
-
* version {Number} For RFC 5424 messages, this should be 1
|
|
402
|
-
*
|
|
403
|
-
* @return {String}
|
|
404
|
-
*/
|
|
405
|
-
function calculatePrival(values) {
|
|
406
|
-
|
|
407
|
-
var pri = {};
|
|
408
|
-
// Facility
|
|
409
|
-
if(typeof values.facility == 'string' && !values.facility.match(/^\d+$/)) {
|
|
410
|
-
pri.facility = FacilityIndex[values.facility.toLowerCase()];
|
|
411
|
-
} else if( parseInt(values.facility, 10) && parseInt(values.facility, 10) < 24) {
|
|
412
|
-
pri.facility = parseInt(values.facility, 10);
|
|
413
|
-
}
|
|
414
|
-
|
|
415
|
-
//Severity
|
|
416
|
-
if(typeof values.severity == 'string' && !values.severity.match(/^\d+$/)) {
|
|
417
|
-
pri.severity = SeverityIndex[values.severity.toLowerCase()];
|
|
418
|
-
} else if( parseInt(values.severity, 10) && parseInt(values.severity, 10) < 8) {
|
|
419
|
-
pri.severity = parseInt(values.severity, 10);
|
|
420
|
-
}
|
|
421
|
-
|
|
422
|
-
if(!isNaN(pri.severity) && !isNaN(pri.facility)) {
|
|
423
|
-
pri.prival = (pri.facility * 8) + pri.severity;
|
|
424
|
-
pri.str = values.version ? '<' + pri.prival + '>' + values.version : '<' + pri.prival + '>';
|
|
425
|
-
return pri.str;
|
|
426
|
-
} else {
|
|
427
|
-
return false;
|
|
428
|
-
}
|
|
429
|
-
|
|
430
|
-
}
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
/*
|
|
434
|
-
* Serialise objects into the structured data segment
|
|
435
|
-
* @param {Object} struct The object to serialise
|
|
436
|
-
* @return {String} structuredData the serialised data
|
|
437
|
-
*/
|
|
438
|
-
function generateStructuredData(struct) {
|
|
439
|
-
if(typeof struct != 'object') return false;
|
|
440
|
-
|
|
441
|
-
var structuredData = '';
|
|
442
|
-
|
|
443
|
-
for(var sdID in struct) {
|
|
444
|
-
sdElement = struct[sdID];
|
|
445
|
-
structuredData += '[' + sdID;
|
|
446
|
-
for(var key in sdElement) {
|
|
447
|
-
sdElement[key] = sdElement[key].toString().replace(/(\]|\\|")/g, '\\$1');
|
|
448
|
-
structuredData += ' ' + key + '="' + sdElement[key] + '"';
|
|
449
|
-
}
|
|
450
|
-
structuredData += ']';
|
|
451
|
-
|
|
452
|
-
}
|
|
453
|
-
|
|
454
|
-
return structuredData;
|
|
455
|
-
}
|
|
456
|
-
|
|
457
|
-
if(typeof module == 'object') {
|
|
458
|
-
module.exports = GlossyProducer;
|
|
459
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name" : "glossy",
|
|
3
|
-
"version" : "0.1.7",
|
|
4
|
-
"description" : "Syslog parser and producer",
|
|
5
|
-
"keywords" : ["syslog", "logging"],
|
|
6
|
-
"url" : "http://github.com/squeeks/glossy",
|
|
7
|
-
"main" : "./index.js",
|
|
8
|
-
"author" : "Squeeks <privacymyass@gmail.com>",
|
|
9
|
-
"maintainers" : [
|
|
10
|
-
{ "name" : "Squeeks", "email" : "privacymyass@gmail.com" }
|
|
11
|
-
],
|
|
12
|
-
"contributors" : [
|
|
13
|
-
{ "name": "artifi", "email": "artifipl@gmail.com" },
|
|
14
|
-
{ "name": "Matt Bornski", "email": "matt@bornski.com" },
|
|
15
|
-
{ "name": "Fyodor Y", "email": "fygrave@o0o.nu" },
|
|
16
|
-
{ "name": "Stan Carney", "email": "stan.carney@rootsh.me" },
|
|
17
|
-
{ "name": "Alexander Metzner", "email": "alexander.metzner@thomann.de" },
|
|
18
|
-
{ "name": "zaphod1984", "email": "zaphod84@gmx.de" },
|
|
19
|
-
{ "name": "Eric Cornelius", "email": "eric.cornelius@mandiant.com" },
|
|
20
|
-
{ "name": "horpto", "email": "_singleton__@hackerdom.ru" }
|
|
21
|
-
],
|
|
22
|
-
"directories" : {
|
|
23
|
-
"lib": "./lib",
|
|
24
|
-
"test": "./test"
|
|
25
|
-
},
|
|
26
|
-
"scripts" : {
|
|
27
|
-
"test": "node test/runner.js"
|
|
28
|
-
},
|
|
29
|
-
"repository" : {
|
|
30
|
-
"type": "git",
|
|
31
|
-
"url": "http://github.com/squeeks/glossy.git"
|
|
32
|
-
},
|
|
33
|
-
"bugs" : {
|
|
34
|
-
"url": "http://github.com/squeeks/glossy/issues"
|
|
35
|
-
},
|
|
36
|
-
"licenses" : [
|
|
37
|
-
{
|
|
38
|
-
"type": "MIT",
|
|
39
|
-
"url": "http://www.opensource.org/licenses/MIT"
|
|
40
|
-
}
|
|
41
|
-
],
|
|
42
|
-
"engines" : { "node": ">= 0.2.5" }
|
|
43
|
-
|
|
44
|
-
,"_resolved": "https://registry.npmjs.org/glossy/-/glossy-0.1.7.tgz"
|
|
45
|
-
,"_integrity": "sha1-dptZhKlvYGarnqdYIkgl7mwhDws="
|
|
46
|
-
,"_from": "glossy@0.1.7"
|
|
47
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
var syslogParser = require('../lib/glossy/parse.js'),
|
|
2
|
-
assert = require('assert');
|
|
3
|
-
|
|
4
|
-
assert.ok(syslogParser, 'parser loaded');
|
|
5
|
-
assert.equal(syslogParser.decideValue(1), "1");
|
|
6
|
-
assert.equal(syslogParser.decideValue('-'), null);
|
|
7
|
-
assert.equal(syslogParser.decideValue('ー'), 'ー');
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
var syslogParser = require('../lib/glossy/parse.js'),
|
|
2
|
-
assert = require('assert');
|
|
3
|
-
|
|
4
|
-
assert.ok(syslogParser, 'parser loaded');
|
|
5
|
-
assert.deepEqual(syslogParser.decodePri('<16>'), {
|
|
6
|
-
prival: 16,
|
|
7
|
-
facilityID: 2,
|
|
8
|
-
severityID: 0,
|
|
9
|
-
facility: 'mail',
|
|
10
|
-
severity: 'emerg'
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
assert.deepEqual(syslogParser.decodePri('<66>1'), {
|
|
14
|
-
prival: 66,
|
|
15
|
-
facilityID: 8,
|
|
16
|
-
severityID: 2,
|
|
17
|
-
facility: 'uucp',
|
|
18
|
-
severity: 'crit'
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
assert.equal(syslogParser.decodePri('1<16>'), false);
|
|
23
|
-
assert.equal(syslogParser.decodePri('<200>'), false);
|
|
24
|
-
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
var syslogParser = require('../lib/glossy/parse.js'),
|
|
2
|
-
syslogGenerator = require('../lib/glossy/produce.js'),
|
|
3
|
-
assert = require('assert');
|
|
4
|
-
|
|
5
|
-
assert.ok(syslogParser, 'parser loaded');
|
|
6
|
-
|
|
7
|
-
var gen = new syslogGenerator({type: 'bsd'});
|
|
8
|
-
|
|
9
|
-
var doubleSpaced = "<13>Feb 5 17:32:18 10.0.0.99 Use the BFG!";
|
|
10
|
-
syslogParser.parse(doubleSpaced, function(parsedMessage){
|
|
11
|
-
var msg = gen.produce(parsedMessage);
|
|
12
|
-
assert.equal(doubleSpaced, msg);
|
|
13
|
-
|
|
14
|
-
var expectedData = {
|
|
15
|
-
originalMessage: doubleSpaced,
|
|
16
|
-
prival: 13,
|
|
17
|
-
facilityID: 1,
|
|
18
|
-
severityID: 5,
|
|
19
|
-
facility: 'user',
|
|
20
|
-
severity: 'notice',
|
|
21
|
-
type: 'RFC3164',
|
|
22
|
-
host: '10.0.0.99',
|
|
23
|
-
message: 'Use the BFG!' };
|
|
24
|
-
|
|
25
|
-
delete parsedMessage.date;
|
|
26
|
-
delete parsedMessage.time;
|
|
27
|
-
delete parsedMessage.timestamp;
|
|
28
|
-
|
|
29
|
-
assert.deepEqual(parsedMessage, expectedData);
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
var withCommand = "<34>Oct 11 22:14:15 mymachine su: 'su root' failed for lonvick on /dev/pts/8";
|
|
33
|
-
syslogParser.parse(withCommand, function(parsedMessage){
|
|
34
|
-
var expectedData = {
|
|
35
|
-
originalMessage: withCommand,
|
|
36
|
-
prival: 34,
|
|
37
|
-
facilityID: 4,
|
|
38
|
-
severityID: 2,
|
|
39
|
-
facility: 'auth',
|
|
40
|
-
severity: 'crit',
|
|
41
|
-
type: 'RFC3164',
|
|
42
|
-
host: 'mymachine',
|
|
43
|
-
message: "su: 'su root' failed for lonvick on /dev/pts/8" };
|
|
44
|
-
|
|
45
|
-
var parsedDate = parsedMessage.time;
|
|
46
|
-
delete parsedMessage.time;
|
|
47
|
-
|
|
48
|
-
assert.equal(parsedDate.getUTCMonth(), 9);
|
|
49
|
-
assert.equal(parsedDate.getUTCHours(), 20);
|
|
50
|
-
assert.deepEqual(parsedMessage, expectedData);
|
|
51
|
-
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
var withDifficultTime = "<191>94103: 51w2d: DHCPD: assigned IP address 10.10.1.94 to client 0100.01c4.21d3.b3";
|
|
55
|
-
syslogParser.parse(withDifficultTime, function(parsedMessage){
|
|
56
|
-
var expectedData = {
|
|
57
|
-
originalMessage: withDifficultTime,
|
|
58
|
-
prival: 191,
|
|
59
|
-
facilityID: 23,
|
|
60
|
-
severityID: 7,
|
|
61
|
-
facility: 'local7',
|
|
62
|
-
severity: 'debug',
|
|
63
|
-
type: 'RFC3164',
|
|
64
|
-
time: undefined,
|
|
65
|
-
message: '51w2d: DHCPD: assigned IP address 10.10.1.94 to client 0100.01c4.21d3.b3'};
|
|
66
|
-
|
|
67
|
-
assert.deepEqual(parsedMessage, expectedData);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
var withYear = "<32>Mar 05 2011 22:21:02: %ASA-6-302013: Built inbound TCP connection 401 for outside:123.123.123.123/4413 (123.123.123.123/4413) to net:BOX/25 (BOX/25)";
|
|
71
|
-
syslogParser.parse(withYear, function(parsedMessage){
|
|
72
|
-
var expectedData = {
|
|
73
|
-
originalMessage: withYear,
|
|
74
|
-
prival: 32,
|
|
75
|
-
facilityID: 4,
|
|
76
|
-
severityID: 0,
|
|
77
|
-
facility: 'auth',
|
|
78
|
-
severity: 'emerg',
|
|
79
|
-
type: 'RFC3164',
|
|
80
|
-
time: undefined,
|
|
81
|
-
host: '22:21:02:',
|
|
82
|
-
message: '%ASA-6-302013: Built inbound TCP connection 401 for outside:123.123.123.123/4413 (123.123.123.123/4413) to net:BOX/25 (BOX/25)' };
|
|
83
|
-
|
|
84
|
-
assert.deepEqual(parsedMessage, expectedData);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
var withSpaces = "<13>Mar 15 11:22:40 myhost.com 0 11,03/15/12,11:22:38,§ó·s,10.10.10.171,,40C6A91373B6,";
|
|
88
|
-
syslogParser.parse(withSpaces, function(parsedMessage){
|
|
89
|
-
var expectedData = {
|
|
90
|
-
originalMessage: withSpaces,
|
|
91
|
-
prival: 13,
|
|
92
|
-
facilityID: 1,
|
|
93
|
-
severityID: 5,
|
|
94
|
-
facility: 'user',
|
|
95
|
-
severity: 'notice',
|
|
96
|
-
type: 'RFC3164',
|
|
97
|
-
host: 'myhost.com',
|
|
98
|
-
message: ' 0 11,03/15/12,11:22:38,§ó·s,10.10.10.171,,40C6A91373B6,' };
|
|
99
|
-
|
|
100
|
-
delete parsedMessage.time;
|
|
101
|
-
assert.deepEqual(parsedMessage, expectedData);
|
|
102
|
-
|
|
103
|
-
});
|
|
104
|
-
|