123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- import type {Entry, EntrySpans} from 'sentry/types';
- import {EntryType} from 'sentry/types';
- import type {Sort} from 'sentry/utils/discover/fields';
- import {useEventDetails} from 'sentry/views/starfish/queries/useEventDetails';
- import {useIndexedSpans} from 'sentry/views/starfish/queries/useIndexedSpans';
- import {SpanIndexedField} from 'sentry/views/starfish/types';
- const DEFAULT_SORT: Sort[] = [{field: 'timestamp', kind: 'desc'}];
- // NOTE: Fetching the top one is a bit naive, but works for now. A better
- // approach might be to fetch several at a time, and let the hook consumer
- // decide how to display them
- export function useFullSpanFromTrace(
- group?: string,
- sorts?: Sort[],
- enabled: boolean = true,
- extraFilters: Record<string, string> = {}
- ) {
- const filters = {...extraFilters};
- if (group) {
- filters[SpanIndexedField.SPAN_GROUP] = group;
- }
- // TODO: we're using all SpanIndexedFields here, but maybe we should only use what we need?
- // Truncate to 20 fields otherwise discover will complain.
- const fields = Object.values(SpanIndexedField).slice(0, 20);
- const indexedSpansResponse = useIndexedSpans({
- filters,
- sorts: sorts || DEFAULT_SORT,
- limit: 1,
- enabled,
- fields,
- referrer: 'api.starfish.full-span-from-trace',
- });
- const firstIndexedSpan = indexedSpansResponse.data?.[0];
- const eventDetailsResponse = useEventDetails({
- eventId: firstIndexedSpan?.[SpanIndexedField.TRANSACTION_ID],
- projectSlug: firstIndexedSpan?.[SpanIndexedField.PROJECT],
- });
- const spanEntry = eventDetailsResponse.data?.entries.find(
- (entry: Entry): entry is EntrySpans => {
- return entry.type === EntryType.SPANS;
- }
- );
- const fullSpan = spanEntry?.data?.find(
- span => span.span_id === firstIndexedSpan?.[SpanIndexedField.ID]
- );
- // N.B. There isn't a great pattern for us to merge the responses together,
- // so we're only merging the three most important properties
- return {
- isLoading: indexedSpansResponse.isLoading || eventDetailsResponse.isLoading,
- isFetching: indexedSpansResponse.isFetching || eventDetailsResponse.isFetching,
- isError: indexedSpansResponse.isError || eventDetailsResponse.isError,
- data: fullSpan,
- };
- }
|