e-scooter-rental-system/server/routes/customers.js

102 lines
3.7 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

const express = require('express');
const router = express.Router();
const Customer = require('../models/Customer');
const Store = require('../models/Store');
const { authMiddleware, requireRole } = require('../middleware/auth');
const { validate } = require('../middleware/validate');
const { schemas } = require('../middleware/validate');
// 获取所有客户admin 或 store 可查)
router.get('/', authMiddleware, requireRole('admin', 'store'), async (req, res) => {
try {
const customers = await Customer.find();
res.json({ success: true, data: customers });
} catch (error) {
res.status(500).json({ success: false, message: "服务器内部错误" });
}
});
// 获取单个客户
router.get('/:id', authMiddleware, requireRole('admin', 'store'), async (req, res) => {
try {
const customer = await Customer.findById(req.params.id);
if (!customer) return res.status(404).json({ success: false, message: '客户不存在' });
res.json({ success: true, data: customer });
} catch (error) {
res.status(500).json({ success: false, message: "服务器内部错误" });
}
});
// 创建客户admin 或 store
router.post('/', authMiddleware, requireRole('admin', 'store'), validate(schemas.customer), async (req, res) => {
try {
const customer = new Customer(req.body);
await customer.save();
res.status(201).json({ success: true, data: customer });
} catch (error) {
res.status(400).json({ success: false, message: "服务器内部错误" });
}
});
// 更新客户
router.put('/:id', authMiddleware, requireRole('admin', 'store'), async (req, res) => {
try {
const customer = await Customer.findByIdAndUpdate(req.params.id, req.body, { new: true, runValidators: true });
if (!customer) return res.status(404).json({ success: false, message: '客户不存在' });
res.json({ success: true, data: customer });
} catch (error) {
res.status(400).json({ success: false, message: "服务器内部错误" });
}
});
// 删除客户(仅 admin
router.delete('/:id', authMiddleware, requireRole('admin'), async (req, res) => {
try {
const customer = await Customer.findByIdAndDelete(req.params.id);
if (!customer) return res.status(404).json({ success: false, message: '客户不存在' });
res.json({ success: true, message: '客户已删除' });
} catch (error) {
res.status(500).json({ success: false, message: "服务器内部错误" });
}
});
// 搜索客户
router.get('/search/:keyword', authMiddleware, requireRole('admin', 'store'), async (req, res) => {
try {
const keyword = req.params.keyword;
const customers = await Customer.find({
$or: [
{ name: { $regex: keyword, $options: 'i' } },
{ phone: { $regex: keyword, $options: 'i' } },
{ customerId: { $regex: keyword, $options: 'i' } }
]
});
res.json({ success: true, data: customers });
} catch (error) {
res.status(500).json({ success: false, message: "服务器内部错误" });
}
});
// 更新客户信用评分admin 或 store
router.patch('/:id/credit', authMiddleware, requireRole('admin', 'store'), async (req, res) => {
try {
const { creditScore } = req.body;
let creditLevel = '优秀';
if (creditScore < 60) creditLevel = '较差';
else if (creditScore < 80) creditLevel = '一般';
else if (creditScore < 90) creditLevel = '良好';
const customer = await Customer.findByIdAndUpdate(
req.params.id,
{ creditScore, creditLevel },
{ new: true }
);
if (!customer) return res.status(404).json({ success: false, message: '客户不存在' });
res.json({ success: true, data: customer });
} catch (error) {
res.status(400).json({ success: false, message: "服务器内部错误" });
}
});
module.exports = router;