added frontent authentication,backend ticket service, frontend ticket creation
This commit is contained in:
@@ -0,0 +1,129 @@
|
||||
const asyncHandler = require("express-async-handler");
|
||||
|
||||
const User = require("../models/userModel");
|
||||
const Ticket = require("../models/ticketModel");
|
||||
|
||||
// @desc Get user ticket
|
||||
// @route GET /api/tickets/:id
|
||||
// @access Private
|
||||
const getTicket = asyncHandler(async (req, res) => {
|
||||
const user = await User.findById(req.user.id);
|
||||
|
||||
if (!user) {
|
||||
res.status(401);
|
||||
throw new Error("User not found");
|
||||
}
|
||||
|
||||
const ticket = await Ticket.findById(req.params.id);
|
||||
if (!ticket) {
|
||||
res.status(404);
|
||||
throw new Error("Ticket not found");
|
||||
}
|
||||
if (ticket.user.toString() !== req.user.id) {
|
||||
res.status(401);
|
||||
throw new Error("Not authorized");
|
||||
}
|
||||
|
||||
res.status(201).json(ticket);
|
||||
});
|
||||
// @desc Get user tickets
|
||||
// @route GET /api/tickets
|
||||
// @access Private
|
||||
const getTickets = asyncHandler(async (req, res) => {
|
||||
const user = await User.findById(req.user.id);
|
||||
|
||||
if (!user) {
|
||||
res.status(401);
|
||||
throw new Error("User not found");
|
||||
}
|
||||
|
||||
const tickets = await Ticket.find({ user: req.user.id });
|
||||
|
||||
res.status(200).json(tickets);
|
||||
});
|
||||
|
||||
// @desc Create a ticket
|
||||
// @route POST /api/tickets
|
||||
// @access Private
|
||||
const createTicket = asyncHandler(async (req, res) => {
|
||||
const { product, description } = req.body;
|
||||
if (!product || !description) {
|
||||
res.status(400);
|
||||
throw new Error("Please provide a product and description");
|
||||
}
|
||||
const user = await User.findById(req.user.id);
|
||||
if (!user) {
|
||||
res.status(401);
|
||||
throw new Error("User not found");
|
||||
}
|
||||
const ticket = await Ticket.create({
|
||||
product,
|
||||
description,
|
||||
user: req.user.id,
|
||||
});
|
||||
res.status(201).json(ticket);
|
||||
});
|
||||
// @desc Delete a ticket
|
||||
// @route DELETE /api/ticket:id
|
||||
// @access Private
|
||||
const deleteTicket = asyncHandler(async (req, res) => {
|
||||
const user = await User.findById(req.user.id);
|
||||
|
||||
if (!user) {
|
||||
res.status(401);
|
||||
throw new Error("User not found");
|
||||
}
|
||||
|
||||
const ticket = await Ticket.findById(req.params.id);
|
||||
|
||||
if (!ticket) {
|
||||
res.status(404);
|
||||
throw new Error("Ticket not found");
|
||||
}
|
||||
|
||||
if (ticket.user.toString() !== req.user.id) {
|
||||
res.status(401);
|
||||
throw new Error("Not authorized");
|
||||
}
|
||||
|
||||
res.status(200).json({ success: true });
|
||||
});
|
||||
|
||||
const updateTicket = asyncHandler(async (req, res) => {
|
||||
const user = await User.findById(req.user.id);
|
||||
|
||||
if (!user) {
|
||||
res.status(401);
|
||||
throw new Error("User not found");
|
||||
}
|
||||
|
||||
const ticket = await Ticket.findById(req.params.id);
|
||||
|
||||
if (!ticket) {
|
||||
res.status(404);
|
||||
throw new Error("Ticket not found");
|
||||
}
|
||||
|
||||
if (ticket.user.toString() !== req.user.id) {
|
||||
res.status(401);
|
||||
throw new Error("Not authorized");
|
||||
}
|
||||
|
||||
const updatedTicket = await Ticket.findByIdAndUpdate(
|
||||
req.params.id,
|
||||
req.body,
|
||||
{
|
||||
new: true,
|
||||
}
|
||||
);
|
||||
|
||||
res.status(200).json(updatedTicket);
|
||||
});
|
||||
|
||||
module.exports = {
|
||||
updateTicket,
|
||||
deleteTicket,
|
||||
getTicket,
|
||||
getTickets,
|
||||
createTicket,
|
||||
};
|
||||
@@ -0,0 +1,30 @@
|
||||
const mongoose = require("mongoose");
|
||||
|
||||
const ticketSchema = mongoose.Schema(
|
||||
{
|
||||
user: {
|
||||
type: mongoose.Schema.Types.ObjectId,
|
||||
required: true,
|
||||
ref: "User",
|
||||
},
|
||||
product: {
|
||||
type: String,
|
||||
required: [true, "Please select a product"],
|
||||
enum: ["iPhone", "Macbook Pro", "iMac", "iPad"],
|
||||
},
|
||||
description: {
|
||||
type: String,
|
||||
required: [true, "Please enter a description of the issue"],
|
||||
},
|
||||
status: {
|
||||
type: String,
|
||||
enum: ['new','open','closed'],
|
||||
default: 'new',
|
||||
},
|
||||
},
|
||||
{
|
||||
timestamps: true,
|
||||
}
|
||||
);
|
||||
|
||||
module.exports = mongoose.model("Ticket", ticketSchema);
|
||||
@@ -0,0 +1,21 @@
|
||||
const express = require("express");
|
||||
const router = express.Router();
|
||||
const {
|
||||
getTicket,
|
||||
getTickets,
|
||||
createTicket,
|
||||
deleteTicket,
|
||||
updateTicket,
|
||||
} = require("../controllers/ticketController");
|
||||
|
||||
const protect = require("../middleware/authMiddleware");
|
||||
|
||||
|
||||
router.route("/").get(protect, getTickets).post(protect, createTicket);
|
||||
router
|
||||
.route("/:id")
|
||||
.get(protect, getTicket)
|
||||
.delete(protect, deleteTicket)
|
||||
.put(protect, updateTicket);
|
||||
|
||||
module.exports = router;
|
||||
@@ -18,6 +18,7 @@ app.get("/", (req, res) => {
|
||||
});
|
||||
|
||||
app.use("/api/users", require("./routes/userRoutes"));
|
||||
app.use("/api/tickets", require("./routes/ticketRoutes"));
|
||||
app.use(errorHandler);
|
||||
|
||||
app.listen(PORT, () => console.log(`Server started on port ${PORT}`));
|
||||
|
||||
Reference in New Issue
Block a user