@contrast/agent 4.7.1 → 4.10.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/bootstrap.js +13 -3
- package/cli-rewriter.js +1 -1
- package/cli.js +1 -1
- package/esm.mjs +34 -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 +3 -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 +1 -1
- package/lib/assess/membrane/index.js +1 -1
- package/lib/assess/membrane/source-membrane.js +1 -1
- package/lib/assess/models/base-event.js +1 -1
- package/lib/assess/models/call-context.js +1 -1
- 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 +7 -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/rules.json +29 -0
- package/lib/assess/policy/signatures.json +6 -6
- package/lib/assess/policy/util.js +1 -1
- package/lib/assess/propagators/JSON/parse.js +1 -1
- package/lib/assess/propagators/JSON/stringify.js +78 -8
- 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 +1 -1
- package/lib/assess/propagators/common.js +1 -1
- package/lib/assess/propagators/dustjs/escape-html.js +1 -1
- package/lib/assess/propagators/dustjs/escape-js.js +1 -1
- package/lib/assess/propagators/ejs-template-generate-source.js +1 -1
- package/lib/assess/propagators/encode-uri/encode-uri-component.js +1 -1
- package/lib/assess/propagators/encode-uri/encode-uri.js +1 -1
- package/lib/assess/propagators/handlebars-compile.js +1 -1
- package/lib/assess/propagators/handlebars-escape-expresssion.js +1 -1
- package/lib/assess/propagators/index.js +1 -1
- package/lib/assess/propagators/joi/any.js +48 -0
- package/lib/assess/propagators/joi/boolean.js +1 -1
- package/lib/assess/propagators/joi/expression.js +1 -1
- package/lib/assess/propagators/joi/index.js +3 -1
- package/lib/assess/propagators/joi/number.js +1 -1
- package/lib/assess/propagators/joi/object.js +61 -0
- package/lib/assess/propagators/joi/string-base.js +17 -1
- package/lib/assess/propagators/joi/string-schema.js +1 -1
- package/lib/assess/propagators/joi/values.js +1 -1
- package/lib/assess/propagators/manager.js +1 -1
- package/lib/assess/propagators/mongoose/helpers.js +1 -1
- package/lib/assess/propagators/mongoose/index.js +1 -1
- package/lib/assess/propagators/mongoose/map.js +1 -1
- package/lib/assess/propagators/mongoose/string.js +9 -1
- package/lib/assess/propagators/mustache/escape.js +1 -1
- package/lib/assess/propagators/number.js +1 -1
- package/lib/assess/propagators/object.js +1 -1
- package/lib/assess/propagators/path/basename.js +1 -1
- package/lib/assess/propagators/path/common.js +1 -1
- package/lib/assess/propagators/path/dirname.js +1 -1
- package/lib/assess/propagators/path/extname.js +1 -1
- 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 +1 -1
- package/lib/assess/propagators/path/relative.js +1 -1
- 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 +1 -1
- package/lib/assess/propagators/querystring/parse.js +1 -1
- package/lib/assess/propagators/querystring/stringify.js +1 -1
- package/lib/assess/propagators/querystring/unescape.js +1 -1
- package/lib/assess/propagators/querystring/utils.js +1 -1
- package/lib/assess/propagators/sequelize/sql-string-escape.js +1 -1
- package/lib/assess/propagators/sequelize/sql-string-format-named-parameters.js +1 -1
- package/lib/assess/propagators/sequelize/sql-string-format.js +1 -1
- package/lib/assess/propagators/sequelize/utils.js +1 -1
- package/lib/assess/propagators/string-prototype-replace.js +1 -1
- package/lib/assess/propagators/string-prototype-split.js +1 -1
- package/lib/assess/propagators/string-prototype-trim.js +1 -1
- package/lib/assess/propagators/string.js +1 -1
- package/lib/assess/propagators/template-escape.js +1 -1
- package/lib/assess/propagators/templates.js +1 -1
- package/lib/assess/propagators/url/url-prototype-parse.js +1 -1
- package/lib/assess/propagators/url/url-url.js +1 -1
- package/lib/assess/propagators/url/utils.js +1 -1
- package/lib/assess/propagators/util/format.js +1 -1
- package/lib/assess/propagators/utils.js +1 -1
- package/lib/assess/propagators/v8/init-hooks.js +1 -1
- package/lib/assess/propagators/validator/init-hooks.js +1 -1
- 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 +1 -1
- package/lib/assess/sinks/dustjs-linkedin-xss.js +1 -1
- 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 +1 -1
- package/lib/assess/sinks/mongodb.js +1 -1
- package/lib/assess/sinks/rethinkdb-nosql-injection.js +142 -0
- package/lib/assess/sinks/ssrf-url.js +1 -1
- package/lib/assess/sources/event-handler.js +307 -0
- package/lib/assess/sources/formidable.js +1 -1
- package/lib/assess/sources/index.js +94 -6
- package/lib/assess/spdy/index.js +23 -0
- package/lib/assess/spdy/sinks/index.js +23 -0
- package/lib/assess/spdy/sinks/xss.js +84 -0
- package/lib/assess/static/hardcoded.js +1 -1
- package/lib/assess/technologies/index.js +3 -2
- package/lib/assess/utils.js +1 -1
- package/lib/cli-rewriter/index.js +1 -1
- package/lib/constants.js +3 -2
- package/lib/contrast.js +7 -7
- 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 +2 -1
- package/lib/core/arch-components/mongodb.js +23 -19
- package/lib/core/arch-components/mysql.js +1 -1
- package/lib/core/arch-components/postgres.js +22 -4
- package/lib/core/arch-components/rethinkdb.js +1 -1
- package/lib/core/arch-components/sqlite3.js +4 -6
- 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 +38 -2
- package/lib/core/config/util.js +1 -1
- package/lib/core/exclusions/exclusion-factory.js +1 -1
- package/lib/core/exclusions/exclusion.js +3 -6
- package/lib/core/exclusions/input.js +1 -1
- package/lib/core/exclusions/url.js +1 -1
- package/lib/core/express/index.js +29 -3
- package/lib/core/express/utils.js +9 -4
- package/lib/core/fastify/index.js +3 -2
- package/lib/core/fastify/utils.js +1 -1
- package/lib/core/hapi/index.js +3 -2
- package/lib/core/hapi/utils.js +1 -1
- package/lib/core/index.js +1 -1
- package/lib/core/koa/index.js +10 -2
- 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 +17 -1
- package/lib/core/rewrite/catch-clause.js +1 -1
- package/lib/core/rewrite/function-wrap.js +1 -1
- package/lib/core/rewrite/import-declaration.js +71 -0
- package/lib/core/rewrite/index.js +10 -8
- package/lib/core/rewrite/injections.js +6 -2
- 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 +1 -1
- package/lib/coverage.js +1 -1
- package/lib/feature-set.js +1 -1
- 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 +1 -1
- package/lib/hooks/frameworks/common.js +1 -1
- package/lib/hooks/frameworks/hapi16.js +1 -1
- package/lib/hooks/frameworks/http.js +1 -1
- package/lib/hooks/frameworks/http2.js +1 -1
- package/lib/hooks/frameworks/index.js +3 -1
- package/lib/hooks/frameworks/spdy.js +87 -0
- package/lib/hooks/hapi-16-reply.js +1 -1
- package/lib/hooks/hapi-16-session.js +1 -1
- package/lib/hooks/http.js +12 -1
- 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 +1 -1
- package/lib/hooks/patcher.js +1 -1
- package/lib/hooks/require.js +1 -1
- package/lib/hooks/stealthy-require.js +1 -1
- package/lib/instrumentation.js +1 -1
- 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 +36 -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 +31 -17
- package/lib/protect/rules/nosqli/nosql-scanner/index.js +2 -2
- package/lib/protect/rules/nosqli/nosql-scanner/mongodbscanner.js +1 -1
- package/lib/protect/rules/nosqli/nosql-scanner/rethinkdbscanner.js +26 -0
- package/lib/protect/rules/path-traversal/path-traversal-rule.js +1 -1
- package/lib/protect/rules/rule-factory.js +1 -1
- 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 +1 -1
- 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 +3 -1
- package/lib/protect/sinks/libxmljs.js +1 -1
- package/lib/protect/sinks/mongodb.js +2 -4
- 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/rethinkdb.js +47 -0
- 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 +1 -1
- package/lib/reporter/translations/to-protobuf/dtm/ip-denylist-details.js +1 -1
- 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 +1 -1
- 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 +5 -5
- 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 +1 -1
- package/lib/reporter/translations/to-protobuf/settings/exclusions.js +1 -1
- 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 +1 -1
- 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 +4 -4
- 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 +18 -12
- package/perf-logs.js +1 -1
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
|
+
Contact: support@contrastsecurity.com
|
|
4
|
+
License: Commercial
|
|
5
|
+
|
|
6
|
+
NOTICE: This Software and the patented inventions embodied within may only be
|
|
7
|
+
used as part of Contrast Security’s commercial offerings. Even though it is
|
|
8
|
+
made available through public repositories, use of this Software is subject to
|
|
9
|
+
the applicable End User Licensing Agreement found at
|
|
10
|
+
https://www.contrastsecurity.com/enduser-terms-0317a or as otherwise agreed
|
|
11
|
+
between Contrast Security and the End User. The Software may not be reverse
|
|
12
|
+
engineered, modified, repackaged, sold, redistributed or otherwise used in a
|
|
13
|
+
way not consistent with the End User License Agreement.
|
|
14
|
+
*/
|
|
15
|
+
'use strict';
|
|
16
|
+
|
|
17
|
+
const agentEmitter = require('../../../agent-emitter');
|
|
18
|
+
const { HTTP_RESPONSE_HOOKED_METHOD_KEYS } = require('../../../constants');
|
|
19
|
+
const policy = require('../../policy');
|
|
20
|
+
const { Signature, CallContext } = require('../../models');
|
|
21
|
+
|
|
22
|
+
class SpdyXss {
|
|
23
|
+
constructor(agent) {
|
|
24
|
+
this.common = require('../../sinks/common')(agent);
|
|
25
|
+
this.rules = policy.rules;
|
|
26
|
+
this.ruleId = 'reflected-xss';
|
|
27
|
+
this.signature = new Signature({
|
|
28
|
+
moduleName: 'spdy.response',
|
|
29
|
+
methodName: 'push',
|
|
30
|
+
isModule: false
|
|
31
|
+
});
|
|
32
|
+
agentEmitter.on(
|
|
33
|
+
HTTP_RESPONSE_HOOKED_METHOD_KEYS.PUSH,
|
|
34
|
+
this.checkResult.bind(this)
|
|
35
|
+
);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* checks if an assess rule is enabled in policy
|
|
40
|
+
*/
|
|
41
|
+
get enabled() {
|
|
42
|
+
return (
|
|
43
|
+
this.rules &&
|
|
44
|
+
this.rules['reflected-xss'] &&
|
|
45
|
+
this.rules['reflected-xss'].enabled
|
|
46
|
+
);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
checkResult(body) {
|
|
50
|
+
if (!this.enabled) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const { ruleId, signature } = this;
|
|
55
|
+
|
|
56
|
+
const {
|
|
57
|
+
isVulnerable,
|
|
58
|
+
xss: { disallowedTags },
|
|
59
|
+
requiredTags,
|
|
60
|
+
report
|
|
61
|
+
} = this.common;
|
|
62
|
+
|
|
63
|
+
if (
|
|
64
|
+
isVulnerable({
|
|
65
|
+
input: body,
|
|
66
|
+
disallowedTags,
|
|
67
|
+
requiredTags,
|
|
68
|
+
ruleId
|
|
69
|
+
})
|
|
70
|
+
) {
|
|
71
|
+
const ctxt = new CallContext({
|
|
72
|
+
obj: body,
|
|
73
|
+
args: [body],
|
|
74
|
+
result: body,
|
|
75
|
+
stackOpts: {
|
|
76
|
+
constructorOpt: agentEmitter.emit
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
report({ ruleId, signature, input: body, ctxt });
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
module.exports = SpdyXss;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -31,7 +31,8 @@ const technologies = {
|
|
|
31
31
|
'fastify',
|
|
32
32
|
'restify',
|
|
33
33
|
'loopback',
|
|
34
|
-
'kraken-js'
|
|
34
|
+
'kraken-js',
|
|
35
|
+
'sails'
|
|
35
36
|
],
|
|
36
37
|
templating: ['jade', 'ejs', 'nunjucks', 'mustache', 'dust', 'handlebars'],
|
|
37
38
|
loggers: ['winston', 'debug'],
|
package/lib/assess/utils.js
CHANGED
package/lib/constants.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -644,7 +644,8 @@ const REQUIRED_SIGNATURE_KEYS = [
|
|
|
644
644
|
|
|
645
645
|
const HTTP_RESPONSE_HOOKED_METHOD_KEYS = {
|
|
646
646
|
WRITE_HEAD: Symbol('writeHead'),
|
|
647
|
-
END: Symbol('end')
|
|
647
|
+
END: Symbol('end'),
|
|
648
|
+
PUSH: Symbol('push')
|
|
648
649
|
};
|
|
649
650
|
|
|
650
651
|
const PATCH_TYPES = {
|
package/lib/contrast.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
/**
|
|
3
|
-
Copyright:
|
|
3
|
+
Copyright: 2022 Contrast Security, Inc
|
|
4
4
|
Contact: support@contrastsecurity.com
|
|
5
5
|
License: Commercial
|
|
6
6
|
|
|
@@ -178,7 +178,7 @@ contrastAgent.configureGlobalLogger = function(config, args, target = global) {
|
|
|
178
178
|
|
|
179
179
|
function getAgentArgs(options) {
|
|
180
180
|
const agentArgs = {};
|
|
181
|
-
|
|
181
|
+
program.options.forEach((opt) => {
|
|
182
182
|
if (opt.name() !== 'application.args' && options[opt.name()]) {
|
|
183
183
|
agentArgs[opt.name()] = options[opt.name()];
|
|
184
184
|
}
|
|
@@ -243,8 +243,8 @@ contrastAgent.prepare = function(...args) {
|
|
|
243
243
|
|
|
244
244
|
logger.info('Using config file at %s', config.configFile);
|
|
245
245
|
// log the argv before and after modification.
|
|
246
|
-
logger.info(`Original argv: ${
|
|
247
|
-
logger.info(`Modified argv: ${
|
|
246
|
+
logger.info(`Original argv: ${program.rawArgs.join(', ')}`);
|
|
247
|
+
logger.info(`Modified argv: ${program.args.join(', ')}`);
|
|
248
248
|
|
|
249
249
|
agent.config = config;
|
|
250
250
|
agent.tsFeatureSet.config = config;
|
|
@@ -335,12 +335,12 @@ contrastAgent.init = async function(args, isCli = false) {
|
|
|
335
335
|
// source: args passed to cli, destination: args after cli parsed it
|
|
336
336
|
.action(async function callPrepare(options, commanderArgs = []) {
|
|
337
337
|
// the user app main differs if a runner vs preload
|
|
338
|
-
script = isCli ?
|
|
338
|
+
script = isCli ? program.args[0] : program.rawArgs[1];
|
|
339
339
|
options.script = script;
|
|
340
340
|
// need to slice off app main in runner mode
|
|
341
341
|
options['application.args'] = isCli
|
|
342
|
-
?
|
|
343
|
-
:
|
|
342
|
+
? program.args.slice(1)
|
|
343
|
+
: program.args;
|
|
344
344
|
|
|
345
345
|
try {
|
|
346
346
|
enabled = await contrastAgent.prepare(options, commanderArgs, isCli);
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -18,3 +18,4 @@ require('./sqlite3');
|
|
|
18
18
|
require('./postgres');
|
|
19
19
|
require('./dynamodb');
|
|
20
20
|
require('./dynamodbv3');
|
|
21
|
+
require('./rethinkdb');
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -28,25 +28,29 @@ ModuleHook.resolve(
|
|
|
28
28
|
patchType: PATCH_TYPES.ARCH_COMPONENT,
|
|
29
29
|
alwaysRun: true,
|
|
30
30
|
post(ctx) {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
if (servers.length === 0) {
|
|
34
|
-
logger.warn('Unable to find any MongoDB servers\n');
|
|
35
|
-
}
|
|
36
|
-
for (const server of servers) {
|
|
37
|
-
agentEmitter.emit('architectureComponent', {
|
|
38
|
-
vendor: 'MongoDB',
|
|
39
|
-
url: `mongodb://${server.host}`,
|
|
40
|
-
remoteHost: '',
|
|
41
|
-
remotePort: server.port
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
} catch (err) {
|
|
45
|
-
logger.warn(
|
|
46
|
-
'unable to report MongoDB architecture component\n%o',
|
|
47
|
-
err
|
|
48
|
-
);
|
|
31
|
+
if (!ctx.result || !ctx.result.then) {
|
|
32
|
+
return;
|
|
49
33
|
}
|
|
34
|
+
|
|
35
|
+
// We should report only when connection is successful
|
|
36
|
+
ctx.result.then(function(client) {
|
|
37
|
+
try {
|
|
38
|
+
const { servers = [] } = ctx.obj.s && ctx.obj.s.options;
|
|
39
|
+
for (const server of servers) {
|
|
40
|
+
agentEmitter.emit('architectureComponent', {
|
|
41
|
+
vendor: 'MongoDB',
|
|
42
|
+
url: `mongodb://${server.host}:${server.port}`,
|
|
43
|
+
remoteHost: '',
|
|
44
|
+
remotePort: server.port
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
} catch (err) {
|
|
48
|
+
logger.warn(
|
|
49
|
+
'unable to report MongoDB architecture component\n%o',
|
|
50
|
+
err
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
50
54
|
}
|
|
51
55
|
});
|
|
52
56
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -26,15 +26,33 @@ ModuleHook.resolve({ name: 'pg', file: 'lib/client.js' }, (pgClient) =>
|
|
|
26
26
|
alwaysRun: true,
|
|
27
27
|
post(wrapCtx) {
|
|
28
28
|
try {
|
|
29
|
-
const {
|
|
29
|
+
const {
|
|
30
|
+
host = process.env.PGHOST,
|
|
31
|
+
port = process.env.PGPORT
|
|
32
|
+
} = wrapCtx.result;
|
|
33
|
+
|
|
34
|
+
if (!host) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
let url = host;
|
|
39
|
+
|
|
40
|
+
// build protocol and port into url prior to parsing
|
|
41
|
+
if (url.indexOf('://') === -1) {
|
|
42
|
+
url = `postgresql://${url}`;
|
|
43
|
+
}
|
|
44
|
+
if (port !== undefined) {
|
|
45
|
+
url = `${url}:${port}`;
|
|
46
|
+
}
|
|
47
|
+
|
|
30
48
|
agentEmitter.emit('architectureComponent', {
|
|
31
49
|
vendor: 'PostgreSQL',
|
|
32
50
|
remotePort: port || 0,
|
|
33
|
-
url: new URL(
|
|
51
|
+
url: new URL(url).toString()
|
|
34
52
|
});
|
|
35
53
|
} catch (err) {
|
|
36
54
|
logger.warn(
|
|
37
|
-
'unable to report PostgreSQL architecture component\n',
|
|
55
|
+
'unable to report PostgreSQL architecture component\n%o',
|
|
38
56
|
err
|
|
39
57
|
);
|
|
40
58
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -13,6 +13,7 @@ Copyright: 2021 Contrast Security, Inc
|
|
|
13
13
|
way not consistent with the End User License Agreement.
|
|
14
14
|
*/
|
|
15
15
|
'use strict';
|
|
16
|
+
|
|
16
17
|
const patcher = require('../../hooks/patcher');
|
|
17
18
|
const ModuleHook = require('../../hooks/require');
|
|
18
19
|
const agentEmitter = require('../../agent-emitter');
|
|
@@ -26,17 +27,14 @@ ModuleHook.resolve({ name: 'sqlite3' }, (sqlite3) => {
|
|
|
26
27
|
alwaysRun: true,
|
|
27
28
|
post(wrapCtx) {
|
|
28
29
|
try {
|
|
29
|
-
// can either be a path to a file or `:memory:'.
|
|
30
|
-
const url = new URL(wrapCtx.args[0]).toString();
|
|
31
|
-
|
|
32
30
|
agentEmitter.emit('architectureComponent', {
|
|
33
31
|
vendor: 'SQLite3',
|
|
34
|
-
url,
|
|
32
|
+
url: wrapCtx.args[0],
|
|
35
33
|
remoteHost: '',
|
|
36
34
|
remotePort: 0
|
|
37
35
|
});
|
|
38
36
|
} catch (err) {
|
|
39
|
-
logger.warn('unable to report SQLite3 architecture component\n', err);
|
|
37
|
+
logger.warn('unable to report SQLite3 architecture component\n%o', err);
|
|
40
38
|
}
|
|
41
39
|
}
|
|
42
40
|
});
|
package/lib/core/common/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -33,7 +33,8 @@ Copyright: 2021 Contrast Security, Inc
|
|
|
33
33
|
* @module lib/core/config/options
|
|
34
34
|
*/
|
|
35
35
|
'use strict';
|
|
36
|
-
const
|
|
36
|
+
const { Command, Option } = require('commander');
|
|
37
|
+
const program = new Command();
|
|
37
38
|
const os = require('os');
|
|
38
39
|
const url = require('url');
|
|
39
40
|
const path = require('path');
|
|
@@ -486,6 +487,18 @@ const agent = [
|
|
|
486
487
|
desc:
|
|
487
488
|
'set limit for stack trace size (larger limits will improve accuracy but increase memory usage)'
|
|
488
489
|
},
|
|
490
|
+
{
|
|
491
|
+
name: 'agent.trust_custom_validators',
|
|
492
|
+
arg: '<trust-custom-validators>',
|
|
493
|
+
default: false,
|
|
494
|
+
desc: `trust incoming strings when they pass custom validators (Mongoose, Joi)`
|
|
495
|
+
},
|
|
496
|
+
{
|
|
497
|
+
name: 'agent.traverse_and_track',
|
|
498
|
+
arg: '<traverse-and-track>',
|
|
499
|
+
default: false,
|
|
500
|
+
desc: 'source membrane alternative'
|
|
501
|
+
},
|
|
489
502
|
{
|
|
490
503
|
name: 'agent.polling.app_activity_ms',
|
|
491
504
|
arg: '<ms>',
|
|
@@ -967,6 +980,16 @@ if (process.env.CONTRAST_DEV) {
|
|
|
967
980
|
}
|
|
968
981
|
];
|
|
969
982
|
}
|
|
983
|
+
const sails = [
|
|
984
|
+
{
|
|
985
|
+
name: 'pathToSails',
|
|
986
|
+
arg: '<path>'
|
|
987
|
+
},
|
|
988
|
+
{
|
|
989
|
+
name: 'gdsrc',
|
|
990
|
+
arg: '<path>'
|
|
991
|
+
}
|
|
992
|
+
];
|
|
970
993
|
|
|
971
994
|
const options = [].concat(
|
|
972
995
|
misc,
|
|
@@ -1008,6 +1031,19 @@ options.forEach((option) => {
|
|
|
1008
1031
|
program.option(name, option.desc);
|
|
1009
1032
|
});
|
|
1010
1033
|
|
|
1034
|
+
// In NODE-2059 it was discovered that a module was appending config options that the
|
|
1035
|
+
// agent didn't recognize and was causing the application to not load properly.
|
|
1036
|
+
// The agent doesn't need to do anything with these options. It just needs to not
|
|
1037
|
+
// throw an error when it encounters them but we also don't need them displayed on
|
|
1038
|
+
// the agent's config option list. The newest version of Commander lets us do exactly this.
|
|
1039
|
+
// This is structured so that if anything like this is discovered again, they can be
|
|
1040
|
+
// added in easily.
|
|
1041
|
+
const hiddenOptions = [].concat(sails);
|
|
1042
|
+
|
|
1043
|
+
hiddenOptions.forEach((option) => {
|
|
1044
|
+
program.addOption(new Option(`--${option.name} ${option.arg}`).hideHelp());
|
|
1045
|
+
});
|
|
1046
|
+
|
|
1011
1047
|
function getDefault(optionName) {
|
|
1012
1048
|
let option;
|
|
1013
1049
|
options.forEach((entry) => {
|
package/lib/core/config/util.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -31,12 +31,9 @@ class Exclusion {
|
|
|
31
31
|
return this.assess && this.appliesToRule(id, this.assessmentRulesList);
|
|
32
32
|
}
|
|
33
33
|
|
|
34
|
+
// When an exclusion applies to all rules, its rules list is empty
|
|
34
35
|
appliesToRule(id, list) {
|
|
35
|
-
|
|
36
|
-
const appliesToAllRules = list.length === 0;
|
|
37
|
-
const appliesToRuleId = list.includes(id);
|
|
38
|
-
|
|
39
|
-
return appliesToAllRules || appliesToRuleId;
|
|
36
|
+
return list.length === 0 || list.includes(id);
|
|
40
37
|
}
|
|
41
38
|
|
|
42
39
|
appliesToAllAssessRules() {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
Copyright:
|
|
2
|
+
Copyright: 2022 Contrast Security, Inc
|
|
3
3
|
Contact: support@contrastsecurity.com
|
|
4
4
|
License: Commercial
|
|
5
5
|
|
|
@@ -120,6 +120,24 @@ class ExpressFramework {
|
|
|
120
120
|
}
|
|
121
121
|
}
|
|
122
122
|
});
|
|
123
|
+
|
|
124
|
+
patcher.patch(express.response, 'push', {
|
|
125
|
+
name: 'express.response.push',
|
|
126
|
+
patchType: PATCH_TYPES.PROTECT_SINK,
|
|
127
|
+
pre(data) {
|
|
128
|
+
agentEmitter.emit(
|
|
129
|
+
EVENTS.REQUEST_SEND,
|
|
130
|
+
data.args[0],
|
|
131
|
+
SINK_TYPES.RESPONSE_BODY
|
|
132
|
+
);
|
|
133
|
+
|
|
134
|
+
const body = data.args[0];
|
|
135
|
+
if (isString(body)) {
|
|
136
|
+
emitSendEvent(body.valueOf());
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
|
|
123
141
|
patcher.patch(express.response, 'end', {
|
|
124
142
|
name: 'express.response.end',
|
|
125
143
|
patchType: PATCH_TYPES.PROTECT_SINK,
|
|
@@ -310,7 +328,9 @@ class ExpressFramework {
|
|
|
310
328
|
}, 'textParser');
|
|
311
329
|
|
|
312
330
|
this.useAfter(function ContrastBodyParsed(req, res, next) {
|
|
313
|
-
agentEmitter.emit(EVENTS.BODY_PARSED, req, res,
|
|
331
|
+
agentEmitter.emit(EVENTS.BODY_PARSED, req, res, {
|
|
332
|
+
type: INPUT_TYPES.BODY
|
|
333
|
+
});
|
|
314
334
|
next();
|
|
315
335
|
}, 'urlencodedParser');
|
|
316
336
|
|
|
@@ -356,7 +376,7 @@ class ExpressFramework {
|
|
|
356
376
|
const self = this;
|
|
357
377
|
|
|
358
378
|
// Hook the request handler so that we can access the top of each route.
|
|
359
|
-
// This is the only place the "params" hash is
|
|
379
|
+
// This is the only place the "params" hash is available
|
|
360
380
|
const Layer = ExpressFramework.getStack(app)[0].constructor;
|
|
361
381
|
const _handle = Layer.prototype.handle_request;
|
|
362
382
|
if (_handle) {
|
|
@@ -377,6 +397,9 @@ class ExpressFramework {
|
|
|
377
397
|
req[LAYER_STACK].pop();
|
|
378
398
|
}
|
|
379
399
|
});
|
|
400
|
+
if (req.query) {
|
|
401
|
+
decorateRequest({ query: req.query });
|
|
402
|
+
}
|
|
380
403
|
const params = new Object(this.params);
|
|
381
404
|
if (Object.keys(params).length) {
|
|
382
405
|
agentEmitter.emit(
|
|
@@ -399,9 +422,12 @@ class ExpressFramework {
|
|
|
399
422
|
|
|
400
423
|
Whatever the core issue is, it doesn't appear to have any effects
|
|
401
424
|
elsewhere in any of our Express/Kraken framework support.
|
|
425
|
+
|
|
426
|
+
BODY_PARSED event is emitted to support Sails framework
|
|
402
427
|
*/
|
|
403
428
|
if (req.body) {
|
|
404
429
|
decorateRequest({ body: req.body });
|
|
430
|
+
agentEmitter.emit(EVENTS.BODY_PARSED, req, res, req.body);
|
|
405
431
|
}
|
|
406
432
|
}
|
|
407
433
|
});
|