mirror of
https://git.mirrors.martin98.com/https://github.com/SigNoz/signoz
synced 2025-08-04 05:30:39 +08:00

* feat: tree is updated to show different node values instead of editor * chore: table view is updated * [Refactoring]: Seperate title and menu to another component (#3531) * refactor: separated the title renderer * refactor: separated styles * refactor: seperate types * refactor: instead of key showing value if array (#3532) * refactor: instead of key showing value if array * feat: added filter for array and also nodekey * refactor: made common check for value is array * refactor: changed the key to value for arrays * chore: getData types is updated * chore: getDataTypes function types is updated * refactor: connection to querybuilder (#3535) Co-authored-by: Palash Gupta <palashgdev@gmail.com> * chore: operator is updated * fix: build is fixed * fix: build is fixed * chore: operator is updated * chore: operator is updated * chore: parsing is updated * chore: key is updated * Refactor: Log parsing updates (#3542) * refactor: updated nodekey * refactor: removed pasred data * refactor: parentIsArray check * chore: added the support for the bool * [Refactor]: handle nested object case (#3545) * refactor: updated nodekey * refactor: removed pasred data * refactor: parentIsArray check * refactor: handled nested array inside object case * fix: float issue parsing * chore: operator is updated * chore: title is updated * chore: title is updated * fix: update tagRegexp * fix: maintain single source of DataTypes * chore: operator is updated * fix: fixed due to merge conflicts --------- Co-authored-by: Rajat Dabade <rajat@signoz.io> Co-authored-by: Yunus A M <myounis.ar@live.com>
178 lines
4.5 KiB
TypeScript
178 lines
4.5 KiB
TypeScript
import {
|
|
getResourceAttributesTagKeys,
|
|
getResourceAttributesTagValues,
|
|
} from 'api/metrics/getResourceAttributes';
|
|
import { OperatorConversions } from 'constants/resourceAttributes';
|
|
import ROUTES from 'constants/routes';
|
|
import { MetricsType } from 'container/MetricsApplication/constant';
|
|
import {
|
|
IOption,
|
|
IResourceAttribute,
|
|
IResourceAttributeProps,
|
|
} from 'hooks/useResourceAttribute/types';
|
|
import { decode } from 'js-base64';
|
|
import history from 'lib/history';
|
|
import { DataTypes } from 'types/api/queryBuilder/queryAutocompleteResponse';
|
|
import { TagFilterItem } from 'types/api/queryBuilder/queryBuilderData';
|
|
import { OperatorValues, Tags } from 'types/reducer/trace';
|
|
import { v4 as uuid } from 'uuid';
|
|
|
|
import { whilelistedKeys } from './config';
|
|
|
|
/**
|
|
* resource_x_y -> x.y
|
|
*/
|
|
export const convertMetricKeyToTrace = (key: string): string => {
|
|
const splittedKey = key.split('_');
|
|
|
|
if (splittedKey.length <= 1) {
|
|
return '';
|
|
}
|
|
return splittedKey.splice(1).join('.');
|
|
};
|
|
|
|
/**
|
|
* x.y -> resource_x_y
|
|
*/
|
|
export const convertTraceKeyToMetric = (key: string): string => {
|
|
const splittedKey = key.split('.');
|
|
return `resource_${splittedKey.join('_')}`;
|
|
};
|
|
|
|
export const convertOperatorLabelToMetricOperator = (label: string): string =>
|
|
OperatorConversions.find((operator) => operator.label === label)
|
|
?.metricValue || '';
|
|
|
|
export const convertOperatorLabelToTraceOperator = (
|
|
label: string,
|
|
): OperatorValues =>
|
|
OperatorConversions.find((operator) => operator.label === label)
|
|
?.traceValue as OperatorValues;
|
|
|
|
export const convertRawQueriesToTraceSelectedTags = (
|
|
queries: IResourceAttribute[],
|
|
tagType = 'ResourceAttribute',
|
|
): Tags[] =>
|
|
queries.map((query) => ({
|
|
Key: convertMetricKeyToTrace(query.tagKey),
|
|
Operator: convertOperatorLabelToTraceOperator(query.operator),
|
|
StringValues: query.tagValue,
|
|
NumberValues: [],
|
|
BoolValues: [],
|
|
TagType: tagType,
|
|
}));
|
|
|
|
/* Convert resource attributes to tagFilter items for queryBuilder */
|
|
export const resourceAttributesToTagFilterItems = (
|
|
queries: IResourceAttribute[],
|
|
isTraceDataSource = false,
|
|
): TagFilterItem[] => {
|
|
if (isTraceDataSource) {
|
|
return convertRawQueriesToTraceSelectedTags(queries).map((e) => ({
|
|
id: e.Key,
|
|
op: e.Operator,
|
|
value: e.StringValues,
|
|
key: {
|
|
dataType: DataTypes.String,
|
|
type: MetricsType.Resource,
|
|
isColumn: false,
|
|
key: e.Key,
|
|
},
|
|
}));
|
|
}
|
|
|
|
return queries.map((res) => ({
|
|
id: `${res.id}`,
|
|
key: {
|
|
key: res.tagKey,
|
|
isColumn: false,
|
|
type: '',
|
|
dataType: DataTypes.EMPTY,
|
|
},
|
|
op: `${res.operator}`,
|
|
value: `${res.tagValue}`.split(','),
|
|
}));
|
|
};
|
|
|
|
export const OperatorSchema: IOption[] = OperatorConversions.map(
|
|
(operator) => ({
|
|
label: operator.label,
|
|
value: operator.label,
|
|
}),
|
|
);
|
|
|
|
export const GetTagKeys = async (): Promise<IOption[]> => {
|
|
const { payload } = await getResourceAttributesTagKeys({
|
|
metricName: 'signoz_calls_total',
|
|
match: 'resource_',
|
|
});
|
|
if (!payload || !payload?.data) {
|
|
return [];
|
|
}
|
|
return payload.data.map((tagKey: string) => ({
|
|
label: convertMetricKeyToTrace(tagKey),
|
|
value: tagKey,
|
|
}));
|
|
};
|
|
|
|
export const GetTagValues = async (tagKey: string): Promise<IOption[]> => {
|
|
const { payload } = await getResourceAttributesTagValues({
|
|
tagKey,
|
|
metricName: 'signoz_calls_total',
|
|
});
|
|
|
|
if (!payload || !payload?.data) {
|
|
return [];
|
|
}
|
|
return payload.data.map((tagValue: string) => ({
|
|
label: tagValue,
|
|
value: tagValue,
|
|
}));
|
|
};
|
|
|
|
export const createQuery = (
|
|
selectedItems: Array<string | string[]> = [],
|
|
): IResourceAttribute | null => {
|
|
if (selectedItems.length === 3) {
|
|
return {
|
|
id: uuid().slice(0, 8),
|
|
tagKey: selectedItems[0] as string,
|
|
operator: selectedItems[1] as string,
|
|
tagValue: selectedItems[2] as string[],
|
|
};
|
|
}
|
|
return null;
|
|
};
|
|
|
|
export function getResourceAttributeQueriesFromURL(): IResourceAttribute[] {
|
|
const resourceAttributeQuery = new URLSearchParams(
|
|
history.location.search,
|
|
).get('resourceAttribute');
|
|
|
|
try {
|
|
if (resourceAttributeQuery) {
|
|
return JSON.parse(decode(resourceAttributeQuery)) as IResourceAttribute[];
|
|
}
|
|
} catch (error) {
|
|
console.error(error);
|
|
}
|
|
|
|
return [];
|
|
}
|
|
|
|
export const isResourceEmpty = (
|
|
queries: IResourceAttributeProps['queries'],
|
|
staging: IResourceAttributeProps['staging'],
|
|
selectedQuery: IResourceAttributeProps['selectedQuery'],
|
|
): boolean => !!(queries.length || staging.length || selectedQuery.length);
|
|
|
|
export const mappingWithRoutesAndKeys = (
|
|
pathname: string,
|
|
filters: IOption[],
|
|
): IOption[] => {
|
|
if (ROUTES.SERVICE_MAP === pathname) {
|
|
return filters.filter((filter) => whilelistedKeys.includes(filter.value));
|
|
}
|
|
return filters;
|
|
};
|