import {Alert} from 'sentry/components/core/alert'; 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 { feedbackOnboardingJsLoader, 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.public}',${ 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 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: ( ), } )}

), }, { description: ( {tct( 'In order to receive stack trace arguments in your errors, make sure to set [code:zend.exception_ignore_args: Off] in your php.ini', { code: , } )} ), }, ], }, ], 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 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 performanceOnboarding: OnboardingConfig = { introduction: () => t( "Adding Performance to your PHP project is simple. Make sure you've got these basics down." ), install: onboarding.install, configure: params => [ { type: StepType.CONFIGURE, description: t( 'To capture all errors and transactions, even the one during the startup of your application, you should initialize the Sentry PHP SDK as soon as possible.' ), configurations: [ { description: tct( 'To initialize the SDK before everything else, create an external file called [code:instrument.js/mjs] and make sure to import it in your apps entrypoint before anything else.', {code: } ), language: 'php', code: ` \\Sentry\\init([ 'dsn' => '${params.dsn.public}', // Set tracesSampleRate to 1.0 to capture 100% // of transactions for performance monitoring. 'traces_sample_rate' => 1.0, ]); `, additionalInfo: tct( 'We recommend adjusting the value of [code:tracesSampleRate] in production. Learn more about tracing [linkTracingOptions:options], how to use the [linkTracesSampler:traces_sampler] function, or how to do [linkSampleTransactions:sampling].', { code: , linkTracingOptions: ( ), linkTracesSampler: ( ), linkSampleTransactions: ( ), } ), }, ], }, ], verify: () => [ { type: StepType.VERIFY, description: tct( 'Verify that performance monitoring is working correctly with our [link:automatic instrumentation] by simply using your Node application.', { link: ( ), } ), }, ], nextSteps: () => [], }; const docs: Docs = { onboarding, replayOnboardingJsLoader, performanceOnboarding, crashReportOnboarding, feedbackOnboardingJsLoader, }; export default docs;