Node.JS SDK API Reference
Node.js SDK
Highlight's Node.js SDK makes it easy to monitor errors and metrics on your Node.js backend.
Just getting started?
Check out our getting started guide to get up and running quickly.
H.init
H.init() initializes the Highlight backend SDK. If you are not using any of the provided handlers for Express, it is required to call this method before recording backend errors or metrics.
Method Parameters
import { H } from "@highlight-run/node";
 
const highlightOptions = {};
if (!H.isInitialized()) {
  H.init(highlightOptions);
}
H.isInitialized
H.isInitialized() returns true if the Highlight backend SDK has been initialized. This may be handy if your initialization code could be called multiple times, e.g. if it is called conditionally from a request handler when a backend error or metric needs to be recorded.
import { H } from "@highlight-run/node";
 
const highlightOptions = {};
if (!H.isInitialized()) {
  H.init(highlightOptions);
}
H.consumeError
H.consumeError() reports an error and its corresponding stack trace to Highlight. The secureSessionId and requestId properties are Highlight ids used to link an error to the session in which the error was thrown. These properties are sent via a header and included in every request to your backend once the Highlight client is initialized. They can be parsed using the H.parseHeaders() helper method.
Method Parameters
errorErrorrequired
The error being reported to Highlight.
secureSessionIdstringrequired
A randomized id representing the Highlight session in which an error was thrown. This can be parsed from the network request's headers using H.parseHeaders().
requestIdstringrequired
A randomized id generated by the Highlight client representing the request for which an error was thrown. This can be parsed from the network request's headers using H.parseHeaders().
import * as http from 'http';
import { H } from "@highlight-run/node";
 
const onError = (request: http.IncomingMessage, error: Error): void => {
  const parsed = H.parseHeaders(request.headers);
  if (parsed !== undefined) {
    H.consumeError(error, parsed.secureSessionId, parsed.requestId)
  }
};
H.recordMetric
H.recordMetric() reports a metric to Highlight. Backend metrics can be used just like frontend metrics for creating custom dashboards.
Method Parameters
secureSessionIdstringrequired
A randomized id representing the Highlight session making the network request. This can be parsed from the network request's headers using H.parseHeaders().
namestringrequired
The name of the metric being reported.
valuenumberrequired
The numeric value of the metric being reported.
requestIdstringoptional
A randomized id generated by the Highlight client representing the request for this metric. This can be parsed from the network request's headers using H.parseHeaders(). If the metric is not request-specific, this argument can be omitted.
tags{ name: string; value: string }[]optional
Tags are arbitrary name-value pairs you can associate to your metrics. This is helpful for categorizing data in dashboards, e.g. for grouping or filtering metrics by particular tags.
import { H } from "@highlight-run/node";
 
const handler = (request) => {
  const parsed = H.parseHeaders(request.headers);
  const start = Date.now();
  doInterestingWork();
  const elapsed = Date.now() - start;
  H.recordMetric(parsed.secureSessionId, "elapsedTimeMs", elapsed, parsed.requestId, ["user": "Zane"]);
};
H.parseHeaders
H.parseHeaders() is a helper function for extracting the Highlight secureSessionId and requestId from network requests. These fields are sent with network requests as the 'x-highlight-request' header, encoded as a slash-separated string: "{secureSessionId}/{requestId}"
Method Parameters
headersIncomingHttpHeadersrequired
The headers sent as part of your network request.
import * as http from 'http';
import { H } from "@highlight-run/node";
 
const onError = (request: http.IncomingMessage, error: Error): void => {
  const parsed = H.parseHeaders(request.headers);
  if (parsed !== undefined) {
    H.consumeError(error, parsed.secureSessionId, parsed.requestId)
  }
};