import ExternalLink from 'sentry/components/links/externalLink';
import {Layout, LayoutProps} from 'sentry/components/onboarding/gettingStartedDoc/layout';
import {ModuleProps} from 'sentry/components/onboarding/gettingStartedDoc/sdkDocumentation';
import {StepType} from 'sentry/components/onboarding/gettingStartedDoc/step';
import {t, tct} from 'sentry/locale';
// Configuration Start
const introduction = (
{tct('The Tryton integration adds support for the [link:Tryton Framework Server].', {
link: ,
})}
);
export const steps = ({
dsn,
}: Partial> = {}): LayoutProps['steps'] => [
{
type: StepType.CONFIGURE,
description: (
{tct(
'To configure the SDK, initialize it with the integration in a custom [code:wsgi.py] script:',
{
code:
,
}
)}
),
configurations: [
{
language: 'python',
code: `
# wsgi.py
import sentry_sdk
import sentry_sdk.integrations.trytond
sentry_sdk.init(
dsn="${dsn}",
integrations=[
sentry_sdk.integrations.trytond.TrytondWSGIIntegration(),
],
# Set traces_sample_rate to 1.0 to capture 100%
# of transactions for performance monitoring.
# We recommend adjusting this value in production,
traces_sample_rate=1.0,
)
from trytond.application import app as application
# ...
`,
},
{
description: t(
'In Tryton>=5.4 an error handler can be registered to respond the client with a custom error message including the Sentry event id instead of a traceback.'
),
language: 'python',
code: `
# wsgi.py
# ...
from trytond.exceptions import TrytonException
from trytond.exceptions import UserError
@application.error_handler
def _(app, request, e):
if isinstance(e, TrytonException):
return
else:
event_id = sentry_sdk.last_event_id()
data = UserError('Custom message', f'{event_id}{e}')
return app.make_response(request, data)
`,
},
],
},
];
// Configuration End
export function GettingStartedWithTryton({dsn, ...props}: ModuleProps) {
return ;
}
export default GettingStartedWithTryton;