Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
df51513
Bump diagnostics-nodejs version
daniyelnnr Jul 25, 2025
aa2e3bb
Refactor telemetry client to support all signals
daniyelnnr Aug 4, 2025
35428ee
Refactor getLogClient to simplify initialization
daniyelnnr Aug 4, 2025
536e16c
Refactor logger client types
daniyelnnr Aug 4, 2025
b5b2425
Add resolution for @grpc/grpc-js dependency
daniyelnnr Aug 5, 2025
ec13074
Update package version to 6.49.8-beta.0
daniyelnnr Aug 5, 2025
00afbcb
Refactor singleton to use dedicated initialization methods for teleme…
daniyelnnr Aug 12, 2025
f3d9c05
Refactor telemetry client initialization logic
daniyelnnr Aug 13, 2025
58d03c9
Update package.json and yarn.lock
daniyelnnr Aug 8, 2025
cfac3a1
Update startApp function to proper init telemetry
daniyelnnr Aug 8, 2025
48127f3
Add metrics client
daniyelnnr Aug 8, 2025
e10016d
Add metrics instruments for monitoring HTTP requests
daniyelnnr Aug 8, 2025
c1d29a9
Add middleware for request metrics
daniyelnnr Aug 8, 2025
4549879
Add middleware usage on app
daniyelnnr Aug 8, 2025
cf53947
Add Koa instrumentation to telemetry client
daniyelnnr Aug 8, 2025
7faeac7
Add Koa context propagation middleware to app worker
daniyelnnr Aug 8, 2025
41f7dee
Add host-metrics instrumentation
daniyelnnr Aug 8, 2025
5b5146d
Add host-metrics instrumentation to telemetry client
daniyelnnr Aug 8, 2025
8b715bd
Merge branch 'master' into chore/bump-diagnostics
daniyelnnr Aug 14, 2025
6503f4d
Release v7.0.1
daniyelnnr Aug 14, 2025
c9bde12
Merge branch 'chore/bump-diagnostics' into update/metrics
daniyelnnr Aug 14, 2025
ff3bbb9
Release v7.1.0-beta.0
daniyelnnr Aug 14, 2025
b54e413
Improves code formatting for setTimeout
daniyelnnr Aug 18, 2025
b596cc7
Refactor instrument init logic on middleware
daniyelnnr Aug 18, 2025
08bef4e
Refactor metric client module
daniyelnnr Aug 26, 2025
1477054
Refactor metrics instruments module
daniyelnnr Aug 26, 2025
6733ee2
Add error handling when init instruments
daniyelnnr Aug 26, 2025
b0c660b
Merge branch 'master' into update/metrics
daniyelnnr Aug 29, 2025
274859c
Bump @vtex/diagnostics-nodejs to 0.1.0-io-beta.20
daniyelnnr Sep 2, 2025
5f78b47
Add new constants for diagnostics configuration
daniyelnnr Sep 3, 2025
8c792fa
Enable log client initialization
daniyelnnr Sep 3, 2025
d236aa6
Add new constants to client.ts
daniyelnnr Sep 3, 2025
43fb4b1
Make clients use new constant for endpoint
daniyelnnr Sep 3, 2025
51f31ea
Use DK_APP_ID on telemetry client creation
daniyelnnr Sep 3, 2025
f41b421
Refactor telemetry client parameters
daniyelnnr Sep 3, 2025
1c9f5d6
Refactor telemetry client initialization with checks
daniyelnnr Sep 3, 2025
92e0b75
Update constant default value
daniyelnnr Sep 4, 2025
ed60b8e
improve logging approach for telemetry status
daniyelnnr Sep 4, 2025
bd3149b
Add new attributes to telemetry client
daniyelnnr Sep 5, 2025
e990260
Merge branch 'master' into config/enable-telemetry-controls
daniyelnnr Sep 8, 2025
a5de07e
release v7.1.1
daniyelnnr Sep 8, 2025
9ee3b6b
update CHANGELOG
daniyelnnr Sep 8, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,15 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).

## [Unreleased]

## [7.1.1] - 2025-09-08
### Changed
- Add conditional enabling for diagnostics telemetry signals

## [7.1.0] - 2025-09-08
### Changed
- Add metrics instrumentation based on diagnostics lib

## [7.1.0] - 2025-09-02
### Changed
- Add new scope argument into auth directive
Expand Down
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@vtex/api",
"version": "7.1.0",
"version": "7.1.1",
"description": "VTEX I/O API client",
"main": "lib/index.js",
"typings": "lib/index.d.ts",
Expand Down Expand Up @@ -53,7 +53,7 @@
"@opentelemetry/instrumentation-koa": "0.47.1",
"@types/koa": "^2.11.0",
"@types/koa-compose": "^3.2.3",
"@vtex/diagnostics-nodejs": "0.1.0-io-beta.19",
"@vtex/diagnostics-nodejs": "0.1.0-io-beta.20",
"@vtex/node-error-report": "^0.0.3",
"@wry/equality": "^0.1.9",
"agentkeepalive": "^4.0.2",
Expand Down
6 changes: 6 additions & 0 deletions src/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,3 +74,9 @@ export const INSPECT_DEBUGGER_PORT = 5858
export const cancellableMethods = new Set(['GET', 'OPTIONS', 'HEAD'])

export const LOG_CLIENT_INIT_TIMEOUT_MS = 5000

export const OTEL_EXPORTER_OTLP_ENDPOINT = process.env.OTEL_EXPORTER_OTLP_ENDPOINT as string;

export const DK_APP_ID = process.env.NODE_VTEX_API_DK_APP_ID as string || "apps-team";

export const DIAGNOSTICS_TELEMETRY_ENABLED = process.env.VTEX_DIAGNOSTICS_TELEMETRY_ENABLED === 'true';
2 changes: 1 addition & 1 deletion src/service/logger/logger.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ export class Logger {
}
}

// this.initLogClient();
this.initLogClient();
}

private initLogClient(): Promise<Types.LogClient | undefined> {
Expand Down
46 changes: 27 additions & 19 deletions src/service/telemetry/client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,12 @@ import {
Metrics,
Traces,
} from '@vtex/diagnostics-nodejs';
import { APP } from '../../constants';
import { APP, OTEL_EXPORTER_OTLP_ENDPOINT, DK_APP_ID, DIAGNOSTICS_TELEMETRY_ENABLED, WORKSPACE, PRODUCTION } from '../../constants';
import { TelemetryClient } from '@vtex/diagnostics-nodejs/dist/telemetry';
import { KoaInstrumentation } from '@opentelemetry/instrumentation-koa';
import { HostMetricsInstrumentation } from '../metrics/instruments/hostMetrics';

const CLIENT_NAME = APP.NAME || 'node-vtex-api';
const APPLICATION_ID = APP.ID || 'vtex-io-app';
const EXPORTER_OTLP_ENDPOINT = process.env.EXPORTER_OTLP_ENDPOINT;

interface TelemetryClients {
logsClient: Logs.LogClient;
Expand All @@ -38,14 +36,14 @@ class TelemetryClientSingleton {
private initializeTracesClient = async (telemetryClient: TelemetryClient) =>
await telemetryClient.newTracesClient({
exporter: Exporters.CreateExporter(Exporters.CreateTracesExporterConfig({
endpoint: EXPORTER_OTLP_ENDPOINT,
endpoint: OTEL_EXPORTER_OTLP_ENDPOINT,
}), 'otlp'),
});

private initializeMetricsClient = async (telemetryClient: TelemetryClient) =>
await telemetryClient.newMetricsClient({
exporter: Exporters.CreateExporter(Exporters.CreateMetricsExporterConfig({
endpoint: EXPORTER_OTLP_ENDPOINT,
endpoint: OTEL_EXPORTER_OTLP_ENDPOINT,
interval: 5,
timeoutSeconds: 5,
}), 'otlp'),
Expand All @@ -54,21 +52,27 @@ class TelemetryClientSingleton {
private initializeLogsClient = async (telemetryClient: TelemetryClient) =>
await telemetryClient.newLogsClient({
exporter: Exporters.CreateExporter(Exporters.CreateLogsExporterConfig({
endpoint: EXPORTER_OTLP_ENDPOINT,
endpoint: OTEL_EXPORTER_OTLP_ENDPOINT,
}), 'otlp'),
loggerName: `node-vtex-api-${APPLICATION_ID}`,
});

private async initializeTelemetryClients(): Promise<TelemetryClients> {

try {
const telemetryClient = await NewTelemetryClient(
APPLICATION_ID,
CLIENT_NAME,
DK_APP_ID,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Wha is the role of this DK app id here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This was a request from o11y team, the proper identifier for this first parameter should be the DK app id instead of the composite id (vendor, app name and version) that we were using here - that's the reason why I opened #602 and proper onboard node-vtex-api.

'node-vtex-api',
APPLICATION_ID,
{
// Use built-in no-op functionality when telemetry is disabled
noop: !DIAGNOSTICS_TELEMETRY_ENABLED,
additionalAttrs: {
'app.id': APPLICATION_ID,
'vendor': APP.VENDOR,
'version': APP.VERSION || '',
'environment': process.env.VTEX_WORKSPACE || 'development',
'workspace': WORKSPACE,
'production': PRODUCTION.toString(),
},
}
);
Expand All @@ -79,16 +83,20 @@ class TelemetryClientSingleton {
this.initializeLogsClient(telemetryClient),
]);

const instrumentations = [
...Instrumentation.CommonInstrumentations.minimal(),
new KoaInstrumentation(),
new HostMetricsInstrumentation({
name: 'host-metrics-instrumentation',
meterProvider: metricsClient.provider(),
}),
];

telemetryClient.registerInstrumentations(instrumentations);
if (DIAGNOSTICS_TELEMETRY_ENABLED) {
console.log(`Telemetry enabled for app: ${APP.ID} (vendor: ${APP.VENDOR})`);

const instrumentations = [
...Instrumentation.CommonInstrumentations.minimal(),
new KoaInstrumentation(),
new HostMetricsInstrumentation({
name: 'host-metrics-instrumentation',
meterProvider: metricsClient.provider(),
}),
];

telemetryClient.registerInstrumentations(instrumentations);
}

const clients: TelemetryClients = {
logsClient,
Expand Down
8 changes: 4 additions & 4 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -1251,10 +1251,10 @@
dependencies:
"@types/yargs-parser" "*"

"@vtex/diagnostics-nodejs@0.1.0-io-beta.19":
version "0.1.0-io-beta.19"
resolved "https://registry.yarnpkg.com/@vtex/diagnostics-nodejs/-/diagnostics-nodejs-0.1.0-io-beta.19.tgz#e8ebc6a0b44014d0ffcda9df736291c52604ee9e"
integrity sha512-p3bcfpCI12k1DXqD2wJvO53dDdrULYsK7muJFHlwiZio4WvnSfPU1Ay5ni9Y8alD/MLX4fP4EEjRYXTGc7wFWQ==
"@vtex/diagnostics-nodejs@0.1.0-io-beta.20":
version "0.1.0-io-beta.20"
resolved "https://registry.yarnpkg.com/@vtex/diagnostics-nodejs/-/diagnostics-nodejs-0.1.0-io-beta.20.tgz#79ee25a88827a501206d1a8ef0715674fa1521b5"
integrity sha512-8DbibPcPEd2yJCRKZOM2JAf4FYr9W90lD+DRV/mOwgMd1ZGdZuXupfoqqOzOdrkOidXhCeLBPhRXne8O2N3QEQ==
dependencies:
"@grpc/grpc-js" "^1.13.4"
"@opentelemetry/api" "^1.9.0"
Expand Down
Loading