Sentry JavaScript SDK Integration that can be used to instrument Supabase JavaScript SDK and collect traces, breadcrumbs and errors. The integration supports browser, Node, and edge environments.
See Showcase section for detailed screenshots of what is captured.
[!IMPORTANT]
If you are using Sentry JavaScript SDK v7, reference README-v7.md instead.
If you are using built-in Http, Fetch or nativeNodeFetchIntegration integrations in your current Sentry setup, you might want to skip some of the spans that will be already covered by supabaseIntegration. Here's a quick snippet how to do that:
See this example for a setup with Next.js to cover browser, server, and edge environments. First, run through the Sentry Next.js wizard to generate the base Next.js configuration. Then add the Supabase Sentry Integration to all your Sentry.init calls with the appropriate filters.
sentry.client.config.ts
import * asSentryfrom"@sentry/nextjs";
import { SupabaseClient } from"@supabase/supabase-js";
import { supabaseIntegration } from"@supabase/sentry-js-integration";
Sentry.init({
dsn: SENTRY_DSN,
// Adjust this value in production, or use tracesSampler for greater controltracesSampleRate: 1,
// Setting this option to true will print useful information to the console while you're setting up Sentry.debug: true,
replaysOnErrorSampleRate: 1.0,
// This sets the sample rate to be 10%. You may want this to be 100% while// in development and sample at a lower rate in productionreplaysSessionSampleRate: 0.1,
// You can remove this option if you're not planning to use the Sentry Session Replay feature:integrations: [
Sentry.replayIntegration({
// Additional Replay configuration goes in here, for example:maskAllText: true,
blockAllMedia: true,
}),
supabaseIntegration(SupabaseClient, Sentry, {
tracing: true,
breadcrumbs: true,
errors: true,
}),
Sentry.browserTracingIntegration({
shouldCreateSpanForRequest: (url) => {
return !url.startsWith(`${process.env.NEXT_PUBLIC_SUPABASE_URL}/rest`);
},
}),
],
});
sentry.server.config.ts
import * asSentryfrom"@sentry/nextjs";
import { SupabaseClient } from"@supabase/supabase-js";
import { supabaseIntegration } from"@supabase/sentry-js-integration";
Sentry.init({
dsn: SENTRY_DSN,
integrations: [
supabaseIntegration(SupabaseClient, Sentry, {
tracing: true,
breadcrumbs: true,
errors: true,
}),
Sentry.nativeNodeFetchIntegration({
ignoreOutgoingRequests: (url) => {
console.log(
"server",
`${process.env.NEXT_PUBLIC_SUPABASE_URL}/rest`,
url
);
return url.startsWith(`${process.env.NEXT_PUBLIC_SUPABASE_URL}/rest`);
},
}),
],
// Adjust this value in production, or use tracesSampler for greater controltracesSampleRate: 1,
// Setting this option to true will print useful information to the console while you're setting up Sentry.debug: true,
});
sentry.edge.config.ts
import * asSentryfrom"@sentry/nextjs";
import { SupabaseClient } from"@supabase/supabase-js";
import { supabaseIntegration } from"@supabase/sentry-js-integration";
Sentry.init({
dsn: SENTRY_DSN,
integrations: [
supabaseIntegration(SupabaseClient, Sentry, {
tracing: true,
breadcrumbs: true,
errors: true,
}),
Sentry.winterCGFetchIntegration({
breadcrumbs: true,
shouldCreateSpanForRequest: (url) => {
return !url.startsWith(`${process.env.NEXT_PUBLIC_SUPABASE_URL}/rest`);
},
}),
],
// Adjust this value in production, or use tracesSampler for greater controltracesSampleRate: 1,
// Setting this option to true will print useful information to the console while you're setting up Sentry.debug: true,
});
exportasyncfunctionregister() {
if (process.env.NEXT_RUNTIME === "nodejs") {
awaitimport("./sentry.server.config");
}
if (process.env.NEXT_RUNTIME === "edge") {
awaitimport("./sentry.edge.config");
}
}
Afterward build your application (npm run build) and start it locally (npm run start). You will now see the transactions being logged in the terminal when making supabase-js requests.
Developing
Run library unit tests:
npm install
npm run lint
npm run test
Run types tests for SDK v8:
cd tests-types/v8
npm install
npm run test
Run types tests for SDK v7:
cd tests-types/v7
npm install
npm run test
Publishing
# Add new files to package.json#files if applicable
npm version <patch|minor|major>
git push --follow-tags
npm publish
The npm package @supabase/sentry-js-integration receives a total of 6,659 weekly downloads. As such, @supabase/sentry-js-integration popularity was classified as popular.
We found that @supabase/sentry-js-integration demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago.It has 0 open source maintainers collaborating on the project.
Package last updated on 03 Sep 2024
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.
A malicious Maven package typosquatting a popular library is secretly stealing OAuth credentials on the 15th of each month, putting Java developers at risk.
Socket and Seal Security collaborate to fix a critical npm overrides bug, resolving a three-year security issue in the JavaScript ecosystem's most popular package manager.
TypeScript is porting its compiler to Go, delivering 10x faster builds, lower memory usage, and improved editor performance for a smoother developer experience.