Джой пользовательская проверка - PullRequest
0 голосов
/ 03 июля 2019

Я использую Joi для проверки некоторых данных от пользователя.Я использую его с таким модулем:

const Joi = require('joi')

// User validation rules
module.exports = {
  create: {
    body: {
      email: Joi.string().email().required(),
      password: Joi.string().min(6).max(128).required(),
      name: Joi.string().max(128).required()
    }
  },
  update: {
    body: {
      password: Joi.string().min(6).max(128).required(),
      name: Joi.string().max(128).required()
    }
  }
}

, а затем в маршрутизаторе я передаю его как промежуточное ПО:

router.post('/register', validator(create), userController.register)

Для обновления я хочу создать собственный валидатор с кодомкак это:

const json = { 
  "email":"aa@aa.pl",
  "password":"someNewPass",
  "name":"John Smith",
  "activationKey":"123123",
  "active":false,
  "resetPasswordKey":"123123"
}

const forbiddenFields = ["email", "activationKey", "active", "resetPasswordKey"];

const validate = (json, forbidden) => {
  for(let i = 0; i < forbidden.length; i++) {
    if(json.hasOwnProperty(forbidden[i])) {
      return false;
    }
  }
  return true;
}

const isValid = validate(json, forbiddenFields)
console.log('is json valid? ', isValid)

Я нашел метод расширения в Joi API , но пример настолько запутанный, что я не могу обработать создание пользовательской проверки с моим кодом.

1 Ответ

1 голос
/ 03 июля 2019

Вы можете использовать запрещенные ключи.

const input = {
    email: 'example@example.com',
    activationKey: 123
};

const schema = {
    email: Joi.string().email(),
    activationKey: Joi.any().forbidden()
};

const result = Joi.validate(input, schema);

if (result.error) {
    console.log(result.error.details)
}
<script src="https://cdn.jsdelivr.net/npm/joi-browser@13.4.0/dist/joi-browser.min.js"></script>
...