Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[JavaScript] Nuxt SDK #9095

Closed
21 of 30 tasks
stephanie-anderson opened this issue Sep 22, 2023 · 66 comments
Closed
21 of 30 tasks

[JavaScript] Nuxt SDK #9095

stephanie-anderson opened this issue Sep 22, 2023 · 66 comments
Assignees
Labels
Package: nuxt Issues related to the Sentry Nuxt SDK

Comments

@stephanie-anderson
Copy link
Contributor

stephanie-anderson commented Sep 22, 2023

Important

This issue is tracking progress on the Nuxt SDK. If you find bugs or problems with the @sentry/nuxt package please open a separate issue. Thank you!

New SDK for https://nuxt.com/

There is an existing discussion: Sentry SDK for Nuxt

Nuxt uses nitro as their server, this means we'll need to have nitro support. It might make sense for us to create an OpenTelemetry instrumentation for nitro. It will also be valuable to add similar instrumentation for the other libraries Nuxt relies on:

Alpha

Preview Give feedback
  1. Package: nuxt
  2. Package: nuxt

Beta

Preview Give feedback
  1. Package: nuxt
    s1gr1d
  2. Package: nuxt
  3. Package: nuxt
    s1gr1d
  4. Package: nuxt
    s1gr1d

Stable Release: #14487

Check the Stable Realease tracking issue for TODOs regarding the stable release: #14487


Nice to have/Stretch Goals

Preview Give feedback
  1. Package: nuxt Type: Tests
  2. Package: cloudflare Package: nuxt
  3. Package: nuxt
@stephanie-anderson stephanie-anderson added the Package: nuxt Issues related to the Sentry Nuxt SDK label Sep 22, 2023
@AbhiPrasad
Copy link
Member

See #6929

@s1gr1d s1gr1d self-assigned this Jun 17, 2024
@TheAlexLichter
Copy link

If you need insights from the Nuxt team at any time, please don't hesitate to reach out! 🙏

@cosbgn
Copy link

cosbgn commented Jun 24, 2024

This is such a great news!

It would be ideal that it would work on all envs.
Nuxt works very well on the edge (cloudflare workers, netlify edge, etc), however not all libraries are compatible as there are some restrictions (no eval, no new Function(), etc).

It would be great if sentry/nuxt would work everywhere from day one.

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Jun 24, 2024
@s1gr1d
Copy link
Member

s1gr1d commented Jun 24, 2024

@cosbgn Thanks for the input! Which libraries do you mean with "not all libraries are compatible"?

@cosbgn
Copy link

cosbgn commented Jun 24, 2024

@cosbgn Thanks for the input! Which libraries do you mean with "not all libraries are compatible"?

Hi @s1gr1d, I don't have an extensive list, but for example AJV doesn't work. Workers don't use node, they use their own runtime (workerd) which is limited to web standards (similarly to deno).

I think if you use only sentry/core it should work as it's used by toucan-js which is an unofficial client for cloudflare workers. I think sentry/node won't work by default, but I might be wrong here.

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Jun 24, 2024
@cosbgn
Copy link

cosbgn commented Jun 24, 2024

This is of course for the backend part of nuxt, i.e. nitro. On the frontend sentry/vue should work perfectly.

@alexcroox
Copy link

alexcroox commented Jun 24, 2024

I use Sentry on my APIs (fullstack Nuxt 3 deployment to Cloudflare pages) with the sentry/browser package on the API side to get around edge restrictions.

The context Sentry devs, for cosbgn's comment, is that Nuxt 3 was built with the "deploy anywhere" ethos, so all the core packages and (new) community modules are designed to be runtime agnostic. That's where https://unjs.io/ was born from.

I initially followed this guide if it helps at all with the PR in general https://www.lichter.io/articles/nuxt3-sentry-recipe (written by a core Nuxt 3 dev)

@lforst
Copy link
Member

lforst commented Jun 24, 2024

While we may not support worker (WinterCG) runtimes from the start we will look into it eventually. We are planning to release the SDK iteratively and in stages. Prioritization of worker runtime support depends of course a bit on the demand. I added an item to the list to track. Technically we have all the building blocks available.

@cosbgn
Copy link

cosbgn commented Jun 24, 2024

I don't have any specific data, but from my understanding a big percent of nuxt apps are deployed on the edge (vercel-edge, workers, netlify edge, etc) as you get better performance for lower costs, and Nuxt pretty much "guarantees" that it will work on the edge, so it's an obvious solution.

I understand if you decide not to prioritize it, I just wanted to let you know that it would be great to have it from day one. It might be as simple as using sentry/core rather than sentry/node (I don't know, just an example).

Anyways, thanks for the first party package, love sentry and I would love to be able to add it to Nuxt easily!

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Nov 25, 2024
@s1gr1d
Copy link
Member

s1gr1d commented Nov 25, 2024

@maximepvrt I am curious - how would your application (or applications in general) benefit from this change?

Both Sentry config files are placed in the root to have them visible in one place and the root is also the place where you would add other configs (like nuxt.config, tailwind.config, ...).

@maximepvrt
Copy link
Contributor

The idea behind this suggestion is that configurations related specifically to the client-side application have been moved to the app folder in Nuxt 3, such as app.config.ts. Placing sentry.client.config.ts in app would align with this convention, making it clear that this configuration applies solely to the client-side. This organization helps keep the root directory focused on global or shared configurations (like nuxt.config, tailwind.config)

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Nov 25, 2024
@iBobik
Copy link

iBobik commented Nov 25, 2024

I hate how so many small libs pollute root directory by their configs.

It is good to have this option for use-cases with a lot of config, but most projects will be ok with defaults, so 2-3 options.

For such amount of config there is convention for Nuxt modules to have their section in the nuxt.config.ts.

@s1gr1d
Copy link
Member

s1gr1d commented Nov 25, 2024

Yes, this makes sense for Nuxt 4 - I'll add it to the list.

The reason why not every part of the Sentry config is added inside the key sentry of the nuxt.config.ts file is because this file is only evaluated during build time. As functions can be passed to the options of the init function, we cannot do this evaluation only during build time. Also, it's easier for people to differentiate between build-time, client-side and server-side if those configs are separated.

@maximepvrt
Copy link
Contributor

@s1gr1d Would it be possible to add an enabled option in nuxt.config for the Sentry module? By default, it could be set to true, but it would allow developers to control in which environments Sentry should be activated using environment overrides. This would make it easier to disable Sentry in specific environments like development or test without additional workarounds.

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Nov 25, 2024
@maximepvrt
Copy link
Contributor

Additionally, is there a way to disable the capturing of specific useError types, such as 404 errors? This would be helpful to avoid reporting expected errors to Sentry.

@chargome
Copy link
Member

@maximepvrt

You could alternatively add enabled: false conditionally to Sentry.init(), or callSentry.init() conditionally altogether. Let's hear @s1gr1d opinion on adding this flag to the module itself 👍

For filtering specific errors you can refer to https://docs.sentry.io/platforms/javascript/guides/nuxt/configuration/filtering/

@CraigDaveyHornby
Copy link

Am I setting the environment wrong as it doesnt seem to be working and shows as production in sentry. I am setting the environment in my .env file and pulling it through into the sentry.server.config.ts file.

This is my implementation.

import * as Sentry from '@sentry/nuxt';

if (process.env.SENTRY_DSN) {
  Sentry.init({
    dsn: process.env.SENTRY_DSN,
    environment: process.env.SENTRY_ENVIRONMENT,
    debug: process.env.SENTRY_ENVIRONMENT === 'development' || process.env.SENTRY_ENVIRONMENT === 'staging'
  });
}

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Jan 7, 2025
@s1gr1d
Copy link
Member

s1gr1d commented Jan 8, 2025

In general, it looks correct how you set the environment. If you log process.env.SENTRY_ENVIRONMENT in this file, is it defined? And is it also defined where you deploy your application?

I just tested it to verify and it worked for the server and the client. When you look into tracing, you will mostly see the environment set for the client (as the pageload happens there). When an error happens on the backend, you should see the environment defined for the server.

--> Error Event on Server:
Image

--> Pageload Trace on Client:
Image

@getsantry getsantry bot removed the status in GitHub Issues with 👀 3 Jan 8, 2025
@mydea mydea unpinned this issue Jan 8, 2025
@s1gr1d
Copy link
Member

s1gr1d commented Jan 8, 2025

Closing this issue as all important tasks for the Nuxt SDK are completed.

Follow-up tasks can be found in the [Nuxt] Follow-up tasks issue. In case you experience problems with the SDK, please file a bug or add a feature request if you have any suggestions.

General open issues, related to the Nuxt SDK are collected as standalone issues with Package: nuxt

@s1gr1d s1gr1d closed this as completed Jan 8, 2025
@getsentry getsentry locked as resolved and limited conversation to collaborators Jan 8, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Package: nuxt Issues related to the Sentry Nuxt SDK
Projects
Archived in project
Development

No branches or pull requests