useSpanMetrics.tsx 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. import {Location} from 'history';
  2. import EventView from 'sentry/utils/discover/eventView';
  3. import {DiscoverDatasets} from 'sentry/utils/discover/types';
  4. import {useLocation} from 'sentry/utils/useLocation';
  5. import type {IndexedSpan} from 'sentry/views/starfish/queries/types';
  6. import {SpanMetricsFields} from 'sentry/views/starfish/types';
  7. import {useSpansQuery} from 'sentry/views/starfish/utils/useSpansQuery';
  8. const {SPAN_GROUP} = SpanMetricsFields;
  9. export type SpanMetrics = {
  10. [metric: string]: number | string;
  11. 'http_error_count()': number;
  12. 'p95(span.self_time)': number;
  13. 'span.op': string;
  14. 'sps()': number;
  15. 'time_spent_percentage()': number;
  16. };
  17. export type SpanSummaryQueryFilters = {
  18. 'transaction.method'?: string;
  19. transactionName?: string;
  20. };
  21. export const useSpanMetrics = (
  22. span?: Pick<IndexedSpan, 'group'>,
  23. queryFilters: SpanSummaryQueryFilters = {},
  24. fields: string[] = [],
  25. referrer: string = 'span-metrics',
  26. enabled: boolean = true
  27. ) => {
  28. const location = useLocation();
  29. const eventView = span ? getEventView(span, location, queryFilters, fields) : undefined;
  30. // TODO: Add referrer
  31. const result = useSpansQuery<SpanMetrics[]>({
  32. eventView,
  33. initialData: [],
  34. enabled: Boolean(span) && enabled,
  35. referrer,
  36. });
  37. return {...result, data: result?.data?.[0] ?? {}};
  38. };
  39. function getEventView(
  40. span: {group: string},
  41. location: Location,
  42. queryFilters?: SpanSummaryQueryFilters,
  43. fields: string[] = []
  44. ) {
  45. const cleanGroupId = span.group.replaceAll('-', '').slice(-16);
  46. return EventView.fromNewQueryWithLocation(
  47. {
  48. name: '',
  49. query: `${SPAN_GROUP}:${cleanGroupId}${
  50. queryFilters?.transactionName
  51. ? ` transaction:${queryFilters?.transactionName}`
  52. : ''
  53. }${
  54. queryFilters?.['transaction.method']
  55. ? ` transaction.method:${queryFilters?.['transaction.method']}`
  56. : ''
  57. }`,
  58. fields,
  59. dataset: DiscoverDatasets.SPANS_METRICS,
  60. version: 2,
  61. },
  62. location
  63. );
  64. }