blob: 0cb1943d66861874f5e14c8eb10403a0f991250c [file] [log] [blame]
/*!
* Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
import * as ValidatorJS from 'validator';
import i18n from 'nfvo-utils/i18n/i18n.js';
class Validator {
static get globalValidationFunctions() {
return {
required: value => {
return typeof value === 'string' ? value.replace(/\s+/g, '') !== '' : value !== '';
},
requiredChooseOption: value => value !== '',
maxLength: (value, length) => ValidatorJS.isLength(value, {max: length}),
minLength: (value, length) => ValidatorJS.isLength(value, {min: length}),
pattern: (value, pattern) => ValidatorJS.matches(value, pattern),
numeric: value => {
if (value === '') {
// to allow empty value which is not zero
return true;
}
return ValidatorJS.isNumeric(value);
},
maximum: (value, maxValue) => {return (value === undefined) ? true : (value <= maxValue);},
minimum: (value, minValue) => {return (value === undefined) ? true : (value >= minValue);},
maximumExclusive: (value, maxValue) => {return (value === undefined) ? true : (value < maxValue);},
minimumExclusive: (value, minValue) => {return (value === undefined) ? true : (value > minValue);},
alphanumeric: value => ValidatorJS.isAlphanumeric(value),
alphanumericWithSpaces: value => ValidatorJS.isAlphanumeric(value.replace(/ /g, '')),
validateName: value => ValidatorJS.isAlphanumeric(value.replace(/\s|\.|\_|\-/g, ''), 'en-US'),
validateVendorName: value => ValidatorJS.isAlphanumeric(value.replace(/[\x7F-\xFF]|\s/g, ''), 'en-US'),
freeEnglishText: value => ValidatorJS.isAlphanumeric(value.replace(/\s|\.|\_|\-|\,|\(|\)|\?/g, ''), 'en-US'),
email: value => ValidatorJS.isEmail(value),
ip: value => ValidatorJS.isIP(value),
url: value => ValidatorJS.isURL(value),
alphanumericWithUnderscores: value => ValidatorJS.isAlphanumeric(value.replace(/_/g, '')),
requiredChoiceWithOther: (value, otherValue) => {
let chosen = value.choice;
// if we have an empty multiple select we have a problem since it's required
let validationFunc = this.globalValidationFunctions['required'];
if (value.choices) {
if (value.choices.length === 0) {
return false;
} else {
// continuing validation with the first chosen value in case we have the 'Other' field
chosen = value.choices[0];
}
}
if (chosen !== otherValue) {
return validationFunc(chosen, true);
} else { // when 'Other' was chosen, validate other value
return validationFunc(value.other, true);
}
}
};
}
static get globalValidationMessagingFunctions() {
return {
required: () => i18n('Field is required'),
requiredChooseOption: () => i18n('Field should have one of these options'),
requiredChoiceWithOther: () => i18n('Field is required'),
maxLength: (value, maxLength) => i18n('Field value has exceeded it\'s limit, {maxLength}. current length: {length}', {
length: value.length,
maxLength
}),
minLength: (value, minLength) => i18n('Field value should contain at least {minLength} characters.', {minLength: minLength}),
pattern: (value, pattern) => i18n('Field value should match the pattern: {pattern}.', {pattern: pattern}),
numeric: () => i18n('Field value should contain numbers only.'),
maximum: (value, maxValue) => i18n('Field value should be less or equal to: {maxValue}.', {maxValue: maxValue}),
minimum: (value, minValue) => i18n('Field value should be at least: {minValue}.', {minValue: minValue.toString()}),
maximumExclusive: (value, maxValue) => i18n('Field value should be less than: {maxValue}.', {maxValue: maxValue}),
minimumExclusive: (value, minValue) => i18n('Field value should be more than: {minValue}.', {minValue: minValue.toString()}),
alphanumeric: () => i18n('Field value should contain letters or digits only.'),
alphanumericWithSpaces: () => i18n('Field value should contain letters, digits or spaces only.'),
validateName: ()=> i18n('Field value should contain English letters, digits , spaces, underscores, dashes and dots only.'),
validateVendorName: ()=> i18n('Field value should contain English letters digits and spaces only.'),
freeEnglishText: ()=> i18n('Field value should contain English letters, digits , spaces, underscores, dashes and dots only.'),
email: () => i18n('Field value should be a valid email address.'),
ip: () => i18n('Field value should be a valid ip address.'),
url: () => i18n('Field value should be a valid url address.'),
general: () => i18n('Field value is invalid.'),
alphanumericWithUnderscores: () => i18n('Field value should contain letters, digits or _ only.')
};
}
static validateItem(value, data, type) {
let validationFunc = this.globalValidationFunctions[type];
const isValid = validationFunc(value, data);
let errorText = '';
if (!isValid) {
errorText = this.globalValidationMessagingFunctions[type](value, data);
}
return {
isValid,
errorText
};
}
static validate(fieldName, value, validations, state, customValidations) {
let result = { isValid: true, errorText: '' };
for (let validation of validations) {
result = this.validateItem(value, validation.data, validation.type);
if (!result.isValid) {
return result;
}
}
if (customValidations) {
let validationFunc = customValidations[fieldName];
if (validationFunc) {
result = validationFunc(value, state);
}
}
return result;
}
static isItemNameAlreadyExistsInList({itemId, itemName, list}) {
itemName = itemName.toLowerCase();
return list[itemName] && list[itemName] !== itemId;
}
}
export default Validator;