dd-trace 5.84.0 → 5.85.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/ci/cypress/polyfills.js +1 -1
- package/ci/init.js +5 -5
- package/ext/exporters.js +1 -1
- package/ext/formats.js +1 -1
- package/ext/index.js +1 -1
- package/ext/kinds.js +1 -1
- package/ext/priority.js +1 -1
- package/ext/scopes.js +1 -1
- package/ext/tags.js +1 -1
- package/ext/types.js +1 -1
- package/index.d.ts +76 -23
- package/initialize.mjs +47 -31
- package/loader-hook.mjs +35 -22
- package/package.json +34 -31
- package/packages/datadog-code-origin/index.js +12 -10
- package/packages/datadog-core/src/utils/src/pick.js +2 -2
- package/packages/datadog-esbuild/index.js +75 -79
- package/packages/datadog-esbuild/src/log.js +32 -0
- package/packages/datadog-esbuild/src/utils.js +12 -8
- package/packages/datadog-instrumentations/src/aerospike.js +3 -3
- package/packages/datadog-instrumentations/src/ai.js +5 -5
- package/packages/datadog-instrumentations/src/amqp10.js +1 -1
- package/packages/datadog-instrumentations/src/amqplib.js +1 -1
- package/packages/datadog-instrumentations/src/anthropic.js +3 -3
- package/packages/datadog-instrumentations/src/apollo-server.js +4 -4
- package/packages/datadog-instrumentations/src/apollo.js +2 -2
- package/packages/datadog-instrumentations/src/avsc.js +1 -1
- package/packages/datadog-instrumentations/src/aws-sdk.js +4 -4
- package/packages/datadog-instrumentations/src/azure-event-hubs.js +2 -2
- package/packages/datadog-instrumentations/src/azure-functions.js +1 -1
- package/packages/datadog-instrumentations/src/azure-service-bus.js +1 -1
- package/packages/datadog-instrumentations/src/body-parser.js +2 -2
- package/packages/datadog-instrumentations/src/bunyan.js +1 -1
- package/packages/datadog-instrumentations/src/cassandra-driver.js +1 -1
- package/packages/datadog-instrumentations/src/child_process.js +7 -7
- package/packages/datadog-instrumentations/src/confluentinc-kafka-javascript.js +17 -16
- package/packages/datadog-instrumentations/src/cookie-parser.js +1 -1
- package/packages/datadog-instrumentations/src/couchbase.js +8 -6
- package/packages/datadog-instrumentations/src/crypto.js +1 -1
- package/packages/datadog-instrumentations/src/cucumber.js +19 -19
- package/packages/datadog-instrumentations/src/cypress.js +1 -1
- package/packages/datadog-instrumentations/src/dns.js +2 -2
- package/packages/datadog-instrumentations/src/elasticsearch.js +2 -2
- package/packages/datadog-instrumentations/src/express-mongo-sanitize.js +2 -2
- package/packages/datadog-instrumentations/src/express-session.js +1 -1
- package/packages/datadog-instrumentations/src/express.js +4 -4
- package/packages/datadog-instrumentations/src/fastify.js +1 -1
- package/packages/datadog-instrumentations/src/fetch.js +2 -2
- package/packages/datadog-instrumentations/src/fs.js +7 -7
- package/packages/datadog-instrumentations/src/generic-pool.js +2 -2
- package/packages/datadog-instrumentations/src/google-cloud-pubsub.js +8 -8
- package/packages/datadog-instrumentations/src/google-cloud-vertexai.js +4 -4
- package/packages/datadog-instrumentations/src/google-genai.js +1 -1
- package/packages/datadog-instrumentations/src/graphql.js +10 -10
- package/packages/datadog-instrumentations/src/grpc/client.js +9 -13
- package/packages/datadog-instrumentations/src/grpc/types.js +1 -1
- package/packages/datadog-instrumentations/src/helpers/bundler-register.js +1 -1
- package/packages/datadog-instrumentations/src/helpers/check-require-cache.js +1 -1
- package/packages/datadog-instrumentations/src/helpers/extract-package-and-module-path.js +2 -2
- package/packages/datadog-instrumentations/src/helpers/hooks.js +1 -1
- package/packages/datadog-instrumentations/src/helpers/register.js +7 -7
- package/packages/datadog-instrumentations/src/helpers/rewriter/instrumentations/index.js +1 -1
- package/packages/datadog-instrumentations/src/helpers/rewriter/instrumentations/langchain.js +55 -55
- package/packages/datadog-instrumentations/src/helpers/rewriter/transforms.js +1 -1
- package/packages/datadog-instrumentations/src/helpers/router-helper.js +7 -7
- package/packages/datadog-instrumentations/src/helpers/shared-utils.js +1 -1
- package/packages/datadog-instrumentations/src/hono.js +6 -6
- package/packages/datadog-instrumentations/src/http/client.js +1 -1
- package/packages/datadog-instrumentations/src/http/server.js +4 -4
- package/packages/datadog-instrumentations/src/http2/server.js +1 -1
- package/packages/datadog-instrumentations/src/ioredis.js +1 -1
- package/packages/datadog-instrumentations/src/iovalkey.js +1 -1
- package/packages/datadog-instrumentations/src/jest.js +162 -57
- package/packages/datadog-instrumentations/src/kafkajs.js +9 -8
- package/packages/datadog-instrumentations/src/knex.js +2 -2
- package/packages/datadog-instrumentations/src/koa.js +3 -1
- package/packages/datadog-instrumentations/src/ldapjs.js +1 -1
- package/packages/datadog-instrumentations/src/light-my-request.js +1 -1
- package/packages/datadog-instrumentations/src/limitd-client.js +1 -1
- package/packages/datadog-instrumentations/src/mariadb.js +1 -1
- package/packages/datadog-instrumentations/src/memcached.js +1 -1
- package/packages/datadog-instrumentations/src/mocha/common.js +3 -3
- package/packages/datadog-instrumentations/src/mocha/main.js +24 -24
- package/packages/datadog-instrumentations/src/mocha/utils.js +15 -11
- package/packages/datadog-instrumentations/src/mocha/worker.js +4 -4
- package/packages/datadog-instrumentations/src/moleculer/server.js +1 -1
- package/packages/datadog-instrumentations/src/mongodb-core.js +3 -3
- package/packages/datadog-instrumentations/src/mongodb.js +7 -7
- package/packages/datadog-instrumentations/src/mongoose.js +10 -10
- package/packages/datadog-instrumentations/src/mquery.js +6 -6
- package/packages/datadog-instrumentations/src/multer.js +1 -1
- package/packages/datadog-instrumentations/src/mysql.js +1 -1
- package/packages/datadog-instrumentations/src/net.js +6 -6
- package/packages/datadog-instrumentations/src/next.js +6 -6
- package/packages/datadog-instrumentations/src/nyc.js +34 -2
- package/packages/datadog-instrumentations/src/openai.js +24 -24
- package/packages/datadog-instrumentations/src/oracledb.js +2 -2
- package/packages/datadog-instrumentations/src/otel-sdk-trace.js +1 -1
- package/packages/datadog-instrumentations/src/passport-http.js +1 -1
- package/packages/datadog-instrumentations/src/passport-local.js +1 -1
- package/packages/datadog-instrumentations/src/passport-utils.js +1 -1
- package/packages/datadog-instrumentations/src/passport.js +1 -1
- package/packages/datadog-instrumentations/src/pg.js +3 -3
- package/packages/datadog-instrumentations/src/pino.js +2 -2
- package/packages/datadog-instrumentations/src/playwright.js +59 -59
- package/packages/datadog-instrumentations/src/prisma.js +24 -78
- package/packages/datadog-instrumentations/src/promise-js.js +1 -1
- package/packages/datadog-instrumentations/src/promise.js +1 -1
- package/packages/datadog-instrumentations/src/protobufjs.js +6 -6
- package/packages/datadog-instrumentations/src/q.js +2 -2
- package/packages/datadog-instrumentations/src/redis.js +2 -2
- package/packages/datadog-instrumentations/src/rhea.js +5 -5
- package/packages/datadog-instrumentations/src/router.js +8 -8
- package/packages/datadog-instrumentations/src/selenium.js +3 -3
- package/packages/datadog-instrumentations/src/sequelize.js +1 -1
- package/packages/datadog-instrumentations/src/sharedb.js +2 -2
- package/packages/datadog-instrumentations/src/tedious.js +1 -1
- package/packages/datadog-instrumentations/src/undici.js +2 -2
- package/packages/datadog-instrumentations/src/url.js +5 -5
- package/packages/datadog-instrumentations/src/vitest.js +56 -45
- package/packages/datadog-instrumentations/src/when.js +1 -1
- package/packages/datadog-instrumentations/src/winston.js +1 -1
- package/packages/datadog-instrumentations/src/ws.js +128 -41
- package/packages/datadog-plugin-aerospike/src/index.js +4 -4
- package/packages/datadog-plugin-ai/src/index.js +1 -1
- package/packages/datadog-plugin-ai/src/tracing.js +2 -2
- package/packages/datadog-plugin-ai/src/utils.js +1 -1
- package/packages/datadog-plugin-amqp10/src/consumer.js +2 -2
- package/packages/datadog-plugin-amqp10/src/index.js +1 -1
- package/packages/datadog-plugin-amqp10/src/producer.js +2 -2
- package/packages/datadog-plugin-amqplib/src/client.js +2 -2
- package/packages/datadog-plugin-amqplib/src/consumer.js +2 -2
- package/packages/datadog-plugin-amqplib/src/index.js +1 -1
- package/packages/datadog-plugin-amqplib/src/producer.js +2 -2
- package/packages/datadog-plugin-amqplib/src/util.js +1 -1
- package/packages/datadog-plugin-anthropic/src/index.js +1 -1
- package/packages/datadog-plugin-anthropic/src/tracing.js +2 -2
- package/packages/datadog-plugin-apollo/src/gateway/fetch.js +1 -1
- package/packages/datadog-plugin-apollo/src/gateway/index.js +1 -1
- package/packages/datadog-plugin-apollo/src/gateway/request.js +5 -5
- package/packages/datadog-plugin-apollo/src/index.js +1 -1
- package/packages/datadog-plugin-avsc/src/schema_iterator.js +3 -3
- package/packages/datadog-plugin-aws-sdk/src/base.js +11 -10
- package/packages/datadog-plugin-aws-sdk/src/services/bedrockruntime/index.js +1 -1
- package/packages/datadog-plugin-aws-sdk/src/services/bedrockruntime/tracing.js +1 -1
- package/packages/datadog-plugin-aws-sdk/src/services/bedrockruntime/utils.js +24 -24
- package/packages/datadog-plugin-aws-sdk/src/services/cloudwatchlogs.js +1 -1
- package/packages/datadog-plugin-aws-sdk/src/services/eventbridge.js +1 -1
- package/packages/datadog-plugin-aws-sdk/src/services/kinesis.js +6 -6
- package/packages/datadog-plugin-aws-sdk/src/services/lambda.js +3 -3
- package/packages/datadog-plugin-aws-sdk/src/services/redshift.js +1 -1
- package/packages/datadog-plugin-aws-sdk/src/services/s3.js +1 -1
- package/packages/datadog-plugin-aws-sdk/src/services/sns.js +5 -5
- package/packages/datadog-plugin-aws-sdk/src/services/sqs.js +12 -12
- package/packages/datadog-plugin-aws-sdk/src/util.js +1 -1
- package/packages/datadog-plugin-azure-event-hubs/src/index.js +1 -1
- package/packages/datadog-plugin-azure-event-hubs/src/producer.js +3 -3
- package/packages/datadog-plugin-azure-functions/src/index.js +11 -10
- package/packages/datadog-plugin-azure-service-bus/src/index.js +1 -1
- package/packages/datadog-plugin-azure-service-bus/src/producer.js +3 -3
- package/packages/datadog-plugin-bullmq/src/consumer.js +2 -2
- package/packages/datadog-plugin-bullmq/src/index.js +1 -1
- package/packages/datadog-plugin-bullmq/src/producer.js +11 -11
- package/packages/datadog-plugin-cassandra-driver/src/index.js +2 -2
- package/packages/datadog-plugin-child_process/src/index.js +2 -2
- package/packages/datadog-plugin-child_process/src/scrub-cmd-params.js +5 -5
- package/packages/datadog-plugin-confluentinc-kafka-javascript/src/index.js +1 -1
- package/packages/datadog-plugin-couchbase/src/index.js +3 -3
- package/packages/datadog-plugin-cucumber/src/index.js +14 -14
- package/packages/datadog-plugin-cypress/src/cypress-plugin.js +68 -55
- package/packages/datadog-plugin-cypress/src/plugin.js +1 -1
- package/packages/datadog-plugin-cypress/src/support.js +56 -9
- package/packages/datadog-plugin-dd-trace-api/src/index.js +1 -1
- package/packages/datadog-plugin-dns/src/index.js +1 -1
- package/packages/datadog-plugin-dns/src/lookup.js +2 -2
- package/packages/datadog-plugin-dns/src/lookup_service.js +3 -3
- package/packages/datadog-plugin-dns/src/resolve.js +2 -2
- package/packages/datadog-plugin-dns/src/reverse.js +2 -2
- package/packages/datadog-plugin-elasticsearch/src/index.js +2 -2
- package/packages/datadog-plugin-express/src/index.js +1 -1
- package/packages/datadog-plugin-fastify/src/index.js +1 -1
- package/packages/datadog-plugin-fs/src/index.js +2 -2
- package/packages/datadog-plugin-google-cloud-pubsub/src/client.js +2 -2
- package/packages/datadog-plugin-google-cloud-pubsub/src/consumer.js +8 -6
- package/packages/datadog-plugin-google-cloud-pubsub/src/index.js +1 -1
- package/packages/datadog-plugin-google-cloud-pubsub/src/producer.js +11 -10
- package/packages/datadog-plugin-google-cloud-pubsub/src/pubsub-push-subscription.js +6 -6
- package/packages/datadog-plugin-google-cloud-vertexai/src/index.js +1 -1
- package/packages/datadog-plugin-google-cloud-vertexai/src/tracing.js +2 -2
- package/packages/datadog-plugin-google-cloud-vertexai/src/utils.js +1 -1
- package/packages/datadog-plugin-google-genai/src/index.js +1 -1
- package/packages/datadog-plugin-google-genai/src/tracing.js +2 -2
- package/packages/datadog-plugin-graphql/src/execute.js +2 -2
- package/packages/datadog-plugin-graphql/src/index.js +2 -2
- package/packages/datadog-plugin-graphql/src/parse.js +1 -1
- package/packages/datadog-plugin-graphql/src/resolve.js +6 -6
- package/packages/datadog-plugin-graphql/src/utils.js +1 -1
- package/packages/datadog-plugin-graphql/src/validate.js +2 -2
- package/packages/datadog-plugin-grpc/src/client.js +3 -3
- package/packages/datadog-plugin-grpc/src/index.js +1 -1
- package/packages/datadog-plugin-grpc/src/server.js +3 -3
- package/packages/datadog-plugin-grpc/src/util.js +2 -2
- package/packages/datadog-plugin-http/src/client.js +10 -10
- package/packages/datadog-plugin-http/src/index.js +1 -1
- package/packages/datadog-plugin-http2/src/client.js +6 -6
- package/packages/datadog-plugin-http2/src/index.js +1 -1
- package/packages/datadog-plugin-http2/src/server.js +1 -1
- package/packages/datadog-plugin-jest/src/index.js +39 -22
- package/packages/datadog-plugin-jest/src/util.js +1 -1
- package/packages/datadog-plugin-kafkajs/src/consumer.js +5 -5
- package/packages/datadog-plugin-kafkajs/src/index.js +1 -1
- package/packages/datadog-plugin-kafkajs/src/producer.js +5 -5
- package/packages/datadog-plugin-kafkajs/src/utils.js +1 -1
- package/packages/datadog-plugin-langchain/src/tokens.js +2 -2
- package/packages/datadog-plugin-langchain/src/tracing.js +4 -4
- package/packages/datadog-plugin-memcached/src/index.js +2 -2
- package/packages/datadog-plugin-mocha/src/index.js +12 -12
- package/packages/datadog-plugin-moleculer/src/client.js +1 -1
- package/packages/datadog-plugin-moleculer/src/index.js +1 -1
- package/packages/datadog-plugin-moleculer/src/server.js +2 -2
- package/packages/datadog-plugin-moleculer/src/util.js +1 -1
- package/packages/datadog-plugin-mongodb-core/src/index.js +5 -5
- package/packages/datadog-plugin-mysql/src/index.js +2 -2
- package/packages/datadog-plugin-net/src/ipc.js +2 -2
- package/packages/datadog-plugin-net/src/tcp.js +4 -4
- package/packages/datadog-plugin-next/src/index.js +4 -4
- package/packages/datadog-plugin-nyc/src/index.js +60 -0
- package/packages/datadog-plugin-openai/src/index.js +1 -1
- package/packages/datadog-plugin-openai/src/services.js +3 -3
- package/packages/datadog-plugin-openai/src/stream-helpers.js +1 -1
- package/packages/datadog-plugin-openai/src/tracing.js +10 -10
- package/packages/datadog-plugin-oracledb/src/connection-parser.js +1 -1
- package/packages/datadog-plugin-oracledb/src/index.js +1 -1
- package/packages/datadog-plugin-pg/src/index.js +2 -2
- package/packages/datadog-plugin-playwright/src/index.js +19 -19
- package/packages/datadog-plugin-prisma/src/datadog-tracing-helper.js +95 -0
- package/packages/datadog-plugin-prisma/src/index.js +129 -10
- package/packages/datadog-plugin-protobufjs/src/schema_iterator.js +3 -3
- package/packages/datadog-plugin-redis/src/index.js +2 -2
- package/packages/datadog-plugin-restify/src/index.js +1 -1
- package/packages/datadog-plugin-rhea/src/consumer.js +2 -2
- package/packages/datadog-plugin-rhea/src/index.js +1 -1
- package/packages/datadog-plugin-rhea/src/producer.js +2 -2
- package/packages/datadog-plugin-router/src/index.js +3 -3
- package/packages/datadog-plugin-selenium/src/index.js +2 -2
- package/packages/datadog-plugin-sharedb/src/index.js +2 -2
- package/packages/datadog-plugin-tedious/src/index.js +2 -2
- package/packages/datadog-plugin-undici/src/index.js +5 -5
- package/packages/datadog-plugin-vitest/src/index.js +39 -18
- package/packages/datadog-plugin-ws/src/close.js +10 -11
- package/packages/datadog-plugin-ws/src/index.js +1 -1
- package/packages/datadog-plugin-ws/src/producer.js +8 -9
- package/packages/datadog-plugin-ws/src/receiver.js +8 -9
- package/packages/datadog-plugin-ws/src/server.js +17 -12
- package/packages/datadog-plugin-ws/src/util.js +48 -16
- package/packages/datadog-shimmer/src/shimmer.js +3 -3
- package/packages/dd-trace/index.js +2 -2
- package/packages/dd-trace/src/agent/info.js +2 -2
- package/packages/dd-trace/src/agent/url.js +1 -1
- package/packages/dd-trace/src/aiguard/client.js +3 -3
- package/packages/dd-trace/src/aiguard/sdk.js +6 -6
- package/packages/dd-trace/src/aiguard/tags.js +1 -1
- package/packages/dd-trace/src/analytics_sampler.js +1 -1
- package/packages/dd-trace/src/appsec/activation.js +1 -1
- package/packages/dd-trace/src/appsec/addresses.js +1 -1
- package/packages/dd-trace/src/appsec/api_security_sampler.js +1 -1
- package/packages/dd-trace/src/appsec/blocked_templates.js +1 -1
- package/packages/dd-trace/src/appsec/blocking.js +5 -5
- package/packages/dd-trace/src/appsec/channels.js +1 -1
- package/packages/dd-trace/src/appsec/graphql.js +13 -13
- package/packages/dd-trace/src/appsec/iast/analyzers/analyzers.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/cookie-analyzer.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/hardcoded-base-analyzer.js +6 -5
- package/packages/dd-trace/src/appsec/iast/analyzers/hardcoded-password-rules.js +2 -2
- package/packages/dd-trace/src/appsec/iast/analyzers/hardcoded-rule-type.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/hardcoded-secret-rules.js +148 -148
- package/packages/dd-trace/src/appsec/iast/analyzers/hardcoded-secrets-rules.js +148 -148
- package/packages/dd-trace/src/appsec/iast/analyzers/index.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/missing-header-analyzer.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/nosql-injection-mongodb-analyzer.js +7 -8
- package/packages/dd-trace/src/appsec/iast/analyzers/path-traversal-analyzer.js +2 -2
- package/packages/dd-trace/src/appsec/iast/analyzers/set-cookies-header-interceptor.js +2 -2
- package/packages/dd-trace/src/appsec/iast/analyzers/unvalidated-redirect-analyzer.js +2 -2
- package/packages/dd-trace/src/appsec/iast/analyzers/vulnerability-analyzer.js +3 -3
- package/packages/dd-trace/src/appsec/iast/analyzers/weak-cipher-analyzer.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/weak-hash-analyzer.js +2 -2
- package/packages/dd-trace/src/appsec/iast/context/context-plugin.js +3 -3
- package/packages/dd-trace/src/appsec/iast/iast-context.js +6 -3
- package/packages/dd-trace/src/appsec/iast/iast-plugin.js +17 -9
- package/packages/dd-trace/src/appsec/iast/index.js +2 -2
- package/packages/dd-trace/src/appsec/iast/overhead-controller.js +9 -9
- package/packages/dd-trace/src/appsec/iast/path-line.js +6 -6
- package/packages/dd-trace/src/appsec/iast/security-controls/index.js +11 -11
- package/packages/dd-trace/src/appsec/iast/security-controls/parser.js +49 -17
- package/packages/dd-trace/src/appsec/iast/tags.js +1 -1
- package/packages/dd-trace/src/appsec/iast/taint-tracking/constants.js +1 -1
- package/packages/dd-trace/src/appsec/iast/taint-tracking/csi-methods.js +2 -2
- package/packages/dd-trace/src/appsec/iast/taint-tracking/filter.js +1 -1
- package/packages/dd-trace/src/appsec/iast/taint-tracking/index.js +2 -2
- package/packages/dd-trace/src/appsec/iast/taint-tracking/operations-taint-object.js +3 -6
- package/packages/dd-trace/src/appsec/iast/taint-tracking/operations.js +2 -2
- package/packages/dd-trace/src/appsec/iast/taint-tracking/plugin.js +5 -5
- package/packages/dd-trace/src/appsec/iast/taint-tracking/rewriter-esm.mjs +4 -4
- package/packages/dd-trace/src/appsec/iast/taint-tracking/rewriter.js +5 -5
- package/packages/dd-trace/src/appsec/iast/taint-tracking/secure-marks.js +6 -4
- package/packages/dd-trace/src/appsec/iast/taint-tracking/source-types.js +1 -1
- package/packages/dd-trace/src/appsec/iast/taint-tracking/taint-tracking-impl.js +8 -8
- package/packages/dd-trace/src/appsec/iast/telemetry/iast-metric.js +4 -4
- package/packages/dd-trace/src/appsec/iast/telemetry/namespaces.js +2 -2
- package/packages/dd-trace/src/appsec/iast/telemetry/span-tags.js +6 -6
- package/packages/dd-trace/src/appsec/iast/telemetry/verbosity.js +2 -2
- package/packages/dd-trace/src/appsec/iast/utils.js +3 -3
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/constants.js +1 -1
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/evidence-redaction/range-utils.js +1 -1
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/evidence-redaction/sensitive-analyzers/hardcoded-password-analyzer.js +1 -1
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/evidence-redaction/sensitive-analyzers/sql-sensitive-analyzer.js +6 -6
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/evidence-redaction/sensitive-analyzers/tainted-range-based-sensitive-analyzer.js +1 -1
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/evidence-redaction/sensitive-handler.js +8 -8
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/evidence-redaction/sensitive-regex.js +1 -1
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/index.js +12 -11
- package/packages/dd-trace/src/appsec/iast/vulnerabilities-formatter/utils.js +5 -5
- package/packages/dd-trace/src/appsec/iast/vulnerabilities.js +1 -1
- package/packages/dd-trace/src/appsec/iast/vulnerability-reporter.js +4 -4
- package/packages/dd-trace/src/appsec/index.js +20 -22
- package/packages/dd-trace/src/appsec/rasp/command_injection.js +3 -3
- package/packages/dd-trace/src/appsec/rasp/fs-plugin.js +4 -4
- package/packages/dd-trace/src/appsec/rasp/index.js +2 -2
- package/packages/dd-trace/src/appsec/rasp/lfi.js +5 -5
- package/packages/dd-trace/src/appsec/rasp/sql_injection.js +2 -2
- package/packages/dd-trace/src/appsec/rasp/ssrf.js +1 -1
- package/packages/dd-trace/src/appsec/rasp/utils.js +4 -4
- package/packages/dd-trace/src/appsec/rc-products.js +1 -1
- package/packages/dd-trace/src/appsec/remote_config.js +3 -3
- package/packages/dd-trace/src/appsec/reporter.js +11 -11
- package/packages/dd-trace/src/appsec/rule_manager.js +1 -1
- package/packages/dd-trace/src/appsec/sdk/index.js +1 -1
- package/packages/dd-trace/src/appsec/sdk/set_user.js +2 -2
- package/packages/dd-trace/src/appsec/sdk/track_event.js +7 -7
- package/packages/dd-trace/src/appsec/sdk/user_blocking.js +1 -1
- package/packages/dd-trace/src/appsec/sdk/utils.js +1 -1
- package/packages/dd-trace/src/appsec/stack_trace.js +5 -5
- package/packages/dd-trace/src/appsec/telemetry/common.js +3 -3
- package/packages/dd-trace/src/appsec/telemetry/index.js +5 -5
- package/packages/dd-trace/src/appsec/telemetry/rasp.js +3 -3
- package/packages/dd-trace/src/appsec/telemetry/user.js +4 -4
- package/packages/dd-trace/src/appsec/telemetry/waf.js +3 -3
- package/packages/dd-trace/src/appsec/user_tracking.js +7 -7
- package/packages/dd-trace/src/appsec/waf/diagnostics.js +2 -2
- package/packages/dd-trace/src/appsec/waf/index.js +1 -1
- package/packages/dd-trace/src/appsec/waf/waf_context_wrapper.js +2 -2
- package/packages/dd-trace/src/azure_metadata.js +16 -9
- package/packages/dd-trace/src/baggage.js +1 -1
- package/packages/dd-trace/src/ci-visibility/coverage-report-discovery.js +82 -0
- package/packages/dd-trace/src/ci-visibility/dynamic-instrumentation/index.js +5 -5
- package/packages/dd-trace/src/ci-visibility/dynamic-instrumentation/worker/index.js +9 -9
- package/packages/dd-trace/src/ci-visibility/early-flake-detection/get-known-tests.js +8 -8
- package/packages/dd-trace/src/ci-visibility/exporters/agent-proxy/index.js +8 -7
- package/packages/dd-trace/src/ci-visibility/exporters/agentless/coverage-writer.js +4 -3
- package/packages/dd-trace/src/ci-visibility/exporters/agentless/di-logs-writer.js +5 -3
- package/packages/dd-trace/src/ci-visibility/exporters/agentless/index.js +2 -0
- package/packages/dd-trace/src/ci-visibility/exporters/agentless/writer.js +4 -3
- package/packages/dd-trace/src/ci-visibility/exporters/ci-visibility-exporter.js +37 -11
- package/packages/dd-trace/src/ci-visibility/exporters/git/git_metadata.js +22 -22
- package/packages/dd-trace/src/ci-visibility/exporters/test-worker/index.js +1 -1
- package/packages/dd-trace/src/ci-visibility/exporters/test-worker/writer.js +1 -1
- package/packages/dd-trace/src/ci-visibility/intelligent-test-runner/get-skippable-suites.js +8 -8
- package/packages/dd-trace/src/ci-visibility/log-submission/log-submission-plugin.js +3 -3
- package/packages/dd-trace/src/ci-visibility/requests/get-library-configuration.js +17 -12
- package/packages/dd-trace/src/ci-visibility/requests/upload-coverage-report.js +92 -0
- package/packages/dd-trace/src/ci-visibility/telemetry.js +2 -2
- package/packages/dd-trace/src/ci-visibility/test-api-manual/test-api-manual-plugin.js +1 -1
- package/packages/dd-trace/src/ci-visibility/test-management/get-test-management-tests.js +6 -6
- package/packages/dd-trace/src/ci-visibility/test-optimization-cache.js +61 -0
- package/packages/dd-trace/src/config/defaults.js +1 -1
- package/packages/dd-trace/src/config/git_properties.js +1 -1
- package/packages/dd-trace/src/config/helper.js +2 -2
- package/packages/dd-trace/src/config/index.js +612 -622
- package/packages/dd-trace/src/config/remote_config.js +1 -1
- package/packages/dd-trace/src/config/stable.js +2 -2
- package/packages/dd-trace/src/config/supported-configurations.json +1 -0
- package/packages/dd-trace/src/constants.js +3 -3
- package/packages/dd-trace/src/crashtracking/crashtracker.js +6 -6
- package/packages/dd-trace/src/datastreams/checkpointer.js +1 -1
- package/packages/dd-trace/src/datastreams/context.js +1 -1
- package/packages/dd-trace/src/datastreams/encoding.js +1 -1
- package/packages/dd-trace/src/datastreams/fnv.js +1 -1
- package/packages/dd-trace/src/datastreams/index.js +8 -8
- package/packages/dd-trace/src/datastreams/pathway.js +5 -3
- package/packages/dd-trace/src/datastreams/processor.js +14 -12
- package/packages/dd-trace/src/datastreams/schemas/schema_builder.js +27 -25
- package/packages/dd-trace/src/datastreams/schemas/schema_sampler.js +1 -1
- package/packages/dd-trace/src/datastreams/size.js +3 -3
- package/packages/dd-trace/src/datastreams/writer.js +3 -3
- package/packages/dd-trace/src/debugger/config.js +2 -1
- package/packages/dd-trace/src/debugger/constants.js +7 -0
- package/packages/dd-trace/src/debugger/devtools_client/breakpoints.js +14 -10
- package/packages/dd-trace/src/debugger/devtools_client/condition.js +2 -2
- package/packages/dd-trace/src/debugger/devtools_client/config.js +4 -5
- package/packages/dd-trace/src/debugger/devtools_client/defaults.js +1 -1
- package/packages/dd-trace/src/debugger/devtools_client/index.js +32 -25
- package/packages/dd-trace/src/debugger/devtools_client/inspector_promises_polyfill.js +1 -1
- package/packages/dd-trace/src/debugger/devtools_client/log.js +1 -1
- package/packages/dd-trace/src/debugger/devtools_client/send.js +54 -10
- package/packages/dd-trace/src/debugger/devtools_client/snapshot/collector.js +94 -37
- package/packages/dd-trace/src/debugger/devtools_client/snapshot/index.js +4 -4
- package/packages/dd-trace/src/debugger/devtools_client/snapshot/processor.js +7 -7
- package/packages/dd-trace/src/debugger/devtools_client/snapshot/redaction.js +2 -2
- package/packages/dd-trace/src/debugger/devtools_client/snapshot/symbols.js +1 -1
- package/packages/dd-trace/src/debugger/devtools_client/snapshot-pruner.js +1 -1
- package/packages/dd-trace/src/debugger/devtools_client/source-maps.js +10 -1
- package/packages/dd-trace/src/debugger/devtools_client/state.js +65 -8
- package/packages/dd-trace/src/debugger/devtools_client/status.js +9 -8
- package/packages/dd-trace/src/debugger/index.js +95 -37
- package/packages/dd-trace/src/dogstatsd.js +14 -9
- package/packages/dd-trace/src/encode/0.4.js +7 -6
- package/packages/dd-trace/src/encode/agentless-ci-visibility.js +8 -8
- package/packages/dd-trace/src/encode/coverage-ci-visibility.js +3 -3
- package/packages/dd-trace/src/encode/span-stats.js +2 -2
- package/packages/dd-trace/src/encode/tags-processors.js +1 -1
- package/packages/dd-trace/src/exporters/agent/index.js +1 -1
- package/packages/dd-trace/src/exporters/agent/writer.js +2 -2
- package/packages/dd-trace/src/exporters/common/agents.js +1 -1
- package/packages/dd-trace/src/exporters/common/buffering-exporter.js +2 -2
- package/packages/dd-trace/src/exporters/common/docker.js +11 -7
- package/packages/dd-trace/src/exporters/common/request.js +28 -8
- package/packages/dd-trace/src/exporters/common/url-to-http-options-polyfill.js +2 -2
- package/packages/dd-trace/src/exporters/common/writer.js +2 -0
- package/packages/dd-trace/src/exporters/span-stats/index.js +1 -1
- package/packages/dd-trace/src/exporters/span-stats/writer.js +3 -3
- package/packages/dd-trace/src/external-logger/src/index.js +4 -4
- package/packages/dd-trace/src/flare/index.js +3 -3
- package/packages/dd-trace/src/guardrails/telemetry.js +1 -1
- package/packages/dd-trace/src/heap_snapshots.js +1 -1
- package/packages/dd-trace/src/id.js +1 -1
- package/packages/dd-trace/src/iitm.js +1 -1
- package/packages/dd-trace/src/lambda/handler.js +1 -1
- package/packages/dd-trace/src/lambda/runtime/errors.js +1 -1
- package/packages/dd-trace/src/lambda/runtime/ritm.js +3 -3
- package/packages/dd-trace/src/llmobs/constants/tags.js +1 -1
- package/packages/dd-trace/src/llmobs/constants/text.js +1 -1
- package/packages/dd-trace/src/llmobs/constants/writers.js +1 -1
- package/packages/dd-trace/src/llmobs/index.js +2 -4
- package/packages/dd-trace/src/llmobs/noop.js +2 -2
- package/packages/dd-trace/src/llmobs/plugins/ai/index.js +8 -8
- package/packages/dd-trace/src/llmobs/plugins/ai/util.js +2 -2
- package/packages/dd-trace/src/llmobs/plugins/anthropic.js +5 -5
- package/packages/dd-trace/src/llmobs/plugins/base.js +1 -1
- package/packages/dd-trace/src/llmobs/plugins/bedrockruntime.js +8 -8
- package/packages/dd-trace/src/llmobs/plugins/genai/index.js +2 -2
- package/packages/dd-trace/src/llmobs/plugins/genai/util.js +15 -15
- package/packages/dd-trace/src/llmobs/plugins/langchain/handlers/chat_model.js +2 -2
- package/packages/dd-trace/src/llmobs/plugins/langchain/handlers/index.js +5 -5
- package/packages/dd-trace/src/llmobs/plugins/langchain/handlers/vectorstore.js +1 -1
- package/packages/dd-trace/src/llmobs/plugins/langchain/index.js +3 -3
- package/packages/dd-trace/src/llmobs/plugins/openai/constants.js +1 -1
- package/packages/dd-trace/src/llmobs/plugins/openai/index.js +17 -17
- package/packages/dd-trace/src/llmobs/plugins/openai/utils.js +3 -3
- package/packages/dd-trace/src/llmobs/plugins/vertexai.js +6 -6
- package/packages/dd-trace/src/llmobs/sdk.js +11 -11
- package/packages/dd-trace/src/llmobs/span_processor.js +6 -6
- package/packages/dd-trace/src/llmobs/tagger.js +4 -4
- package/packages/dd-trace/src/llmobs/telemetry.js +8 -8
- package/packages/dd-trace/src/llmobs/util.js +1 -1
- package/packages/dd-trace/src/llmobs/writers/base.js +9 -9
- package/packages/dd-trace/src/llmobs/writers/evaluations.js +5 -5
- package/packages/dd-trace/src/llmobs/writers/spans.js +3 -3
- package/packages/dd-trace/src/llmobs/writers/util.js +1 -1
- package/packages/dd-trace/src/log/channels.js +2 -2
- package/packages/dd-trace/src/log/index.js +2 -2
- package/packages/dd-trace/src/log/log.js +1 -1
- package/packages/dd-trace/src/log/writer.js +1 -1
- package/packages/dd-trace/src/noop/span.js +2 -2
- package/packages/dd-trace/src/openfeature/constants/constants.js +1 -1
- package/packages/dd-trace/src/openfeature/flagging_provider.js +4 -4
- package/packages/dd-trace/src/openfeature/index.js +2 -2
- package/packages/dd-trace/src/openfeature/noop.js +3 -3
- package/packages/dd-trace/src/openfeature/remote_config.js +1 -1
- package/packages/dd-trace/src/openfeature/writers/base.js +12 -12
- package/packages/dd-trace/src/openfeature/writers/exposures.js +10 -10
- package/packages/dd-trace/src/openfeature/writers/util.js +1 -1
- package/packages/dd-trace/src/opentelemetry/context_manager.js +48 -29
- package/packages/dd-trace/src/opentelemetry/logs/index.js +2 -2
- package/packages/dd-trace/src/opentelemetry/logs/logger_provider.js +2 -2
- package/packages/dd-trace/src/opentelemetry/logs/otlp_transformer.js +10 -10
- package/packages/dd-trace/src/opentelemetry/metrics/constants.js +3 -3
- package/packages/dd-trace/src/opentelemetry/metrics/index.js +2 -2
- package/packages/dd-trace/src/opentelemetry/metrics/instruments.js +3 -3
- package/packages/dd-trace/src/opentelemetry/metrics/meter.js +1 -1
- package/packages/dd-trace/src/opentelemetry/metrics/otlp_transformer.js +11 -11
- package/packages/dd-trace/src/opentelemetry/metrics/periodic_metric_reader.js +18 -18
- package/packages/dd-trace/src/opentelemetry/otlp/otlp_http_exporter_base.js +6 -6
- package/packages/dd-trace/src/opentelemetry/otlp/otlp_transformer_base.js +10 -7
- package/packages/dd-trace/src/opentelemetry/otlp/protobuf_loader.js +3 -3
- package/packages/dd-trace/src/opentelemetry/span.js +8 -8
- package/packages/dd-trace/src/opentelemetry/span_context.js +1 -1
- package/packages/dd-trace/src/opentelemetry/span_processor.js +1 -1
- package/packages/dd-trace/src/opentelemetry/tracer.js +4 -4
- package/packages/dd-trace/src/opentracing/propagation/log.js +2 -2
- package/packages/dd-trace/src/opentracing/propagation/text_map.js +14 -12
- package/packages/dd-trace/src/opentracing/propagation/text_map_dsm.js +2 -0
- package/packages/dd-trace/src/opentracing/span.js +20 -20
- package/packages/dd-trace/src/opentracing/span_context.js +3 -3
- package/packages/dd-trace/src/opentracing/tracer.js +3 -3
- package/packages/dd-trace/src/payload-tagging/config/index.js +1 -1
- package/packages/dd-trace/src/payload-tagging/index.js +1 -1
- package/packages/dd-trace/src/payload-tagging/tagging.js +2 -2
- package/packages/dd-trace/src/plugin_manager.js +6 -6
- package/packages/dd-trace/src/plugins/apollo.js +4 -4
- package/packages/dd-trace/src/plugins/ci_plugin.js +101 -36
- package/packages/dd-trace/src/plugins/database.js +1 -1
- package/packages/dd-trace/src/plugins/index.js +1 -1
- package/packages/dd-trace/src/plugins/log_plugin.js +2 -2
- package/packages/dd-trace/src/plugins/outbound.js +9 -8
- package/packages/dd-trace/src/plugins/plugin.js +17 -7
- package/packages/dd-trace/src/plugins/producer.js +6 -5
- package/packages/dd-trace/src/plugins/tracing.js +37 -8
- package/packages/dd-trace/src/plugins/util/ci.js +40 -40
- package/packages/dd-trace/src/plugins/util/env.js +2 -2
- package/packages/dd-trace/src/plugins/util/git-cache.js +2 -2
- package/packages/dd-trace/src/plugins/util/git.js +20 -18
- package/packages/dd-trace/src/plugins/util/inferred_proxy.js +6 -6
- package/packages/dd-trace/src/plugins/util/ip_extractor.js +3 -3
- package/packages/dd-trace/src/plugins/util/llm.js +1 -1
- package/packages/dd-trace/src/plugins/util/stacktrace.js +3 -3
- package/packages/dd-trace/src/plugins/util/tags.js +1 -1
- package/packages/dd-trace/src/plugins/util/test.js +46 -40
- package/packages/dd-trace/src/plugins/util/url.js +1 -1
- package/packages/dd-trace/src/plugins/util/urlfilter.js +1 -1
- package/packages/dd-trace/src/plugins/util/user-provided-git.js +2 -2
- package/packages/dd-trace/src/plugins/util/web.js +12 -12
- package/packages/dd-trace/src/priority_sampler.js +4 -4
- package/packages/dd-trace/src/process-tags/index.js +2 -2
- package/packages/dd-trace/src/profiler.js +1 -1
- package/packages/dd-trace/src/profiling/config.js +8 -8
- package/packages/dd-trace/src/profiling/constants.js +2 -2
- package/packages/dd-trace/src/profiling/exporter_cli.js +3 -3
- package/packages/dd-trace/src/profiling/exporters/agent.js +5 -5
- package/packages/dd-trace/src/profiling/exporters/event_serializer.js +8 -8
- package/packages/dd-trace/src/profiling/index.js +1 -1
- package/packages/dd-trace/src/profiling/libuv-size.js +1 -1
- package/packages/dd-trace/src/profiling/loggers/console.js +1 -1
- package/packages/dd-trace/src/profiling/profiler.js +21 -23
- package/packages/dd-trace/src/profiling/profilers/event_plugins/event.js +1 -1
- package/packages/dd-trace/src/profiling/profilers/event_plugins/fs.js +3 -3
- package/packages/dd-trace/src/profiling/profilers/events.js +27 -19
- package/packages/dd-trace/src/profiling/profilers/shared.js +2 -2
- package/packages/dd-trace/src/profiling/profilers/wall.js +4 -4
- package/packages/dd-trace/src/profiling/tagger.js +1 -1
- package/packages/dd-trace/src/profiling/webspan-utils.js +2 -2
- package/packages/dd-trace/src/proxy.js +13 -13
- package/packages/dd-trace/src/remote_config/apply_states.js +1 -1
- package/packages/dd-trace/src/remote_config/index.js +15 -15
- package/packages/dd-trace/src/remote_config/scheduler.js +1 -1
- package/packages/dd-trace/src/ritm.js +1 -1
- package/packages/dd-trace/src/runtime_metrics/index.js +2 -2
- package/packages/dd-trace/src/runtime_metrics/runtime_metrics.js +3 -3
- package/packages/dd-trace/src/serverless.js +1 -1
- package/packages/dd-trace/src/service-naming/extra-services.js +1 -1
- package/packages/dd-trace/src/service-naming/index.js +1 -1
- package/packages/dd-trace/src/service-naming/schemas/v0/graphql.js +3 -3
- package/packages/dd-trace/src/service-naming/schemas/v0/messaging.js +25 -25
- package/packages/dd-trace/src/service-naming/schemas/v0/serverless.js +3 -3
- package/packages/dd-trace/src/service-naming/schemas/v0/storage.js +18 -18
- package/packages/dd-trace/src/service-naming/schemas/v0/web.js +23 -23
- package/packages/dd-trace/src/service-naming/schemas/v0/websocket.js +9 -9
- package/packages/dd-trace/src/service-naming/schemas/v1/graphql.js +3 -3
- package/packages/dd-trace/src/service-naming/schemas/v1/messaging.js +21 -21
- package/packages/dd-trace/src/service-naming/schemas/v1/serverless.js +3 -3
- package/packages/dd-trace/src/service-naming/schemas/v1/storage.js +17 -17
- package/packages/dd-trace/src/service-naming/schemas/v1/web.js +23 -23
- package/packages/dd-trace/src/service-naming/schemas/v1/websocket.js +9 -9
- package/packages/dd-trace/src/span_format.js +4 -4
- package/packages/dd-trace/src/span_sampler.js +1 -1
- package/packages/dd-trace/src/span_stats.js +11 -11
- package/packages/dd-trace/src/spanleak.js +1 -1
- package/packages/dd-trace/src/standalone/index.js +1 -1
- package/packages/dd-trace/src/standalone/product.js +2 -2
- package/packages/dd-trace/src/standalone/tracesource.js +1 -1
- package/packages/dd-trace/src/startup-log.js +2 -2
- package/packages/dd-trace/src/tagger.js +3 -1
- package/packages/dd-trace/src/telemetry/dependencies.js +4 -4
- package/packages/dd-trace/src/telemetry/endpoints.js +4 -4
- package/packages/dd-trace/src/telemetry/index.js +1 -1
- package/packages/dd-trace/src/telemetry/logs/index.js +2 -2
- package/packages/dd-trace/src/telemetry/logs/log-collector.js +2 -2
- package/packages/dd-trace/src/telemetry/metrics.js +6 -6
- package/packages/dd-trace/src/telemetry/send-data.js +5 -5
- package/packages/dd-trace/src/telemetry/telemetry.js +10 -10
- package/packages/dd-trace/src/tracer.js +3 -2
- package/packages/dd-trace/src/util.js +1 -1
- package/scripts/preinstall.js +1 -1
- package/vendor/dist/@datadog/sketches-js/index.js +1 -1
- package/vendor/dist/@datadog/source-map/index.js +1 -1
- package/vendor/dist/@isaacs/ttlcache/index.js +1 -1
- package/vendor/dist/@opentelemetry/core/index.js +1 -1
- package/vendor/dist/@opentelemetry/resources/index.js +1 -1
- package/vendor/dist/astring/index.js +1 -1
- package/vendor/dist/crypto-randomuuid/index.js +1 -1
- package/vendor/dist/escape-string-regexp/index.js +1 -1
- package/vendor/dist/esquery/index.js +1 -1
- package/vendor/dist/ignore/index.js +1 -1
- package/vendor/dist/istanbul-lib-coverage/index.js +1 -1
- package/vendor/dist/jest-docblock/index.js +1 -1
- package/vendor/dist/jsonpath-plus/index.js +1 -1
- package/vendor/dist/limiter/index.js +1 -1
- package/vendor/dist/lodash.sortby/index.js +1 -1
- package/vendor/dist/lru-cache/index.js +1 -1
- package/vendor/dist/meriyah/index.js +1 -1
- package/vendor/dist/module-details-from-path/index.js +1 -1
- package/vendor/dist/mutexify/promise/index.js +1 -1
- package/vendor/dist/opentracing/index.js +1 -1
- package/vendor/dist/path-to-regexp/index.js +1 -1
- package/vendor/dist/pprof-format/index.js +1 -1
- package/vendor/dist/protobufjs/index.js +1 -1
- package/vendor/dist/protobufjs/minimal/index.js +1 -1
- package/vendor/dist/retry/index.js +1 -1
- package/vendor/dist/rfdc/index.js +1 -1
- package/vendor/dist/semifies/index.js +1 -1
- package/vendor/dist/shell-quote/index.js +1 -1
- package/vendor/dist/source-map/index.js +1 -1
- package/vendor/dist/source-map/lib/util/index.js +1 -1
- package/vendor/dist/tlhunter-sorted-set/index.js +1 -1
- package/vendor/dist/ttl-set/index.js +1 -1
- package/packages/datadog-plugin-prisma/src/client.js +0 -60
- package/packages/datadog-plugin-prisma/src/engine.js +0 -81
|
@@ -5,7 +5,7 @@ const web = require('../plugins/util/web')
|
|
|
5
5
|
const { extractIp } = require('../plugins/util/ip_extractor')
|
|
6
6
|
const { HTTP_CLIENT_IP } = require('../../../../ext/tags')
|
|
7
7
|
const { storage } = require('../../../datadog-core')
|
|
8
|
-
const {
|
|
8
|
+
const { IS_SERVERLESS } = require('../serverless')
|
|
9
9
|
const RuleManager = require('./rule_manager')
|
|
10
10
|
const appsecRemoteConfig = require('./remote_config')
|
|
11
11
|
const {
|
|
@@ -29,7 +29,7 @@ const {
|
|
|
29
29
|
responseSetHeader,
|
|
30
30
|
routerParam,
|
|
31
31
|
fastifyResponseChannel,
|
|
32
|
-
fastifyPathParams
|
|
32
|
+
fastifyPathParams,
|
|
33
33
|
} = require('./channels')
|
|
34
34
|
const waf = require('./waf')
|
|
35
35
|
const addresses = require('./addresses')
|
|
@@ -96,7 +96,7 @@ function enable (_config) {
|
|
|
96
96
|
isEnabled = true
|
|
97
97
|
config = _config
|
|
98
98
|
} catch (err) {
|
|
99
|
-
if (!
|
|
99
|
+
if (!IS_SERVERLESS) {
|
|
100
100
|
log.error('[ASM] Unable to start AppSec', err)
|
|
101
101
|
}
|
|
102
102
|
|
|
@@ -122,7 +122,6 @@ function onRequestBodyParsed ({ req, res, body, abortController }) {
|
|
|
122
122
|
storedBodies.set(req, body)
|
|
123
123
|
}
|
|
124
124
|
|
|
125
|
-
// eslint-disable-next-line eslint-rules/eslint-safe-typeof-object
|
|
126
125
|
if (typeof body === 'object') {
|
|
127
126
|
if (isEmptyObject(body)) return
|
|
128
127
|
analyzedBodies.add(body)
|
|
@@ -130,8 +129,8 @@ function onRequestBodyParsed ({ req, res, body, abortController }) {
|
|
|
130
129
|
|
|
131
130
|
const results = waf.run({
|
|
132
131
|
persistent: {
|
|
133
|
-
[addresses.HTTP_INCOMING_BODY]: body
|
|
134
|
-
}
|
|
132
|
+
[addresses.HTTP_INCOMING_BODY]: body,
|
|
133
|
+
},
|
|
135
134
|
}, req)
|
|
136
135
|
|
|
137
136
|
handleResults(results?.actions, req, res, rootSpan, abortController)
|
|
@@ -150,8 +149,8 @@ function onRequestCookieParser ({ req, res, abortController, cookies }) {
|
|
|
150
149
|
|
|
151
150
|
const results = waf.run({
|
|
152
151
|
persistent: {
|
|
153
|
-
[addresses.HTTP_INCOMING_COOKIES]: cookies
|
|
154
|
-
}
|
|
152
|
+
[addresses.HTTP_INCOMING_COOKIES]: cookies,
|
|
153
|
+
},
|
|
155
154
|
}, req)
|
|
156
155
|
|
|
157
156
|
handleResults(results?.actions, req, res, rootSpan, abortController)
|
|
@@ -166,7 +165,7 @@ function incomingHttpStartTranslator ({ req, res, abortController }) {
|
|
|
166
165
|
rootSpan.addTags({
|
|
167
166
|
'_dd.appsec.enabled': 1,
|
|
168
167
|
'_dd.runtime_family': 'nodejs',
|
|
169
|
-
[HTTP_CLIENT_IP]: clientIp
|
|
168
|
+
[HTTP_CLIENT_IP]: clientIp,
|
|
170
169
|
})
|
|
171
170
|
|
|
172
171
|
const requestHeaders = { ...req.headers }
|
|
@@ -175,7 +174,7 @@ function incomingHttpStartTranslator ({ req, res, abortController }) {
|
|
|
175
174
|
const persistent = {
|
|
176
175
|
[addresses.HTTP_INCOMING_URL]: req.url,
|
|
177
176
|
[addresses.HTTP_INCOMING_HEADERS]: requestHeaders,
|
|
178
|
-
[addresses.HTTP_INCOMING_METHOD]: req.method
|
|
177
|
+
[addresses.HTTP_INCOMING_METHOD]: req.method,
|
|
179
178
|
}
|
|
180
179
|
|
|
181
180
|
if (clientIp) {
|
|
@@ -192,7 +191,6 @@ function incomingHttpEndTranslator ({ req, res }) {
|
|
|
192
191
|
|
|
193
192
|
// we need to keep this to support other body parsers
|
|
194
193
|
if (req.body !== undefined && req.body !== null) {
|
|
195
|
-
// eslint-disable-next-line eslint-rules/eslint-safe-typeof-object
|
|
196
194
|
if (typeof req.body === 'object') {
|
|
197
195
|
if (!isEmptyObject(req.body) && !analyzedBodies.has(req.body)) {
|
|
198
196
|
persistent[addresses.HTTP_INCOMING_BODY] = req.body
|
|
@@ -283,8 +281,8 @@ function onExpressSession ({ req, res, sessionId, abortController }) {
|
|
|
283
281
|
|
|
284
282
|
const results = waf.run({
|
|
285
283
|
persistent: {
|
|
286
|
-
[addresses.USER_SESSION_ID]: sessionId
|
|
287
|
-
}
|
|
284
|
+
[addresses.USER_SESSION_ID]: sessionId,
|
|
285
|
+
},
|
|
288
286
|
}, req)
|
|
289
287
|
|
|
290
288
|
handleResults(results?.actions, req, res, rootSpan, abortController)
|
|
@@ -305,8 +303,8 @@ function onRequestQueryParsed ({ req, res, query, abortController }) {
|
|
|
305
303
|
|
|
306
304
|
const results = waf.run({
|
|
307
305
|
persistent: {
|
|
308
|
-
[addresses.HTTP_INCOMING_QUERY]: query
|
|
309
|
-
}
|
|
306
|
+
[addresses.HTTP_INCOMING_QUERY]: query,
|
|
307
|
+
},
|
|
310
308
|
}, req)
|
|
311
309
|
|
|
312
310
|
handleResults(results?.actions, req, res, rootSpan, abortController)
|
|
@@ -320,8 +318,8 @@ function onRequestProcessParams ({ req, res, abortController, params }) {
|
|
|
320
318
|
|
|
321
319
|
const results = waf.run({
|
|
322
320
|
persistent: {
|
|
323
|
-
[addresses.HTTP_INCOMING_PARAMS]: params
|
|
324
|
-
}
|
|
321
|
+
[addresses.HTTP_INCOMING_PARAMS]: params,
|
|
322
|
+
},
|
|
325
323
|
}, req)
|
|
326
324
|
|
|
327
325
|
handleResults(results?.actions, req, res, rootSpan, abortController)
|
|
@@ -334,8 +332,8 @@ function onResponseBody ({ req, res, body }) {
|
|
|
334
332
|
// we don't support blocking at this point, so no results needed
|
|
335
333
|
waf.run({
|
|
336
334
|
persistent: {
|
|
337
|
-
[addresses.HTTP_INCOMING_RESPONSE_BODY]: body
|
|
338
|
-
}
|
|
335
|
+
[addresses.HTTP_INCOMING_RESPONSE_BODY]: body,
|
|
336
|
+
},
|
|
339
337
|
}, req)
|
|
340
338
|
}
|
|
341
339
|
|
|
@@ -369,8 +367,8 @@ function onResponseWriteHead ({ req, res, abortController, statusCode, responseH
|
|
|
369
367
|
const results = waf.run({
|
|
370
368
|
persistent: {
|
|
371
369
|
[addresses.HTTP_INCOMING_RESPONSE_CODE]: String(statusCode),
|
|
372
|
-
[addresses.HTTP_INCOMING_RESPONSE_HEADERS]: responseHeaders
|
|
373
|
-
}
|
|
370
|
+
[addresses.HTTP_INCOMING_RESPONSE_HEADERS]: responseHeaders,
|
|
371
|
+
},
|
|
374
372
|
}, req)
|
|
375
373
|
|
|
376
374
|
responseAnalyzedSet.add(res)
|
|
@@ -445,5 +443,5 @@ module.exports = {
|
|
|
445
443
|
enable,
|
|
446
444
|
disable,
|
|
447
445
|
incomingHttpStartTranslator,
|
|
448
|
-
incomingHttpEndTranslator
|
|
446
|
+
incomingHttpEndTranslator,
|
|
449
447
|
}
|
|
@@ -12,14 +12,14 @@ function enable (_config) {
|
|
|
12
12
|
config = _config
|
|
13
13
|
|
|
14
14
|
childProcessExecutionTracingChannel.subscribe({
|
|
15
|
-
start: analyzeCommandInjection
|
|
15
|
+
start: analyzeCommandInjection,
|
|
16
16
|
})
|
|
17
17
|
}
|
|
18
18
|
|
|
19
19
|
function disable () {
|
|
20
20
|
if (childProcessExecutionTracingChannel.start.hasSubscribers) {
|
|
21
21
|
childProcessExecutionTracingChannel.unsubscribe({
|
|
22
|
-
start: analyzeCommandInjection
|
|
22
|
+
start: analyzeCommandInjection,
|
|
23
23
|
})
|
|
24
24
|
}
|
|
25
25
|
}
|
|
@@ -52,5 +52,5 @@ function analyzeCommandInjection ({ file, fileArgs, shell, abortController }) {
|
|
|
52
52
|
|
|
53
53
|
module.exports = {
|
|
54
54
|
enable,
|
|
55
|
-
disable
|
|
55
|
+
disable,
|
|
56
56
|
}
|
|
@@ -9,7 +9,7 @@ const IAST_MODULE = 'iast'
|
|
|
9
9
|
|
|
10
10
|
const enabledFor = {
|
|
11
11
|
[RASP_MODULE]: false,
|
|
12
|
-
[IAST_MODULE]: false
|
|
12
|
+
[IAST_MODULE]: false,
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
let fsPlugin
|
|
@@ -21,8 +21,8 @@ function getStoreToStart (fsProps, store = storage('legacy').getStore()) {
|
|
|
21
21
|
fs: {
|
|
22
22
|
...store.fs,
|
|
23
23
|
...fsProps,
|
|
24
|
-
parentStore: store
|
|
25
|
-
}
|
|
24
|
+
parentStore: store,
|
|
25
|
+
},
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
28
|
|
|
@@ -99,5 +99,5 @@ module.exports = {
|
|
|
99
99
|
AppsecFsPlugin,
|
|
100
100
|
|
|
101
101
|
RASP_MODULE,
|
|
102
|
-
IAST_MODULE
|
|
102
|
+
IAST_MODULE,
|
|
103
103
|
}
|
|
@@ -5,7 +5,7 @@ const {
|
|
|
5
5
|
setUncaughtExceptionCaptureCallbackStart,
|
|
6
6
|
expressMiddlewareError,
|
|
7
7
|
fastifyMiddlewareError,
|
|
8
|
-
routerMiddlewareError
|
|
8
|
+
routerMiddlewareError,
|
|
9
9
|
} = require('../channels')
|
|
10
10
|
const { block, registerBlockDelegation, isBlocked } = require('../blocking')
|
|
11
11
|
const { updateRaspRuleMatchMetricTags } = require('../telemetry')
|
|
@@ -136,5 +136,5 @@ module.exports = {
|
|
|
136
136
|
enable,
|
|
137
137
|
disable,
|
|
138
138
|
handleUncaughtExceptionMonitor, // exported only for testing purpose
|
|
139
|
-
blockOnDatadogRaspAbortError // exported only for testing purpose
|
|
139
|
+
blockOnDatadogRaspAbortError, // exported only for testing purpose
|
|
140
140
|
}
|
|
@@ -63,14 +63,14 @@ function analyzeLfi (ctx) {
|
|
|
63
63
|
const { req, fs, res } = store
|
|
64
64
|
if (!req || !fs) return
|
|
65
65
|
|
|
66
|
-
getPaths(ctx, fs)
|
|
66
|
+
for (const path of getPaths(ctx, fs)) {
|
|
67
67
|
analyzeLfiPath(path, req, res, ctx.abortController)
|
|
68
|
-
}
|
|
68
|
+
}
|
|
69
69
|
}
|
|
70
70
|
|
|
71
71
|
function analyzeLfiPath (path, req, res, abortController) {
|
|
72
72
|
const ephemeral = {
|
|
73
|
-
[FS_OPERATION_PATH]: path
|
|
73
|
+
[FS_OPERATION_PATH]: path,
|
|
74
74
|
}
|
|
75
75
|
|
|
76
76
|
const raspRule = { type: RULE_TYPES.LFI }
|
|
@@ -90,7 +90,7 @@ function getPaths (ctx, fs) {
|
|
|
90
90
|
ctx.path,
|
|
91
91
|
ctx.prefix,
|
|
92
92
|
ctx.src,
|
|
93
|
-
ctx.target
|
|
93
|
+
ctx.target,
|
|
94
94
|
]
|
|
95
95
|
|
|
96
96
|
return pathArguments
|
|
@@ -125,5 +125,5 @@ function shouldAnalyzeURLFile (path, fs) {
|
|
|
125
125
|
|
|
126
126
|
module.exports = {
|
|
127
127
|
enable,
|
|
128
|
-
disable
|
|
128
|
+
disable,
|
|
129
129
|
}
|
|
@@ -4,7 +4,7 @@ const {
|
|
|
4
4
|
pgQueryStart,
|
|
5
5
|
pgPoolQueryStart,
|
|
6
6
|
wafRunFinished,
|
|
7
|
-
mysql2OuterQueryStart
|
|
7
|
+
mysql2OuterQueryStart,
|
|
8
8
|
} = require('../channels')
|
|
9
9
|
const { storage } = require('../../../../datadog-core')
|
|
10
10
|
const addresses = require('../addresses')
|
|
@@ -69,7 +69,7 @@ function analyzeSqlInjection (query, dbSystem, abortController) {
|
|
|
69
69
|
|
|
70
70
|
const ephemeral = {
|
|
71
71
|
[addresses.DB_STATEMENT]: query,
|
|
72
|
-
[addresses.DB_SYSTEM]: dbSystem
|
|
72
|
+
[addresses.DB_SYSTEM]: dbSystem,
|
|
73
73
|
}
|
|
74
74
|
|
|
75
75
|
const raspRule = { type: RULE_TYPES.SQL_INJECTION }
|
|
@@ -16,12 +16,12 @@ const RULE_TYPES = {
|
|
|
16
16
|
COMMAND_INJECTION: 'command_injection',
|
|
17
17
|
LFI: 'lfi',
|
|
18
18
|
SQL_INJECTION: 'sql_injection',
|
|
19
|
-
SSRF: 'ssrf'
|
|
19
|
+
SSRF: 'ssrf',
|
|
20
20
|
}
|
|
21
21
|
|
|
22
22
|
const ALLOWED_ROOTSPAN_NAMES = new Set([
|
|
23
23
|
'express.request',
|
|
24
|
-
'fastify.request'
|
|
24
|
+
'fastify.request',
|
|
25
25
|
])
|
|
26
26
|
|
|
27
27
|
class DatadogRaspAbortError extends Error {
|
|
@@ -37,7 +37,7 @@ class DatadogRaspAbortError extends Error {
|
|
|
37
37
|
// hide these props to not pollute app logs
|
|
38
38
|
Object.defineProperties(this, {
|
|
39
39
|
req: { enumerable: false },
|
|
40
|
-
res: { enumerable: false }
|
|
40
|
+
res: { enumerable: false },
|
|
41
41
|
})
|
|
42
42
|
}
|
|
43
43
|
}
|
|
@@ -81,5 +81,5 @@ function handleResult (result, req, res, abortController, config, raspRule) {
|
|
|
81
81
|
module.exports = {
|
|
82
82
|
handleResult,
|
|
83
83
|
RULE_TYPES,
|
|
84
|
-
DatadogRaspAbortError
|
|
84
|
+
DatadogRaspAbortError,
|
|
85
85
|
}
|
|
@@ -80,8 +80,8 @@ function enableOrDisableAppsec (action, rcConfig, config, appsec) {
|
|
|
80
80
|
{
|
|
81
81
|
name: 'appsec.enabled',
|
|
82
82
|
origin: isRemoteConfigControlling ? 'remote_config' : config.getOrigin('appsec.enabled'),
|
|
83
|
-
value: shouldEnable
|
|
84
|
-
}
|
|
83
|
+
value: shouldEnable,
|
|
84
|
+
},
|
|
85
85
|
], config)
|
|
86
86
|
}
|
|
87
87
|
}
|
|
@@ -173,5 +173,5 @@ function disableWafUpdate () {
|
|
|
173
173
|
module.exports = {
|
|
174
174
|
enable,
|
|
175
175
|
enableWafUpdate,
|
|
176
|
-
disableWafUpdate
|
|
176
|
+
disableWafUpdate,
|
|
177
177
|
}
|
|
@@ -16,7 +16,7 @@ const {
|
|
|
16
16
|
updateWafRequestsMetricTags,
|
|
17
17
|
updateRaspRequestsMetricTags,
|
|
18
18
|
updateRaspRuleSkippedMetricTags,
|
|
19
|
-
getRequestMetrics
|
|
19
|
+
getRequestMetrics,
|
|
20
20
|
} = require('./telemetry')
|
|
21
21
|
const { DIAGNOSTIC_KEYS } = require('./waf/diagnostics')
|
|
22
22
|
|
|
@@ -33,7 +33,7 @@ const config = {
|
|
|
33
33
|
headersExtendedCollectionEnabled: false,
|
|
34
34
|
maxHeadersCollected: 0,
|
|
35
35
|
headersRedaction: false,
|
|
36
|
-
raspBodyCollection: false
|
|
36
|
+
raspBodyCollection: false,
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
const metricsQueue = new Map()
|
|
@@ -44,12 +44,12 @@ const extendedDataCollectionRequest = new WeakMap()
|
|
|
44
44
|
const contentHeaderList = [
|
|
45
45
|
'content-length',
|
|
46
46
|
'content-encoding',
|
|
47
|
-
'content-language'
|
|
47
|
+
'content-language',
|
|
48
48
|
]
|
|
49
49
|
|
|
50
50
|
const responseHeaderList = [
|
|
51
51
|
...contentHeaderList,
|
|
52
|
-
'content-type'
|
|
52
|
+
'content-type',
|
|
53
53
|
]
|
|
54
54
|
|
|
55
55
|
const identificationHeaders = [
|
|
@@ -60,7 +60,7 @@ const identificationHeaders = [
|
|
|
60
60
|
'x-appgw-trace-id',
|
|
61
61
|
'x-sigsci-requestid',
|
|
62
62
|
'x-sigsci-tags',
|
|
63
|
-
'akamai-user-risk'
|
|
63
|
+
'akamai-user-risk',
|
|
64
64
|
]
|
|
65
65
|
|
|
66
66
|
const eventHeadersList = [
|
|
@@ -71,14 +71,14 @@ const eventHeadersList = [
|
|
|
71
71
|
...contentHeaderList,
|
|
72
72
|
'host',
|
|
73
73
|
'accept-encoding',
|
|
74
|
-
'accept-language'
|
|
74
|
+
'accept-language',
|
|
75
75
|
]
|
|
76
76
|
|
|
77
77
|
const requestHeadersList = [
|
|
78
78
|
'content-type',
|
|
79
79
|
'user-agent',
|
|
80
80
|
'accept',
|
|
81
|
-
...identificationHeaders
|
|
81
|
+
...identificationHeaders,
|
|
82
82
|
]
|
|
83
83
|
|
|
84
84
|
const redactedHeadersList = [
|
|
@@ -89,7 +89,7 @@ const redactedHeadersList = [
|
|
|
89
89
|
'authentication-info',
|
|
90
90
|
'proxy-authentication-info',
|
|
91
91
|
'cookie',
|
|
92
|
-
'set-cookie'
|
|
92
|
+
'set-cookie',
|
|
93
93
|
]
|
|
94
94
|
|
|
95
95
|
// these request headers are always collected - it breaks the expected spec orders
|
|
@@ -251,7 +251,7 @@ function logWafDiagnosticMessage (product, rcConfigId, configKey, message, level
|
|
|
251
251
|
telemetryLogCh.publish({
|
|
252
252
|
message,
|
|
253
253
|
level,
|
|
254
|
-
tags
|
|
254
|
+
tags,
|
|
255
255
|
})
|
|
256
256
|
}
|
|
257
257
|
|
|
@@ -340,7 +340,7 @@ function reportAttack ({ events: attackData, actions }) {
|
|
|
340
340
|
const currentTags = rootSpan.context()._tags
|
|
341
341
|
|
|
342
342
|
const newTags = {
|
|
343
|
-
'appsec.event': 'true'
|
|
343
|
+
'appsec.event': 'true',
|
|
344
344
|
}
|
|
345
345
|
|
|
346
346
|
// TODO: maybe add this to format.js later (to take decision as late as possible)
|
|
@@ -578,5 +578,5 @@ module.exports = {
|
|
|
578
578
|
reportAttributes,
|
|
579
579
|
finishRequest,
|
|
580
580
|
mapHeaderAndTags,
|
|
581
|
-
truncateRequestBody
|
|
581
|
+
truncateRequestBody,
|
|
582
582
|
}
|
|
@@ -6,7 +6,7 @@ const {
|
|
|
6
6
|
trackUserLoginFailureEvent,
|
|
7
7
|
trackCustomEvent,
|
|
8
8
|
trackUserLoginSuccessV2,
|
|
9
|
-
trackUserLoginFailureV2
|
|
9
|
+
trackUserLoginFailureV2,
|
|
10
10
|
} = require('./track_event')
|
|
11
11
|
const { checkUserAndSetUser, blockRequest } = require('./user_blocking')
|
|
12
12
|
const { setUser } = require('./set_user')
|
|
@@ -28,7 +28,7 @@ function setUser (tracer, user) {
|
|
|
28
28
|
setUserTags(user, rootSpan)
|
|
29
29
|
|
|
30
30
|
const persistent = {
|
|
31
|
-
[addresses.USER_ID]: String(user.id)
|
|
31
|
+
[addresses.USER_ID]: String(user.id),
|
|
32
32
|
}
|
|
33
33
|
|
|
34
34
|
if (user.session_id && typeof user.session_id === 'string') {
|
|
@@ -40,5 +40,5 @@ function setUser (tracer, user) {
|
|
|
40
40
|
|
|
41
41
|
module.exports = {
|
|
42
42
|
setUserTags,
|
|
43
|
-
setUser
|
|
43
|
+
setUser,
|
|
44
44
|
}
|
|
@@ -51,7 +51,7 @@ function trackUserLoginFailureEvent (tracer, userId, exists, metadata) {
|
|
|
51
51
|
'usr.id': userId,
|
|
52
52
|
'usr.login': userId,
|
|
53
53
|
'usr.exists': exists ? 'true' : 'false',
|
|
54
|
-
...metadata
|
|
54
|
+
...metadata,
|
|
55
55
|
}
|
|
56
56
|
|
|
57
57
|
trackEvent('users.login.failure', fields, 'trackUserLoginFailureEvent', getRootSpan(tracer))
|
|
@@ -94,7 +94,7 @@ function trackUserLoginSuccessV2 (tracer, login, user, metadata) {
|
|
|
94
94
|
|
|
95
95
|
metadata = {
|
|
96
96
|
'usr.login': login,
|
|
97
|
-
...metadata
|
|
97
|
+
...metadata,
|
|
98
98
|
}
|
|
99
99
|
|
|
100
100
|
if (user) {
|
|
@@ -138,7 +138,7 @@ function trackUserLoginFailureV2 (tracer, login, exists, metadata) {
|
|
|
138
138
|
metadata = {
|
|
139
139
|
'usr.login': login,
|
|
140
140
|
'usr.exists': exists ? 'true' : 'false',
|
|
141
|
-
...metadata
|
|
141
|
+
...metadata,
|
|
142
142
|
}
|
|
143
143
|
|
|
144
144
|
trackEvent('users.login.failure', metadata, 'eventTrackingV2.trackUserLoginFailure', rootSpan)
|
|
@@ -149,7 +149,7 @@ function trackUserLoginFailureV2 (tracer, login, exists, metadata) {
|
|
|
149
149
|
function flattenFields (fields, depth = 0) {
|
|
150
150
|
if (depth > 4) {
|
|
151
151
|
return {
|
|
152
|
-
truncated: true
|
|
152
|
+
truncated: true,
|
|
153
153
|
}
|
|
154
154
|
}
|
|
155
155
|
|
|
@@ -183,7 +183,7 @@ function trackEvent (eventName, fields, sdkMethodName, rootSpan) {
|
|
|
183
183
|
|
|
184
184
|
const tags = {
|
|
185
185
|
[`appsec.events.${eventName}.track`]: 'true',
|
|
186
|
-
[`_dd.appsec.events.${eventName}.sdk`]: 'true'
|
|
186
|
+
[`_dd.appsec.events.${eventName}.sdk`]: 'true',
|
|
187
187
|
}
|
|
188
188
|
|
|
189
189
|
if (fields) {
|
|
@@ -205,7 +205,7 @@ function trackEvent (eventName, fields, sdkMethodName, rootSpan) {
|
|
|
205
205
|
|
|
206
206
|
function runWaf (eventName, user) {
|
|
207
207
|
const persistent = {
|
|
208
|
-
[`server.business_logic.${eventName}`]: null
|
|
208
|
+
[`server.business_logic.${eventName}`]: null,
|
|
209
209
|
}
|
|
210
210
|
|
|
211
211
|
if (user?.id) {
|
|
@@ -226,5 +226,5 @@ module.exports = {
|
|
|
226
226
|
trackUserLoginSuccessV2,
|
|
227
227
|
trackUserLoginFailureV2,
|
|
228
228
|
trackEvent,
|
|
229
|
-
runWaf
|
|
229
|
+
runWaf,
|
|
230
230
|
}
|
|
@@ -7,7 +7,7 @@ const LIBRARY_FRAMES_BUFFER = 20
|
|
|
7
7
|
|
|
8
8
|
const STACK_TRACE_NAMESPACES = {
|
|
9
9
|
RASP: 'exploit',
|
|
10
|
-
IAST: 'vulnerability'
|
|
10
|
+
IAST: 'vulnerability',
|
|
11
11
|
}
|
|
12
12
|
|
|
13
13
|
function prepareStackTrace (_, callsites) {
|
|
@@ -44,7 +44,7 @@ function filterOutFramesFromLibrary (callSiteList) {
|
|
|
44
44
|
const callSiteLocation = {
|
|
45
45
|
path: callSite.getTranslatedFileName?.() ?? callSite.getFileName(),
|
|
46
46
|
line: callSite.getTranslatedLineNumber?.() ?? callSite.getLineNumber(),
|
|
47
|
-
column: callSite.getTranslatedColumnNumber?.() ?? callSite.getColumnNumber()
|
|
47
|
+
column: callSite.getTranslatedColumnNumber?.() ?? callSite.getColumnNumber(),
|
|
48
48
|
}
|
|
49
49
|
const { path } = getOriginalPathAndLineFromSourceMap(callSiteLocation)
|
|
50
50
|
return !path?.startsWith(ddBasePath)
|
|
@@ -73,7 +73,7 @@ function getCallsiteFrames (maxDepth = 32, constructorOpt = getCallsiteFrames, c
|
|
|
73
73
|
column: callSite.getTranslatedColumnNumber?.() ?? callSite.getColumnNumber(),
|
|
74
74
|
function: callSite.getFunctionName(),
|
|
75
75
|
class_name: callSite.getTypeName(),
|
|
76
|
-
isNative: callSite.isNative()
|
|
76
|
+
isNative: callSite.isNative(),
|
|
77
77
|
})
|
|
78
78
|
}
|
|
79
79
|
|
|
@@ -99,7 +99,7 @@ function reportStackTrace (rootSpan, stackId, frames, namespace = STACK_TRACE_NA
|
|
|
99
99
|
rootSpan.meta_struct['_dd.stack'][namespace].push({
|
|
100
100
|
id: stackId,
|
|
101
101
|
language: 'nodejs',
|
|
102
|
-
frames
|
|
102
|
+
frames,
|
|
103
103
|
})
|
|
104
104
|
}
|
|
105
105
|
|
|
@@ -113,5 +113,5 @@ module.exports = {
|
|
|
113
113
|
getCallsiteFrames,
|
|
114
114
|
reportStackTrace,
|
|
115
115
|
canReportStackTrace,
|
|
116
|
-
STACK_TRACE_NAMESPACES
|
|
116
|
+
STACK_TRACE_NAMESPACES,
|
|
117
117
|
}
|
|
@@ -11,18 +11,18 @@ const tags = {
|
|
|
11
11
|
RULE_TRIGGERED: 'rule_triggered',
|
|
12
12
|
WAF_ERROR: 'waf_error',
|
|
13
13
|
WAF_TIMEOUT: 'waf_timeout',
|
|
14
|
-
WAF_VERSION: 'waf_version'
|
|
14
|
+
WAF_VERSION: 'waf_version',
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
function getVersionsTags (wafVersion, rulesVersion) {
|
|
18
18
|
return {
|
|
19
19
|
[tags.WAF_VERSION]: wafVersion,
|
|
20
|
-
[tags.EVENT_RULES_VERSION]: rulesVersion || 'unknown'
|
|
20
|
+
[tags.EVENT_RULES_VERSION]: rulesVersion || 'unknown',
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
|
|
24
24
|
module.exports = {
|
|
25
25
|
tags,
|
|
26
26
|
getVersionsTags,
|
|
27
|
-
DD_TELEMETRY_REQUEST_METRICS
|
|
27
|
+
DD_TELEMETRY_REQUEST_METRICS,
|
|
28
28
|
}
|
|
@@ -6,7 +6,7 @@ const {
|
|
|
6
6
|
addRaspRequestMetrics,
|
|
7
7
|
trackRaspMetrics,
|
|
8
8
|
trackRaspRuleMatch,
|
|
9
|
-
trackRaspRuleSkipped
|
|
9
|
+
trackRaspRuleSkipped,
|
|
10
10
|
} = require('./rasp')
|
|
11
11
|
const {
|
|
12
12
|
addWafRequestMetrics,
|
|
@@ -14,7 +14,7 @@ const {
|
|
|
14
14
|
incrementWafInit,
|
|
15
15
|
incrementWafUpdates,
|
|
16
16
|
incrementWafConfigErrors,
|
|
17
|
-
incrementWafRequests
|
|
17
|
+
incrementWafRequests,
|
|
18
18
|
} = require('./waf')
|
|
19
19
|
|
|
20
20
|
const metricsStoreMap = new WeakMap()
|
|
@@ -42,8 +42,8 @@ function newStore () {
|
|
|
42
42
|
wafErrorCode: null,
|
|
43
43
|
raspErrorCode: null,
|
|
44
44
|
wafVersion: null,
|
|
45
|
-
rulesVersion: null
|
|
46
|
-
}
|
|
45
|
+
rulesVersion: null,
|
|
46
|
+
},
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
49
|
|
|
@@ -180,5 +180,5 @@ module.exports = {
|
|
|
180
180
|
incrementMissingUserIdMetric,
|
|
181
181
|
incrementSdkEventMetric,
|
|
182
182
|
|
|
183
|
-
getRequestMetrics
|
|
183
|
+
getRequestMetrics,
|
|
184
184
|
}
|
|
@@ -8,7 +8,7 @@ const appsecMetrics = telemetryMetrics.manager.namespace('appsec')
|
|
|
8
8
|
const BLOCKING_STATUS = {
|
|
9
9
|
FAILURE: 'failure',
|
|
10
10
|
IRRELEVANT: 'irrelevant',
|
|
11
|
-
SUCCESS: 'success'
|
|
11
|
+
SUCCESS: 'success',
|
|
12
12
|
}
|
|
13
13
|
|
|
14
14
|
function addRaspRequestMetrics (store, { duration, durationExt, wafTimeout, errorCode }) {
|
|
@@ -67,7 +67,7 @@ function trackRaspRuleMatch (store, raspRule, blockTriggered, blocked) {
|
|
|
67
67
|
waf_version: telemetryMetrics.wafVersion,
|
|
68
68
|
event_rules_version: telemetryMetrics.rulesVersion,
|
|
69
69
|
rule_type: raspRule.type,
|
|
70
|
-
block: getRuleMatchBlockingStatus(blockTriggered, blocked)
|
|
70
|
+
block: getRuleMatchBlockingStatus(blockTriggered, blocked),
|
|
71
71
|
}
|
|
72
72
|
|
|
73
73
|
if (raspRule.variant) {
|
|
@@ -99,5 +99,5 @@ module.exports = {
|
|
|
99
99
|
addRaspRequestMetrics,
|
|
100
100
|
trackRaspMetrics,
|
|
101
101
|
trackRaspRuleMatch,
|
|
102
|
-
trackRaspRuleSkipped
|
|
102
|
+
trackRaspRuleSkipped,
|
|
103
103
|
}
|