123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 |
- import {t} from 'sentry/locale';
- import {Organization} from 'sentry/types';
- import {
- Dataset,
- EventTypes,
- SessionsAggregate,
- } from 'sentry/views/alerts/rules/metric/types';
- export type AlertType =
- | 'issues'
- | 'num_errors'
- | 'users_experiencing_errors'
- | 'throughput'
- | 'trans_duration'
- | 'apdex'
- | 'failure_rate'
- | 'lcp'
- | 'fid'
- | 'cls'
- | 'custom'
- | 'crash_free_sessions'
- | 'crash_free_users';
- export enum MEPAlertsQueryType {
- ERROR = 0,
- PERFORMANCE = 1,
- CRASH_RATE = 2,
- }
- export enum MEPAlertsDataset {
- DISCOVER = 'discover',
- METRICS = 'metrics',
- METRICS_ENHANCED = 'metricsEnhanced',
- }
- export type MetricAlertType = Exclude<AlertType, 'issues'>;
- export const DatasetMEPAlertQueryTypes: Record<Dataset, MEPAlertsQueryType> = {
- [Dataset.ERRORS]: MEPAlertsQueryType.ERROR,
- [Dataset.TRANSACTIONS]: MEPAlertsQueryType.PERFORMANCE,
- [Dataset.GENERIC_METRICS]: MEPAlertsQueryType.PERFORMANCE,
- [Dataset.METRICS]: MEPAlertsQueryType.CRASH_RATE,
- [Dataset.SESSIONS]: MEPAlertsQueryType.CRASH_RATE,
- };
- export const AlertWizardAlertNames: Record<AlertType, string> = {
- issues: t('Issues'),
- num_errors: t('Number of Errors'),
- users_experiencing_errors: t('Users Experiencing Errors'),
- throughput: t('Throughput'),
- trans_duration: t('Transaction Duration'),
- apdex: t('Apdex'),
- failure_rate: t('Failure Rate'),
- lcp: t('Largest Contentful Paint'),
- fid: t('First Input Delay'),
- cls: t('Cumulative Layout Shift'),
- custom: t('Custom Metric'),
- crash_free_sessions: t('Crash Free Session Rate'),
- crash_free_users: t('Crash Free User Rate'),
- };
- type AlertWizardCategory = {
- categoryHeading: string;
- options: AlertType[];
- };
- export const getAlertWizardCategories = (org: Organization): AlertWizardCategory[] => [
- {
- categoryHeading: t('Errors'),
- options: ['issues', 'num_errors', 'users_experiencing_errors'],
- },
- ...(org.features.includes('crash-rate-alerts')
- ? [
- {
- categoryHeading: t('Sessions'),
- options: ['crash_free_sessions', 'crash_free_users'] as AlertType[],
- },
- ]
- : []),
- {
- categoryHeading: t('Performance'),
- options: [
- 'throughput',
- 'trans_duration',
- 'apdex',
- 'failure_rate',
- 'lcp',
- 'fid',
- 'cls',
- ],
- },
- {
- categoryHeading: t('Other'),
- options: ['custom'],
- },
- ];
- export type WizardRuleTemplate = {
- aggregate: string;
- dataset: Dataset;
- eventTypes: EventTypes;
- };
- export const AlertWizardRuleTemplates: Record<
- MetricAlertType,
- Readonly<WizardRuleTemplate>
- > = {
- num_errors: {
- aggregate: 'count()',
- dataset: Dataset.ERRORS,
- eventTypes: EventTypes.ERROR,
- },
- users_experiencing_errors: {
- aggregate: 'count_unique(user)',
- dataset: Dataset.ERRORS,
- eventTypes: EventTypes.ERROR,
- },
- throughput: {
- aggregate: 'count()',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- trans_duration: {
- aggregate: 'p95(transaction.duration)',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- apdex: {
- aggregate: 'apdex(300)',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- failure_rate: {
- aggregate: 'failure_rate()',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- lcp: {
- aggregate: 'p95(measurements.lcp)',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- fid: {
- aggregate: 'p95(measurements.fid)',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- cls: {
- aggregate: 'p95(measurements.cls)',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- custom: {
- aggregate: 'p95(measurements.fp)',
- dataset: Dataset.TRANSACTIONS,
- eventTypes: EventTypes.TRANSACTION,
- },
- crash_free_sessions: {
- aggregate: SessionsAggregate.CRASH_FREE_SESSIONS,
- // TODO(scttcper): Use Dataset.Metric on GA of alert-crash-free-metrics
- dataset: Dataset.SESSIONS,
- eventTypes: EventTypes.SESSION,
- },
- crash_free_users: {
- aggregate: SessionsAggregate.CRASH_FREE_USERS,
- // TODO(scttcper): Use Dataset.Metric on GA of alert-crash-free-metrics
- dataset: Dataset.SESSIONS,
- eventTypes: EventTypes.USER,
- },
- };
- export const DEFAULT_WIZARD_TEMPLATE = AlertWizardRuleTemplates.num_errors;
- export const hidePrimarySelectorSet = new Set<AlertType>([
- 'num_errors',
- 'users_experiencing_errors',
- 'throughput',
- 'apdex',
- 'failure_rate',
- 'crash_free_sessions',
- 'crash_free_users',
- ]);
- export const hideParameterSelectorSet = new Set<AlertType>([
- 'trans_duration',
- 'lcp',
- 'fid',
- 'cls',
- ]);
- export function getFunctionHelpText(alertType: AlertType): {
- labelText: string;
- timeWindowText?: string;
- } {
- const timeWindowText = t('over');
- if (alertType === 'apdex') {
- return {
- labelText: t('Select apdex threshold and time interval'),
- timeWindowText,
- };
- }
- if (hidePrimarySelectorSet.has(alertType)) {
- return {
- labelText: t('Select time interval'),
- };
- }
- return {
- labelText: t('Select function and time interval'),
- timeWindowText,
- };
- }
- export function getMEPAlertsDataset(
- dataset: Dataset,
- newAlert: boolean
- ): MEPAlertsDataset {
- // Dataset.ERRORS overrides all cases
- if (dataset === Dataset.ERRORS) {
- return MEPAlertsDataset.DISCOVER;
- }
- if (newAlert) {
- return MEPAlertsDataset.METRICS_ENHANCED;
- }
- if (dataset === Dataset.GENERIC_METRICS) {
- return MEPAlertsDataset.METRICS;
- }
- return MEPAlertsDataset.DISCOVER;
- }
|