From 74aab5b7392429f995c2fc64d988c7857847cd95 Mon Sep 17 00:00:00 2001 From: Christos Nasikas Date: Wed, 8 Jun 2022 11:48:52 +0200 Subject: [PATCH] Filter docs without _source --- .../cases/server/client/alerts/get.test.ts | 34 +++++++++++++++++++ .../plugins/cases/server/client/alerts/get.ts | 6 ++-- 2 files changed, 38 insertions(+), 2 deletions(-) diff --git a/x-pack/plugins/cases/server/client/alerts/get.test.ts b/x-pack/plugins/cases/server/client/alerts/get.test.ts index fab525d36bf48..be675ed20a5cb 100644 --- a/x-pack/plugins/cases/server/client/alerts/get.test.ts +++ b/x-pack/plugins/cases/server/client/alerts/get.test.ts @@ -101,4 +101,38 @@ describe('getAlerts', () => { }, ]); }); + + it('filters docs without _source correctly', async () => { + esClient.mget.mockResolvedValue({ + docs: [ + ...docs, + { + _index: '.internal.alerts-security.alerts-default-000002', + _id: 'd3869d546717e8c581add9cbf7d24578f34cd3e72cbc8d8b8e9a9330a899f70f', + found: true, + }, + ], + }); + const clientArgs = { alertsService } as unknown as CasesClientArgs; + + const res = await getAlerts( + [ + { + index: '.internal.alerts-security.alerts-default-000001', + id: 'c3869d546717e8c581add9cbf7d24578f34cd3e72cbc8d8b8e9a9330a899f70f', + }, + ], + clientArgs + ); + + expect(res).toEqual([ + { + index: '.internal.alerts-security.alerts-default-000001', + id: 'c3869d546717e8c581add9cbf7d24578f34cd3e72cbc8d8b8e9a9330a899f70f', + destination: { mac: 'ff:ff:ff:ff:ff:ff' }, + source: { bytes: 444, mac: '11:1f:1e:13:15:14', packets: 6 }, + ecs: { version: '8.0.0' }, + }, + ]); + }); }); diff --git a/x-pack/plugins/cases/server/client/alerts/get.ts b/x-pack/plugins/cases/server/client/alerts/get.ts index 66cfe094021b4..6a3f09cf30a89 100644 --- a/x-pack/plugins/cases/server/client/alerts/get.ts +++ b/x-pack/plugins/cases/server/client/alerts/get.ts @@ -11,8 +11,10 @@ import { CasesClientArgs } from '..'; import { AlertInfo } from '../../common/types'; import { Alert } from '../../services/alerts'; -function isAlert(doc?: MgetResponseItem): doc is GetGetResult { - return Boolean(doc && !('error' in doc)); +function isAlert( + doc?: MgetResponseItem +): doc is Omit, '_source'> & { _source: Alert } { + return Boolean(doc && !('error' in doc) && '_source' in doc); } export const getAlerts = async (