order.controller.js 2.71 KB
Newer Older
kusang96's avatar
card    
kusang96 committed
1
import mongoose from 'mongoose';
Jiwon Yoon's avatar
Jiwon Yoon committed
2
import Order from "../schemas/Order.js";
3
import User from "../schemas/User.js";
Jiwon Yoon's avatar
Jiwon Yoon committed
4
import Product from "../schemas/Product.js";
Jiwon Yoon's avatar
Jiwon Yoon committed
5
6
7
8

const addorder = async (req, res) => {
    const { userId, products, receiverInfo, total } = req.body
    try {
kusang96's avatar
kusang96 committed
9
        const newOrder = await new Order({ userId, products, receiverInfo, total }).save()
Jiwon Yoon's avatar
Jiwon Yoon committed
10
11
12
13
14
15
16
        res.status(200).send('Order DB에 저장 완료')
    } catch (error) {
        console.log(error)
        res.status(500).send('Order DB에 저장 실패')
    }
}

17
18
19
const Ordered = async (req, res) => {
    const { db } = req.body
    try {
kusang96's avatar
kusang96 committed
20
        const ordered = await req.body.findOne({}, { _id: 0 }).select(`${db}`)
21
22
        res.json(ordered);
    } catch (error) {
Kim, Subin's avatar
정리    
Kim, Subin committed
23
        console.log(error)
24
25
26
27
        res.status(500).send('카테고리를 불러오지 못했습니다.')
    }
}

Jiwon Yoon's avatar
Jiwon Yoon committed
28
29
const showorder = async (req, res) => {
    try {
kusang96's avatar
kusang96 committed
30
        const order = await Order.find({ userId: req.userId }).sort({ _id: -1 }).limit(1).populate({
Jiwon Yoon's avatar
Jiwon Yoon committed
31
32
33
            path: 'products.productId',
            model: 'Product'
        })
34
        res.status(200).json(order[0])
Jiwon Yoon's avatar
Jiwon Yoon committed
35
36
37
38
39
40
    } catch (error) {
        console.log(error)
        res.status(500).send('쇼핑카트를 불러오지 못했습니다.')
    }
}

41
42
43
44
45
46
47
48
49
50
51
52
53
const orderById = async (req, res, next, id) => {
    try {
        const user = await User.findById(id)
        if (!user) {
            res.status(404).send('사용자를 찾을 수 없습니다')
        }
        req.userId = user
        next()
    } catch (error) {
        console.log(error);
        res.status(500).send('사용자 아이디 검색 실패')
    }
}
Jiwon Yoon's avatar
Jiwon Yoon committed
54

kusang96's avatar
card    
kusang96 committed
55
const recommendPro = async (req, res) => {
Jiwon Yoon's avatar
Jiwon Yoon committed
56
    const productId = req.query.products
이재연's avatar
aaaa    
이재연 committed
57
58
    try {
        const recommend = await Order.aggregate([
kusang96's avatar
card    
kusang96 committed
59
60
            {
                $match: {
Jiwon Yoon's avatar
Jiwon Yoon committed
61
                    'products.productId': mongoose.Types.ObjectId(productId)
kusang96's avatar
card    
kusang96 committed
62
63
                }
            },
Jiwon Yoon's avatar
Jiwon Yoon committed
64
            { $unwind: "$products" },
이재연's avatar
aaaa    
이재연 committed
65
            {
kusang96's avatar
card    
kusang96 committed
66
                $group: {
Jiwon Yoon's avatar
Jiwon Yoon committed
67
68
                    _id: "$products.productId",
                    count: { $sum: 1 }
이재연's avatar
aaaa    
이재연 committed
69
                }
70
71
72
73
74
75
76
77
78
79
80
            },
            { $sort: { count: -1 } },
            { $limit: 5 },
            {
                $lookup:
                {
                    from: "products",
                    localField: "_id",
                    foreignField: "_id",
                    as: "product"
                }
이재연's avatar
aaaa    
이재연 committed
81
82
            }
        ])
Jiwon Yoon's avatar
Jiwon Yoon committed
83
        const filteredRecommend = recommend.filter((el) => String(el._id) !== String(productId))
84
        res.json(filteredRecommend)
이재연's avatar
aaaa    
이재연 committed
85
    } catch (error) {
Kim, Subin's avatar
정리    
Kim, Subin committed
86
87
        console.log(error)
        res.status(404).send('추천 상품이 없습니다.')
이재연's avatar
aaaa    
이재연 committed
88
89
90
    }
}

kusang96's avatar
card    
kusang96 committed
91
export default { addorder, showorder, orderById, Ordered, recommendPro }