import {Fragment} from 'react';
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';
interface StepProps {
dsn: string;
organizationSlug?: string;
projectSlug?: string;
sourcePackageRegistries?: ModuleProps['sourcePackageRegistries'];
}
// Configuration Start
const introduction = (
{tct(
'Sentry for Java is a collection of modules provided by Sentry; it supports Java 1.8 and above. At its core, Sentry for Java provides a raw client for sending events to Sentry. If you use [strong:Spring Boot, Spring, Logback, or Log4j2], we recommend visiting our Sentry Java documentation for installation instructions.',
{
strong: ,
link: ,
}
)}
);
export const steps = ({
dsn,
sourcePackageRegistries,
projectSlug,
organizationSlug,
}: StepProps): LayoutProps['steps'] => [
{
type: StepType.INSTALL,
description: t('Install the SDK via Gradle, Maven, or SBT:'),
configurations: [
{
description: {t('Gradle')}
,
configurations: [
{
language: 'groovy',
partialLoading: sourcePackageRegistries?.isLoading,
description: (
{tct('For Gradle, add to your [code:build.gradle] file:', {
code:
,
})}
),
code: `
// Make sure mavenCentral is there.
repositories {
mavenCentral()
}
// Add Sentry's SDK as a dependency.
dependencies {
implementation 'io.sentry:sentry:${
sourcePackageRegistries?.isLoading
? t('\u2026loading')
: sourcePackageRegistries?.data?.['sentry.java']?.version ?? '6.27.0'
}'
}
`,
},
{
language: 'groovy',
partialLoading: sourcePackageRegistries?.isLoading,
description: t(
'To upload your source code to Sentry so it can be shown in stack traces, use our Gradle plugin.'
),
code: `
buildscript {
repositories {
mavenCentral()
}
}
plugins {
id "io.sentry.jvm.gradle" version "${
sourcePackageRegistries?.isLoading
? t('\u2026loading')
: sourcePackageRegistries?.data?.['sentry.java.android.gradle-plugin']?.version ??
'3.11.1'
}"
}
sentry {
// Generates a JVM (Java, Kotlin, etc.) source bundle and uploads your source code to Sentry.
// This enables source context, allowing you to see your source
// code as part of your stack traces in Sentry.
includeSourceContext = true
org = "${organizationSlug}"
projectName = "${projectSlug}"
authToken = "your-sentry-auth-token"
}
`,
},
],
},
{
description: {t('Maven')}
,
configurations: [
{
language: 'xml',
partialLoading: sourcePackageRegistries?.isLoading,
description: (
{tct('For Maven, add to your [code:pom.xml] file:', {code:
})}
),
code: `
io.sentry
sentry
${
sourcePackageRegistries?.isLoading
? t('\u2026loading')
: sourcePackageRegistries?.data?.['sentry.java']?.version ?? '6.27.0'
}
`,
},
{
language: 'xml',
partialLoading: sourcePackageRegistries?.isLoading,
description: t(
'To upload your source code to Sentry so it can be shown in stack traces, use our Maven plugin.'
),
code: `
io.sentry
sentry-maven-plugin
${
sourcePackageRegistries?.isLoading
? t('\u2026loading')
: sourcePackageRegistries?.data?.['sentry.java.mavenplugin']?.version ?? '0.0.3'
}
true
/path/to/sentry-cli
${organizationSlug}
${projectSlug}
env.SENTRY_AUTH_TOKEN
generate-resources
uploadSourceBundle
...
`,
},
],
},
{
description: {t('SBT')}
,
configurations: [
{
description: {tct('For [strong:SBT]:', {strong: })}
,
language: 'scala',
partialLoading: sourcePackageRegistries?.isLoading,
code: `libraryDependencies += "io.sentry" % "sentry" % "${
sourcePackageRegistries?.isLoading
? t('\u2026loading')
: sourcePackageRegistries?.data?.['sentry.java']?.version ?? '6.27.0'
}"`,
},
],
},
],
additionalInfo: (
{tct(
'To upload your source code to Sentry so it can be shown in stack traces, please refer to [link:Manually Uploading Source Context].',
{
link: (
),
}
)}
),
},
{
type: StepType.CONFIGURE,
description: t(
"Configure Sentry as soon as possible in your application's lifecycle:"
),
configurations: [
{
language: 'java',
code: `
import io.sentry.Sentry;
Sentry.init(options -> {
options.setDsn("${dsn}");
// Set tracesSampleRate to 1.0 to capture 100% of transactions for performance monitoring.
// We recommend adjusting this value in production.
options.setTracesSampleRate(1.0);
// When first trying Sentry it's good to see what the SDK is doing:
options.setDebug(true);
});
`,
},
],
},
{
type: StepType.VERIFY,
description: (
{tct(
'Trigger your first event from your development environment by intentionally creating an error with the [code:Sentry#captureException] method, to test that everything is working:',
{code:
}
)}
),
configurations: [
{
language: 'java',
code: `
import java.lang.Exception;
import io.sentry.Sentry;
try {
throw new Exception("This is a test.");
} catch (Exception e) {
Sentry.captureException(e);
}
`,
},
],
additionalInfo: (
{t(
"If you're new to Sentry, use the email alert to access your account and complete a product tour."
)}
{t(
"If you're an existing user and have disabled alerts, you won't receive this email."
)}
),
},
{
title: t('Measure Performance'),
description: t('You can capture transactions using the SDK. For example:'),
configurations: [
{
language: 'java',
code: `
import io.sentry.ITransaction;
import io.sentry.Sentry;
import io.sentry.SpanStatus;
// A good name for the transaction is key, to help identify what this is about
ITransaction transaction = Sentry.startTransaction("processOrderBatch()", "task");
try {
processOrderBatch();
} catch (Exception e) {
transaction.setThrowable(e);
transaction.setStatus(SpanStatus.INTERNAL_ERROR);
throw e;
} finally {
transaction.finish();
}
`,
},
],
additionalInfo: (
{tct(
'For more information about the API and automatic instrumentations included in the SDK, [link:visit the docs].',
{
link: (
),
}
)}
),
},
];
// Configuration End
export function GettingStartedWithJava({
dsn,
sourcePackageRegistries,
projectSlug,
organization,
...props
}: ModuleProps) {
return (
);
}
export default GettingStartedWithJava;