From 7ad2b1b55c52b9e420fc60b0ac80a9e322299a82 Mon Sep 17 00:00:00 2001 From: "Michael R. Torres" <6692889+micrictor@users.noreply.github.com> Date: Thu, 22 Apr 2021 16:38:25 -0700 Subject: [PATCH] [BUG] Add support for CIDR mask filters on IP fields (#300) Signed-off-by: Michael Torres Fixes #306 --- .../lib/filter_editor_utils.test.ts | 64 +++++++++++++++++++ .../filter_editor/lib/filter_editor_utils.ts | 5 +- 2 files changed, 68 insertions(+), 1 deletion(-) diff --git a/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.test.ts b/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.test.ts index 66fb1c65a89c..685da14c0d4a 100644 --- a/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.test.ts +++ b/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.test.ts @@ -45,6 +45,7 @@ import { getOperatorFromFilter, getOperatorOptions, isFilterValid, + validateParams, } from './filter_editor_utils'; import { existsOperator, isBetweenOperator, isOneOfOperator, isOperator } from './filter_operators'; @@ -149,6 +150,69 @@ describe('Filter editor utils', () => { }); }); + describe('validateParams', () => { + it('should return false if date is not string', () => { + const isValidParams = validateParams(1234, 'date'); + expect(isValidParams).toBe(false); + }); + + it('should return false if date is not valid string', () => { + const isValidParams = validateParams('this is not a date', 'date'); + expect(isValidParams).toBe(false); + }); + + it('should return true if date is valid relative time', () => { + const isValidParams = validateParams('now-15m', 'date'); + expect(isValidParams).toBe(true); + }); + + it('should return true if date is valid absolute time', () => { + const isValidParams = validateParams('1997-01-03', 'date'); + expect(isValidParams).toBe(true); + }); + + it('should return false if ip address is not valid CIDR or IP', () => { + const isValidParams = validateParams('not.a.valid.ip', 'ip'); + expect(isValidParams).toBe(false); + }); + + it('should return false if ip address is has out-of-range octets', () => { + const isValidParams = validateParams('1.1.1.256', 'ip'); + expect(isValidParams).toBe(false); + }); + + it('should return false if ip address CIDR has invalid mask', () => { + const isValidParams = validateParams('1.1.1.1/33', 'ip'); + expect(isValidParams).toBe(false); + }); + + it('should return false if ip address CIDR has invalid network', () => { + const isValidParams = validateParams('256.256.256.256/24', 'ip'); + expect(isValidParams).toBe(false); + }); + + it('should return false if ip address CIDR is invalid CIDR', () => { + const isValidParams = validateParams('192.168.0.0//24', 'ip'); + expect(isValidParams).toBe(false); + }); + + it('should return true if ip address is valid string', () => { + const isValidParams = validateParams('1.1.1.1', 'ip'); + expect(isValidParams).toBe(true); + }); + + it('should return true if ip address is valid CIDR string', () => { + const isValidParams = validateParams('192.168.0.0/24', 'ip'); + expect(isValidParams).toBe(true); + }); + + it('should return true if type is not ip or date', () => { + const testTypes = ['text', 'version', 'keyword']; + const isValidParams = testTypes.every((type) => validateParams('test filter', type)); + expect(isValidParams).toBe(true); + }); + }); + describe('isFilterValid', () => { it('should return false if index pattern is not provided', () => { const isValid = isFilterValid(undefined, stubFields[0], isOperator, 'foo'); diff --git a/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts b/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts index 8365ed841532..bba6e0566c2e 100644 --- a/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts +++ b/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts @@ -33,6 +33,7 @@ import dateMath from '@elastic/datemath'; import { FILTER_OPERATORS, Operator } from './filter_operators'; import { + CidrMask, isFilterable, IIndexPattern, IFieldType, @@ -68,7 +69,9 @@ export function validateParams(params: any, type: string) { return Boolean(typeof params === 'string' && moment && moment.isValid()); case 'ip': try { - return Boolean(new Ipv4Address(params)); + return params.includes('/') + ? Boolean(new CidrMask(params)) + : Boolean(new Ipv4Address(params)); } catch (e) { return false; }