blob: 324198ef2e682b783a0377405c06fdbf6e7e6fea [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;