user.controller.js 1 KB
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
        const user=await User.findOne({id})
        if(user){
            return res.status(422).send(`${id}가 이미 사용중입니다.`)
        }
이재연's avatar
이재연 committed
16
        
이재연's avatar
aa    
이재연 committed
17
18
19

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

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

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

37
export default { signup }