@contrast/agent 4.3.1-0 → 4.5.1
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 +10 -10
- package/README.md +86 -57
- package/agent-loader.js +14 -0
- package/bin/VERSION +1 -0
- 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 +14 -0
- package/cli-rewriter.js +14 -0
- package/cli.js +14 -0
- package/esm.mjs +14 -0
- package/lib/agent-emitter.js +14 -0
- package/lib/agent.js +14 -0
- package/lib/app-info.js +14 -0
- package/lib/assess/deadzones/index.js +14 -0
- package/lib/assess/deadzones/rewrite.js +14 -0
- package/lib/assess/express/index.js +14 -0
- package/lib/assess/express/route-coverage.js +14 -0
- package/lib/assess/express/sinks/index.js +14 -0
- package/lib/assess/express/sinks/xss.js +14 -0
- package/lib/assess/express/sources.js +14 -0
- package/lib/assess/fastify/index.js +14 -0
- package/lib/assess/fastify/route-coverage.js +14 -0
- package/lib/assess/fastify/sinks/index.js +14 -0
- package/lib/assess/fastify/sinks/response-scanning.js +14 -0
- package/lib/assess/fastify/sinks/unvalidated-redirect.js +14 -0
- package/lib/assess/fastify/sinks/xss.js +14 -0
- package/lib/assess/fastify/sources.js +14 -0
- package/lib/assess/hapi/index.js +14 -0
- package/lib/assess/hapi/route-coverage.js +17 -3
- package/lib/assess/hapi/sinks/index.js +14 -0
- package/lib/assess/hapi/sinks/response-scanning.js +14 -0
- package/lib/assess/hapi/sinks/session.js +14 -0
- package/lib/assess/hapi/sinks/unvalidated-redirect.js +14 -0
- package/lib/assess/hapi/sinks/xss.js +14 -0
- package/lib/assess/hapi/sources.js +14 -0
- package/lib/assess/index.js +14 -0
- package/lib/assess/koa/index.js +14 -0
- package/lib/assess/koa/route-coverage.js +14 -0
- package/lib/assess/koa/sinks/index.js +14 -0
- package/lib/assess/koa/sinks/response-scanning.js +14 -0
- package/lib/assess/koa/sinks/unvalidated-redirect.js +14 -0
- package/lib/assess/koa/sinks/xss.js +14 -0
- package/lib/assess/koa/sources.js +14 -0
- package/lib/assess/loopback4/index.js +14 -0
- package/lib/assess/loopback4/route-coverage.js +14 -0
- package/lib/assess/loopback4/sinks/index.js +14 -0
- package/lib/assess/loopback4/sinks/response-scanning.js +14 -0
- package/lib/assess/loopback4/sinks/xss.js +14 -0
- package/lib/assess/loopback4/sources.js +14 -0
- package/lib/assess/membrane/debraner.js +14 -0
- package/lib/assess/membrane/deserialization-membrane.js +14 -0
- package/lib/assess/membrane/index.js +16 -8
- package/lib/assess/membrane/source-membrane.js +17 -4
- package/lib/assess/models/base-event.js +16 -2
- package/lib/assess/models/call-context.js +14 -3
- package/lib/assess/models/index.js +14 -0
- package/lib/assess/models/propagation-event.js +14 -0
- package/lib/assess/models/signature.js +14 -0
- package/lib/assess/models/sink-event.js +14 -0
- package/lib/assess/models/source-event.js +14 -0
- package/lib/assess/models/tag-range/index.js +20 -16
- package/lib/assess/models/tag-range/relationships.js +14 -0
- package/lib/assess/models/tag-range/util.js +14 -0
- package/lib/assess/policy/index.js +14 -0
- package/lib/assess/policy/init.js +14 -0
- package/lib/assess/policy/signatures.json +95 -0
- package/lib/assess/policy/util.js +23 -2
- package/lib/assess/propagators/JSON/parse.js +14 -0
- package/lib/assess/propagators/JSON/stringify.js +14 -0
- package/lib/assess/propagators/ajv/conditionals.js +14 -0
- package/lib/assess/propagators/ajv/evaluator-shim.js +14 -0
- package/lib/assess/propagators/ajv/index.js +14 -0
- package/lib/assess/propagators/ajv/json-schema-type-evaluators.js +14 -0
- package/lib/assess/propagators/ajv/object-walk.js +14 -0
- package/lib/assess/propagators/ajv/refs.js +14 -0
- package/lib/assess/propagators/ajv/schema-context.js +14 -0
- package/lib/assess/propagators/array-prototype-join.js +14 -0
- package/lib/assess/propagators/common.js +14 -0
- package/lib/assess/propagators/ejs-template-generate-source.js +14 -0
- package/lib/assess/propagators/handlebars-compile.js +14 -0
- package/lib/assess/propagators/handlebars-escape-expresssion.js +14 -0
- package/lib/assess/propagators/index.js +14 -0
- package/lib/assess/propagators/joi/boolean.js +14 -0
- package/lib/assess/propagators/joi/expression.js +14 -0
- package/lib/assess/propagators/joi/index.js +14 -0
- package/lib/assess/propagators/joi/number.js +14 -0
- package/lib/assess/propagators/joi/string-base.js +14 -0
- package/lib/assess/propagators/joi/string-schema.js +14 -0
- package/lib/assess/propagators/joi/values.js +14 -0
- package/lib/assess/propagators/manager.js +31 -3
- package/lib/assess/propagators/object.js +14 -0
- package/lib/assess/propagators/path/basename.js +14 -0
- package/lib/assess/propagators/path/common.js +47 -13
- package/lib/assess/propagators/path/dirname.js +14 -0
- package/lib/assess/propagators/path/extname.js +14 -0
- package/lib/assess/propagators/path/format.js +14 -0
- package/lib/assess/propagators/path/join.js +14 -0
- package/lib/assess/propagators/path/normalize.js +20 -1
- package/lib/assess/propagators/path/parse.js +14 -0
- package/lib/assess/propagators/path/relative.js +14 -0
- package/lib/assess/propagators/path/resolve.js +14 -0
- package/lib/assess/propagators/path/to-namespaced-path.js +14 -0
- package/lib/assess/propagators/pug-compile.js +14 -0
- package/lib/assess/propagators/querystring/escape.js +14 -0
- package/lib/assess/propagators/querystring/parse.js +14 -0
- package/lib/assess/propagators/querystring/stringify.js +14 -0
- package/lib/assess/propagators/querystring/unescape.js +14 -0
- package/lib/assess/propagators/querystring/utils.js +14 -0
- package/lib/assess/propagators/sequelize/sql-string-escape.js +14 -0
- package/lib/assess/propagators/sequelize/sql-string-format-named-parameters.js +14 -0
- package/lib/assess/propagators/sequelize/sql-string-format.js +14 -0
- package/lib/assess/propagators/sequelize/utils.js +14 -0
- package/lib/assess/propagators/string-prototype-replace.js +14 -0
- package/lib/assess/propagators/string-prototype-split.js +14 -0
- package/lib/assess/propagators/string-prototype-trim.js +14 -0
- package/lib/assess/propagators/string.js +14 -0
- package/lib/assess/propagators/templates.js +14 -0
- package/lib/assess/propagators/url/url-prototype-parse.js +14 -0
- package/lib/assess/propagators/url/url-url.js +14 -0
- package/lib/assess/propagators/url/utils.js +14 -0
- package/lib/assess/propagators/util/format.js +14 -0
- package/lib/assess/propagators/utils.js +14 -0
- package/lib/assess/propagators/v8/init-hooks.js +14 -0
- package/lib/assess/propagators/validator/init-hooks.js +14 -0
- package/lib/assess/propagators/validator/validator-methods.js +14 -0
- package/lib/assess/response-scanning/app-activity.js +14 -0
- package/lib/assess/response-scanning/autocomplete-missing.js +14 -2
- package/lib/assess/response-scanning/cache-controls-missing.js +14 -0
- package/lib/assess/response-scanning/clickjacking-control-missing.js +14 -0
- package/lib/assess/response-scanning/common.js +14 -0
- package/lib/assess/response-scanning/cookies/common.js +14 -0
- package/lib/assess/response-scanning/cookies/events.js +14 -0
- package/lib/assess/response-scanning/cookies/httponly.js +14 -0
- package/lib/assess/response-scanning/cookies/secure-flag-missing.js +14 -0
- package/lib/assess/response-scanning/headers/csp-header-insecure.js +14 -0
- package/lib/assess/response-scanning/headers/csp-header-missing.js +14 -0
- package/lib/assess/response-scanning/headers/csp-utils.js +14 -0
- package/lib/assess/response-scanning/headers/hsts-header-missing.js +14 -0
- package/lib/assess/response-scanning/headers/powered-by.js +14 -0
- package/lib/assess/response-scanning/headers/xcontenttype-header-missing.js +14 -0
- package/lib/assess/response-scanning/headers/xxssprotection-header-disabled.js +14 -0
- package/lib/assess/response-scanning/parameter-pollution.js +14 -2
- package/lib/assess/response-scanning/parseable-response-emitter.js +14 -0
- package/lib/assess/restify/index.js +14 -0
- package/lib/assess/restify/route-coverage.js +14 -0
- package/lib/assess/restify/session.js +14 -0
- package/lib/assess/restify/sinks/index.js +14 -0
- package/lib/assess/restify/sinks/response-scanning.js +14 -0
- package/lib/assess/restify/sinks/unvalidated-redirect.js +14 -0
- package/lib/assess/restify/sinks/xss.js +14 -0
- package/lib/assess/restify/sources.js +14 -0
- package/lib/assess/sinks/common.js +14 -0
- package/lib/assess/sinks/dynamo.js +14 -0
- package/lib/assess/sinks/hapi-16-xss.js +14 -0
- package/lib/assess/sinks/index.js +14 -0
- package/lib/assess/sinks/libxmljs-xxe.js +14 -0
- package/lib/assess/sinks/mongodb.js +25 -7
- package/lib/assess/sinks/ssrf-url.js +14 -0
- package/lib/assess/sources/formidable.js +14 -0
- package/lib/assess/sources/index.js +14 -0
- package/lib/assess/static/hardcoded.js +14 -0
- package/lib/assess/technologies/index.js +14 -0
- package/lib/assess/utils.js +14 -0
- package/lib/cli-rewriter/index.js +14 -0
- package/lib/constants.js +14 -0
- package/lib/contrast.js +18 -5
- package/lib/core/arch-components/dynamodb.js +14 -0
- package/lib/core/arch-components/index.js +14 -0
- package/lib/core/arch-components/mongodb.js +14 -0
- package/lib/core/arch-components/mysql.js +14 -0
- package/lib/core/arch-components/postgres.js +14 -0
- package/lib/core/arch-components/sqlite3.js +14 -0
- package/lib/core/async-storage/context.js +14 -0
- package/lib/core/async-storage/hooks/bluebird.js +34 -0
- package/lib/core/async-storage/hooks/mongodb-core.js +14 -0
- package/lib/core/async-storage/hooks/mysql.js +14 -0
- package/lib/core/async-storage/hooks/redis.js +14 -0
- package/lib/core/async-storage/hooks/utils.js +14 -0
- package/lib/core/async-storage/index.js +14 -0
- package/lib/core/async-storage/scopes/index.js +14 -0
- package/lib/core/common/formidable.js +14 -0
- package/lib/core/common/index.js +14 -0
- package/lib/core/config/options.js +14 -0
- package/lib/core/config/util.js +14 -0
- package/lib/core/exclusions/exclusion-factory.js +14 -0
- package/lib/core/exclusions/exclusion.js +14 -0
- package/lib/core/exclusions/input.js +14 -0
- package/lib/core/exclusions/url.js +14 -0
- package/lib/core/express/index.js +14 -0
- package/lib/core/express/utils.js +15 -1
- package/lib/core/fastify/index.js +14 -0
- package/lib/core/fastify/utils.js +14 -0
- package/lib/core/hapi/index.js +14 -0
- package/lib/core/hapi/utils.js +14 -0
- package/lib/core/index.js +14 -0
- package/lib/core/koa/index.js +14 -0
- package/lib/core/koa/utils.js +14 -0
- package/lib/core/logger/daily-rotate-file.js +14 -0
- package/lib/core/logger/dataflow-monitor.js +14 -0
- package/lib/core/logger/debug-logger.js +29 -17
- package/lib/core/logger/index.js +14 -0
- package/lib/core/logger/perf-logger.js +14 -0
- package/lib/core/logger/umbrella-logger.js +14 -0
- package/lib/core/loopback4/index.js +14 -0
- package/lib/core/metrics/index.js +14 -0
- package/lib/core/restify/index.js +14 -0
- package/lib/core/restify/utils.js +14 -0
- package/lib/core/rewrite/assignment-expression.js +14 -0
- package/lib/core/rewrite/binary-expression.js +14 -0
- package/lib/core/rewrite/call-expression.js +14 -0
- package/lib/core/rewrite/callees.js +14 -0
- package/lib/core/rewrite/catch-clause.js +14 -0
- package/lib/core/rewrite/function-wrap.js +14 -0
- package/lib/core/rewrite/index.js +14 -0
- package/lib/core/rewrite/injections.js +14 -0
- package/lib/core/rewrite/is-contrast-method.js +14 -0
- package/lib/core/rewrite/log.js +14 -0
- package/lib/core/rewrite/member-expression.js +14 -0
- package/lib/core/rewrite/object-property.js +14 -0
- package/lib/core/rewrite/prepend-globals.js +14 -0
- package/lib/core/rewrite/rewrite-log.js +14 -0
- package/lib/core/rewrite/switch-statement.js +14 -0
- package/lib/core/rewrite/template-literal.js +14 -0
- package/lib/core/stacktrace.js +15 -3
- package/lib/coverage.js +14 -0
- package/lib/feature-set.js +16 -1
- package/lib/generator-function.js +14 -0
- package/lib/hooks/array.js +14 -0
- package/lib/hooks/cluster.js +14 -0
- package/lib/hooks/dataflow-monitor.js +14 -0
- package/lib/hooks/encoding.js +15 -1
- package/lib/hooks/express-fileupload.js +14 -0
- package/lib/hooks/express-session.js +14 -0
- package/lib/hooks/fn-to-string.js +14 -0
- package/lib/hooks/frameworks/base.js +14 -0
- package/lib/hooks/frameworks/common.js +14 -0
- package/lib/hooks/frameworks/hapi16.js +14 -0
- package/lib/hooks/frameworks/http.js +14 -0
- package/lib/hooks/frameworks/https.js +14 -0
- package/lib/hooks/frameworks/index.js +14 -0
- package/lib/hooks/hapi-16-reply.js +14 -0
- package/lib/hooks/hapi-16-session.js +14 -0
- package/lib/hooks/http.js +14 -0
- package/lib/hooks/module/extensions.js +14 -0
- package/lib/hooks/module/helpers.js +14 -0
- package/lib/hooks/module/index.js +14 -0
- package/lib/hooks/newrelic.js +14 -0
- package/lib/hooks/object-is.js +14 -0
- package/lib/hooks/object-to-primitive.js +14 -0
- package/lib/hooks/patcher.js +28 -24
- package/lib/hooks/require.js +14 -0
- package/lib/hooks/stealthy-require.js +14 -0
- package/lib/instrumentation.js +14 -0
- package/lib/libraries.js +21 -3
- package/lib/library-usage.js +14 -0
- package/lib/list-installed.js +14 -0
- package/lib/protect/analysis/aho-corasick.js +27 -30
- package/lib/protect/analysis/dfsa-analyzer.js +14 -0
- package/lib/protect/errors/handler.js +14 -0
- package/lib/protect/errors/security-exception.js +14 -0
- package/lib/protect/express/index.js +14 -0
- package/lib/protect/express/sinks.js +14 -0
- package/lib/protect/express/sources.js +14 -0
- package/lib/protect/fastify/index.js +14 -0
- package/lib/protect/fastify/sinks.js +14 -0
- package/lib/protect/fastify/sources.js +14 -0
- package/lib/protect/hapi/error-handler.js +14 -0
- package/lib/protect/hapi/index.js +14 -0
- package/lib/protect/hapi/sinks.js +14 -0
- package/lib/protect/hapi/sources.js +14 -0
- package/lib/protect/index.js +14 -0
- package/lib/protect/input-analysis.js +14 -0
- package/lib/protect/koa/index.js +14 -0
- package/lib/protect/koa/sinks.js +14 -0
- package/lib/protect/koa/sources.js +14 -0
- package/lib/protect/listeners.js +14 -0
- package/lib/protect/loopback4/index.js +14 -0
- package/lib/protect/loopback4/sources.js +14 -0
- package/lib/protect/models/application-context.js +14 -0
- package/lib/protect/models/sink-event.js +14 -0
- package/lib/protect/models/source-event.js +14 -0
- package/lib/protect/restify/index.js +14 -0
- package/lib/protect/restify/sinks.js +14 -0
- package/lib/protect/restify/sources.js +14 -0
- package/lib/protect/rules/assessment.js +14 -0
- package/lib/protect/rules/attack-patterns.js +14 -0
- package/lib/protect/rules/base-scanner/index.js +14 -0
- package/lib/protect/rules/base-scanner/java-script-scanner.js +14 -0
- package/lib/protect/rules/base-scanner/postgresqlscanner.js +14 -0
- package/lib/protect/rules/base-scanner/scan-state.js +14 -0
- package/lib/protect/rules/base-scanner/substring-finder.js +14 -0
- package/lib/protect/rules/base-scanner/token-sequence.js +14 -0
- package/lib/protect/rules/bot-blocker/bot-blocker-rule.js +14 -0
- package/lib/protect/rules/bot-blocker/index.js +14 -0
- package/lib/protect/rules/cmd-injection/cmdinjection-rule.js +14 -0
- package/lib/protect/rules/cmd-injection-command-backdoors/backdoor-detector.js +17 -3
- package/lib/protect/rules/cmd-injection-command-backdoors/cmd-injection-command-backdoors-rule.js +14 -0
- package/lib/protect/rules/cmd-injection-semantic-chained-commands/chained-command-scanner.js +14 -0
- package/lib/protect/rules/cmd-injection-semantic-chained-commands/cmd-injection-semantic-chained-commands-rule.js +14 -0
- package/lib/protect/rules/cmd-injection-semantic-dangerous-paths/cmd-injection-semantic-dangerous-paths-rule.js +14 -0
- package/lib/protect/rules/cmd-injection-semantic-dangerous-paths/dangerous-paths-scanner.js +14 -0
- package/lib/protect/rules/common.js +14 -0
- package/lib/protect/rules/index.js +14 -0
- package/lib/protect/rules/ip-denylist/ip-denylist-rule.js +14 -0
- package/lib/protect/rules/method-tampering/evaluator.js +14 -0
- package/lib/protect/rules/method-tampering/method-tampering-rule.js +14 -0
- package/lib/protect/rules/nosqli/no-sql-injection-rule.js +14 -0
- package/lib/protect/rules/nosqli/nosql-scanner/index.js +14 -0
- package/lib/protect/rules/nosqli/nosql-scanner/mongodbscanner.js +14 -0
- package/lib/protect/rules/path-traversal/path-traversal-rule.js +14 -0
- package/lib/protect/rules/rule-factory.js +14 -0
- package/lib/protect/rules/signatures/cmd-injection/custom-searchers/chained-command-searcher.js +14 -0
- package/lib/protect/rules/signatures/cmd-injection/custom-searchers/index.js +14 -0
- package/lib/protect/rules/signatures/cmd-injection/index.js +14 -0
- package/lib/protect/rules/signatures/evaluator.js +14 -0
- package/lib/protect/rules/signatures/index.js +14 -0
- package/lib/protect/rules/signatures/nosql-injection/custom-searchers/index.js +14 -0
- package/lib/protect/rules/signatures/nosql-injection/custom-searchers/nosql-comment-searcher.js +14 -0
- package/lib/protect/rules/signatures/nosql-injection/custom-searchers/simple-or-searcher.js +14 -0
- package/lib/protect/rules/signatures/nosql-injection/index.js +14 -0
- package/lib/protect/rules/signatures/path-traversal/index.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/behavior-url-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/function-definition-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/immediate-function-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/index.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/link-and-src-target-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/location-set-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/map-access-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/native-function-execution-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/no-alnum-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/redefined-function-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/style-url-injection-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/custom-searchers/variable-assignment-searcher.js +14 -0
- package/lib/protect/rules/signatures/reflected-xss/helpers/function-call.js +15 -1
- package/lib/protect/rules/signatures/reflected-xss/index.js +14 -0
- package/lib/protect/rules/signatures/signature.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/if-else-drop-searcher.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/index.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/simple-or-searcher.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/sql-comment-searcher.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/time-function-searcher.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/custom-searchers/tsql-exec-searcher.js +14 -0
- package/lib/protect/rules/signatures/sql-injection/index.js +14 -0
- package/lib/protect/rules/signatures/ssjs-injection/index.js +14 -0
- package/lib/protect/rules/signatures/unsafe-file-upload/index.js +14 -0
- package/lib/protect/rules/signatures/untrusted-deserialization/index.js +14 -0
- package/lib/protect/rules/sqli/generic-complicated.js +14 -0
- package/lib/protect/rules/sqli/sql-injection-rule.js +14 -0
- package/lib/protect/rules/sqli/sql-scanner/index.js +14 -0
- package/lib/protect/rules/sqli/sql-scanner/mysql-scanner.js +14 -0
- package/lib/protect/rules/ssjs-injection/evaluator.js +14 -0
- package/lib/protect/rules/ssjs-injection/ssjsinjection-rule.js +14 -0
- package/lib/protect/rules/unsafe-file-upload/unsafe-file-upload-rule.js +14 -0
- package/lib/protect/rules/untrusted-deserialization/untrusted-deserialization-rule.js +14 -0
- package/lib/protect/rules/virtual-patch/index.js +14 -0
- package/lib/protect/rules/virtual-patch/utils.js +14 -0
- package/lib/protect/rules/virtual-patch/virtual-patch-rule.js +14 -0
- package/lib/protect/rules/xss/helpers/function-call.js +15 -1
- package/lib/protect/rules/xss/reflected-xss-rule.js +14 -0
- package/lib/protect/rules/xxe/xxerule.js +14 -0
- package/lib/protect/sample-aggregator.js +14 -0
- package/lib/protect/samples.js +14 -0
- package/lib/protect/service.js +14 -0
- package/lib/protect/sinks/child-process.js +14 -0
- package/lib/protect/sinks/eval.js +14 -0
- package/lib/protect/sinks/fs.js +14 -0
- package/lib/protect/sinks/function.js +14 -0
- package/lib/protect/sinks/index.js +14 -0
- package/lib/protect/sinks/libxmljs.js +14 -0
- package/lib/protect/sinks/mongodb.js +14 -0
- package/lib/protect/sinks/mysql.js +14 -0
- package/lib/protect/sinks/node-serialize.js +14 -0
- package/lib/protect/sinks/postgres.js +14 -0
- package/lib/protect/sinks/sequelize.js +14 -0
- package/lib/protect/sinks/sqlite3.js +14 -0
- package/lib/protect/sinks/vm.js +14 -0
- package/lib/protect/sources/busboy.js +14 -0
- package/lib/protect/sources/formidable.js +14 -0
- package/lib/protect/sources/index.js +14 -0
- package/lib/protect/validators/authorization.js +14 -0
- package/lib/protect/validators/common.js +14 -0
- package/lib/protect/validators/connection.js +14 -0
- package/lib/protect/validators/content-length.js +14 -0
- package/lib/protect/validators/host.js +14 -0
- package/lib/protect/validators/if-none-match.js +14 -0
- package/lib/protect/validators/index.js +14 -0
- package/lib/protect/validators/origin.js +14 -0
- package/lib/reporter/app-activity-queue.js +14 -0
- package/lib/reporter/grpc-client.js +14 -0
- package/lib/reporter/messages/speedracer/activity.js +14 -0
- package/lib/reporter/messages/speedracer/application-create.js +14 -0
- package/lib/reporter/messages/speedracer/application-update.js +14 -0
- package/lib/reporter/messages/speedracer/base.js +14 -0
- package/lib/reporter/messages/speedracer/index.js +14 -0
- package/lib/reporter/messages/speedracer/observed-route.js +14 -0
- package/lib/reporter/messages/speedracer/poll.js +14 -0
- package/lib/reporter/messages/speedracer/request.js +14 -0
- package/lib/reporter/messages/speedracer/startup.js +14 -0
- package/lib/reporter/messaging-router.js +14 -0
- package/lib/reporter/models/app-activity/app-activity.js +14 -0
- package/lib/reporter/models/app-activity/attacker-activity.js +14 -0
- package/lib/reporter/models/app-activity/defend.js +14 -0
- package/lib/reporter/models/app-activity/inventory.js +14 -0
- package/lib/reporter/models/app-activity/protection-rule-activity.js +14 -0
- package/lib/reporter/models/app-activity/rule-events.js +14 -0
- package/lib/reporter/models/app-activity/sample.js +14 -0
- package/lib/reporter/models/app-activity/source.js +14 -0
- package/lib/reporter/models/app-activity/user-input.js +14 -0
- package/lib/reporter/models/app-create.js +14 -0
- package/lib/reporter/models/app-update/index.js +16 -4
- package/lib/reporter/models/app-update/library-manifest.js +14 -0
- package/lib/reporter/models/app-update/library-usage.js +14 -0
- package/lib/reporter/models/app-update/library.js +14 -0
- package/lib/reporter/models/event-tag.js +14 -0
- package/lib/reporter/models/finding/event.js +14 -0
- package/lib/reporter/models/finding/finding.js +14 -0
- package/lib/reporter/models/frameworks/express-request.js +14 -0
- package/lib/reporter/models/frameworks/fastify-request.js +14 -0
- package/lib/reporter/models/frameworks/hapi-request.js +14 -0
- package/lib/reporter/models/frameworks/index.js +14 -0
- package/lib/reporter/models/frameworks/koa-request.js +14 -0
- package/lib/reporter/models/frameworks/restify-request.js +14 -0
- package/lib/reporter/models/observed-route.js +14 -0
- package/lib/reporter/models/request.js +14 -0
- package/lib/reporter/models/route-coverage.js +14 -0
- package/lib/reporter/models/startup.js +14 -0
- package/lib/reporter/models/trace-event-source.js +14 -0
- package/lib/reporter/models/utils/request-factory.js +14 -0
- package/lib/reporter/models/utils/user-input-factory.js +14 -0
- package/lib/reporter/models/utils/user-input-kit.js +14 -0
- package/lib/reporter/mq-client.js +14 -0
- package/lib/reporter/server-activity-queue.js +14 -0
- package/lib/reporter/socket-client.js +14 -0
- package/lib/reporter/speedracer/base-connection-state.js +14 -0
- package/lib/reporter/speedracer/constants.js +14 -0
- package/lib/reporter/speedracer/failure-connection-state.js +14 -0
- package/lib/reporter/speedracer/index.js +14 -0
- package/lib/reporter/speedracer/success-connection-state.js +14 -0
- package/lib/reporter/speedracer/unknown-connection-state.js +14 -0
- package/lib/reporter/translations/enums.js +14 -0
- package/lib/reporter/translations/helpers.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/activity.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/address.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/agent-startup.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/application-create.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/application-update.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/architecture-component.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/attack-result.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/bot-blocker-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/cmd-injection-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/cmd-injection-semantic-analysis-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/finding.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/http-method-tampering-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/http-request.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/index.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/ip-denylist-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/library-usage-update.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/no-sql-injection-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/observed-route.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/pair.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/path-traversal-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/poll.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/rasp-rule-sample.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/raw-request.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/route-coverage.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/simple-pair.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/sql-injection-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/ssjs-injection-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/stack-trace-element.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/action.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/index.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/parent-object-id.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-event-object.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-event-signature.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-event-source.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-stack.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/trace-taint-range.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/trace-event/type.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/untrusted-deserialization-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/user-input.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/virtual-patch-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/xss-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/dtm/xxe-details.js +14 -0
- package/lib/reporter/translations/to-protobuf/index.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/application-settings.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/assess-features.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/auth.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/bot-blocker.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/custom-rule-feature.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/defend-features.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/exclusions.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/index.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/input-analysis-result.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/inventory-features.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/ip-filter.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/log-enhancer.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/protection-rule.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/reaction.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/rule-definition.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/sampling.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/server-features.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/syslog.js +14 -0
- package/lib/reporter/translations/to-protobuf/settings/virtual-patch.js +14 -0
- package/lib/reporter/ts-reporter.js +14 -0
- package/lib/tracker.js +14 -0
- package/lib/util/base64.js +14 -0
- package/lib/util/bitset.js +14 -0
- package/lib/util/block-request.js +14 -0
- package/lib/util/callback-resolver.js +14 -0
- package/lib/util/clean-stack.js +15 -1
- package/lib/util/clean-string/brackets.js +17 -3
- package/lib/util/clean-string/clean-string-base.js +14 -0
- package/lib/util/clean-string/comments.js +14 -0
- package/lib/util/clean-string/concatenations.js +15 -1
- package/lib/util/clean-string/jsclean-string.js +14 -0
- package/lib/util/clean-string/placeholders.js +14 -0
- package/lib/util/clean-string/util.js +15 -2
- package/lib/util/colors.js +14 -0
- package/lib/util/file-finder.js +14 -0
- package/lib/util/heap-dump.js +14 -0
- package/lib/util/html-util.js +14 -0
- package/lib/util/ip-analyzer.js +15 -1
- package/lib/util/is-agent-path.js +14 -0
- package/lib/util/is-contrast-error.js +14 -0
- package/lib/util/is-piped-to-dev.js +14 -0
- package/lib/util/is-string.js +14 -0
- package/lib/util/partial.js +14 -0
- package/lib/util/pkg-name.js +14 -0
- package/lib/util/request-util.js +14 -0
- package/lib/util/resolve-obj.js +14 -0
- package/lib/util/route-info.js +14 -0
- package/lib/util/source-map.js +14 -0
- package/lib/util/static-rules.js +14 -0
- package/lib/util/trace-util.js +14 -0
- package/lib/util/traverse.js +14 -0
- package/lib/util/user-input-evaluator.js +14 -0
- package/lib/util/xml-analyzer/external-entity-finder.js +15 -1
- package/node_modules/bindings/LICENSE.md +22 -0
- package/node_modules/bindings/README.md +98 -0
- package/node_modules/bindings/bindings.js +221 -0
- package/node_modules/bindings/package.json +32 -0
- package/node_modules/file-uri-to-path/.npmignore +1 -0
- package/node_modules/file-uri-to-path/.travis.yml +30 -0
- package/node_modules/file-uri-to-path/History.md +21 -0
- package/node_modules/file-uri-to-path/LICENSE +20 -0
- package/node_modules/file-uri-to-path/README.md +74 -0
- package/node_modules/file-uri-to-path/index.d.ts +2 -0
- package/node_modules/file-uri-to-path/index.js +66 -0
- package/node_modules/file-uri-to-path/package.json +36 -0
- package/node_modules/file-uri-to-path/test/test.js +24 -0
- package/node_modules/file-uri-to-path/test/tests.json +13 -0
- package/node_modules/nan/CHANGELOG.md +537 -0
- package/node_modules/nan/LICENSE.md +13 -0
- package/node_modules/nan/README.md +455 -0
- package/node_modules/nan/doc/asyncworker.md +146 -0
- package/node_modules/nan/doc/buffers.md +54 -0
- package/node_modules/nan/doc/callback.md +76 -0
- package/node_modules/nan/doc/converters.md +41 -0
- package/node_modules/nan/doc/errors.md +226 -0
- package/node_modules/nan/doc/json.md +62 -0
- package/node_modules/nan/doc/maybe_types.md +583 -0
- package/node_modules/nan/doc/methods.md +664 -0
- package/node_modules/nan/doc/new.md +147 -0
- package/node_modules/nan/doc/node_misc.md +123 -0
- package/node_modules/nan/doc/object_wrappers.md +263 -0
- package/node_modules/nan/doc/persistent.md +296 -0
- package/node_modules/nan/doc/scopes.md +73 -0
- package/node_modules/nan/doc/script.md +38 -0
- package/node_modules/nan/doc/string_bytes.md +62 -0
- package/node_modules/nan/doc/v8_internals.md +199 -0
- package/node_modules/nan/doc/v8_misc.md +85 -0
- package/node_modules/nan/include_dirs.js +1 -0
- package/node_modules/nan/nan.h +2898 -0
- package/node_modules/nan/nan_callbacks.h +88 -0
- package/node_modules/nan/nan_callbacks_12_inl.h +514 -0
- package/node_modules/nan/nan_callbacks_pre_12_inl.h +520 -0
- package/node_modules/nan/nan_converters.h +72 -0
- package/node_modules/nan/nan_converters_43_inl.h +68 -0
- package/node_modules/nan/nan_converters_pre_43_inl.h +42 -0
- package/node_modules/nan/nan_define_own_property_helper.h +29 -0
- package/node_modules/nan/nan_implementation_12_inl.h +430 -0
- package/node_modules/nan/nan_implementation_pre_12_inl.h +263 -0
- package/node_modules/nan/nan_json.h +166 -0
- package/node_modules/nan/nan_maybe_43_inl.h +356 -0
- package/node_modules/nan/nan_maybe_pre_43_inl.h +268 -0
- package/node_modules/nan/nan_new.h +340 -0
- package/node_modules/nan/nan_object_wrap.h +156 -0
- package/node_modules/nan/nan_persistent_12_inl.h +132 -0
- package/node_modules/nan/nan_persistent_pre_12_inl.h +242 -0
- package/node_modules/nan/nan_private.h +73 -0
- package/node_modules/nan/nan_string_bytes.h +305 -0
- package/node_modules/nan/nan_typedarray_contents.h +96 -0
- package/node_modules/nan/nan_weak.h +437 -0
- package/node_modules/nan/package.json +41 -0
- package/node_modules/nan/tools/1to2.js +412 -0
- package/node_modules/nan/tools/README.md +14 -0
- package/node_modules/nan/tools/package.json +19 -0
- package/node_modules/unix-dgram/LICENSE +13 -0
- package/node_modules/unix-dgram/README.md +107 -0
- package/node_modules/unix-dgram/binding.gyp +20 -0
- package/node_modules/unix-dgram/build/Makefile +324 -0
- package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram/src/unix_dgram.o.d +58 -0
- package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram.node.d +1 -0
- package/node_modules/unix-dgram/build/Release/.deps/Release/unix_dgram.node.d +1 -0
- 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 +6 -0
- package/node_modules/unix-dgram/build/config.gypi +213 -0
- package/node_modules/unix-dgram/build/unix_dgram.target.mk +159 -0
- package/node_modules/unix-dgram/lib/unix_dgram.js +168 -0
- package/node_modules/unix-dgram/package.json +36 -0
- package/node_modules/unix-dgram/src/unix_dgram.cc +404 -0
- package/node_modules/unix-dgram/src/win_dummy.cc +7 -0
- package/node_modules/unix-dgram/test/test-connect-callback.js +68 -0
- package/node_modules/unix-dgram/test/test-connect.js +53 -0
- package/node_modules/unix-dgram/test/test-dgram-unix.js +58 -0
- package/node_modules/unix-dgram/test/test-send-error.js +26 -0
- package/package.json +3 -2
- package/perf-logs.js +14 -0
|
@@ -0,0 +1,404 @@
|
|
|
1
|
+
// -D_GNU_SOURCE makes SOCK_NONBLOCK etc. available on linux
|
|
2
|
+
#undef _GNU_SOURCE
|
|
3
|
+
#define _GNU_SOURCE
|
|
4
|
+
|
|
5
|
+
#include <nan.h>
|
|
6
|
+
|
|
7
|
+
#include <errno.h>
|
|
8
|
+
#include <stddef.h>
|
|
9
|
+
#include <unistd.h>
|
|
10
|
+
#include <fcntl.h>
|
|
11
|
+
|
|
12
|
+
#include <sys/types.h>
|
|
13
|
+
#include <sys/stat.h>
|
|
14
|
+
|
|
15
|
+
#include <sys/socket.h>
|
|
16
|
+
#include <sys/un.h>
|
|
17
|
+
|
|
18
|
+
#include <map>
|
|
19
|
+
|
|
20
|
+
#define offset_of(type, member) \
|
|
21
|
+
((intptr_t) ((char *) &(((type *) 8)->member) - 8))
|
|
22
|
+
|
|
23
|
+
#define container_of(ptr, type, member) \
|
|
24
|
+
((type *) ((char *) (ptr) - offset_of(type, member)))
|
|
25
|
+
|
|
26
|
+
namespace {
|
|
27
|
+
|
|
28
|
+
void OnEvent(uv_poll_t* handle, int status, int events);
|
|
29
|
+
|
|
30
|
+
using v8::Context;
|
|
31
|
+
using v8::Function;
|
|
32
|
+
using v8::FunctionTemplate;
|
|
33
|
+
using v8::Integer;
|
|
34
|
+
using v8::Local;
|
|
35
|
+
using v8::Null;
|
|
36
|
+
using v8::Object;
|
|
37
|
+
using v8::Persistent;
|
|
38
|
+
using v8::String;
|
|
39
|
+
using v8::Value;
|
|
40
|
+
|
|
41
|
+
struct SocketContext {
|
|
42
|
+
Nan::Callback recv_cb_;
|
|
43
|
+
Nan::Callback writable_cb_;
|
|
44
|
+
uv_poll_t handle_;
|
|
45
|
+
int fd_;
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
typedef std::map<int, SocketContext*> watchers_t;
|
|
49
|
+
|
|
50
|
+
watchers_t watchers;
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
inline void SetNonBlock(int fd) {
|
|
54
|
+
int flags;
|
|
55
|
+
int r;
|
|
56
|
+
|
|
57
|
+
flags = fcntl(fd, F_GETFL);
|
|
58
|
+
assert(flags != -1);
|
|
59
|
+
|
|
60
|
+
r = fcntl(fd, F_SETFL, flags | O_NONBLOCK);
|
|
61
|
+
assert(r != -1);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
|
|
65
|
+
inline void SetCloExec(int fd) {
|
|
66
|
+
int flags;
|
|
67
|
+
int r;
|
|
68
|
+
|
|
69
|
+
flags = fcntl(fd, F_GETFD);
|
|
70
|
+
assert(flags != -1);
|
|
71
|
+
|
|
72
|
+
r = fcntl(fd, F_SETFD, flags | FD_CLOEXEC);
|
|
73
|
+
assert(r != -1);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
void OnRecv(SocketContext* sc) {
|
|
77
|
+
Nan::HandleScope scope;
|
|
78
|
+
Local<Value> argv[3];
|
|
79
|
+
msghdr msg;
|
|
80
|
+
iovec iov;
|
|
81
|
+
ssize_t err;
|
|
82
|
+
char scratch[65536];
|
|
83
|
+
|
|
84
|
+
/* Union to avoid breaking strict-aliasing rules */
|
|
85
|
+
union {
|
|
86
|
+
struct sockaddr_un s;
|
|
87
|
+
struct sockaddr_storage ss;
|
|
88
|
+
} u_addr;
|
|
89
|
+
|
|
90
|
+
argv[0] = argv[1] = argv[2] = Nan::Null();
|
|
91
|
+
|
|
92
|
+
iov.iov_base = scratch;
|
|
93
|
+
iov.iov_len = sizeof scratch;
|
|
94
|
+
|
|
95
|
+
u_addr.s.sun_path[0] = '\0';
|
|
96
|
+
|
|
97
|
+
memset(&msg, 0, sizeof msg);
|
|
98
|
+
msg.msg_iovlen = 1;
|
|
99
|
+
msg.msg_iov = &iov;
|
|
100
|
+
msg.msg_name = &u_addr.ss;
|
|
101
|
+
msg.msg_namelen = sizeof u_addr.ss;
|
|
102
|
+
|
|
103
|
+
do
|
|
104
|
+
err = recvmsg(sc->fd_, &msg, 0);
|
|
105
|
+
while (err == -1 && errno == EINTR);
|
|
106
|
+
|
|
107
|
+
if (err == -1) {
|
|
108
|
+
err = -errno;
|
|
109
|
+
} else {
|
|
110
|
+
argv[1] = Nan::CopyBuffer(scratch, err).ToLocalChecked();
|
|
111
|
+
if (u_addr.s.sun_path[0] != '\0') {
|
|
112
|
+
argv[2] = Nan::New<String>(u_addr.s.sun_path).ToLocalChecked();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
argv[0] = Nan::New<Integer>(static_cast<int32_t>(err));
|
|
117
|
+
|
|
118
|
+
Nan::Call(sc->recv_cb_, sizeof(argv) / sizeof(argv[0]), argv);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
void OnWritable(SocketContext* sc) {
|
|
122
|
+
Nan::HandleScope scope;
|
|
123
|
+
uv_poll_start(&sc->handle_, UV_READABLE, OnEvent);
|
|
124
|
+
Nan::Call(sc->writable_cb_, 0, NULL);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
void OnEvent(uv_poll_t* handle, int status, int events) {
|
|
128
|
+
assert(0 == status);
|
|
129
|
+
assert(0 == (events & ~(UV_READABLE | UV_WRITABLE)));
|
|
130
|
+
SocketContext* sc = container_of(handle, SocketContext, handle_);
|
|
131
|
+
if (events & UV_READABLE)
|
|
132
|
+
OnRecv(sc);
|
|
133
|
+
|
|
134
|
+
if (events & UV_WRITABLE)
|
|
135
|
+
OnWritable(sc);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
void StartWatcher(int fd, Local<Value> recv_cb, Local<Value> writable_cb) {
|
|
139
|
+
// start listening for incoming dgrams
|
|
140
|
+
SocketContext* sc = new SocketContext;
|
|
141
|
+
sc->recv_cb_.Reset(recv_cb.As<Function>());
|
|
142
|
+
sc->writable_cb_.Reset(writable_cb.As<Function>());
|
|
143
|
+
sc->fd_ = fd;
|
|
144
|
+
|
|
145
|
+
uv_poll_init(uv_default_loop(), &sc->handle_, fd);
|
|
146
|
+
uv_poll_start(&sc->handle_, UV_READABLE, OnEvent);
|
|
147
|
+
|
|
148
|
+
// so we can disarm the watcher when close(fd) is called
|
|
149
|
+
watchers.insert(watchers_t::value_type(fd, sc));
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
|
|
153
|
+
void FreeSocketContext(uv_handle_t* handle) {
|
|
154
|
+
SocketContext* sc = container_of(handle, SocketContext, handle_);
|
|
155
|
+
delete sc;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
void StopWatcher(int fd) {
|
|
160
|
+
watchers_t::iterator iter = watchers.find(fd);
|
|
161
|
+
assert(iter != watchers.end());
|
|
162
|
+
|
|
163
|
+
SocketContext* sc = iter->second;
|
|
164
|
+
sc->recv_cb_.Reset();
|
|
165
|
+
sc->writable_cb_.Reset();
|
|
166
|
+
watchers.erase(iter);
|
|
167
|
+
|
|
168
|
+
uv_poll_stop(&sc->handle_);
|
|
169
|
+
uv_close(reinterpret_cast<uv_handle_t*>(&sc->handle_), FreeSocketContext);
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
|
|
173
|
+
NAN_METHOD(Socket) {
|
|
174
|
+
Nan::HandleScope scope;
|
|
175
|
+
Local<Value> recv_cb;
|
|
176
|
+
Local<Value> writable_cb;
|
|
177
|
+
int protocol;
|
|
178
|
+
int domain;
|
|
179
|
+
int type;
|
|
180
|
+
int fd;
|
|
181
|
+
|
|
182
|
+
assert(info.Length() == 5);
|
|
183
|
+
|
|
184
|
+
domain = Nan::To<int32_t>(info[0]).FromJust();
|
|
185
|
+
type = Nan::To<int32_t>(info[1]).FromJust();
|
|
186
|
+
protocol = Nan::To<int32_t>(info[2]).FromJust();
|
|
187
|
+
recv_cb = info[3];
|
|
188
|
+
writable_cb = info[4];
|
|
189
|
+
|
|
190
|
+
#if defined(SOCK_NONBLOCK)
|
|
191
|
+
type |= SOCK_NONBLOCK;
|
|
192
|
+
#endif
|
|
193
|
+
#if defined(SOCK_CLOEXEC)
|
|
194
|
+
type |= SOCK_CLOEXEC;
|
|
195
|
+
#endif
|
|
196
|
+
|
|
197
|
+
fd = socket(domain, type, protocol);
|
|
198
|
+
if (fd == -1) {
|
|
199
|
+
fd = -errno;
|
|
200
|
+
goto out;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
#if !defined(SOCK_NONBLOCK)
|
|
204
|
+
SetNonBlock(fd);
|
|
205
|
+
#endif
|
|
206
|
+
#if !defined(SOCK_CLOEXEC)
|
|
207
|
+
SetCloExec(fd);
|
|
208
|
+
#endif
|
|
209
|
+
|
|
210
|
+
StartWatcher(fd, recv_cb, writable_cb);
|
|
211
|
+
|
|
212
|
+
out:
|
|
213
|
+
info.GetReturnValue().Set(fd);
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
|
|
217
|
+
NAN_METHOD(Bind) {
|
|
218
|
+
Nan::HandleScope scope;
|
|
219
|
+
sockaddr_un s;
|
|
220
|
+
int err;
|
|
221
|
+
int fd;
|
|
222
|
+
|
|
223
|
+
assert(info.Length() == 2);
|
|
224
|
+
|
|
225
|
+
fd = Nan::To<int32_t>(info[0]).FromJust();
|
|
226
|
+
Nan::Utf8String path(info[1]);
|
|
227
|
+
|
|
228
|
+
memset(&s, 0, sizeof(s));
|
|
229
|
+
strncpy(s.sun_path, *path, sizeof(s.sun_path) - 1);
|
|
230
|
+
s.sun_family = AF_UNIX;
|
|
231
|
+
|
|
232
|
+
err = 0;
|
|
233
|
+
if (bind(fd, reinterpret_cast<sockaddr*>(&s), sizeof(s)))
|
|
234
|
+
err = -errno;
|
|
235
|
+
|
|
236
|
+
info.GetReturnValue().Set(err);
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
NAN_METHOD(SendTo) {
|
|
240
|
+
Nan::HandleScope scope;
|
|
241
|
+
Local<Object> buf;
|
|
242
|
+
sockaddr_un s;
|
|
243
|
+
size_t offset;
|
|
244
|
+
size_t length;
|
|
245
|
+
msghdr msg;
|
|
246
|
+
iovec iov;
|
|
247
|
+
int err;
|
|
248
|
+
int fd;
|
|
249
|
+
int r;
|
|
250
|
+
|
|
251
|
+
assert(info.Length() == 5);
|
|
252
|
+
|
|
253
|
+
fd = Nan::To<int32_t>(info[0]).FromJust();
|
|
254
|
+
buf = Nan::To<Object>(info[1]).ToLocalChecked();
|
|
255
|
+
offset = Nan::To<uint32_t>(info[2]).FromJust();
|
|
256
|
+
length = Nan::To<uint32_t>(info[3]).FromJust();
|
|
257
|
+
Nan::Utf8String path(info[4]);
|
|
258
|
+
|
|
259
|
+
assert(node::Buffer::HasInstance(buf));
|
|
260
|
+
assert(offset + length <= node::Buffer::Length(buf));
|
|
261
|
+
|
|
262
|
+
iov.iov_base = node::Buffer::Data(buf) + offset;
|
|
263
|
+
iov.iov_len = length;
|
|
264
|
+
|
|
265
|
+
memset(&s, 0, sizeof(s));
|
|
266
|
+
strncpy(s.sun_path, *path, sizeof(s.sun_path) - 1);
|
|
267
|
+
s.sun_family = AF_UNIX;
|
|
268
|
+
|
|
269
|
+
memset(&msg, 0, sizeof msg);
|
|
270
|
+
msg.msg_iovlen = 1;
|
|
271
|
+
msg.msg_iov = &iov;
|
|
272
|
+
msg.msg_name = reinterpret_cast<void*>(&s);
|
|
273
|
+
msg.msg_namelen = sizeof(s);
|
|
274
|
+
|
|
275
|
+
do
|
|
276
|
+
r = sendmsg(fd, &msg, 0);
|
|
277
|
+
while (r == -1 && errno == EINTR);
|
|
278
|
+
|
|
279
|
+
err = 0;
|
|
280
|
+
if (r == -1)
|
|
281
|
+
err = -errno;
|
|
282
|
+
|
|
283
|
+
info.GetReturnValue().Set(err);
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
NAN_METHOD(Send) {
|
|
287
|
+
Nan::HandleScope scope;
|
|
288
|
+
Local<Object> buf;
|
|
289
|
+
msghdr msg;
|
|
290
|
+
iovec iov;
|
|
291
|
+
int err;
|
|
292
|
+
int fd;
|
|
293
|
+
int r;
|
|
294
|
+
|
|
295
|
+
assert(info.Length() == 2);
|
|
296
|
+
|
|
297
|
+
fd = Nan::To<int32_t>(info[0]).FromJust();
|
|
298
|
+
buf = Nan::To<Object>(info[1]).ToLocalChecked();
|
|
299
|
+
assert(node::Buffer::HasInstance(buf));
|
|
300
|
+
|
|
301
|
+
iov.iov_base = node::Buffer::Data(buf);
|
|
302
|
+
iov.iov_len = node::Buffer::Length(buf);
|
|
303
|
+
|
|
304
|
+
memset(&msg, 0, sizeof msg);
|
|
305
|
+
msg.msg_iovlen = 1;
|
|
306
|
+
msg.msg_iov = &iov;
|
|
307
|
+
|
|
308
|
+
do
|
|
309
|
+
r = sendmsg(fd, &msg, 0);
|
|
310
|
+
while (r == -1 && errno == EINTR);
|
|
311
|
+
|
|
312
|
+
err = 0;
|
|
313
|
+
if (r == -1) {
|
|
314
|
+
err = -errno;
|
|
315
|
+
if ((errno == EAGAIN) || (errno == EWOULDBLOCK) || (errno == ENOBUFS)) {
|
|
316
|
+
watchers_t::iterator iter = watchers.find(fd);
|
|
317
|
+
assert(iter != watchers.end());
|
|
318
|
+
SocketContext* sc = iter->second;
|
|
319
|
+
uv_poll_start(&sc->handle_, UV_READABLE | UV_WRITABLE, OnEvent);
|
|
320
|
+
err = 1;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
info.GetReturnValue().Set(err);
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
NAN_METHOD(Connect) {
|
|
328
|
+
Nan::HandleScope scope;
|
|
329
|
+
sockaddr_un s;
|
|
330
|
+
int err;
|
|
331
|
+
int fd;
|
|
332
|
+
|
|
333
|
+
assert(info.Length() == 2);
|
|
334
|
+
|
|
335
|
+
fd = Nan::To<int32_t>(info[0]).FromJust();
|
|
336
|
+
Nan::Utf8String path(info[1]);
|
|
337
|
+
|
|
338
|
+
memset(&s, 0, sizeof(s));
|
|
339
|
+
strncpy(s.sun_path, *path, sizeof(s.sun_path) - 1);
|
|
340
|
+
s.sun_family = AF_UNIX;
|
|
341
|
+
|
|
342
|
+
err = 0;
|
|
343
|
+
if (connect(fd, reinterpret_cast<sockaddr*>(&s), sizeof(s)))
|
|
344
|
+
err = -errno;
|
|
345
|
+
|
|
346
|
+
info.GetReturnValue().Set(err);
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
|
|
350
|
+
NAN_METHOD(Close) {
|
|
351
|
+
Nan::HandleScope scope;
|
|
352
|
+
int err;
|
|
353
|
+
int fd;
|
|
354
|
+
|
|
355
|
+
assert(info.Length() == 1);
|
|
356
|
+
fd = Nan::To<int32_t>(info[0]).FromJust();
|
|
357
|
+
|
|
358
|
+
// Suppress EINTR and EINPROGRESS. EINTR means that the close() system call
|
|
359
|
+
// was interrupted by a signal. According to POSIX, the file descriptor is
|
|
360
|
+
// in an undefined state afterwards. It's not safe to try closing it again
|
|
361
|
+
// because it may have been closed, despite the signal. If we call close()
|
|
362
|
+
// again, then it would either:
|
|
363
|
+
//
|
|
364
|
+
// a) fail with EBADF, or
|
|
365
|
+
//
|
|
366
|
+
// b) close the wrong file descriptor if another thread or a signal handler
|
|
367
|
+
// has reused it in the mean time.
|
|
368
|
+
//
|
|
369
|
+
// Neither is what we want but scenario B is particularly bad. Not retrying
|
|
370
|
+
// the close() could, in theory, lead to file descriptor leaks but, in
|
|
371
|
+
// practice, operating systems do the right thing and close the file
|
|
372
|
+
// descriptor, regardless of whether the operation was interrupted by
|
|
373
|
+
// a signal.
|
|
374
|
+
//
|
|
375
|
+
// EINPROGRESS is benign. It means the close operation was interrupted but
|
|
376
|
+
// that the file descriptor has been closed or is being closed in the
|
|
377
|
+
// background. It's informative, not an error.
|
|
378
|
+
err = 0;
|
|
379
|
+
if (close(fd))
|
|
380
|
+
if (errno != EINTR && errno != EINPROGRESS)
|
|
381
|
+
err = -errno;
|
|
382
|
+
|
|
383
|
+
StopWatcher(fd);
|
|
384
|
+
info.GetReturnValue().Set(err);
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
|
|
388
|
+
void Initialize(Local<Object> target) {
|
|
389
|
+
// don't need to be read-only, only used by the JS shim
|
|
390
|
+
Nan::Set(target, Nan::New("AF_UNIX").ToLocalChecked(), Nan::New(AF_UNIX));
|
|
391
|
+
Nan::Set(target, Nan::New("SOCK_DGRAM").ToLocalChecked(),
|
|
392
|
+
Nan::New(SOCK_DGRAM));
|
|
393
|
+
Nan::SetMethod(target, "socket", Socket);
|
|
394
|
+
Nan::SetMethod(target, "bind", Bind);
|
|
395
|
+
Nan::SetMethod(target, "sendto", SendTo);
|
|
396
|
+
Nan::SetMethod(target, "send", Send);
|
|
397
|
+
Nan::SetMethod(target, "connect", Connect);
|
|
398
|
+
Nan::SetMethod(target, "close", Close);
|
|
399
|
+
}
|
|
400
|
+
|
|
401
|
+
|
|
402
|
+
} // anonymous namespace
|
|
403
|
+
|
|
404
|
+
NODE_MODULE(unix_dgram, Initialize)
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
var assert = require('assert');
|
|
2
|
+
var fs = require('fs');
|
|
3
|
+
|
|
4
|
+
var unix = require('../lib/unix_dgram');
|
|
5
|
+
var SOCKNAME = '/tmp/unix_dgram.sock';
|
|
6
|
+
|
|
7
|
+
var sentCount = 0;
|
|
8
|
+
var seenCount = 0;
|
|
9
|
+
var expected = 300;
|
|
10
|
+
|
|
11
|
+
process.on('exit', function() {
|
|
12
|
+
assert.equal(seenCount, sentCount);
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
try { fs.unlinkSync(SOCKNAME); } catch (e) { /* swallow */ }
|
|
16
|
+
|
|
17
|
+
var server = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
18
|
+
assert.equal('' + buf, 'PING' + seenCount);
|
|
19
|
+
if (++ seenCount === expected) {
|
|
20
|
+
server.close();
|
|
21
|
+
client.close();
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
server.bind(SOCKNAME);
|
|
25
|
+
|
|
26
|
+
var client = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
27
|
+
assert(0);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
client.on('error', function(err) {
|
|
31
|
+
console.error(err);
|
|
32
|
+
assert(0);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
client.on('connect', function() {
|
|
36
|
+
console.error('connected');
|
|
37
|
+
|
|
38
|
+
client.on('congestion', function() {
|
|
39
|
+
throw new Error('Should not emit congestion');
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
client.on('writable', function() {
|
|
43
|
+
// swallow
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
function send() {
|
|
47
|
+
var msg = Buffer.from('PING' + sentCount);
|
|
48
|
+
client.send(msg, function(err) {
|
|
49
|
+
if (!err) {
|
|
50
|
+
++ sentCount;
|
|
51
|
+
if (sentCount < expected) {
|
|
52
|
+
// process.nextTick() in today's Node.js master seems to stall
|
|
53
|
+
// after about ~194 process.nextTick() calls, that's why we
|
|
54
|
+
// use setImmediate() as a workaround.
|
|
55
|
+
setImmediate(send);
|
|
56
|
+
}
|
|
57
|
+
} else if (err.code < 0) {
|
|
58
|
+
throw new Error(err);
|
|
59
|
+
} else {
|
|
60
|
+
client.once('writable', send);
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
send();
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
client.connect(SOCKNAME);
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
var assert = require('assert');
|
|
2
|
+
var fs = require('fs');
|
|
3
|
+
|
|
4
|
+
var unix = require('../lib/unix_dgram');
|
|
5
|
+
var SOCKNAME = '/tmp/unix_dgram.sock';
|
|
6
|
+
|
|
7
|
+
var seenCount = 0;
|
|
8
|
+
var expected = 300; // arbitrary enough to generate congestion
|
|
9
|
+
|
|
10
|
+
process.on('exit', function() {
|
|
11
|
+
assert.equal(seenCount, expected);
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
try { fs.unlinkSync(SOCKNAME); } catch (e) { /* swallow */ }
|
|
15
|
+
|
|
16
|
+
var server = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
17
|
+
assert.equal('' + buf, 'PING' + seenCount);
|
|
18
|
+
if (++ seenCount === expected) {
|
|
19
|
+
server.close();
|
|
20
|
+
client.close();
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
server.bind(SOCKNAME);
|
|
24
|
+
|
|
25
|
+
var client = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
26
|
+
assert(0);
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
client.on('error', function(err) {
|
|
30
|
+
console.error(err);
|
|
31
|
+
assert(0);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
// This test case create a huge congestion which throw a warn (possible EventEmitter memory leak detected)
|
|
35
|
+
// In real process, it would be handled a smarter way (queued to re-send...)
|
|
36
|
+
client.setMaxListeners(300);
|
|
37
|
+
|
|
38
|
+
client.on('connect', function() {
|
|
39
|
+
console.error('connected');
|
|
40
|
+
client.on('congestion', function(buf) {
|
|
41
|
+
client.once('writable', function() {
|
|
42
|
+
client.send(buf);
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
var msg;
|
|
47
|
+
for(var i=0; i<expected; i++) {
|
|
48
|
+
msg = Buffer.from('PING' + i);
|
|
49
|
+
client.send(msg);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
client.connect(SOCKNAME);
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
var assert = require('assert');
|
|
2
|
+
var fs = require('fs');
|
|
3
|
+
|
|
4
|
+
var unix = require('../lib/unix_dgram');
|
|
5
|
+
var SOCKNAME = '/tmp/unix_dgram.sock';
|
|
6
|
+
var SOCKNAME_CLIENT = '/tmp/unix_dgram_client.sock';
|
|
7
|
+
|
|
8
|
+
var sentPing1 = false;
|
|
9
|
+
var sentPing2 = false;
|
|
10
|
+
var seenPing1 = false;
|
|
11
|
+
var seenPing2 = false;
|
|
12
|
+
|
|
13
|
+
process.on('exit', function() {
|
|
14
|
+
assert.equal(sentPing1, true);
|
|
15
|
+
assert.equal(sentPing2, true);
|
|
16
|
+
assert.equal(seenPing1, true);
|
|
17
|
+
assert.equal(seenPing2, true);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
try { fs.unlinkSync(SOCKNAME); } catch (e) { /* swallow */ }
|
|
21
|
+
try { fs.unlinkSync(SOCKNAME_CLIENT); } catch (e) { /* swallow */ }
|
|
22
|
+
|
|
23
|
+
var n = 0;
|
|
24
|
+
|
|
25
|
+
var server = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
26
|
+
console.error('server recv', '' + buf, arguments);
|
|
27
|
+
switch (++n) {
|
|
28
|
+
case 1:
|
|
29
|
+
assert.equal('' + buf, 'PING1');
|
|
30
|
+
assert.equal(rinfo.path, null);
|
|
31
|
+
seenPing1 = true;
|
|
32
|
+
client.bind(SOCKNAME_CLIENT);
|
|
33
|
+
client.send(Buffer.from('PING2'), 0, 5, SOCKNAME, function() {
|
|
34
|
+
console.error('client send', arguments);
|
|
35
|
+
sentPing2 = true;
|
|
36
|
+
});
|
|
37
|
+
break;
|
|
38
|
+
case 2:
|
|
39
|
+
assert.equal('' + buf, 'PING2');
|
|
40
|
+
assert.equal(rinfo.path, SOCKNAME_CLIENT);
|
|
41
|
+
seenPing2 = true;
|
|
42
|
+
server.close();
|
|
43
|
+
client.close();
|
|
44
|
+
break;
|
|
45
|
+
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
server.bind(SOCKNAME);
|
|
49
|
+
|
|
50
|
+
var client = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
51
|
+
console.error('client recv', arguments);
|
|
52
|
+
assert(0);
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
client.send(Buffer.from('PING1'), 0, 5, SOCKNAME, function() {
|
|
56
|
+
console.error('client send', arguments);
|
|
57
|
+
sentPing1 = true;
|
|
58
|
+
});
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
var assert = require('assert');
|
|
2
|
+
var fs = require('fs');
|
|
3
|
+
|
|
4
|
+
var unix = require('../lib/unix_dgram');
|
|
5
|
+
var SOCKNAME = '/tmp/unix_dgram.sock';
|
|
6
|
+
|
|
7
|
+
try { fs.unlinkSync(SOCKNAME); } catch (e) { /* swallow */ }
|
|
8
|
+
|
|
9
|
+
var client = unix.createSocket('unix_dgram', function(buf, rinfo) {
|
|
10
|
+
console.error('client recv', arguments);
|
|
11
|
+
assert(0);
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
client.once('error', function(err) {
|
|
15
|
+
assert.ok(err);
|
|
16
|
+
client.once('error', function(err) {
|
|
17
|
+
assert.ifError(err);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
client.send(Buffer.from('ERROR2'), 0, 6, SOCKNAME, function(err) {
|
|
21
|
+
assert.ok(err);
|
|
22
|
+
client.close();
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
client.send(Buffer.from('ERROR1'), 0, 6, SOCKNAME);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@contrast/agent",
|
|
3
|
-
"version": "4.
|
|
3
|
+
"version": "4.5.1",
|
|
4
4
|
"description": "Node.js security instrumentation by Contrast Security",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"security",
|
|
@@ -74,7 +74,7 @@
|
|
|
74
74
|
"@contrast/fn-inspect": "^2.4.2",
|
|
75
75
|
"@contrast/heapdump": "^1.1.0",
|
|
76
76
|
"@contrast/protobuf-api": "^3.2.0",
|
|
77
|
-
"@contrast/require-hook": "^2.0.
|
|
77
|
+
"@contrast/require-hook": "^2.0.5",
|
|
78
78
|
"@contrast/synchronous-source-maps": "^1.1.0",
|
|
79
79
|
"amqp-connection-manager": "^3.2.2",
|
|
80
80
|
"amqplib": "^0.8.0",
|
|
@@ -129,6 +129,7 @@
|
|
|
129
129
|
"config": "^3.3.3",
|
|
130
130
|
"csv-writer": "^1.2.0",
|
|
131
131
|
"deasync": "^0.1.20",
|
|
132
|
+
"ejs": "^3.1.6",
|
|
132
133
|
"escape-html": "^1.0.3",
|
|
133
134
|
"eslint": "^5.16.0",
|
|
134
135
|
"eslint-config-prettier": "^6.11.0",
|
package/perf-logs.js
CHANGED
|
@@ -1,4 +1,18 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
Copyright: 2021 Contrast Security, Inc
|
|
4
|
+
Contact: support@contrastsecurity.com
|
|
5
|
+
License: Commercial
|
|
6
|
+
|
|
7
|
+
NOTICE: This Software and the patented inventions embodied within may only be
|
|
8
|
+
used as part of Contrast Security’s commercial offerings. Even though it is
|
|
9
|
+
made available through public repositories, use of this Software is subject to
|
|
10
|
+
the applicable End User Licensing Agreement found at
|
|
11
|
+
https://www.contrastsecurity.com/enduser-terms-0317a or as otherwise agreed
|
|
12
|
+
between Contrast Security and the End User. The Software may not be reverse
|
|
13
|
+
engineered, modified, repackaged, sold, redistributed or otherwise used in a
|
|
14
|
+
way not consistent with the End User License Agreement.
|
|
15
|
+
*/
|
|
2
16
|
'use strict';
|
|
3
17
|
|
|
4
18
|
const { program } = require('commander');
|