User routes
This commit is contained in:
committed by
Andrew Trieu
parent
8b276dbadb
commit
6c35f7d006
@@ -9,3 +9,4 @@ Table:
|
|||||||
| 07.07.2023 | Brainstorming and initialize project | 2 |
|
| 07.07.2023 | Brainstorming and initialize project | 2 |
|
||||||
| 07.07.2023 | Setting up database | 2 |
|
| 07.07.2023 | Setting up database | 2 |
|
||||||
| 07.07.2023 | Authentication and authorization | 6 |
|
| 07.07.2023 | Authentication and authorization | 6 |
|
||||||
|
| 10.07.2023 | User routes | 4 |
|
||||||
|
|||||||
101
server/controllers/users.js
Normal file
101
server/controllers/users.js
Normal file
@@ -0,0 +1,101 @@
|
|||||||
|
import User from "../models/User";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Read - GET
|
||||||
|
*/
|
||||||
|
export const getUser = async (req, res) => {
|
||||||
|
try {
|
||||||
|
const { id } = req.params;
|
||||||
|
const user = await User.findById(id);
|
||||||
|
|
||||||
|
res.status(200).json(user);
|
||||||
|
} catch (error) {
|
||||||
|
res.status(404).json({ error: error.message });
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getFriends = async (req, res) => {
|
||||||
|
try {
|
||||||
|
const { id } = req.params;
|
||||||
|
const user = await User.findById(id);
|
||||||
|
const friends = await Promise.all(
|
||||||
|
user.friends.map((id) => User.findById(id))
|
||||||
|
);
|
||||||
|
const friendList = friends.map(
|
||||||
|
({
|
||||||
|
_id,
|
||||||
|
firstName,
|
||||||
|
lastName,
|
||||||
|
profilePicturePath,
|
||||||
|
location,
|
||||||
|
description,
|
||||||
|
admin,
|
||||||
|
}) => {
|
||||||
|
return {
|
||||||
|
_id,
|
||||||
|
firstName,
|
||||||
|
lastName,
|
||||||
|
profilePicturePath,
|
||||||
|
location,
|
||||||
|
description,
|
||||||
|
admin,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
res.status(200).json(friendList);
|
||||||
|
} catch (error) {
|
||||||
|
res.status(404).json({ error: error.message });
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update - PATCH
|
||||||
|
*/
|
||||||
|
export const patchFriend = async (req, res) => {
|
||||||
|
try {
|
||||||
|
const { id, friendId } = req.params;
|
||||||
|
const user = await User.findById(id);
|
||||||
|
const friend = await User.findById(friendId);
|
||||||
|
|
||||||
|
if (user.friends.includes(friendId)) {
|
||||||
|
user.friends = user.friends.filter((id) => id !== friendId);
|
||||||
|
friend.friends = friend.friends.filter((id) => id !== id);
|
||||||
|
} else {
|
||||||
|
user.friends.push(friendId);
|
||||||
|
friend.friends.push(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
await user.save();
|
||||||
|
await friend.save();
|
||||||
|
|
||||||
|
const friends = await Promise.all(
|
||||||
|
user.friends.map((id) => User.findById(id))
|
||||||
|
);
|
||||||
|
const friendList = friends.map(
|
||||||
|
({
|
||||||
|
_id,
|
||||||
|
firstName,
|
||||||
|
lastName,
|
||||||
|
profilePicturePath,
|
||||||
|
location,
|
||||||
|
description,
|
||||||
|
admin,
|
||||||
|
}) => {
|
||||||
|
return {
|
||||||
|
_id,
|
||||||
|
firstName,
|
||||||
|
lastName,
|
||||||
|
profilePicturePath,
|
||||||
|
location,
|
||||||
|
description,
|
||||||
|
admin,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
res.status(200).json(friendList);
|
||||||
|
} catch (error) {
|
||||||
|
res.status(404).json({ error: error.message });
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -8,9 +8,15 @@ import helmet from "helmet";
|
|||||||
import morgan from "morgan";
|
import morgan from "morgan";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
import { fileURLToPath } from "url";
|
import { fileURLToPath } from "url";
|
||||||
|
/* Routes */
|
||||||
import authRoutes from "./routes/auth.js";
|
import authRoutes from "./routes/auth.js";
|
||||||
|
import userRoutes from "./routes/user.js";
|
||||||
|
import postRoutes from "./routes/post.js";
|
||||||
/* Controllers */
|
/* Controllers */
|
||||||
import { register } from "./controllers/auth.js";
|
import { register } from "./controllers/auth.js";
|
||||||
|
import { createPost } from "./controllers/post.js";
|
||||||
|
/* Middlewares */
|
||||||
|
import { verifyToken } from "./middlewares/auth.js";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Config
|
* Config
|
||||||
@@ -45,6 +51,10 @@ const upload = multer({ storage });
|
|||||||
* Routes
|
* Routes
|
||||||
* */
|
* */
|
||||||
app.post("/auth/register", upload.single("profilePicture"), register);
|
app.post("/auth/register", upload.single("profilePicture"), register);
|
||||||
|
app.post("/posts", verifyToken, upload.single("image"), createPost);
|
||||||
|
app.use("/auth", authRoutes);
|
||||||
|
app.use("/users", userRoutes);
|
||||||
|
app.use("/posts", postRoutes);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Database
|
* Database
|
||||||
|
|||||||
18
server/routes/users.js
Normal file
18
server/routes/users.js
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
import express from "express";
|
||||||
|
import { getUser, getFriends, patchFriend } from "../controllers/users.js";
|
||||||
|
import { verifyToken } from "../middlewares/auth.js";
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Read - GET
|
||||||
|
*/
|
||||||
|
router.get("/:id", verifyToken, getUser);
|
||||||
|
router.get("/:id/friends", verifyToken, getFriends);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update - PATCH
|
||||||
|
*/
|
||||||
|
router.patch("/:id/:friendId", verifyToken, patchFriend);
|
||||||
|
|
||||||
|
export default router;
|
||||||
Reference in New Issue
Block a user