POST input validation
This commit is contained in:
@@ -1,12 +1,29 @@
|
||||
const express = require("express");
|
||||
const yup = require("yup");
|
||||
const { Op } = require("sequelize");
|
||||
const { User } = require("../models");
|
||||
const router = express.Router();
|
||||
|
||||
router.post("/", async (req, res) => {
|
||||
let data = req.body;
|
||||
let result = await User.create(data);
|
||||
res.json(result);
|
||||
// Validate request body
|
||||
let validationSchema = yup.object({
|
||||
id: yup.number().min(0).required(),
|
||||
firstName: yup.string().trim().min(1).max(100).required(),
|
||||
lastName: yup.string().trim().min(1).max(100).required(),
|
||||
email: yup.string().trim().min(5).max(69).email().required(),
|
||||
phoneNumber: yup.string().trim().length(8).required(),
|
||||
passwordHash: yup.string().trim().min(128).max(255).required(),
|
||||
description: yup.string().trim().min(3).max(500).required(),
|
||||
});
|
||||
try {
|
||||
data = await validationSchema.validate(data, { abortEarly: false });
|
||||
// Process valid data
|
||||
let result = await User.create(data);
|
||||
res.json(result);
|
||||
} catch (err) {
|
||||
res.status(400).json({ errors: err.errors });
|
||||
}
|
||||
});
|
||||
|
||||
router.get("/", async (req, res) => {
|
||||
|
||||
Reference in New Issue
Block a user