From 408ebdc3c3694ba202f992aeb2e129ff9db7fe10 Mon Sep 17 00:00:00 2001 From: Davis Plumlee Date: Fri, 16 Jul 2021 03:21:51 -0600 Subject: [PATCH 1/2] adds catch for toString --- .../public/common/components/exceptions/helpers.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx b/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx index 3c8652637a997..8830a0a57735a 100644 --- a/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx +++ b/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx @@ -326,7 +326,7 @@ export const getCodeSignatureValue = ( return codeSignature.map((signature) => { return { subjectName: signature.subject_name ?? '', - trusted: signature.trusted.toString() ?? '', + trusted: signature?.trusted.toString() ?? '', }; }); } else { From bbb8cdb03d8dbe98a4444047a06ce0c2c58afd37 Mon Sep 17 00:00:00 2001 From: Davis Plumlee Date: Fri, 16 Jul 2021 12:40:23 -0600 Subject: [PATCH 2/2] adds test --- .../common/components/exceptions/helpers.test.tsx | 15 ++++++++++++++- .../common/components/exceptions/helpers.tsx | 4 ++-- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.test.tsx b/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.test.tsx index 32eb4baad5059..bf6a94c53b477 100644 --- a/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.test.tsx @@ -26,8 +26,9 @@ import { getProcessCodeSignature, retrieveAlertOsTypes, filterIndexPatterns, + getCodeSignatureValue, } from './helpers'; -import { AlertData } from './types'; +import { AlertData, Flattened } from './types'; import { ListOperatorTypeEnum as OperatorTypeEnum, EntriesArray, @@ -41,6 +42,7 @@ import { getCommentsArrayMock } from '../../../../../lists/common/schemas/types/ import { fields } from '../../../../../../../src/plugins/data/common/index_patterns/fields/fields.mocks'; import { ENTRIES, OLD_DATE_RELATIVE_TO_DATE_NOW } from '../../../../../lists/common/constants.mock'; import { IFieldType, IIndexPattern } from 'src/plugins/data/common'; +import { CodeSignature } from '../../../../common/ecs/file'; jest.mock('uuid', () => ({ v4: jest.fn().mockReturnValue('123'), @@ -340,6 +342,17 @@ describe('Exception helpers', () => { }); }); + describe('#getCodeSignatureValue', () => { + test('it should return empty string if code_signature nested value are undefined', () => { + // Using the unsafe casting because with our types this shouldn't be possible but there have been issues with old data having undefined values in these fields + const payload = ([{ trusted: undefined, subject_name: undefined }] as unknown) as Flattened< + CodeSignature[] + >; + const result = getCodeSignatureValue(payload); + expect(result).toEqual([{ trusted: '', subjectName: '' }]); + }); + }); + describe('#entryHasNonEcsType', () => { const mockEcsIndexPattern = { title: 'testIndex', diff --git a/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx b/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx index 8830a0a57735a..f8260062f6974 100644 --- a/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx +++ b/x-pack/plugins/security_solution/public/common/components/exceptions/helpers.tsx @@ -325,8 +325,8 @@ export const getCodeSignatureValue = ( if (Array.isArray(codeSignature) && codeSignature.length > 0) { return codeSignature.map((signature) => { return { - subjectName: signature.subject_name ?? '', - trusted: signature?.trusted.toString() ?? '', + subjectName: signature?.subject_name ?? '', + trusted: signature?.trusted?.toString() ?? '', }; }); } else {