npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@code-like-a-carpenter/telemetry

v3.5.0

Published

OpenTelemetry wrappers that make it easier to do basic things

Downloads

596

Readme

@code-like-a-carpenter/telemetry

standard-readme compliant

OpenTelemetry wrappers that make it easier to do basic things

Table of Contents

Install

npm i @code-like-a-carpenter/telemetry

Usage

captureException

Helper function that attaches a thrown exception to the current span and adds other interesting span details. It takes two arguments, the exception and whether or not it escaped its current span. If you rethrow, escaped should be true, if you handle it, escaped should be false. If it's worth capturing an exception when escaped is false, then it's probably worth alerting on.

If you're using @code-like-a-carpenter/lambda-handlers, you probably don't need to think about captureException.

Sentry

This package automatically initializes Sentry and wires it into captureException. This really isn't ideal as so far there's not obvious way to opt-out of this behavior if you're not using Sentry.

At time of writing, Sentry's behavior induces aws-sdk v2 to be bundled, so you'll want to exclude it using your bundler config.

runWith*

This packages contains several functions run a function inside a new OpenTelemetry span. In most cases, you'll want runWithNewSpan and in some cases, you'll want runWithNewSpanFromContext (see its in-line docs for specifics). runWithSpan is a lower-level function that is used by the other two and probably won't be used directly by consumers, but is exported for completeness.

import {runWithNewSpan} from '@code-like-a-carpenter/telemetry';

export async function handler(...args) {
    const result = await runWithNewSpan(
        'handler',
        {attrs: {'com.example.foo': 'bar'}},
        async () => {
            return await doSomething(...args);
        }
    );
    return result;
}

withTelemetry

Note that withTelemetry is on its way to deprecation and so you should prefer one of instrument*Handler functions if there's one that fits your use case.

withTelemetry is an all-purpose wrapper around a standard Lambda handler which adds the appropriate OTel attributes based on the type of event being handled.

withTelemetry specifically knows how to handle API Gateway events, SQS events, API Gateway Token Authorizer events, and DynamoDB Stream events. If you need other event types, please open an issue. If you're using it with a DynamoDB Stream, make sure you've set FunctionResponseTypes: ['ReportBatchItemFailures'] in your CloudFormation template.

import {withTelemetry} from '@code-like-a-carpenter/telemetry';

export function handler(event, context) {
    return withTelemetry(
        'handler',
        {attrs: {'com.example.foo': 'bar'}},
        async () => await doSomething(...args)
    );
}

Maintainer

Ian Remmel

Contributing

Please see contributing guidelines at the project homepage.

License

MIT © Ian Remmel 2023 until at least now