From 84b911a0a16c3e15357e1d0d0996591975ac0ed2 Mon Sep 17 00:00:00 2001 From: Federico Rodriguez Date: Thu, 3 Nov 2022 09:07:20 +0100 Subject: [PATCH] Add multi-line validation parameters in config description (#4785) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Add MultiLine validations to config description * Reverse tsconfig change * Add changelog Co-authored-by: Álex (cherry picked from commit 35b797be1bf6860c080fae66df6bedb9d772b161) --- CHANGELOG.md | 2 +- common/constants.ts | 13 +++++++------ common/services/settings-validator.ts | 10 +++++----- common/services/settings.ts | 4 ++++ 4 files changed, 17 insertions(+), 12 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d72f382ed2..ff7170a28f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,7 +10,7 @@ All notable changes to the Wazuh app project will be documented in this file. - Added agent synchronization status in the agent module. [#3874](https://github.com/wazuh/wazuh-kibana-app/pull/3874) - Redesign the SCA table from agent's dashboard [#4512](https://github.com/wazuh/wazuh-kibana-app/pull/4512) - Enhanced the plugin setting description displayed in the UI and the configuration file. [#4501](https://github.com/wazuh/wazuh-kibana-app/pull/4501) -- Added validation to the plugin settings in the form of `Settings/Configuration` and the endpoint to update the plugin configuration [#4503](https://github.com/wazuh/wazuh-kibana-app/pull/4503) +- Added validation to the plugin settings in the form of `Settings/Configuration` and the endpoint to update the plugin configuration [#4503](https://github.com/wazuh/wazuh-kibana-app/pull/4503)[#4785](https://github.com/wazuh/wazuh-kibana-app/pull/4785) - Added new plugin settings to customize the header and footer on the PDF reports [#4505](https://github.com/wazuh/wazuh-kibana-app/pull/4505) - Add a new plugin setting to enable or disable the customization [#4507](https://github.com/wazuh/wazuh-kibana-app/pull/4507) diff --git a/common/constants.ts b/common/constants.ts index aba25d68bb..dbc42ac656 100644 --- a/common/constants.ts +++ b/common/constants.ts @@ -358,7 +358,8 @@ export enum SettingCategory { }; type TPluginSettingOptionsTextArea = { - rowsSize?: number + maxRows?: number + minRows?: number maxLength?: number }; @@ -1115,11 +1116,11 @@ export const PLUGIN_SETTINGS: { [key: string]: TPluginSetting } = { defaultValueIfNotSet: REPORTS_PAGE_FOOTER_TEXT, isConfigurableFromFile: true, isConfigurableFromUI: true, - options: { rowsSize: 2, maxLength: 30 }, + options: { maxRows: 2, maxLength: 30 }, validate: function (value) { return SettingsValidator.multipleLinesString({ - max: this.options.rowsSize, - maxLength: this.options.maxLength + maxRows: this.options?.maxRows, + maxLength: this.options?.maxLength })(value) }, validateBackend: function (schema) { @@ -1135,10 +1136,10 @@ export const PLUGIN_SETTINGS: { [key: string]: TPluginSetting } = { defaultValueIfNotSet: REPORTS_PAGE_HEADER_TEXT, isConfigurableFromFile: true, isConfigurableFromUI: true, - options: { rowsSize: 3, maxLength: 20 }, + options: { maxRows: 3, maxLength: 20 }, validate: function (value) { return SettingsValidator.multipleLinesString({ - max: this.options.rowsSize, + maxRows: this.options?.maxRows, maxLength: this.options?.maxLength })(value) }, diff --git a/common/services/settings-validator.ts b/common/services/settings-validator.ts index 75fef368be..b62675f0f9 100644 --- a/common/services/settings-validator.ts +++ b/common/services/settings-validator.ts @@ -56,17 +56,17 @@ export class SettingsValidator { * @param options * @returns */ - static multipleLinesString(options: { min?: number, max?: number, maxLength?: number } = {}) { + static multipleLinesString(options: { minRows?: number, maxRows?: number, maxLength?: number } = {}) { return function (value: number) { const lines = value.split(/\r\n|\r|\n/).length; if (typeof options.maxLength !== 'undefined' && value.split('\n').some(line => line.length > options.maxLength)) { return `The maximum length of a line is ${options.maxLength} characters.`; }; - if (typeof options.min !== 'undefined' && lines < options.min) { - return `The string should have more or ${options.min} line/s.`; + if (typeof options.minRows !== 'undefined' && lines < options.minRows) { + return `The string should have more or ${options.minRows} line/s.`; }; - if (typeof options.max !== 'undefined' && lines > options.max) { - return `The string should have less or equal to ${options.max} line/s.`; + if (typeof options.maxRows !== 'undefined' && lines > options.maxRows) { + return `The string should have less or equal to ${options.maxRows} line/s.`; }; } }; diff --git a/common/services/settings.ts b/common/services/settings.ts index d88f1dc6ae..868f54c984 100644 --- a/common/services/settings.ts +++ b/common/services/settings.ts @@ -116,6 +116,10 @@ export function groupSettingsByCategory(settings: TPluginSettingWithKey[]){ // File size ...((options?.file?.size && typeof options.file.size.minBytes !== 'undefined') ? [`Minimum file size: ${formatBytes(options.file.size.minBytes)}.`] : []), ...((options?.file?.size && typeof options.file.size.maxBytes !== 'undefined') ? [`Maximum file size: ${formatBytes(options.file.size.maxBytes)}.`] : []), + // Multi line text + ...((options?.maxRows && typeof options.maxRows !== 'undefined' ? [`Maximum amount of lines: ${options.maxRows}.`] : [])), + ...((options?.minRows && typeof options.minRows !== 'undefined' ? [`Minimum amount of lines: ${options.minRows}.`] : [])), + ...((options?.maxLength && typeof options.maxLength !== 'undefined' ? [`Maximum lines length is ${options.maxLength} characters.`] : [])), ].join(' '); };