user.controller.js 3.04 KB
Newer Older
한규민's avatar
한규민 committed
1
2
import jwt from "jsonwebtoken";
import config from "../config/app.config.js";
한규민's avatar
한규민 committed
3
import { User, Role } from '../db/index.js'
한규민's avatar
한규민 committed
4

한규민's avatar
한규민 committed
5
6
7
8
9
10
11
12
13
const login = async(req, res) => {
    try {
        const { id, password } = req.body;
        //사용자 존재 확인
        const user = await User.scope("withPassword").findOne({ where: { userId: id } });

        if (!user) {
            return res.status(422).send(`사용자가 존재하지 않습니다`);
        }
한규민's avatar
한규민 committed
14
        // 2) 비밀번호 확인은 데이터베이스 프로토타입 메소드에서 처리(사용자가 입력한 비밀번호와 서버에 있는 비번 비교)
한규민's avatar
한규민 committed
15
16
17
18
19
20
21
22
23
24
25
        const passwordMatch = await user.comparePassword(password);
        if (passwordMatch) {
            // 3) 비밀번호가 맞으면 토큰 생성
            // const userRole = await user.getRole();
            const signData = {
                userId: user.id,
                //   role: userRole.name,
            };
            const token = jwt.sign(signData, config.jwtSecret, {
                expiresIn: config.jwtExpires,
            });
한규민's avatar
한규민 committed
26
            console.log("token = ", token);
한규민's avatar
한규민 committed
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
            // 4) 토큰을 쿠키에 저장
            res.cookie(config.cookieName, token, {
                maxAge: config.cookieMaxAge,
                path: "/",
                httpOnly: config.env === "production",
                secure: config.env === "production",
            });
            // 5) 사용자 반환
            res.json({
                userId: user.id,
                isLoggedIn: true,
                // role: userRole.name,
                // isMember: user.isMember,
            });
        } else {
            // 6) 비밀번호 불일치
            res.status(401).send("비밀번호가 일치하지 않습니다");
        }
    } catch (error) {
        console.error(error);
        return res.status(500).send("로그인 에러");
    }

}


한규민's avatar
한규민 committed
53
54
const compareId = async (req, res) => {
    const id = req.params.userId;
한규민's avatar
한규민 committed
55
56
    const userid = await User.findOne({where:{userId: id}});
        if(userid !== null){
한규민's avatar
한규민 committed
57
58
59
60
61
62
        return res.json(true);
    }else{
        return res.json(false);
    }
}

한규민's avatar
한규민 committed
63
64
65
66
67
68
69
70
71
const signup = async (req, res) => {
    const { userId, userNickName, userBirthday, userPassword } = req.body;
    // 휴대폰 중복 확인
    const userMbnum = String(req.body.userMbnum);
    try {
        const mbnum  = await User.findOne({ where: { phoneNumber: userMbnum } });
        if (mbnum) {
            return res.status(422).send(`이미 있는 휴대폰번호입니다.`);
        }
한규민's avatar
한규민 committed
72
        const role = await Role.findOne({ where: {name: "user"} })
한규민's avatar
한규민 committed
73
74
75
76
77
        const newUser = await User.create({
            userId: userId,
            nickname: userNickName,
            birth: userBirthday,
            phoneNumber: userMbnum,
한규민's avatar
한규민 committed
78
79
            password: userPassword,
            roleId: role.id
한규민's avatar
한규민 committed
80
81
82
83
84
85
86
87
88
        });
        res.json(newUser);
    } catch (error) {
        console.error(error.message);
        res.status(500).send("회원가입 에러. 나중에 다시 시도 해주세요");
    }
};


한규민's avatar
한규민 committed
89
export default {
한규민's avatar
한규민 committed
90
91
92
    login,
    compareId,
    signup
한규민's avatar
한규민 committed
93
}