Вы можете фактически обеспечить обратный вызов для функции error()
и проверить, что вызвало ошибку.
Обратный вызов в вашем случае будет выглядеть так:
const onError = x => {
switch (x[0].type) {
case 'any.required': {
return new Error('category is required');
}
case 'string.regex.base': {
return new Error('category is not valid');
}
default: {
return new Error('category has some error');
}
}
};
Тогда вы можете использовать его так:
category: Joi.string()
.regex(/^[a-zA-Z]*$/)
.required()
.error(onError)
Вот полный фрагмент, который я использовал:
const Joi = require('joi');
const onError = x => {
switch (x[0].type) {
case 'any.required': {
return new Error('category is required');
}
case 'string.regex.base': {
return new Error('category is not valid');
}
default: {
return new Error('category has some error');
}
}
};
const schema = Joi.object().keys({
category: Joi.string()
.regex(/^[a-zA-Z]*$/)
.required()
.error(onError)
});
const testCategories = [{ category: 'ABCD' }, {}, { category: '&&&' }];
testCategories.forEach(aCategory => {
schema
.validate(aCategory)
.then(() => {
console.log(JSON.stringify(aCategory), 'passed!');
})
.catch(e => {
console.log(JSON.stringify(aCategory), 'failed', e);
});
});