user.controller.js 1016 Bytes
Newer Older
kusang96's avatar
dd    
kusang96 committed
1
import User from "../schemas/User.js";
kusang96's avatar
kusang96 committed
2
3
import isLength from 'validator/lib/isLength.js';
import bcrypt from 'bcryptjs';
Kim, Subin's avatar
Kim, Subin committed
4
5

const signup = async (req, res) => {
이재연's avatar
이재연 committed
6
    console.log(req.body)
이재연's avatar
이재연 committed
7
    const { name, number1, number2, id, password,  tel } = req.body
Kim, Subin's avatar
Kim, Subin committed
8
    try {
이재연's avatar
이재연 committed
9
        if(!isLength(password,{min:8, max:15})){
이재연's avatar
aa    
이재연 committed
10
            return res.status(422).send('비밀번호는 8-15자리로 입력해주세요.')
이재연's avatar
이재연 committed
11
        }
이재연's avatar
aa    
이재연 committed
12
13
14
15
16
17
18
        const user=await User.findOne({id})
        if(user){
            return res.status(422).send(`${id}가 이미 사용중입니다.`)
        }

        const hash=await bcrypt.hash(password,10)

Kim, Subin's avatar
Kim, Subin committed
19
20
        const newUser = await new User ({
            name,
이재연's avatar
이재연 committed
21
22
            number1,
            number2,
이재연's avatar
이재연 committed
23
            id,
이재연's avatar
aa    
이재연 committed
24
            password:hash,
이재연's avatar
이재연 committed
25
            tel,
Kim, Subin's avatar
Kim, Subin committed
26
27
28
        }).save()
        console.log(newUser)
        res.json(newUser)
kusang96's avatar
kusang96 committed
29

Kim, Subin's avatar
Kim, Subin committed
30
31
    } catch (error) {
        console.log(error)
이재연's avatar
aa    
이재연 committed
32
        res.status(500).send('죄송합니다. 다시 입력해 주십시오.')
Kim, Subin's avatar
Kim, Subin committed
33
34
35
    }
}

36
export default { signup }