From 1b5ab44b6cc1364f2addc7e527fe17d8d9844a13 Mon Sep 17 00:00:00 2001 From: Adam Tackett Date: Tue, 7 Jan 2025 16:01:51 -0800 Subject: [PATCH] add validation to url mode Signed-off-by: Adam Tackett --- public/components/trace_analytics/home.tsx | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/public/components/trace_analytics/home.tsx b/public/components/trace_analytics/home.tsx index fa85e63f0..3d3e7ed39 100644 --- a/public/components/trace_analytics/home.tsx +++ b/public/components/trace_analytics/home.tsx @@ -210,6 +210,10 @@ export const Home = (props: HomeProps) => { ]); }; + const isValidTraceAnalyticsMode = (urlMode: string | null): urlMode is TraceAnalyticsMode => { + return ['jaeger', 'data_prepper', 'custom_data_prepper'].includes(urlMode || ''); + }; + useEffect(() => { handleDataPrepperIndicesExistRequest( props.http, @@ -406,7 +410,8 @@ export const Home = (props: HomeProps) => { render={(_routerProps) => { const queryParams = new URLSearchParams(window.location.href.split('?')[1]); const traceId = queryParams.get('traceId'); - const traceMode = queryParams.get('mode'); + const traceModeFromURL = queryParams.get('mode'); + const traceMode = isValidTraceAnalyticsMode(traceModeFromURL) ? traceModeFromURL : mode; const SideBarComponent = !isNavGroupEnabled ? TraceSideBar : React.Fragment; if (!traceId) { @@ -451,7 +456,10 @@ export const Home = (props: HomeProps) => { render={(_routerProps) => { const queryParams = new URLSearchParams(window.location.href.split('?')[1]); const serviceId = queryParams.get('serviceId'); - const serviceMode = queryParams.get('mode'); + const serviceModeFromURL = queryParams.get('mode'); + const serviceMode = isValidTraceAnalyticsMode(serviceModeFromURL) + ? serviceModeFromURL + : mode; const SideBarComponent = !isNavGroupEnabled ? TraceSideBar : React.Fragment; if (!serviceId) {