40 lines
1.5 KiB
JavaScript
40 lines
1.5 KiB
JavaScript
|
/**
|
||
|
* NOTE: This requires `@sentry/nextjs` version 7.3.0 or higher.
|
||
|
*
|
||
|
* NOTE: If using this with `next` version 12.2.0 or lower, uncomment the
|
||
|
* penultimate line in `CustomErrorComponent`.
|
||
|
*
|
||
|
* This page is loaded by Nextjs:
|
||
|
* - on the server, when data-fetching methods throw or reject
|
||
|
* - on the client, when `getInitialProps` throws or rejects
|
||
|
* - on the client, when a React lifecycle method throws or rejects, and it's
|
||
|
* caught by the built-in Nextjs error boundary
|
||
|
*
|
||
|
* See:
|
||
|
* - https://nextjs.org/docs/basic-features/data-fetching/overview
|
||
|
* - https://nextjs.org/docs/api-reference/data-fetching/get-initial-props
|
||
|
* - https://reactjs.org/docs/error-boundaries.html
|
||
|
*/
|
||
|
|
||
|
import * as Sentry from '@sentry/nextjs';
|
||
|
import NextErrorComponent from 'next/error';
|
||
|
|
||
|
const CustomErrorComponent = props => {
|
||
|
// If you're using a Nextjs version prior to 12.2.1, uncomment this to
|
||
|
// compensate for https://github.com/vercel/next.js/issues/8592
|
||
|
// Sentry.captureUnderscoreErrorException(props);
|
||
|
|
||
|
return <NextErrorComponent statusCode={props.statusCode} />;
|
||
|
};
|
||
|
|
||
|
CustomErrorComponent.getInitialProps = async contextData => {
|
||
|
// In case this is running in a serverless function, await this in order to give Sentry
|
||
|
// time to send the error before the lambda exits
|
||
|
await Sentry.captureUnderscoreErrorException(contextData);
|
||
|
|
||
|
// This will contain the status code of the response
|
||
|
return NextErrorComponent.getInitialProps(contextData);
|
||
|
};
|
||
|
|
||
|
export default CustomErrorComponent;
|