autotel-backends 2.12.28 → 2.12.30

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/dist/datadog.cjs CHANGED
@@ -1,116 +1,138 @@
1
- 'use strict';
2
-
3
- var module$1 = require('module');
4
-
5
- var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
6
- // src/datadog.ts
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ let node_module = require("node:module");
3
+ //#region src/datadog.ts
4
+ /**
5
+ * Datadog preset for autotel
6
+ *
7
+ * Provides a simplified configuration helper for Datadog integration
8
+ * with best practices built-in.
9
+ *
10
+ * @example Direct cloud ingestion (serverless, edge)
11
+ * ```typescript
12
+ * import { init } from 'autotel';
13
+ * import { createDatadogConfig } from 'autotel-backends/datadog';
14
+ *
15
+ * init(createDatadogConfig({
16
+ * apiKey: process.env.DATADOG_API_KEY!,
17
+ * service: 'my-lambda',
18
+ * enableLogs: true,
19
+ * }));
20
+ * ```
21
+ *
22
+ * @example Local Datadog Agent (long-running services, Kubernetes)
23
+ * ```typescript
24
+ * import { init } from 'autotel';
25
+ * import { createDatadogConfig } from 'autotel-backends/datadog';
26
+ *
27
+ * init(createDatadogConfig({
28
+ * service: 'my-api',
29
+ * useAgent: true, // No API key needed - Agent handles it
30
+ * }));
31
+ * ```
32
+ */
33
+ /**
34
+ * Create an autotel configuration optimized for Datadog.
35
+ *
36
+ * This preset handles:
37
+ * - Proper OTLP endpoint configuration (Agent vs direct ingestion)
38
+ * - Direct: https://otlp.{site} → SDK appends /v1/traces, /v1/metrics, /v1/logs
39
+ * - Agent: http://localhost:4318 (default)
40
+ * - Datadog API key authentication headers (direct ingestion only)
41
+ * - Unified service tagging (service, env, version)
42
+ * - Resource attribute best practices
43
+ * - Optional log export configuration
44
+ *
45
+ * @param config - Datadog-specific configuration options
46
+ * @returns AutotelConfig ready to pass to init()
47
+ *
48
+ * @example Simple cloud ingestion
49
+ * ```typescript
50
+ * init(createDatadogConfig({
51
+ * apiKey: process.env.DATADOG_API_KEY!,
52
+ * service: 'my-app',
53
+ * }));
54
+ * ```
55
+ *
56
+ * @example With logs and custom environment
57
+ * ```typescript
58
+ * init(createDatadogConfig({
59
+ * apiKey: process.env.DATADOG_API_KEY!,
60
+ * service: 'my-app',
61
+ * environment: 'production',
62
+ * version: '2.1.0',
63
+ * enableLogs: true,
64
+ * }));
65
+ * ```
66
+ *
67
+ * @example Using local Datadog Agent
68
+ * ```typescript
69
+ * init(createDatadogConfig({
70
+ * service: 'my-api',
71
+ * useAgent: true,
72
+ * agentHost: 'datadog-agent.default.svc.cluster.local', // Kubernetes
73
+ * }));
74
+ * ```
75
+ */
7
76
  function createDatadogConfig(config) {
8
- const {
9
- apiKey,
10
- site = "datadoghq.com",
11
- service,
12
- environment,
13
- version,
14
- enableLogs = false,
15
- useAgent = false,
16
- agentHost = "localhost",
17
- agentPort = 4318,
18
- logRecordProcessors
19
- } = config;
20
- if (!useAgent && !apiKey) {
21
- throw new Error(
22
- "Datadog API key is required for direct cloud ingestion. Either provide apiKey or set useAgent: true to use local Datadog Agent."
23
- );
24
- }
25
- const baseConfig = {
26
- service,
27
- environment,
28
- version
29
- };
30
- if (useAgent) {
31
- const agentEndpoint = `http://${agentHost}:${agentPort}`;
32
- if (enableLogs) {
33
- const logsEndpoint = `http://${agentHost}:${agentPort}/v1/logs`;
34
- if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) {
35
- process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;
36
- }
37
- if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) {
38
- process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = "http/protobuf";
39
- }
40
- const resourceAttrs = [
41
- `service.name=${service}`,
42
- environment ? `deployment.environment=${environment}` : null,
43
- version ? `service.version=${version}` : null
44
- ].filter(Boolean).join(",");
45
- if (!process.env.OTEL_RESOURCE_ATTRIBUTES) {
46
- process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;
47
- }
48
- }
49
- return {
50
- ...baseConfig,
51
- endpoint: agentEndpoint
52
- // No API key or headers needed - Agent handles authentication
53
- };
54
- }
55
- const otlpEndpoint = `https://otlp.${site}`;
56
- const authHeaders = `dd-api-key=${apiKey}`;
57
- const cloudConfig = {
58
- ...baseConfig,
59
- endpoint: otlpEndpoint,
60
- headers: authHeaders
61
- };
62
- if (enableLogs) {
63
- const logsEndpoint = useAgent ? `http://${agentHost}:${agentPort}/v1/logs` : `https://otlp.${site}/v1/logs`;
64
- if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) {
65
- process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;
66
- }
67
- if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) {
68
- process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = "http/protobuf";
69
- }
70
- if (!useAgent && apiKey && !process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS) {
71
- process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS = `dd-api-key=${apiKey}`;
72
- }
73
- const resourceAttrs = [
74
- `service.name=${service}`,
75
- environment ? `deployment.environment=${environment}` : null,
76
- version ? `service.version=${version}` : null
77
- ].filter(Boolean).join(",");
78
- if (!process.env.OTEL_RESOURCE_ATTRIBUTES) {
79
- process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;
80
- }
81
- if (logRecordProcessors) {
82
- cloudConfig.logRecordProcessors = logRecordProcessors;
83
- } else {
84
- try {
85
- const pkgRequire = module$1.createRequire(
86
- typeof __filename === "string" ? __filename : (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('datadog.cjs', document.baseURI).href))
87
- );
88
- const { BatchLogRecordProcessor } = pkgRequire(
89
- "@opentelemetry/sdk-logs"
90
- );
91
- const { OTLPLogExporter } = pkgRequire(
92
- "@opentelemetry/exporter-logs-otlp-http"
93
- );
94
- cloudConfig.logRecordProcessors = [
95
- new BatchLogRecordProcessor(
96
- new OTLPLogExporter({
97
- url: `${otlpEndpoint}/v1/logs`,
98
- headers: {
99
- "dd-api-key": apiKey
100
- }
101
- })
102
- )
103
- ];
104
- } catch {
105
- throw new Error(
106
- "Log export requires @opentelemetry/sdk-logs and @opentelemetry/exporter-logs-otlp-http. Install them or set enableLogs: false."
107
- );
108
- }
109
- }
110
- }
111
- return cloudConfig;
77
+ const { apiKey, site = "datadoghq.com", service, environment, version, enableLogs = false, useAgent = false, agentHost = "localhost", agentPort = 4318, logRecordProcessors } = config;
78
+ if (!useAgent && !apiKey) throw new Error("Datadog API key is required for direct cloud ingestion. Either provide apiKey or set useAgent: true to use local Datadog Agent.");
79
+ const baseConfig = {
80
+ service,
81
+ environment,
82
+ version
83
+ };
84
+ if (useAgent) {
85
+ const agentEndpoint = `http://${agentHost}:${agentPort}`;
86
+ if (enableLogs) {
87
+ const logsEndpoint = `http://${agentHost}:${agentPort}/v1/logs`;
88
+ if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;
89
+ if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = "http/protobuf";
90
+ const resourceAttrs = [
91
+ `service.name=${service}`,
92
+ environment ? `deployment.environment=${environment}` : null,
93
+ version ? `service.version=${version}` : null
94
+ ].filter(Boolean).join(",");
95
+ if (!process.env.OTEL_RESOURCE_ATTRIBUTES) process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;
96
+ }
97
+ return {
98
+ ...baseConfig,
99
+ endpoint: agentEndpoint
100
+ };
101
+ }
102
+ const otlpEndpoint = `https://otlp.${site}`;
103
+ const authHeaders = `dd-api-key=${apiKey}`;
104
+ const cloudConfig = {
105
+ ...baseConfig,
106
+ endpoint: otlpEndpoint,
107
+ headers: authHeaders
108
+ };
109
+ if (enableLogs) {
110
+ const logsEndpoint = useAgent ? `http://${agentHost}:${agentPort}/v1/logs` : `https://otlp.${site}/v1/logs`;
111
+ if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;
112
+ if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = "http/protobuf";
113
+ if (!useAgent && apiKey && !process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS) process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS = `dd-api-key=${apiKey}`;
114
+ const resourceAttrs = [
115
+ `service.name=${service}`,
116
+ environment ? `deployment.environment=${environment}` : null,
117
+ version ? `service.version=${version}` : null
118
+ ].filter(Boolean).join(",");
119
+ if (!process.env.OTEL_RESOURCE_ATTRIBUTES) process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;
120
+ if (logRecordProcessors) cloudConfig.logRecordProcessors = logRecordProcessors;
121
+ else try {
122
+ const pkgRequire = (0, node_module.createRequire)(typeof __filename === "string" ? __filename : require("url").pathToFileURL(__filename).href);
123
+ const { BatchLogRecordProcessor } = pkgRequire("@opentelemetry/sdk-logs");
124
+ const { OTLPLogExporter } = pkgRequire("@opentelemetry/exporter-logs-otlp-http");
125
+ cloudConfig.logRecordProcessors = [new BatchLogRecordProcessor(new OTLPLogExporter({
126
+ url: `${otlpEndpoint}/v1/logs`,
127
+ headers: { "dd-api-key": apiKey }
128
+ }))];
129
+ } catch {
130
+ throw new Error("Log export requires @opentelemetry/sdk-logs and @opentelemetry/exporter-logs-otlp-http. Install them or set enableLogs: false.");
131
+ }
132
+ }
133
+ return cloudConfig;
112
134
  }
113
-
135
+ //#endregion
114
136
  exports.createDatadogConfig = createDatadogConfig;
115
- //# sourceMappingURL=datadog.cjs.map
137
+
116
138
  //# sourceMappingURL=datadog.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/datadog.ts"],"names":["createRequire"],"mappings":"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","file":"datadog.cjs","sourcesContent":["/**\n * Datadog preset for autotel\n *\n * Provides a simplified configuration helper for Datadog integration\n * with best practices built-in.\n *\n * @example Direct cloud ingestion (serverless, edge)\n * ```typescript\n * import { init } from 'autotel';\n * import { createDatadogConfig } from 'autotel-backends/datadog';\n *\n * init(createDatadogConfig({\n * apiKey: process.env.DATADOG_API_KEY!,\n * service: 'my-lambda',\n * enableLogs: true,\n * }));\n * ```\n *\n * @example Local Datadog Agent (long-running services, Kubernetes)\n * ```typescript\n * import { init } from 'autotel';\n * import { createDatadogConfig } from 'autotel-backends/datadog';\n *\n * init(createDatadogConfig({\n * service: 'my-api',\n * useAgent: true, // No API key needed - Agent handles it\n * }));\n * ```\n */\n\nimport { createRequire } from 'node:module';\nimport type { AutotelConfig } from 'autotel';\nimport type { LogRecordProcessor } from '@opentelemetry/sdk-logs';\n\n// `__filename` exists under CJS (including esbuild's CJS output wrapper) but\n// not pure ESM. `typeof` is safe against an undeclared identifier and lets\n// the conditional pick the working URL in either format.\ndeclare const __filename: string | undefined;\n\n/**\n * Datadog site regions\n */\nexport type DatadogSite =\n | 'datadoghq.com' // US1 (default)\n | 'datadoghq.eu' // EU\n | 'us3.datadoghq.com' // US3\n | 'us5.datadoghq.com' // US5\n | 'ap1.datadoghq.com' // AP1\n | 'ddog-gov.com'; // US1-FED\n\n/**\n * Configuration options for Datadog preset\n */\nexport interface DatadogPresetConfig {\n /**\n * Datadog API key (required for direct cloud ingestion).\n * Not needed if using local Datadog Agent (useAgent: true).\n *\n * Get your API key from:\n * https://app.datadoghq.com/organization-settings/api-keys\n */\n apiKey?: string;\n\n /**\n * Datadog site/region.\n * Determines which Datadog intake endpoint to use.\n *\n * @default 'datadoghq.com' (US1)\n */\n site?: DatadogSite;\n\n /**\n * Service name (required).\n * Appears in Datadog APM, Service Catalog, and all telemetry.\n */\n service: string;\n\n /**\n * Deployment environment (e.g., 'production', 'staging', 'development').\n * Used for environment filtering in Datadog.\n *\n * @default process.env.DD_ENV || process.env.NODE_ENV || 'development'\n */\n environment?: string;\n\n /**\n * Service version for deployment tracking.\n * Enables Deployment Tracking in Datadog APM.\n *\n * @default process.env.DD_VERSION || auto-detected from package.json\n */\n version?: string;\n\n /**\n * Enable log export to Datadog via OTLP.\n *\n * When enabled, this:\n * 1. Sets up OTel Logs SDK with OTLP exporter (for direct OTel logs API usage)\n * 2. Auto-configures OTEL_EXPORTER_OTLP_LOGS_* env vars for pino-opentelemetry-transport\n *\n * For Pino users: Just add pino-opentelemetry-transport to your logger config:\n * ```typescript\n * const logger = pino({\n * transport: {\n * targets: [\n * { target: 'pino-pretty' },\n * { target: 'pino-opentelemetry-transport' }, // Auto-configured!\n * ],\n * },\n * });\n * ```\n *\n * @default false\n */\n enableLogs?: boolean;\n\n /**\n * Use local Datadog Agent instead of direct cloud ingestion.\n *\n * Benefits:\n * - Lower egress costs (Agent aggregates locally)\n * - Advanced features: trace-log correlation, multi-line logs, data scrubbing\n * - 500+ integrations for enrichment\n * - Infrastructure metrics collection\n *\n * Requires: Datadog Agent 7.35+ with OTLP enabled\n *\n * @default false\n */\n useAgent?: boolean;\n\n /**\n * Datadog Agent hostname (when useAgent: true).\n *\n * @default 'localhost'\n */\n agentHost?: string;\n\n /**\n * Datadog Agent OTLP port (when useAgent: true).\n *\n * @default 4318 (OTLP HTTP)\n */\n agentPort?: number;\n\n /**\n * Custom log record processors (advanced).\n * Overrides the default log processor if enableLogs is true.\n */\n logRecordProcessors?: LogRecordProcessor[];\n}\n\n/**\n * Create an autotel configuration optimized for Datadog.\n *\n * This preset handles:\n * - Proper OTLP endpoint configuration (Agent vs direct ingestion)\n * - Direct: https://otlp.{site} → SDK appends /v1/traces, /v1/metrics, /v1/logs\n * - Agent: http://localhost:4318 (default)\n * - Datadog API key authentication headers (direct ingestion only)\n * - Unified service tagging (service, env, version)\n * - Resource attribute best practices\n * - Optional log export configuration\n *\n * @param config - Datadog-specific configuration options\n * @returns AutotelConfig ready to pass to init()\n *\n * @example Simple cloud ingestion\n * ```typescript\n * init(createDatadogConfig({\n * apiKey: process.env.DATADOG_API_KEY!,\n * service: 'my-app',\n * }));\n * ```\n *\n * @example With logs and custom environment\n * ```typescript\n * init(createDatadogConfig({\n * apiKey: process.env.DATADOG_API_KEY!,\n * service: 'my-app',\n * environment: 'production',\n * version: '2.1.0',\n * enableLogs: true,\n * }));\n * ```\n *\n * @example Using local Datadog Agent\n * ```typescript\n * init(createDatadogConfig({\n * service: 'my-api',\n * useAgent: true,\n * agentHost: 'datadog-agent.default.svc.cluster.local', // Kubernetes\n * }));\n * ```\n */\nexport function createDatadogConfig(\n config: DatadogPresetConfig,\n): AutotelConfig {\n const {\n apiKey,\n site = 'datadoghq.com',\n service,\n environment,\n version,\n enableLogs = false,\n useAgent = false,\n agentHost = 'localhost',\n agentPort = 4318,\n logRecordProcessors,\n } = config;\n\n // Validation: API key required for direct ingestion\n if (!useAgent && !apiKey) {\n throw new Error(\n 'Datadog API key is required for direct cloud ingestion. ' +\n 'Either provide apiKey or set useAgent: true to use local Datadog Agent.',\n );\n }\n\n const baseConfig: AutotelConfig = {\n service,\n environment,\n version,\n };\n\n // Local Datadog Agent configuration\n if (useAgent) {\n const agentEndpoint = `http://${agentHost}:${agentPort}`;\n\n // Auto-configure env vars for pino-opentelemetry-transport in agent mode\n if (enableLogs) {\n const logsEndpoint = `http://${agentHost}:${agentPort}/v1/logs`;\n\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;\n }\n\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = 'http/protobuf';\n }\n\n // No API key header needed for agent mode - Agent handles authentication\n\n const resourceAttrs = [\n `service.name=${service}`,\n environment ? `deployment.environment=${environment}` : null,\n version ? `service.version=${version}` : null,\n ]\n .filter(Boolean)\n .join(',');\n\n if (!process.env.OTEL_RESOURCE_ATTRIBUTES) {\n process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;\n }\n }\n\n return {\n ...baseConfig,\n endpoint: agentEndpoint,\n // No API key or headers needed - Agent handles authentication\n };\n }\n\n // Direct cloud ingestion configuration\n // Datadog OTLP endpoint: base URL without path (SDK appends /v1/traces, /v1/metrics, /v1/logs)\n const otlpEndpoint = `https://otlp.${site}`;\n const authHeaders = `dd-api-key=${apiKey}`;\n\n const cloudConfig: AutotelConfig = {\n ...baseConfig,\n endpoint: otlpEndpoint,\n headers: authHeaders,\n };\n\n // Add log export if enabled\n if (enableLogs) {\n // Auto-configure env vars for pino-opentelemetry-transport and other OTel log transports\n // These are read by pino-opentelemetry-transport, otlp-logger, and similar libraries\n const logsEndpoint = useAgent\n ? `http://${agentHost}:${agentPort}/v1/logs`\n : `https://otlp.${site}/v1/logs`;\n\n // Only set if not already configured (allow user override)\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;\n }\n\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = 'http/protobuf';\n }\n\n // Only set API key header for direct cloud ingestion (not agent mode)\n if (!useAgent && apiKey && !process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS = `dd-api-key=${apiKey}`;\n }\n\n // Set resource attributes for service identification\n const resourceAttrs = [\n `service.name=${service}`,\n environment ? `deployment.environment=${environment}` : null,\n version ? `service.version=${version}` : null,\n ]\n .filter(Boolean)\n .join(',');\n\n if (!process.env.OTEL_RESOURCE_ATTRIBUTES) {\n process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;\n }\n\n if (logRecordProcessors) {\n // Use custom processors if provided\n cloudConfig.logRecordProcessors = logRecordProcessors;\n } else {\n // Create default OTLP log exporter\n try {\n const pkgRequire = createRequire(\n typeof __filename === 'string' ? __filename : import.meta.url,\n );\n const { BatchLogRecordProcessor } = pkgRequire(\n '@opentelemetry/sdk-logs',\n );\n const { OTLPLogExporter } = pkgRequire(\n '@opentelemetry/exporter-logs-otlp-http',\n );\n\n cloudConfig.logRecordProcessors = [\n new BatchLogRecordProcessor(\n new OTLPLogExporter({\n url: `${otlpEndpoint}/v1/logs`,\n headers: {\n 'dd-api-key': apiKey,\n },\n }),\n ),\n ];\n } catch {\n throw new Error(\n 'Log export requires @opentelemetry/sdk-logs and @opentelemetry/exporter-logs-otlp-http. ' +\n 'Install them or set enableLogs: false.',\n );\n }\n }\n }\n\n return cloudConfig;\n}\n"]}
1
+ {"version":3,"file":"datadog.cjs","names":[],"sources":["../src/datadog.ts"],"sourcesContent":["/**\n * Datadog preset for autotel\n *\n * Provides a simplified configuration helper for Datadog integration\n * with best practices built-in.\n *\n * @example Direct cloud ingestion (serverless, edge)\n * ```typescript\n * import { init } from 'autotel';\n * import { createDatadogConfig } from 'autotel-backends/datadog';\n *\n * init(createDatadogConfig({\n * apiKey: process.env.DATADOG_API_KEY!,\n * service: 'my-lambda',\n * enableLogs: true,\n * }));\n * ```\n *\n * @example Local Datadog Agent (long-running services, Kubernetes)\n * ```typescript\n * import { init } from 'autotel';\n * import { createDatadogConfig } from 'autotel-backends/datadog';\n *\n * init(createDatadogConfig({\n * service: 'my-api',\n * useAgent: true, // No API key needed - Agent handles it\n * }));\n * ```\n */\n\nimport { createRequire } from 'node:module';\nimport type { AutotelConfig } from 'autotel';\nimport type { LogRecordProcessor } from '@opentelemetry/sdk-logs';\n\n// `__filename` exists under CJS (including esbuild's CJS output wrapper) but\n// not pure ESM. `typeof` is safe against an undeclared identifier and lets\n// the conditional pick the working URL in either format.\ndeclare const __filename: string | undefined;\n\n/**\n * Datadog site regions\n */\nexport type DatadogSite =\n | 'datadoghq.com' // US1 (default)\n | 'datadoghq.eu' // EU\n | 'us3.datadoghq.com' // US3\n | 'us5.datadoghq.com' // US5\n | 'ap1.datadoghq.com' // AP1\n | 'ddog-gov.com'; // US1-FED\n\n/**\n * Configuration options for Datadog preset\n */\nexport interface DatadogPresetConfig {\n /**\n * Datadog API key (required for direct cloud ingestion).\n * Not needed if using local Datadog Agent (useAgent: true).\n *\n * Get your API key from:\n * https://app.datadoghq.com/organization-settings/api-keys\n */\n apiKey?: string;\n\n /**\n * Datadog site/region.\n * Determines which Datadog intake endpoint to use.\n *\n * @default 'datadoghq.com' (US1)\n */\n site?: DatadogSite;\n\n /**\n * Service name (required).\n * Appears in Datadog APM, Service Catalog, and all telemetry.\n */\n service: string;\n\n /**\n * Deployment environment (e.g., 'production', 'staging', 'development').\n * Used for environment filtering in Datadog.\n *\n * @default process.env.DD_ENV || process.env.NODE_ENV || 'development'\n */\n environment?: string;\n\n /**\n * Service version for deployment tracking.\n * Enables Deployment Tracking in Datadog APM.\n *\n * @default process.env.DD_VERSION || auto-detected from package.json\n */\n version?: string;\n\n /**\n * Enable log export to Datadog via OTLP.\n *\n * When enabled, this:\n * 1. Sets up OTel Logs SDK with OTLP exporter (for direct OTel logs API usage)\n * 2. Auto-configures OTEL_EXPORTER_OTLP_LOGS_* env vars for pino-opentelemetry-transport\n *\n * For Pino users: Just add pino-opentelemetry-transport to your logger config:\n * ```typescript\n * const logger = pino({\n * transport: {\n * targets: [\n * { target: 'pino-pretty' },\n * { target: 'pino-opentelemetry-transport' }, // Auto-configured!\n * ],\n * },\n * });\n * ```\n *\n * @default false\n */\n enableLogs?: boolean;\n\n /**\n * Use local Datadog Agent instead of direct cloud ingestion.\n *\n * Benefits:\n * - Lower egress costs (Agent aggregates locally)\n * - Advanced features: trace-log correlation, multi-line logs, data scrubbing\n * - 500+ integrations for enrichment\n * - Infrastructure metrics collection\n *\n * Requires: Datadog Agent 7.35+ with OTLP enabled\n *\n * @default false\n */\n useAgent?: boolean;\n\n /**\n * Datadog Agent hostname (when useAgent: true).\n *\n * @default 'localhost'\n */\n agentHost?: string;\n\n /**\n * Datadog Agent OTLP port (when useAgent: true).\n *\n * @default 4318 (OTLP HTTP)\n */\n agentPort?: number;\n\n /**\n * Custom log record processors (advanced).\n * Overrides the default log processor if enableLogs is true.\n */\n logRecordProcessors?: LogRecordProcessor[];\n}\n\n/**\n * Create an autotel configuration optimized for Datadog.\n *\n * This preset handles:\n * - Proper OTLP endpoint configuration (Agent vs direct ingestion)\n * - Direct: https://otlp.{site} → SDK appends /v1/traces, /v1/metrics, /v1/logs\n * - Agent: http://localhost:4318 (default)\n * - Datadog API key authentication headers (direct ingestion only)\n * - Unified service tagging (service, env, version)\n * - Resource attribute best practices\n * - Optional log export configuration\n *\n * @param config - Datadog-specific configuration options\n * @returns AutotelConfig ready to pass to init()\n *\n * @example Simple cloud ingestion\n * ```typescript\n * init(createDatadogConfig({\n * apiKey: process.env.DATADOG_API_KEY!,\n * service: 'my-app',\n * }));\n * ```\n *\n * @example With logs and custom environment\n * ```typescript\n * init(createDatadogConfig({\n * apiKey: process.env.DATADOG_API_KEY!,\n * service: 'my-app',\n * environment: 'production',\n * version: '2.1.0',\n * enableLogs: true,\n * }));\n * ```\n *\n * @example Using local Datadog Agent\n * ```typescript\n * init(createDatadogConfig({\n * service: 'my-api',\n * useAgent: true,\n * agentHost: 'datadog-agent.default.svc.cluster.local', // Kubernetes\n * }));\n * ```\n */\nexport function createDatadogConfig(\n config: DatadogPresetConfig,\n): AutotelConfig {\n const {\n apiKey,\n site = 'datadoghq.com',\n service,\n environment,\n version,\n enableLogs = false,\n useAgent = false,\n agentHost = 'localhost',\n agentPort = 4318,\n logRecordProcessors,\n } = config;\n\n // Validation: API key required for direct ingestion\n if (!useAgent && !apiKey) {\n throw new Error(\n 'Datadog API key is required for direct cloud ingestion. ' +\n 'Either provide apiKey or set useAgent: true to use local Datadog Agent.',\n );\n }\n\n const baseConfig: AutotelConfig = {\n service,\n environment,\n version,\n };\n\n // Local Datadog Agent configuration\n if (useAgent) {\n const agentEndpoint = `http://${agentHost}:${agentPort}`;\n\n // Auto-configure env vars for pino-opentelemetry-transport in agent mode\n if (enableLogs) {\n const logsEndpoint = `http://${agentHost}:${agentPort}/v1/logs`;\n\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;\n }\n\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = 'http/protobuf';\n }\n\n // No API key header needed for agent mode - Agent handles authentication\n\n const resourceAttrs = [\n `service.name=${service}`,\n environment ? `deployment.environment=${environment}` : null,\n version ? `service.version=${version}` : null,\n ]\n .filter(Boolean)\n .join(',');\n\n if (!process.env.OTEL_RESOURCE_ATTRIBUTES) {\n process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;\n }\n }\n\n return {\n ...baseConfig,\n endpoint: agentEndpoint,\n // No API key or headers needed - Agent handles authentication\n };\n }\n\n // Direct cloud ingestion configuration\n // Datadog OTLP endpoint: base URL without path (SDK appends /v1/traces, /v1/metrics, /v1/logs)\n const otlpEndpoint = `https://otlp.${site}`;\n const authHeaders = `dd-api-key=${apiKey}`;\n\n const cloudConfig: AutotelConfig = {\n ...baseConfig,\n endpoint: otlpEndpoint,\n headers: authHeaders,\n };\n\n // Add log export if enabled\n if (enableLogs) {\n // Auto-configure env vars for pino-opentelemetry-transport and other OTel log transports\n // These are read by pino-opentelemetry-transport, otlp-logger, and similar libraries\n const logsEndpoint = useAgent\n ? `http://${agentHost}:${agentPort}/v1/logs`\n : `https://otlp.${site}/v1/logs`;\n\n // Only set if not already configured (allow user override)\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_ENDPOINT = logsEndpoint;\n }\n\n if (!process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL = 'http/protobuf';\n }\n\n // Only set API key header for direct cloud ingestion (not agent mode)\n if (!useAgent && apiKey && !process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS) {\n process.env.OTEL_EXPORTER_OTLP_LOGS_HEADERS = `dd-api-key=${apiKey}`;\n }\n\n // Set resource attributes for service identification\n const resourceAttrs = [\n `service.name=${service}`,\n environment ? `deployment.environment=${environment}` : null,\n version ? `service.version=${version}` : null,\n ]\n .filter(Boolean)\n .join(',');\n\n if (!process.env.OTEL_RESOURCE_ATTRIBUTES) {\n process.env.OTEL_RESOURCE_ATTRIBUTES = resourceAttrs;\n }\n\n if (logRecordProcessors) {\n // Use custom processors if provided\n cloudConfig.logRecordProcessors = logRecordProcessors;\n } else {\n // Create default OTLP log exporter\n try {\n const pkgRequire = createRequire(\n typeof __filename === 'string' ? __filename : import.meta.url,\n );\n const { BatchLogRecordProcessor } = pkgRequire(\n '@opentelemetry/sdk-logs',\n );\n const { OTLPLogExporter } = pkgRequire(\n '@opentelemetry/exporter-logs-otlp-http',\n );\n\n cloudConfig.logRecordProcessors = [\n new BatchLogRecordProcessor(\n new OTLPLogExporter({\n url: `${otlpEndpoint}/v1/logs`,\n headers: {\n 'dd-api-key': apiKey,\n },\n }),\n ),\n ];\n } catch {\n throw new Error(\n 'Log export requires @opentelemetry/sdk-logs and @opentelemetry/exporter-logs-otlp-http. ' +\n 'Install them or set enableLogs: false.',\n );\n }\n }\n }\n\n return cloudConfig;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmMA,SAAgB,oBACd,QACe;CACf,MAAM,EACJ,QACA,OAAO,iBACP,SACA,aACA,SACA,aAAa,OACb,WAAW,OACX,YAAY,aACZ,YAAY,MACZ,wBACE;CAGJ,IAAI,CAAC,YAAY,CAAC,QAChB,MAAM,IAAI,MACR,iIAEF;CAGF,MAAM,aAA4B;EAChC;EACA;EACA;CACF;CAGA,IAAI,UAAU;EACZ,MAAM,gBAAgB,UAAU,UAAU,GAAG;EAG7C,IAAI,YAAY;GACd,MAAM,eAAe,UAAU,UAAU,GAAG,UAAU;GAEtD,IAAI,CAAC,QAAQ,IAAI,kCACf,QAAQ,IAAI,mCAAmC;GAGjD,IAAI,CAAC,QAAQ,IAAI,kCACf,QAAQ,IAAI,mCAAmC;GAKjD,MAAM,gBAAgB;IACpB,gBAAgB;IAChB,cAAc,0BAA0B,gBAAgB;IACxD,UAAU,mBAAmB,YAAY;GAC3C,CAAC,CACE,OAAO,OAAO,CAAC,CACf,KAAK,GAAG;GAEX,IAAI,CAAC,QAAQ,IAAI,0BACf,QAAQ,IAAI,2BAA2B;EAE3C;EAEA,OAAO;GACL,GAAG;GACH,UAAU;EAEZ;CACF;CAIA,MAAM,eAAe,gBAAgB;CACrC,MAAM,cAAc,cAAc;CAElC,MAAM,cAA6B;EACjC,GAAG;EACH,UAAU;EACV,SAAS;CACX;CAGA,IAAI,YAAY;EAGd,MAAM,eAAe,WACjB,UAAU,UAAU,GAAG,UAAU,YACjC,gBAAgB,KAAK;EAGzB,IAAI,CAAC,QAAQ,IAAI,kCACf,QAAQ,IAAI,mCAAmC;EAGjD,IAAI,CAAC,QAAQ,IAAI,kCACf,QAAQ,IAAI,mCAAmC;EAIjD,IAAI,CAAC,YAAY,UAAU,CAAC,QAAQ,IAAI,iCACtC,QAAQ,IAAI,kCAAkC,cAAc;EAI9D,MAAM,gBAAgB;GACpB,gBAAgB;GAChB,cAAc,0BAA0B,gBAAgB;GACxD,UAAU,mBAAmB,YAAY;EAC3C,CAAC,CACE,OAAO,OAAO,CAAC,CACf,KAAK,GAAG;EAEX,IAAI,CAAC,QAAQ,IAAI,0BACf,QAAQ,IAAI,2BAA2B;EAGzC,IAAI,qBAEF,YAAY,sBAAsB;OAGlC,IAAI;GACF,MAAM,cAAA,GAAA,YAAA,cAAA,CACJ,OAAO,eAAe,WAAW,aAAA,QAAA,KAAA,CAAA,CAAA,cAAA,UAAA,CAAA,CAAA,IACnC;GACA,MAAM,EAAE,4BAA4B,WAClC,yBACF;GACA,MAAM,EAAE,oBAAoB,WAC1B,wCACF;GAEA,YAAY,sBAAsB,CAChC,IAAI,wBACF,IAAI,gBAAgB;IAClB,KAAK,GAAG,aAAa;IACrB,SAAS,EACP,cAAc,OAChB;GACF,CAAC,CACH,CACF;EACF,QAAQ;GACN,MAAM,IAAI,MACR,gIAEF;EACF;CAEJ;CAEA,OAAO;AACT"}
@@ -1,36 +1,7 @@
1
- import { AutotelConfig } from 'autotel';
2
- import { LogRecordProcessor } from '@opentelemetry/sdk-logs';
3
-
4
- /**
5
- * Datadog preset for autotel
6
- *
7
- * Provides a simplified configuration helper for Datadog integration
8
- * with best practices built-in.
9
- *
10
- * @example Direct cloud ingestion (serverless, edge)
11
- * ```typescript
12
- * import { init } from 'autotel';
13
- * import { createDatadogConfig } from 'autotel-backends/datadog';
14
- *
15
- * init(createDatadogConfig({
16
- * apiKey: process.env.DATADOG_API_KEY!,
17
- * service: 'my-lambda',
18
- * enableLogs: true,
19
- * }));
20
- * ```
21
- *
22
- * @example Local Datadog Agent (long-running services, Kubernetes)
23
- * ```typescript
24
- * import { init } from 'autotel';
25
- * import { createDatadogConfig } from 'autotel-backends/datadog';
26
- *
27
- * init(createDatadogConfig({
28
- * service: 'my-api',
29
- * useAgent: true, // No API key needed - Agent handles it
30
- * }));
31
- * ```
32
- */
1
+ import { AutotelConfig } from "autotel";
2
+ import { LogRecordProcessor } from "@opentelemetry/sdk-logs";
33
3
 
4
+ //#region src/datadog.d.ts
34
5
  /**
35
6
  * Datadog site regions
36
7
  */
@@ -39,93 +10,93 @@ type DatadogSite = 'datadoghq.com' | 'datadoghq.eu' | 'us3.datadoghq.com' | 'us5
39
10
  * Configuration options for Datadog preset
40
11
  */
41
12
  interface DatadogPresetConfig {
42
- /**
43
- * Datadog API key (required for direct cloud ingestion).
44
- * Not needed if using local Datadog Agent (useAgent: true).
45
- *
46
- * Get your API key from:
47
- * https://app.datadoghq.com/organization-settings/api-keys
48
- */
49
- apiKey?: string;
50
- /**
51
- * Datadog site/region.
52
- * Determines which Datadog intake endpoint to use.
53
- *
54
- * @default 'datadoghq.com' (US1)
55
- */
56
- site?: DatadogSite;
57
- /**
58
- * Service name (required).
59
- * Appears in Datadog APM, Service Catalog, and all telemetry.
60
- */
61
- service: string;
62
- /**
63
- * Deployment environment (e.g., 'production', 'staging', 'development').
64
- * Used for environment filtering in Datadog.
65
- *
66
- * @default process.env.DD_ENV || process.env.NODE_ENV || 'development'
67
- */
68
- environment?: string;
69
- /**
70
- * Service version for deployment tracking.
71
- * Enables Deployment Tracking in Datadog APM.
72
- *
73
- * @default process.env.DD_VERSION || auto-detected from package.json
74
- */
75
- version?: string;
76
- /**
77
- * Enable log export to Datadog via OTLP.
78
- *
79
- * When enabled, this:
80
- * 1. Sets up OTel Logs SDK with OTLP exporter (for direct OTel logs API usage)
81
- * 2. Auto-configures OTEL_EXPORTER_OTLP_LOGS_* env vars for pino-opentelemetry-transport
82
- *
83
- * For Pino users: Just add pino-opentelemetry-transport to your logger config:
84
- * ```typescript
85
- * const logger = pino({
86
- * transport: {
87
- * targets: [
88
- * { target: 'pino-pretty' },
89
- * { target: 'pino-opentelemetry-transport' }, // Auto-configured!
90
- * ],
91
- * },
92
- * });
93
- * ```
94
- *
95
- * @default false
96
- */
97
- enableLogs?: boolean;
98
- /**
99
- * Use local Datadog Agent instead of direct cloud ingestion.
100
- *
101
- * Benefits:
102
- * - Lower egress costs (Agent aggregates locally)
103
- * - Advanced features: trace-log correlation, multi-line logs, data scrubbing
104
- * - 500+ integrations for enrichment
105
- * - Infrastructure metrics collection
106
- *
107
- * Requires: Datadog Agent 7.35+ with OTLP enabled
108
- *
109
- * @default false
110
- */
111
- useAgent?: boolean;
112
- /**
113
- * Datadog Agent hostname (when useAgent: true).
114
- *
115
- * @default 'localhost'
116
- */
117
- agentHost?: string;
118
- /**
119
- * Datadog Agent OTLP port (when useAgent: true).
120
- *
121
- * @default 4318 (OTLP HTTP)
122
- */
123
- agentPort?: number;
124
- /**
125
- * Custom log record processors (advanced).
126
- * Overrides the default log processor if enableLogs is true.
127
- */
128
- logRecordProcessors?: LogRecordProcessor[];
13
+ /**
14
+ * Datadog API key (required for direct cloud ingestion).
15
+ * Not needed if using local Datadog Agent (useAgent: true).
16
+ *
17
+ * Get your API key from:
18
+ * https://app.datadoghq.com/organization-settings/api-keys
19
+ */
20
+ apiKey?: string;
21
+ /**
22
+ * Datadog site/region.
23
+ * Determines which Datadog intake endpoint to use.
24
+ *
25
+ * @default 'datadoghq.com' (US1)
26
+ */
27
+ site?: DatadogSite;
28
+ /**
29
+ * Service name (required).
30
+ * Appears in Datadog APM, Service Catalog, and all telemetry.
31
+ */
32
+ service: string;
33
+ /**
34
+ * Deployment environment (e.g., 'production', 'staging', 'development').
35
+ * Used for environment filtering in Datadog.
36
+ *
37
+ * @default process.env.DD_ENV || process.env.NODE_ENV || 'development'
38
+ */
39
+ environment?: string;
40
+ /**
41
+ * Service version for deployment tracking.
42
+ * Enables Deployment Tracking in Datadog APM.
43
+ *
44
+ * @default process.env.DD_VERSION || auto-detected from package.json
45
+ */
46
+ version?: string;
47
+ /**
48
+ * Enable log export to Datadog via OTLP.
49
+ *
50
+ * When enabled, this:
51
+ * 1. Sets up OTel Logs SDK with OTLP exporter (for direct OTel logs API usage)
52
+ * 2. Auto-configures OTEL_EXPORTER_OTLP_LOGS_* env vars for pino-opentelemetry-transport
53
+ *
54
+ * For Pino users: Just add pino-opentelemetry-transport to your logger config:
55
+ * ```typescript
56
+ * const logger = pino({
57
+ * transport: {
58
+ * targets: [
59
+ * { target: 'pino-pretty' },
60
+ * { target: 'pino-opentelemetry-transport' }, // Auto-configured!
61
+ * ],
62
+ * },
63
+ * });
64
+ * ```
65
+ *
66
+ * @default false
67
+ */
68
+ enableLogs?: boolean;
69
+ /**
70
+ * Use local Datadog Agent instead of direct cloud ingestion.
71
+ *
72
+ * Benefits:
73
+ * - Lower egress costs (Agent aggregates locally)
74
+ * - Advanced features: trace-log correlation, multi-line logs, data scrubbing
75
+ * - 500+ integrations for enrichment
76
+ * - Infrastructure metrics collection
77
+ *
78
+ * Requires: Datadog Agent 7.35+ with OTLP enabled
79
+ *
80
+ * @default false
81
+ */
82
+ useAgent?: boolean;
83
+ /**
84
+ * Datadog Agent hostname (when useAgent: true).
85
+ *
86
+ * @default 'localhost'
87
+ */
88
+ agentHost?: string;
89
+ /**
90
+ * Datadog Agent OTLP port (when useAgent: true).
91
+ *
92
+ * @default 4318 (OTLP HTTP)
93
+ */
94
+ agentPort?: number;
95
+ /**
96
+ * Custom log record processors (advanced).
97
+ * Overrides the default log processor if enableLogs is true.
98
+ */
99
+ logRecordProcessors?: LogRecordProcessor[];
129
100
  }
130
101
  /**
131
102
  * Create an autotel configuration optimized for Datadog.
@@ -171,5 +142,6 @@ interface DatadogPresetConfig {
171
142
  * ```
172
143
  */
173
144
  declare function createDatadogConfig(config: DatadogPresetConfig): AutotelConfig;
174
-
175
- export { type DatadogPresetConfig, type DatadogSite, createDatadogConfig };
145
+ //#endregion
146
+ export { DatadogPresetConfig, DatadogSite, createDatadogConfig };
147
+ //# sourceMappingURL=datadog.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"datadog.d.cts","names":[],"sources":["../src/datadog.ts"],"mappings":";;;;;;;KA0CY,WAAA;AA2JI;;;AAAA,UAhJC,mBAAA;;;;;;;;EAQf,MAAA;;;;;;;EAQA,IAAA,GAAO,WAAA;;;;;EAMP,OAAA;;;;;;;EAQA,WAAA;;;;;;;EAQA,OAAA;;;;;;;;;;;;;;;;;;;;;;EAuBA,UAAA;;;;;;;;;;;;;;EAeA,QAAA;;;;;;EAOA,SAAA;;;;;;EAOA,SAAA;;;;;EAMA,mBAAA,GAAsB,kBAAkB;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBA8C1B,mBAAA,CACd,MAAA,EAAQ,mBAAA,GACP,aAAa"}