user.controller.ts 2.37 KB
Newer Older
Yoon, Daeki's avatar
Yoon, Daeki committed
1
2
import { userDb } from "../db";
import { asyncWrap } from "../helpers/asyncWrap";
Kim, MinGyu's avatar
Kim, MinGyu committed
3
import { Request } from "express";
Kim, MinGyu's avatar
Kim, MinGyu committed
4
import formidable from "formidable";
5
6
import { ObjectId } from "mongoose";
import fs from "fs";
Kim, MinGyu's avatar
Kim, MinGyu committed
7
8
9
10

export interface TypedRequestAuth<T> extends Request {
  auth: T;
}
Yoon, Daeki's avatar
Yoon, Daeki committed
11
12
13
14
15
16
17
18
19
20

export const getUsers = asyncWrap(async (req, res) => {
  const users = await userDb.getUsers();
  return res.json(users);
});

export const createUser = asyncWrap(async (req, res) => {
  const user = req.body;
  console.log("user body", user);
  const newUser = await userDb.createUser(user);
Yoon, Daeki's avatar
Yoon, Daeki committed
21
  return res.json(newUser);
Yoon, Daeki's avatar
Yoon, Daeki committed
22
});
Kim, MinGyu's avatar
Kim, MinGyu committed
23
24

export const getProfile = asyncWrap(async (reqExp, res) => {
25
  const req = reqExp as TypedRequestAuth<{ userId: string }>; // 앞에서는 토큰으로써 사용하기 때문에 JwtPayload 를 사용하고 여기서는 verify 에서 토큰을 디코딩했기에 ObjectId 타입의 string으로 바뀌게 된다.
Kim, MinGyu's avatar
Kim, MinGyu committed
26

27
  const { userId } = req.auth;
Kim, MinGyu's avatar
Kim, MinGyu committed
28
  const profile = await userDb.getProfile(userId);
29
30
31
32
33
34
35
36
  res.json(profile);
});

export const postPicture = asyncWrap(async (reqExp, res) => {
  const req = reqExp as TypedRequestAuth<{ userId: ObjectId }>;
  const { userId } = req.auth;

  const form = formidable({
Kim, MinGyu's avatar
Kim, MinGyu committed
37
    uploadDir: "uploads",
38
39
40
41
42
43
44
    keepExtensions: true,
    multiples: false,
  });

  form.parse(req, (err, fields, files) => {
    if (!Array.isArray(files.picture)) {
      //파일 좁히기 중
Kim, MinGyu's avatar
Kim, MinGyu committed
45
      if (!Array.isArray(fields.nickname)) {
Kim, MinGyu's avatar
Kim, MinGyu committed
46
        const nickname = fields.nickname;
Kim, MinGyu's avatar
Kim, MinGyu committed
47
48
49
50
51
52
53
54
55
56
57
58
59
60
        if (!(files.picture === undefined)) {
          const originalfilename = files.picture.originalFilename;
          const newfilename = files.picture.newFilename;
          const picturepath = files.picture.filepath;
          userDb.postPicture(
            userId,
            nickname,
            originalfilename,
            newfilename,
            picturepath
          );
        } else {
          userDb.postPicture(userId, nickname);
        }
Kim, MinGyu's avatar
Kim, MinGyu committed
61
      }
62
63
    }
  });
Kim, MinGyu's avatar
Kim, MinGyu committed
64

65
66
  res.json();
});
Kim, MinGyu's avatar
Kim, MinGyu committed
67
68
69
70
71
72
73
74

export const deleteUser = asyncWrap(async (reqExp, res) => {
  const req = reqExp as TypedRequestAuth<{ userId: ObjectId }>; // 앞에서는 토큰으로써 사용하기 때문에 JwtPayload 를 사용하고 여기서는 verify 에서 토큰을 디코딩했기에 ObjectId 타입의 string으로 바뀌게 된다.

  const { userId } = req.auth;
  const profile = await userDb.deleteUser(userId);
  res.json(profile);
});