Socket
Socket
Sign inDemoInstall

fastify-gcloud-trace

Package Overview
Dependencies
87
Maintainers
1
Versions
6
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    fastify-gcloud-trace

Google Cloud Trace API Connector for Fastify


Version published
Weekly downloads
59
increased by1.72%
Maintainers
1
Install size
6.53 MB
Created
Weekly downloads
 

Changelog

Source

[2.0.0] - 2020-04-05

Changed

  • Avoid modifing request objects too much. Now you can access root span under req.gtrace property. This is not a backward compatible chage.

Readme

Source

fastify-gcloud-trace

Google Cloud Trace API Connector for Fastify

js-standard-style Build Status

fastify-gcloud-trace is a plugin that connects your application with Stackdriver Trace API for Fastify. It is build on top of Stackdriver Trace package, so you can configure Stackdriver Trace API by passing options to traceApiOptions.

This plugin measures how long each event takes in one request, and generates trace results. Here is an example trace result that you can find on Google Cloud Console:

IMAGE

Install

npm i fastify-gcloud-trace --save

or

yarn add fastify-gcloud-trace

Usage

Register the plugin with your project in the following way and that's it!

const fastify = require('fastify')();

// Please register this plugin at the beginning unless there is a specific reason not to.
fastify.register(
  require('fastify-gcloud-trace')({
    traceApiOptions: {
      // Pass options for Stackdriver Trace API
      ignoreMethods: ['OPTIONS'],
    },
  }),
);

fastify.listen(3000, err => {
  if (err) throw err;
});

This plugin attaches a Trace object to each request, and the object is accessible as rootSpan in a request.gtrace object. Therefore, you can access the trace instance in your application code, and perform all functionalities defined in the Stackdriver Trace API. For example, you can create a childSpan in the following way. It is important to note that rootSpan is only defined when traceAPI generates a "traced" root span, so your application code has to handle the case where rootSpan is null. You can find the different types of span here.

fastify.get('/foo', (req, reply) => {
  const span = req.gtrace.rootSpan
    ? req.gtrace.rootSpan.createChildSpan({name: 'Perform Heavy Calculation'})
    : null;
  // Do something
  if (span) {
    span.endSpan();
  }
  reply.send({hello: 'world'});
});

Options

This is the list of available options.

  • traceApiOptions - The options for the Trace API. The details are here.
  • tracePluginOptions:
    • enabled - If it is true, it generates a trace. The default value is true.
    • nameOverride - You can pass a function to overide a name for a trace. The function should take a Request as an argument.

Limitations

It only supports StackDriver Trace API right now. If there is enough demand, I would also build support for OpenCensus packages unless Google adds automatic support for Fasify.

License Licensed under MIT.

Keywords

FAQs

Last updated on 09 Apr 2020

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc