import ExternalLink from 'sentry/components/links/externalLink'; import {StepType} from 'sentry/components/onboarding/gettingStartedDoc/step'; import type { Docs, DocsParams, OnboardingConfig, } from 'sentry/components/onboarding/gettingStartedDoc/types'; import { getCrashReportModalConfigDescription, getCrashReportModalIntroduction, getCrashReportPHPInstallStep, } from 'sentry/components/onboarding/gettingStartedDoc/utils/feedbackOnboarding'; import exampleSnippets from 'sentry/components/onboarding/gettingStartedDoc/utils/metricsExampleSnippets'; import replayOnboardingJsLoader from 'sentry/gettingStartedDocs/javascript/jsLoader/jsLoader'; import {t, tct} from 'sentry/locale'; type Params = DocsParams; const getConfigureSnippet = (params: Params) => `\\Sentry\\init([ 'dsn' => '${params.dsn}',${ params.isPerformanceSelected ? ` // Specify a fixed sample rate 'traces_sample_rate' => 1.0,` : '' }${ params.isProfilingSelected ? ` // Set a sampling rate for profiling - this is relative to traces_sample_rate 'profiles_sample_rate' => 1.0,` : '' } ]);`; const getMetricsConfigureSnippet = () => ` use function \\Sentry\\init; \\Sentry\\init([ 'attach_metric_code_locations' => true, ]);`; const getVerifySnippet = () => ` try { $this->functionFailsForSure(); } catch (\\Throwable $exception) { \\Sentry\\captureException($exception); }`; const onboarding: OnboardingConfig = { install: params => [ { type: StepType.INSTALL, description: tct( 'To install the PHP SDK, you need to be using Composer in your project. For more details about Composer, see the [composerDocumentationLink:Composer documentation].', { composerDocumentationLink: , } ), configurations: [ { language: 'bash', code: 'composer require sentry/sentry', }, ...(params.isProfilingSelected ? [ { description: t('Install the Excimer extension via PECL:'), language: 'bash', code: 'pecl install excimer', }, { description: tct( "The Excimer PHP extension supports PHP 7.2 and up. Excimer requires Linux or macOS and doesn't support Windows. For additional ways to install Excimer, see [sentryPhpDocumentationLink: Sentry documentation].", { sentryPhpDocumentationLink: ( ), } ), }, ] : []), ], }, ], configure: params => [ { type: StepType.CONFIGURE, description: t( 'To capture all errors, even the one during the startup of your application, you should initialize the Sentry PHP SDK as soon as possible.' ), configurations: [ { language: 'php', code: getConfigureSnippet(params), additionalInfo: params.isPerformanceSelected && (

{tct( 'To instrument certain regions of your code, you can [instrumentationLink:create transactions to capture them].', { instrumentationLink: ( ), } )}

), }, ], }, ], verify: () => [ { type: StepType.VERIFY, description: t( 'In PHP you can either capture a caught exception or capture the last error with captureLastError.' ), configurations: [ { language: 'php', code: getVerifySnippet(), }, ], }, ], nextSteps: () => [], }; const customMetricsOnboarding: OnboardingConfig = { install: () => [ { type: StepType.INSTALL, description: tct( 'You need a minimum version [codeVersion:4.3.0] of the Sentry PHP SDK installed.', { codeVersion: , } ), configurations: [ { language: 'bash', code: 'composer install sentry/sentry', }, ], }, ], configure: () => [ { type: StepType.CONFIGURE, description: t( 'Once the SDK is installed or updated, you can enable code locations being emitted with your metrics:' ), configurations: [ { code: [ { label: 'PHP', value: 'php', language: 'php', code: getMetricsConfigureSnippet(), }, ], }, ], }, ], verify: () => [ { type: StepType.VERIFY, description: tct( "Then you'll be able to add metrics as [codeCounters:counters], [codeSets:sets], [codeDistribution:distributions], and [codeGauge:gauges]. Try out this example:", { codeCounters: , codeSets: , codeDistribution: , codeGauge: , codeNamespace: , } ), configurations: [ { code: [ { label: 'Counter', value: 'counter', language: 'php', code: exampleSnippets.php.counter, }, { label: 'Distribution', value: 'distribution', language: 'php', code: exampleSnippets.php.distribution, }, { label: 'Set', value: 'set', language: 'php', code: exampleSnippets.php.set, }, { label: 'Gauge', value: 'gauge', language: 'php', code: exampleSnippets.php.gauge, }, ], }, { description: t( 'With a bit of delay you can see the data appear in the Sentry UI.' ), }, { description: tct( 'Learn more about metrics and how to configure them, by reading the [docsLink:docs].', { docsLink: ( ), } ), }, ], }, ], }; const crashReportOnboarding: OnboardingConfig = { introduction: () => getCrashReportModalIntroduction(), install: (params: Params) => getCrashReportPHPInstallStep(params), configure: () => [ { type: StepType.CONFIGURE, description: getCrashReportModalConfigDescription({ link: 'https://docs.sentry.io/platforms/php/user-feedback/configuration/#crash-report-modal', }), }, ], verify: () => [], nextSteps: () => [], }; const docs: Docs = { onboarding, replayOnboardingJsLoader, customMetricsOnboarding, crashReportOnboarding, }; export default docs;