From 44d85c7d8c80308bd29d110e315daead94bf6e41 Mon Sep 17 00:00:00 2001 From: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> Date: Wed, 24 Jul 2024 00:47:29 +0200 Subject: [PATCH] [8.15] [Security solution] Remove `isEnabledLangChain` from UI and telemetry (#188990) (#189012) # Backport This will backport the following commits from `main` to `8.15`: - [[Security solution] Remove `isEnabledLangChain` from UI and telemetry (#188990)](https://github.com/elastic/kibana/pull/188990) ### Questions ? Please refer to the [Backport tool documentation](https://github.com/sqren/backport) Co-authored-by: Steph Milovic --- .../alerts/settings/alerts_settings.test.tsx | 4 - .../chat_send/use_chat_send.test.tsx | 5 - .../assistant/chat_send/use_chat_send.tsx | 12 +- .../impl/assistant/index.tsx | 4 - .../select_system_prompt/index.test.tsx | 4 - .../quick_prompts/quick_prompts.test.tsx | 3 - .../assistant/quick_prompts/quick_prompts.tsx | 11 +- .../use_settings_updater.test.tsx | 31 +- .../use_settings_updater.tsx | 29 +- .../impl/assistant/types.ts | 2 - .../impl/assistant_context/constants.tsx | 2 - .../impl/assistant_context/index.tsx | 2 - .../impl/assistant_context/types.tsx | 8 +- .../knowledge_base_settings.test.tsx | 2 - .../assistant/get_comments/index.test.tsx | 1 - .../public/assistant/get_comments/index.tsx | 10 - .../get_comments/stream/index.test.tsx | 2 - .../assistant/get_comments/stream/index.tsx | 6 - .../stream/stream_observable.test.ts | 373 +----------------- .../get_comments/stream/stream_observable.ts | 236 +---------- .../get_comments/stream/use_stream.test.tsx | 2 - .../get_comments/stream/use_stream.tsx | 11 +- .../use_attack_discovery/helpers.test.ts | 2 - .../use_attack_discovery/index.test.tsx | 2 - .../telemetry/events/ai_assistant/index.ts | 25 +- .../telemetry/events/ai_assistant/types.ts | 5 +- 26 files changed, 36 insertions(+), 758 deletions(-) diff --git a/x-pack/packages/kbn-elastic-assistant/impl/alerts/settings/alerts_settings.test.tsx b/x-pack/packages/kbn-elastic-assistant/impl/alerts/settings/alerts_settings.test.tsx index e708082296112..3e730451ba1d5 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/alerts/settings/alerts_settings.test.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/alerts/settings/alerts_settings.test.tsx @@ -20,8 +20,6 @@ describe('AlertsSettings', () => { it('updates the knowledgeBase settings when the alerts range slider is changed', () => { const setUpdatedKnowledgeBaseSettings = jest.fn(); const knowledgeBase: KnowledgeBaseConfig = { - isEnabledRAGAlerts: true, - isEnabledKnowledgeBase: false, latestAlerts: DEFAULT_LATEST_ALERTS, }; @@ -36,8 +34,6 @@ describe('AlertsSettings', () => { fireEvent.change(rangeSlider, { target: { value: '10' } }); expect(setUpdatedKnowledgeBaseSettings).toHaveBeenCalledWith({ - isEnabledRAGAlerts: true, - isEnabledKnowledgeBase: false, latestAlerts: 10, }); }); diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.test.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.test.tsx index a9231499570c7..77045b9572841 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.test.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.test.tsx @@ -63,7 +63,6 @@ describe('use chat send', () => { assistantTelemetry: { reportAssistantMessageSent, }, - knowledgeBase: { isEnabledKnowledgeBase: false, isEnabledRAGAlerts: false }, }); }); it('handleOnChatCleared clears the conversation', async () => { @@ -150,8 +149,6 @@ describe('use chat send', () => { expect(reportAssistantMessageSent).toHaveBeenNthCalledWith(1, { conversationId: testProps.currentConversation?.title, role: 'user', - isEnabledKnowledgeBase: false, - isEnabledRAGAlerts: false, actionTypeId: '.gen-ai', model: undefined, provider: 'OpenAI', @@ -159,8 +156,6 @@ describe('use chat send', () => { expect(reportAssistantMessageSent).toHaveBeenNthCalledWith(2, { conversationId: testProps.currentConversation?.title, role: 'assistant', - isEnabledKnowledgeBase: false, - isEnabledRAGAlerts: false, actionTypeId: '.gen-ai', model: undefined, provider: 'OpenAI', diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.tsx index c501adc91293f..c571912310905 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/chat_send/use_chat_send.tsx @@ -57,11 +57,7 @@ export const useChatSend = ({ setUserPrompt, setCurrentConversation, }: UseChatSendProps): UseChatSend => { - const { - assistantTelemetry, - knowledgeBase: { isEnabledKnowledgeBase, isEnabledRAGAlerts }, - toasts, - } = useAssistantContext(); + const { assistantTelemetry, toasts } = useAssistantContext(); const { isLoading, sendMessage, abortStream } = useSendMessage(); const { clearConversation, removeLastMessage } = useConversation(); @@ -129,8 +125,6 @@ export const useChatSend = ({ assistantTelemetry?.reportAssistantMessageSent({ conversationId: currentConversation.title, role: userMessage.role, - isEnabledKnowledgeBase, - isEnabledRAGAlerts, actionTypeId: currentConversation.apiConfig.actionTypeId, model: currentConversation.apiConfig.model, provider: currentConversation.apiConfig.provider, @@ -149,8 +143,6 @@ export const useChatSend = ({ actionTypeId: currentConversation.apiConfig.actionTypeId, model: currentConversation.apiConfig.model, provider: currentConversation.apiConfig.provider, - isEnabledKnowledgeBase, - isEnabledRAGAlerts, }); }, [ @@ -159,8 +151,6 @@ export const useChatSend = ({ currentConversation, editingSystemPromptId, http, - isEnabledKnowledgeBase, - isEnabledRAGAlerts, selectedPromptContexts, sendMessage, setCurrentConversation, diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/index.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/index.tsx index 92b285c7eca55..e4457a8f38d4d 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/index.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/index.tsx @@ -118,7 +118,6 @@ const AssistantComponent: React.FC = ({ assistantAvailability: { isAssistantEnabled }, getComments, http, - knowledgeBase: { isEnabledKnowledgeBase, isEnabledRAGAlerts }, promptContexts, setLastConversationId, getLastConversationId, @@ -585,7 +584,6 @@ const AssistantComponent: React.FC = ({ showAnonymizedValues, refetchCurrentConversation, regenerateMessage: handleRegenerateResponse, - isEnabledLangChain: isEnabledKnowledgeBase || isEnabledRAGAlerts, isFetchingResponse: isLoadingChatSend, setIsStreaming, currentUserAvatar, @@ -612,8 +610,6 @@ const AssistantComponent: React.FC = ({ showAnonymizedValues, refetchCurrentConversation, handleRegenerateResponse, - isEnabledKnowledgeBase, - isEnabledRAGAlerts, isLoadingChatSend, currentUserAvatar, selectedPromptContextsCount, diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/prompt_editor/system_prompt/select_system_prompt/index.test.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/prompt_editor/system_prompt/select_system_prompt/index.test.tsx index 7c8f575cd49d7..e04d813b85dd1 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/prompt_editor/system_prompt/select_system_prompt/index.test.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/prompt_editor/system_prompt/select_system_prompt/index.test.tsx @@ -74,10 +74,6 @@ const mockUseAssistantContext = { }, ], setAllSystemPrompts: jest.fn(), - knowledgeBase: { - isEnabledRAGAlerts: false, - isEnabledKnowledgeBase: false, - }, }; jest.mock('../../../../assistant_context', () => { const original = jest.requireActual('../../../../assistant_context'); diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.test.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.test.tsx index dda9f8e503b6e..e46f54ddede40 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.test.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.test.tsx @@ -26,9 +26,6 @@ const mockUseAssistantContext = { setSelectedSettingsTab, promptContexts: {}, allQuickPrompts: MOCK_QUICK_PROMPTS, - knowledgeBase: { - isEnabledKnowledgeBase: true, - }, }; const testTitle = 'SPL_QUERY_CONVERSION_TITLE'; diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.tsx index e910d238ccc5d..cbe4d8b1b9ff3 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/quick_prompts/quick_prompts.tsx @@ -43,14 +43,13 @@ export const QuickPrompts: React.FC = React.memo( ({ setInput, setIsSettingsModalVisible, trackPrompt, allPrompts }) => { const [quickPromptsContainerRef, { width }] = useMeasure(); - const { knowledgeBase, promptContexts, setSelectedSettingsTab } = useAssistantContext(); + const { promptContexts, setSelectedSettingsTab } = useAssistantContext(); const contextFilteredQuickPrompts = useMemo(() => { const registeredPromptContextTitles = Object.values(promptContexts).map((pc) => pc.category); - // If KB is enabled, include KNOWLEDGE_BASE_CATEGORY so KB dependent quick prompts are shown - if (knowledgeBase.isEnabledKnowledgeBase) { - registeredPromptContextTitles.push(KNOWLEDGE_BASE_CATEGORY); - } + // include KNOWLEDGE_BASE_CATEGORY so KB dependent quick prompts are shown + registeredPromptContextTitles.push(KNOWLEDGE_BASE_CATEGORY); + return allPrompts.filter((prompt) => { // only quick prompts if (prompt.promptType !== PromptTypeEnum.quick) { @@ -65,7 +64,7 @@ export const QuickPrompts: React.FC = React.memo( }); } }); - }, [allPrompts, knowledgeBase.isEnabledKnowledgeBase, promptContexts]); + }, [allPrompts, promptContexts]); // Overflow state const [isOverflowPopoverOpen, setIsOverflowPopoverOpen] = useState(false); diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.test.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.test.tsx index c7efa1f8e5922..e3a6ab1fc75b5 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.test.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.test.tsx @@ -48,8 +48,6 @@ const mockValues = { allSystemPrompts: mockSystemPrompts, allQuickPrompts: mockQuickPrompts, knowledgeBase: { - isEnabledRAGAlerts: true, - isEnabledKnowledgeBase: true, latestAlerts: DEFAULT_LATEST_ALERTS, }, baseConversations: {}, @@ -82,9 +80,7 @@ const updatedValues = { ], }, knowledgeBase: { - isEnabledRAGAlerts: false, - isEnabledKnowledgeBase: false, - latestAlerts: DEFAULT_LATEST_ALERTS, + latestAlerts: DEFAULT_LATEST_ALERTS + 10, }, assistantStreamingEnabled: false, }; @@ -206,7 +202,7 @@ describe('useSettingsUpdater', () => { expect(setKnowledgeBaseMock).toHaveBeenCalledWith(updatedValues.knowledgeBase); }); }); - it('should track which toggles have been updated when saveSettings is called', async () => { + it('should track when alerts count is updated', async () => { await act(async () => { const { result, waitForNextUpdate } = renderHook(() => useSettingsUpdater( @@ -225,16 +221,14 @@ describe('useSettingsUpdater', () => { await waitForNextUpdate(); const { setUpdatedKnowledgeBaseSettings } = result.current; - setUpdatedKnowledgeBaseSettings(updatedValues.knowledgeBase); - - await result.current.saveSettings(); - expect(reportAssistantSettingToggled).toHaveBeenCalledWith({ - isEnabledKnowledgeBase: false, - isEnabledRAGAlerts: false, + setUpdatedKnowledgeBaseSettings({ + ...updatedValues.knowledgeBase, }); + await result.current.saveSettings(); + expect(reportAssistantSettingToggled).toHaveBeenCalledWith({ alertsCountUpdated: true }); }); }); - it('should track only toggles that updated', async () => { + it('should track when streaming is updated', async () => { await act(async () => { const { result, waitForNextUpdate } = renderHook(() => useSettingsUpdater( @@ -251,19 +245,16 @@ describe('useSettingsUpdater', () => { ) ); await waitForNextUpdate(); - const { setUpdatedKnowledgeBaseSettings } = result.current; + const { setUpdatedAssistantStreamingEnabled } = result.current; - setUpdatedKnowledgeBaseSettings({ - ...updatedValues.knowledgeBase, - isEnabledKnowledgeBase: true, - }); + setUpdatedAssistantStreamingEnabled(false); await result.current.saveSettings(); expect(reportAssistantSettingToggled).toHaveBeenCalledWith({ - isEnabledRAGAlerts: false, + assistantStreamingEnabled: false, }); }); }); - it('if no toggles update, do not track anything', async () => { + it('if no settings update, do not track anything', async () => { await act(async () => { const { result, waitForNextUpdate } = renderHook(() => useSettingsUpdater( diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.tsx index f08a6f9fe6866..3d326acb66a06 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/settings/use_settings_updater/use_settings_updater.tsx @@ -172,21 +172,13 @@ export const useSettingsUpdater = ( const bulkResult = hasBulkConversations ? await bulkUpdateConversations(http, conversationsSettingsBulkActions, toasts) : undefined; - - const didUpdateKnowledgeBase = - knowledgeBase.isEnabledKnowledgeBase !== updatedKnowledgeBaseSettings.isEnabledKnowledgeBase; - const didUpdateRAGAlerts = - knowledgeBase.isEnabledRAGAlerts !== updatedKnowledgeBaseSettings.isEnabledRAGAlerts; const didUpdateAssistantStreamingEnabled = assistantStreamingEnabled !== updatedAssistantStreamingEnabled; - if (didUpdateKnowledgeBase || didUpdateRAGAlerts || didUpdateAssistantStreamingEnabled) { + const didUpdateAlertsCount = + knowledgeBase.latestAlerts !== updatedKnowledgeBaseSettings.latestAlerts; + if (didUpdateAssistantStreamingEnabled || didUpdateAlertsCount) { assistantTelemetry?.reportAssistantSettingToggled({ - ...(didUpdateKnowledgeBase - ? { isEnabledKnowledgeBase: updatedKnowledgeBaseSettings.isEnabledKnowledgeBase } - : {}), - ...(didUpdateRAGAlerts - ? { isEnabledRAGAlerts: updatedKnowledgeBaseSettings.isEnabledRAGAlerts } - : {}), + ...(didUpdateAlertsCount ? { alertsCountUpdated: didUpdateAlertsCount } : {}), ...(didUpdateAssistantStreamingEnabled ? { assistantStreamingEnabled: updatedAssistantStreamingEnabled } : {}), @@ -207,21 +199,20 @@ export const useSettingsUpdater = ( (bulkPromptsResult?.success ?? true) ); }, [ - hasBulkConversations, + hasBulkPrompts, http, - conversationsSettingsBulkActions, + promptsBulkActions, toasts, - knowledgeBase.isEnabledKnowledgeBase, - knowledgeBase.isEnabledRAGAlerts, - updatedKnowledgeBaseSettings, + hasBulkConversations, + conversationsSettingsBulkActions, assistantStreamingEnabled, updatedAssistantStreamingEnabled, + knowledgeBase.latestAlerts, + updatedKnowledgeBaseSettings, setAssistantStreamingEnabled, setKnowledgeBase, hasBulkAnonymizationFields, anonymizationFieldsBulkActions, - hasBulkPrompts, - promptsBulkActions, assistantTelemetry, ]); diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant/types.ts b/x-pack/packages/kbn-elastic-assistant/impl/assistant/types.ts index 587be76910c3e..a5e29665e2c4e 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant/types.ts +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant/types.ts @@ -6,8 +6,6 @@ */ export interface KnowledgeBaseConfig { - isEnabledRAGAlerts: boolean; - isEnabledKnowledgeBase: boolean; latestAlerts: number; } diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/constants.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/constants.tsx index 0262dbe3ed778..a4ae8e4931fbc 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/constants.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/constants.tsx @@ -24,7 +24,5 @@ export const ANONYMIZATION_TABLE_SESSION_STORAGE_KEY = 'anonymizationTable'; export const DEFAULT_LATEST_ALERTS = 20; export const DEFAULT_KNOWLEDGE_BASE_SETTINGS: KnowledgeBaseConfig = { - isEnabledRAGAlerts: false, - isEnabledKnowledgeBase: false, latestAlerts: DEFAULT_LATEST_ALERTS, }; diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/index.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/index.tsx index 08076a95377f3..d8c6c558a524e 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/index.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/index.tsx @@ -66,7 +66,6 @@ export interface AssistantProviderProps { getComments: (commentArgs: { abortStream: () => void; currentConversation?: Conversation; - isEnabledLangChain: boolean; isFetchingResponse: boolean; refetchCurrentConversation: ({ isStreamRefetch }: { isStreamRefetch?: boolean }) => void; regenerateMessage: (conversationId: string) => void; @@ -106,7 +105,6 @@ export interface UseAssistantContext { getComments: (commentArgs: { abortStream: () => void; currentConversation?: Conversation; - isEnabledLangChain: boolean; isFetchingResponse: boolean; refetchCurrentConversation: ({ isStreamRefetch }: { isStreamRefetch?: boolean }) => void; regenerateMessage: () => void; diff --git a/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/types.tsx b/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/types.tsx index 4058f9fdf6845..995bb493f43a4 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/types.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/assistant_context/types.tsx @@ -64,18 +64,12 @@ export interface AssistantTelemetry { reportAssistantMessageSent: (params: { conversationId: string; role: string; - isEnabledKnowledgeBase: boolean; - isEnabledRAGAlerts: boolean; actionTypeId: string; model?: string; provider?: string; }) => void; reportAssistantQuickPrompt: (params: { conversationId: string; promptTitle: string }) => void; - reportAssistantSettingToggled: (params: { - isEnabledKnowledgeBase?: boolean; - isEnabledRAGAlerts?: boolean; - assistantStreamingEnabled?: boolean; - }) => void; + reportAssistantSettingToggled: (params: { assistantStreamingEnabled?: boolean }) => void; } export interface AssistantAvailability { diff --git a/x-pack/packages/kbn-elastic-assistant/impl/knowledge_base/knowledge_base_settings.test.tsx b/x-pack/packages/kbn-elastic-assistant/impl/knowledge_base/knowledge_base_settings.test.tsx index e5bac53d3d1ab..8415ed54b10ca 100644 --- a/x-pack/packages/kbn-elastic-assistant/impl/knowledge_base/knowledge_base_settings.test.tsx +++ b/x-pack/packages/kbn-elastic-assistant/impl/knowledge_base/knowledge_base_settings.test.tsx @@ -40,8 +40,6 @@ jest.mock('../assistant_context', () => { const setUpdatedKnowledgeBaseSettings = jest.fn(); const defaultProps = { knowledgeBase: { - isEnabledKnowledgeBase: true, - isEnabledRAGAlerts: false, latestAlerts: DEFAULT_LATEST_ALERTS, }, setUpdatedKnowledgeBaseSettings, diff --git a/x-pack/plugins/security_solution/public/assistant/get_comments/index.test.tsx b/x-pack/plugins/security_solution/public/assistant/get_comments/index.test.tsx index 884af527f4be0..9671ba49d762b 100644 --- a/x-pack/plugins/security_solution/public/assistant/get_comments/index.test.tsx +++ b/x-pack/plugins/security_solution/public/assistant/get_comments/index.test.tsx @@ -35,7 +35,6 @@ const testProps = { setIsStreaming: jest.fn(), refetchCurrentConversation: jest.fn(), regenerateMessage: jest.fn(), - isEnabledLangChain: false, isFetchingResponse: false, currentConversation, showAnonymizedValues, diff --git a/x-pack/plugins/security_solution/public/assistant/get_comments/index.tsx b/x-pack/plugins/security_solution/public/assistant/get_comments/index.tsx index addb856ea6a65..05e0dad25e1e6 100644 --- a/x-pack/plugins/security_solution/public/assistant/get_comments/index.tsx +++ b/x-pack/plugins/security_solution/public/assistant/get_comments/index.tsx @@ -55,7 +55,6 @@ const transformMessageWithReplacements = ({ export const getComments = ({ abortStream, currentConversation, - isEnabledLangChain, isFetchingResponse, refetchCurrentConversation, regenerateMessage, @@ -65,7 +64,6 @@ export const getComments = ({ }: { abortStream: () => void; currentConversation?: Conversation; - isEnabledLangChain: boolean; isFetchingResponse: boolean; refetchCurrentConversation: ({ isStreamRefetch }: { isStreamRefetch?: boolean }) => void; regenerateMessage: (conversationId: string) => void; @@ -78,8 +76,6 @@ export const getComments = ({ const regenerateMessageOfConversation = () => { regenerateMessage(currentConversation.id); }; - // should only happen when no apiConfig is present - const actionTypeId = currentConversation.apiConfig?.actionTypeId ?? ''; const extraLoadingComment = isFetchingResponse ? [ @@ -94,11 +90,9 @@ export const getComments = ({ children: ( ({ content: '' } as unknown as ContentMessage)} isFetching @@ -165,10 +159,8 @@ export const getComments = ({ children: ( , children: ( void; content?: string; - isEnabledLangChain: boolean; isError?: boolean; isFetching?: boolean; isControlsEnabled?: boolean; index: number; - actionTypeId: string; reader?: ReadableStreamDefaultReader; refetchCurrentConversation: ({ isStreamRefetch }: { isStreamRefetch?: boolean }) => void; regenerateMessage: () => void; @@ -33,10 +31,8 @@ interface Props { export const StreamComment = ({ abortStream, content, - actionTypeId, index, isControlsEnabled = false, - isEnabledLangChain, isError = false, isFetching = false, reader, @@ -48,9 +44,7 @@ export const StreamComment = ({ const { error, isLoading, isStreaming, pendingMessage, setComplete } = useStream({ refetchCurrentConversation, content, - actionTypeId, reader, - isEnabledLangChain, isError, }); useEffect(() => { diff --git a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.test.ts b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.test.ts index f4257e12e1587..dc2f6166b04ad 100644 --- a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.test.ts +++ b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.test.ts @@ -9,8 +9,6 @@ import { API_ERROR } from '../translations'; import type { PromptObservableState } from './types'; import { Subject } from 'rxjs'; -import { EventStreamCodec } from '@smithy/eventstream-codec'; -import { fromUtf8, toUtf8 } from '@smithy/util-utf8'; describe('getStreamObservable', () => { const mockReader = { read: jest.fn(), @@ -21,8 +19,6 @@ describe('getStreamObservable', () => { const setLoading = jest.fn(); const defaultProps = { - actionTypeId: '.gen-ai', - isEnabledLangChain: false, isError: false, reader: typedReader, setLoading, @@ -30,211 +26,6 @@ describe('getStreamObservable', () => { beforeEach(() => { jest.clearAllMocks(); }); - it('should emit loading state and chunks for Bedrock', (done) => { - const completeSubject = new Subject(); - const expectedStates: PromptObservableState[] = [ - { chunks: [], loading: true }, - { - // when i log the actual emit, chunks equal to message.split(''); test is wrong - chunks: ['My', ' new', ' message'], - message: 'My', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new message', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new message', - loading: false, - }, - ]; - - mockReader.read - .mockResolvedValueOnce({ - done: false, - value: encodeBedrockResponse('My'), - }) - .mockResolvedValueOnce({ - done: false, - value: encodeBedrockResponse(' new'), - }) - .mockResolvedValueOnce({ - done: false, - value: encodeBedrockResponse(' message'), - }) - .mockResolvedValue({ - done: true, - }); - - const source = getStreamObservable({ - ...defaultProps, - actionTypeId: '.bedrock', - }); - const emittedStates: PromptObservableState[] = []; - - source.subscribe({ - next: (state) => { - return emittedStates.push(state); - }, - complete: () => { - expect(emittedStates).toEqual(expectedStates); - done(); - - completeSubject.subscribe({ - next: () => { - expect(setLoading).toHaveBeenCalledWith(false); - expect(typedReader.cancel).toHaveBeenCalled(); - done(); - }, - }); - }, - error: (err) => done(err), - }); - }); - it('should emit loading state and chunks for OpenAI', (done) => { - const chunk1 = `data: {"object":"chat.completion.chunk","choices":[{"delta":{"content":"My"}}]}\ndata: {"object":"chat.completion.chunk","choices":[{"delta":{"content":" new"}}]}`; - const chunk2 = `\ndata: {"object":"chat.completion.chunk","choices":[{"delta":{"content":" message"}}]}\ndata: [DONE]`; - const completeSubject = new Subject(); - const expectedStates: PromptObservableState[] = [ - { chunks: [], loading: true }, - { - // when i log the actual emit, chunks equal to message.split(''); test is wrong - chunks: ['My', ' new', ' message'], - message: 'My', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new message', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new message', - loading: false, - }, - ]; - - mockReader.read - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk1)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk2)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode('')), - }) - .mockResolvedValue({ - done: true, - }); - - const source = getStreamObservable(defaultProps); - const emittedStates: PromptObservableState[] = []; - - source.subscribe({ - next: (state) => { - return emittedStates.push(state); - }, - complete: () => { - expect(emittedStates).toEqual(expectedStates); - done(); - - completeSubject.subscribe({ - next: () => { - expect(setLoading).toHaveBeenCalledWith(false); - expect(typedReader.cancel).toHaveBeenCalled(); - done(); - }, - }); - }, - error: (err) => done(err), - }); - }); - it('should emit loading state and chunks for partial response OpenAI', (done) => { - const chunk1 = `data: {"object":"chat.completion.chunk","choices":[{"delta":{"content":"My"}}]}\ndata: {"object":"chat.completion.chunk","choices":[{"delta":{"content":" new"`; - const chunk2 = `}}]}\ndata: {"object":"chat.completion.chunk","choices":[{"delta":{"content":" message"}}]}\ndata: [DONE]`; - const completeSubject = new Subject(); - const expectedStates: PromptObservableState[] = [ - { chunks: [], loading: true }, - { - // when i log the actual emit, chunks equal to message.split(''); test is wrong - chunks: ['My', ' new', ' message'], - message: 'My', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new message', - loading: true, - }, - { - chunks: ['My', ' new', ' message'], - message: 'My new message', - loading: false, - }, - ]; - - mockReader.read - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk1)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk2)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode('')), - }) - .mockResolvedValue({ - done: true, - }); - - const source = getStreamObservable(defaultProps); - const emittedStates: PromptObservableState[] = []; - - source.subscribe({ - next: (state) => { - return emittedStates.push(state); - }, - complete: () => { - expect(emittedStates).toEqual(expectedStates); - done(); - - completeSubject.subscribe({ - next: () => { - expect(setLoading).toHaveBeenCalledWith(false); - expect(typedReader.cancel).toHaveBeenCalled(); - done(); - }, - }); - }, - error: (err) => done(err), - }); - }); it('should emit loading state and chunks for LangChain', (done) => { const chunk1 = `{"payload":"","type":"content"} {"payload":"My","type":"content"} @@ -299,7 +90,7 @@ describe('getStreamObservable', () => { done: true, }); - const source = getStreamObservable({ ...defaultProps, isEnabledLangChain: true }); + const source = getStreamObservable(defaultProps); const emittedStates: PromptObservableState[] = []; source.subscribe({ @@ -376,148 +167,7 @@ describe('getStreamObservable', () => { done: true, }); - const source = getStreamObservable({ ...defaultProps, isEnabledLangChain: true }); - const emittedStates: PromptObservableState[] = []; - - source.subscribe({ - next: (state) => { - return emittedStates.push(state); - }, - complete: () => { - expect(emittedStates).toEqual(expectedStates); - done(); - - completeSubject.subscribe({ - next: () => { - expect(setLoading).toHaveBeenCalledWith(false); - expect(typedReader.cancel).toHaveBeenCalled(); - done(); - }, - }); - }, - error: (err) => done(err), - }); - }); - it('should emit loading state and chunks for Gemini', (done) => { - const chunk1 = `data: {"candidates": [{"content":{"role":"model","parts":[{"text":"My"}]}}]}\rdata: {"candidates": [{"content":{"role":"model","parts":[{"text":" new"}]}}]}`; - const chunk2 = `\rdata: {"candidates": [{"content": {"role": "model","parts": [{"text": " message"}]},"finishReason": "STOP"}],"usageMetadata": {"promptTokenCount": 23,"candidatesTokenCount": 50,"totalTokenCount": 73}}`; - const completeSubject = new Subject(); - const expectedStates: PromptObservableState[] = [ - { chunks: [], loading: true }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My ', - loading: true, - }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My ', - loading: true, - }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My new ', - loading: true, - }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My new message', - loading: false, - }, - ]; - - mockReader.read - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk1)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk2)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode('')), - }) - .mockResolvedValue({ - done: true, - }); - - const source = getStreamObservable({ - ...defaultProps, - actionTypeId: '.gemini', - }); - const emittedStates: PromptObservableState[] = []; - - source.subscribe({ - next: (state) => { - return emittedStates.push(state); - }, - complete: () => { - expect(emittedStates).toEqual(expectedStates); - done(); - - completeSubject.subscribe({ - next: () => { - expect(setLoading).toHaveBeenCalledWith(false); - expect(typedReader.cancel).toHaveBeenCalled(); - done(); - }, - }); - }, - error: (err) => done(err), - }); - }); - - it('should emit loading state and chunks for partial response Gemini', (done) => { - const chunk1 = `data: {"candidates": [{"content":{"role":"model","parts":[{"text":"My"}]}}]}\rdata: {"candidates": [{"content":{"role":"model","parts":[{"text":" new"}]}}]}`; - const chunk2 = `\rdata: {"candidates": [{"content": {"role": "model","parts": [{"text": " message"}]},"finishReason": "STOP"}],"usageMetadata": {"promptTokenCount": 23,"candidatesTokenCount": 50,"totalTokenCount": 73}}`; - const completeSubject = new Subject(); - const expectedStates: PromptObservableState[] = [ - { chunks: [], loading: true }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My ', - loading: true, - }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My ', - loading: true, - }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My new ', - loading: true, - }, - { - chunks: ['My ', ' ', 'new ', ' message'], - message: 'My new message', - loading: false, - }, - ]; - - mockReader.read - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk1)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode(chunk2)), - }) - .mockResolvedValueOnce({ - done: false, - value: new Uint8Array(new TextEncoder().encode('')), - }) - .mockResolvedValue({ - done: true, - }); - - const source = getStreamObservable({ - ...defaultProps, - actionTypeId: '.gemini', - }); + const source = getStreamObservable(defaultProps); const emittedStates: PromptObservableState[] = []; source.subscribe({ @@ -613,22 +263,3 @@ describe('getStreamObservable', () => { }); }); }); - -function encodeBedrockResponse(completion: string) { - return new EventStreamCodec(toUtf8, fromUtf8).encode({ - headers: {}, - body: Uint8Array.from( - Buffer.from( - JSON.stringify({ - bytes: Buffer.from( - JSON.stringify({ - type: 'content_block_delta', - index: 0, - delta: { type: 'text_delta', text: completion }, - }) - ).toString('base64'), - }) - ) - ), - }); -} diff --git a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.ts b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.ts index 338ed7b661f84..4eeaefdc1c7f5 100644 --- a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.ts +++ b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/stream_observable.ts @@ -7,55 +7,25 @@ import { concatMap, delay, finalize, Observable, of, scan, timestamp } from 'rxjs'; import type { Dispatch, SetStateAction } from 'react'; -import { handleBedrockChunk } from '@kbn/elastic-assistant-common'; import type { PromptObservableState } from './types'; import { API_ERROR } from '../translations'; const MIN_DELAY = 35; interface StreamObservable { - actionTypeId: string; - isEnabledLangChain: boolean; isError: boolean; reader: ReadableStreamDefaultReader; setLoading: Dispatch>; } -interface ResponseSchema { - candidates: Candidate[]; - usageMetadata: { - promptTokenCount: number; - candidatesTokenCount: number; - totalTokenCount: number; - }; -} - -interface Part { - text: string; -} - -interface Candidate { - content: Content; - finishReason: string; -} - -interface Content { - role: string; - parts: Part[]; -} - /** * Returns an Observable that reads data from a ReadableStream and emits values representing the state of the data processing. * - * @param connectorTypeTitle - The title of the connector type. - * @param isEnabledLangChain - indicates whether langchain is enabled or not * @param isError - indicates whether the reader response is an error message or not * @param reader - The ReadableStreamDefaultReader used to read data from the stream. * @param setLoading - A function to update the loading state. * @returns {Observable} An Observable that emits PromptObservableState */ export const getStreamObservable = ({ - actionTypeId, - isEnabledLangChain, isError, reader, setLoading, @@ -64,14 +34,8 @@ export const getStreamObservable = ({ observer.next({ chunks: [], loading: true }); const decoder = new TextDecoder(); const chunks: string[] = []; - // Initialize an empty string to store the OpenAI buffer. - let openAIBuffer: string = ''; // Initialize an empty string to store the LangChain buffer. let langChainBuffer: string = ''; - // Initialize an empty Uint8Array to store the Bedrock concatenated buffer. - let bedrockBuffer: Uint8Array = new Uint8Array(0); - // Initialize an empty string to store the Gemini buffer. - let geminiBuffer: string = ''; // read data from LangChain stream function readLangChain() { @@ -130,166 +94,7 @@ export const getStreamObservable = ({ observer.error(err); }); } - - // read data from OpenAI stream - function readOpenAI() { - reader - .read() - .then(({ done, value }: { done: boolean; value?: Uint8Array }) => { - try { - if (done) { - if (openAIBuffer) { - chunks.push(getOpenAIChunks([openAIBuffer])[0]); - } - observer.next({ - chunks, - message: chunks.join(''), - loading: false, - }); - observer.complete(); - return; - } - - const decoded = decoder.decode(value); - let nextChunks; - if (isError) { - nextChunks = [`${API_ERROR}\n\n${JSON.parse(decoded).message}`]; - } else { - const lines = decoded.split('\n'); - lines[0] = openAIBuffer + lines[0]; - openAIBuffer = lines.pop() || ''; - nextChunks = getOpenAIChunks(lines); - } - nextChunks.forEach((chunk: string) => { - chunks.push(chunk); - observer.next({ - chunks, - message: chunks.join(''), - loading: true, - }); - }); - } catch (err) { - observer.error(err); - return; - } - readOpenAI(); - }) - .catch((err) => { - observer.error(err); - }); - } - - // read data from Bedrock stream - function readBedrock() { - reader - .read() - .then(({ done, value }: { done: boolean; value?: Uint8Array }) => { - try { - if (done) { - observer.next({ - chunks, - message: chunks.join(''), - loading: false, - }); - observer.complete(); - return; - } - - let content; - if (isError) { - content = `${API_ERROR}\n\n${JSON.parse(decoder.decode(value)).message}`; - chunks.push(content); - observer.next({ - chunks, - message: chunks.join(''), - loading: true, - }); - } else if (value != null) { - const chunk: Uint8Array = value; - const chunkHandler = (decodedChunk: string) => { - chunks.push(decodedChunk); - observer.next({ - chunks, - message: chunks.join(''), - loading: true, - }); - }; - const processedChunk = handleBedrockChunk({ chunk, bedrockBuffer, chunkHandler }); - bedrockBuffer = processedChunk.bedrockBuffer; - } - } catch (err) { - observer.error(err); - return; - } - readBedrock(); - }) - .catch((err) => { - observer.error(err); - }); - } - - // read data from Gemini stream - function readGemini() { - reader - .read() - .then(({ done, value }: { done: boolean; value?: Uint8Array }) => { - try { - if (done) { - if (geminiBuffer) { - chunks.push(getGeminiChunks([geminiBuffer])[0]); - } - observer.next({ - chunks, - message: chunks.join(''), - loading: false, - }); - observer.complete(); - return; - } - - const decoded = decoder.decode(value, { stream: true }); - const lines = decoded.split('\r'); - lines[0] = geminiBuffer + lines[0]; - geminiBuffer = lines.pop() || ''; - - const nextChunks = getGeminiChunks(lines); - - nextChunks.forEach((chunk: string) => { - const splitBySpace = chunk.split(' '); - for (const word of splitBySpace) { - chunks.push(`${word} `); - observer.next({ - chunks, - message: chunks.join(''), - loading: true, - }); - } - }); - } catch (err) { - observer.error(err); - return; - } - readGemini(); - }) - .catch((err) => { - observer.error(err); - }); - } - - // this should never actually happen - function badConnector() { - observer.next({ - chunks: [`Invalid connector type - ${actionTypeId} is not a supported GenAI connector.`], - message: `Invalid connector type - ${actionTypeId} is not a supported GenAI connector.`, - loading: false, - }); - observer.complete(); - } - if (isEnabledLangChain) readLangChain(); - else if (actionTypeId === '.bedrock') readBedrock(); - else if (actionTypeId === '.gen-ai') readOpenAI(); - else if (actionTypeId === '.gemini') readGemini(); - else badConnector(); + readLangChain(); return () => { reader.cancel(); @@ -325,26 +130,6 @@ export const getStreamObservable = ({ finalize(() => setLoading(false)) ); -/** - * Parses an OpenAI response from a string. - * @param lines - * @returns {string[]} - Parsed string array from the OpenAI response. - */ -const getOpenAIChunks = (lines: string[]): string[] => { - const nextChunk = lines - .map((str) => str.substring(6)) - .filter((str) => !!str && str !== '[DONE]') - .map((line) => { - try { - const openaiResponse = JSON.parse(line); - return openaiResponse.choices[0]?.delta.content ?? ''; - } catch (err) { - return ''; - } - }); - return nextChunk; -}; - /** * Parses a LangChain response from a string. * @param lines @@ -366,23 +151,4 @@ const getLangChainChunks = (lines: string[]): string[] => return acc; }, []); -/** - * Parses an Gemini response from a string. - * @param lines - * @returns {string[]} - Parsed string array from the Gemini response. - */ -const getGeminiChunks = (lines: string[]): string[] => { - return lines - .filter((str) => !!str && str !== '[DONE]') - .map((line) => { - try { - const newLine = line.replaceAll('data: ', ''); - const geminiResponse: ResponseSchema = JSON.parse(newLine); - return geminiResponse.candidates[0]?.content.parts.map((part) => part.text).join('') ?? ''; - } catch (err) { - return ''; - } - }); -}; - export const getPlaceholderObservable = () => new Observable(); diff --git a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.test.tsx b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.test.tsx index 7bc71c1d9c57f..9aa3491218f88 100644 --- a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.test.tsx +++ b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.test.tsx @@ -39,9 +39,7 @@ const readerComplete = { const defaultProps = { refetchCurrentConversation, reader: readerComplete, - isEnabledLangChain: false, isError: false, - actionTypeId: '.gen-ai', }; // FLAKY: https://github.com/elastic/kibana/issues/180091 diff --git a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.tsx b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.tsx index 11c76e7a7ea1b..9d31d90bc7dfe 100644 --- a/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.tsx +++ b/x-pack/plugins/security_solution/public/assistant/get_comments/stream/use_stream.tsx @@ -11,10 +11,8 @@ import { getPlaceholderObservable, getStreamObservable } from './stream_observab interface UseStreamProps { refetchCurrentConversation: ({ isStreamRefetch }: { isStreamRefetch?: boolean }) => void; - isEnabledLangChain: boolean; isError: boolean; content?: string; - actionTypeId: string; reader?: ReadableStreamDefaultReader; } interface UseStream { @@ -33,17 +31,12 @@ interface UseStream { * A hook that takes a ReadableStreamDefaultReader and returns an object with properties and functions * that can be used to handle streaming data from a readable stream * @param content - the content of the message. If provided, the function will not use the reader to stream data. - * @param actionTypeId - the actionTypeId of the connector type * @param refetchCurrentConversation - refetch the current conversation - * @param reader - The readable stream reader used to stream data. If provided, the function will use this reader to stream data. - * @param isEnabledLangChain - indicates whether langchain is enabled or not * @param isError - indicates whether the reader response is an error message or not * @param reader - The readable stream reader used to stream data. If provided, the function will use this reader to stream data. */ export const useStream = ({ content, - actionTypeId, - isEnabledLangChain, isError, reader, refetchCurrentConversation, @@ -55,9 +48,9 @@ export const useStream = ({ const observer$ = useMemo( () => content == null && reader != null - ? getStreamObservable({ actionTypeId, reader, setLoading, isEnabledLangChain, isError }) + ? getStreamObservable({ reader, setLoading, isError }) : getPlaceholderObservable(), - [content, isEnabledLangChain, isError, reader, actionTypeId] + [content, isError, reader] ); const onCompleteStream = useCallback( (didAbort: boolean) => { diff --git a/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/helpers.test.ts b/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/helpers.test.ts index a15cb7090f6cc..f2fd17d5978b7 100644 --- a/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/helpers.test.ts +++ b/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/helpers.test.ts @@ -133,8 +133,6 @@ describe('getRequestBody', () => { ], }; const knowledgeBase = { - isEnabledKnowledgeBase: true, - isEnabledRAGAlerts: true, latestAlerts: 20, }; const traceOptions = { diff --git a/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/index.test.tsx b/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/index.test.tsx index ca6f2c8ca02df..d21630bb4c835 100644 --- a/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/index.test.tsx +++ b/x-pack/plugins/security_solution/public/attack_discovery/use_attack_discovery/index.test.tsx @@ -37,8 +37,6 @@ jest.mock('@kbn/elastic-assistant', () => ({ alertsIndexPattern: 'alerts-index-pattern', assistantAvailability: mockAssistantAvailability(), knowledgeBase: { - isEnabledRAGAlerts: true, - isEnabledKnowledgeBase: true, latestAlerts: 20, }, }), diff --git a/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/index.ts b/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/index.ts index 106b93373b970..482a38a983f4e 100644 --- a/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/index.ts +++ b/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/index.ts @@ -45,20 +45,6 @@ export const assistantMessageSentEvent: TelemetryEvent = { optional: false, }, }, - isEnabledKnowledgeBase: { - type: 'boolean', - _meta: { - description: 'Is knowledge base enabled', - optional: false, - }, - }, - isEnabledRAGAlerts: { - type: 'boolean', - _meta: { - description: 'Is RAG on Alerts enabled', - optional: false, - }, - }, actionTypeId: { type: 'keyword', _meta: { @@ -106,17 +92,10 @@ export const assistantQuickPrompt: TelemetryEvent = { export const assistantSettingToggledEvent: TelemetryEvent = { eventType: TelemetryEventTypes.AssistantSettingToggled, schema: { - isEnabledKnowledgeBase: { - type: 'boolean', - _meta: { - description: 'Is knowledge base enabled', - optional: true, - }, - }, - isEnabledRAGAlerts: { + alertsCountUpdated: { type: 'boolean', _meta: { - description: 'Is RAG on Alerts enabled', + description: 'Did alerts count update', optional: true, }, }, diff --git a/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/types.ts b/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/types.ts index 54a9660d3b2d8..ee879d516885d 100644 --- a/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/types.ts +++ b/x-pack/plugins/security_solution/public/common/lib/telemetry/events/ai_assistant/types.ts @@ -16,8 +16,6 @@ export interface ReportAssistantInvokedParams { export interface ReportAssistantMessageSentParams { conversationId: string; role: string; - isEnabledKnowledgeBase: boolean; - isEnabledRAGAlerts: boolean; actionTypeId: string; provider?: string; model?: string; @@ -29,8 +27,7 @@ export interface ReportAssistantQuickPromptParams { } export interface ReportAssistantSettingToggledParams { - isEnabledKnowledgeBase?: boolean; - isEnabledRAGAlerts?: boolean; + alertsCountUpdated?: boolean; assistantStreamingEnabled?: boolean; }