From 3416924eb39a8015fc0237e5c35ea8a0d796d5ac Mon Sep 17 00:00:00 2001 From: Marc-Antoine Hinse Date: Mon, 18 Nov 2024 12:35:26 -0500 Subject: [PATCH] Creating flare index on first configuration and let user change their cron job index in the configuration screen --- .../src/ConfigurationScreen.tsx | 28 +++++- .../components/ConfigurationCompletedStep.tsx | 10 +- .../components/ConfigurationGlobalStep.css | 9 +- .../components/ConfigurationInitialStep.tsx | 46 ++++----- .../ConfigurationUserPreferencesStep.css | 1 + .../ConfigurationUserPreferencesStep.tsx | 53 ++++++++--- .../src/components/Select.css | 2 +- packages/configuration-screen/src/global.css | 2 +- .../configuration-screen/src/models/splunk.ts | 14 ++- .../src/utils/configurationFileHelper.ts | 22 +++-- .../src/utils/setupConfiguration.ts | 93 ++++++++++++++----- packages/flare/bin/cron_job_ingest_events.py | 6 -- .../flare/tests/bin/test_ingest_events.py | 15 --- packages/status-screen/src/StatusScreen.tsx | 52 +++++++---- 14 files changed, 226 insertions(+), 127 deletions(-) diff --git a/packages/configuration-screen/src/ConfigurationScreen.tsx b/packages/configuration-screen/src/ConfigurationScreen.tsx index 3278ee2..eb52b24 100644 --- a/packages/configuration-screen/src/ConfigurationScreen.tsx +++ b/packages/configuration-screen/src/ConfigurationScreen.tsx @@ -1,7 +1,11 @@ import React, { useEffect, useState, FC } from 'react'; import { + appName, + createFlareIndex, redirectToHomepage, retrieveApiKey, + retrieveAvailableIndexNames, + retrieveCurrentIndexName, retrieveIngestMetadataOnly, retrieveTenantId, retrieveUserTenants, @@ -25,11 +29,13 @@ const TOAST_TENANT_SUCCESS = 'tenant_success'; const ConfigurationScreen: FC<{ theme: string }> = ({ theme }) => { const [apiKey, setApiKey] = useState(''); const [tenantId, setTenantId] = useState(-1); + const [indexName, setIndexName] = useState(appName); const [errorMessage, setErrorMessage] = useState(''); const [tenants, setUserTenants] = useState([]); const [isIngestingMetadataOnly, setIsIngestingMetadataOnly] = useState(false); const [isLoading, setIsLoading] = useState(false); const [isCompleted, setIsCompleted] = useState(false); + const [indexNames, setIndexNames] = useState([]); toastManager.setTheme(theme); @@ -54,6 +60,7 @@ const ConfigurationScreen: FC<{ theme: string }> = ({ theme }) => { const handleApiKeyChange = (e): void => setApiKey(e.target.value); const handleTenantIdChange = (e): void => setTenantId(parseInt(e.target.value, 10)); + const handleIndexNameChange = (e): void => setIndexName(e.target.value); const handleIsIngestingMetadataChange = (e): void => { setIsIngestingMetadataOnly(e.target.checked); }; @@ -95,7 +102,7 @@ const ConfigurationScreen: FC<{ theme: string }> = ({ theme }) => { const handleSubmitTenant = (): void => { setIsLoading(true); - saveConfiguration(apiKey, tenantId, isIngestingMetadataOnly) + saveConfiguration(apiKey, tenantId, indexName, isIngestingMetadataOnly) .then(() => { setIsLoading(false); setIsCompleted(true); @@ -128,13 +135,21 @@ const ConfigurationScreen: FC<{ theme: string }> = ({ theme }) => { if (isCompleted) { return; } - Promise.all([retrieveApiKey(), retrieveTenantId(), retrieveIngestMetadataOnly()]).then( - ([key, id, ingestMetadataOnly]) => { + createFlareIndex().then(() => { + Promise.all([ + retrieveApiKey(), + retrieveTenantId(), + retrieveIngestMetadataOnly(), + retrieveCurrentIndexName(), + retrieveAvailableIndexNames(), + ]).then(([key, id, ingestMetadataOnly, index, availableIndexNames]) => { setApiKey(key); setTenantId(id); setIsIngestingMetadataOnly(ingestMetadataOnly); - } - ); + setIndexName(index); + setIndexNames(availableIndexNames); + }); + }); }, [isCompleted]); useEffect(() => { @@ -178,11 +193,14 @@ const ConfigurationScreen: FC<{ theme: string }> = ({ theme }) => { show={currentConfigurationStep === ConfigurationSteps.UserPreferences} selectedTenantId={tenantId} tenants={tenants} + selectedIndexName={indexName} + indexNames={indexNames} isLoading={isLoading} isIngestingMetadataOnly={isIngestingMetadataOnly} onNavigateBackClick={handleBackButton} onSubmitUserPreferencesClick={handleSubmitTenant} onTenantIdChange={handleTenantIdChange} + onIndexNameChange={handleIndexNameChange} onIngestingMetadataChange={handleIsIngestingMetadataChange} /> void; }> = ({ show, tenantName, onEditConfigurationClick }) => { - const [indexName, setIndexName] = useState(); - - useEffect(() => { - getFlareDataUrl().then((name) => setIndexName(name)); - }, []); - return ( diff --git a/packages/configuration-screen/src/components/ConfigurationGlobalStep.css b/packages/configuration-screen/src/components/ConfigurationGlobalStep.css index adacccd..94c04e6 100644 --- a/packages/configuration-screen/src/components/ConfigurationGlobalStep.css +++ b/packages/configuration-screen/src/components/ConfigurationGlobalStep.css @@ -3,7 +3,7 @@ flex-direction: row; justify-content: space-between; align-items: center; - margin-top: 2.5rem; + margin-top: 1.5rem; gap: 1rem; } @@ -13,6 +13,13 @@ width: 100%; align-items: flex-start; margin-top: 1rem; + gap: 1rem; +} + +.form-item { + display: flex; + flex-direction: column; + align-items: flex-start; } .progress-bar-container { diff --git a/packages/configuration-screen/src/components/ConfigurationInitialStep.tsx b/packages/configuration-screen/src/components/ConfigurationInitialStep.tsx index a0a3d2d..a1256f7 100644 --- a/packages/configuration-screen/src/components/ConfigurationInitialStep.tsx +++ b/packages/configuration-screen/src/components/ConfigurationInitialStep.tsx @@ -28,28 +28,30 @@ const ConfigurationInitialStep: FC<{