first commit

This commit is contained in:
2023-10-12 18:29:47 +05:00
commit 826ac1f621
64 changed files with 5159 additions and 0 deletions
+13
View File
@@ -0,0 +1,13 @@
import { Router } from "express";
import Company from "../models/Company.js";
const appRouter = Router();
appRouter.post("/", async (_req, res) => {
const companies = await Company.find();
console.log(companies);
res.json({ route: "app" });
});
export default appRouter;
+18
View File
@@ -0,0 +1,18 @@
import { Router } from "express";
import Build from "../models/Build.js";
const buildsRouter = Router();
buildsRouter.get("/", async (_req, res) => {
await Build.find();
res.json({ ok: 1 });
});
buildsRouter.post("/", async (req, res) => {
const build = await Build.create(req.body);
res.json(build);
});
export default buildsRouter;
+85
View File
@@ -0,0 +1,85 @@
import { Router } from "express";
import Company from "../models/Company.js";
import { parseISO, startOfDay, endOfDay } from "date-fns";
const companiesRouter = Router();
// companiesRouter.get("/", async (_req, res) => {
// const companies = await Company.find();
// res.json(companies);
// });
companiesRouter.get("/:id", async (req, res) => {
if (req.params.id != res.locals.user.companyId) {
res.json({ error: "Access denied!" });
return;
}
const company = await Company.findById(req.params.id);
res.json(company);
});
companiesRouter.get("/:id/builds", async (req, res) => {
if (req.params.id != res.locals.user.companyId) {
res.json({ error: "Access denied!" });
return;
}
const company: any = await Company.findById(req.params.id).populate("builds");
const { builds } = company;
res.json(builds);
});
companiesRouter.get("/:id/users", async (req, res) => {
if (req.params.id != res.locals.user.companyId) {
res.json({ error: "Access denied!" });
return;
}
const company: any = await Company.findById(req.params.id).populate("users");
const { users } = company;
res.json(users);
});
companiesRouter.get(
"/:id/builds/:buildId/scheduled_sessions",
async (req, res) => {
if (req.params.id != res.locals.user.companyId) {
res.json({ error: "Access denied!" });
return;
}
if (!req.query.date) {
res.json({ error: "req.query.date" });
return;
}
const date = parseISO(req.query.date as string);
const company: any = await Company.findById(req.params.id).populate({
path: "builds",
match: {
_id: req.params.buildId,
},
populate: {
path: "scheduledSessions",
match: {
startAt: {
$gte: startOfDay(date),
$lte: endOfDay(date),
},
},
},
});
const { scheduledSessions } = company.builds[0];
res.json(scheduledSessions);
}
);
export default companiesRouter;
+39
View File
@@ -0,0 +1,39 @@
import { Router } from "express";
import jwt, { Secret } from "jsonwebtoken";
import bcrypt from "bcrypt";
import User from "../models/User.js";
import Token from "../models/Token.js";
const router = Router();
router.post("/", async (req, res) => {
const { username, password } = req.body;
if (!username || !password) {
return res.json({
error: "You must pass the 'username' and 'password' parameters",
});
}
const user = await User.findOne({ username });
if (!user) {
return res.json({ error: "A user with this name was not found" });
}
if (!bcrypt.compareSync(password, user.password)) {
return res.json({ error: "Invalid username or password" });
}
const accessToken = jwt.sign({ username }, process.env.JWT_SECRET as Secret, {
expiresIn: "365d",
});
await Token.create({ userId: user.id, accessToken });
res.json({ accessToken, user });
});
const loginRouter = router;
export default loginRouter;
+40
View File
@@ -0,0 +1,40 @@
import { Router } from "express";
import jwt, { Secret } from "jsonwebtoken";
import bcrypt from "bcrypt";
import User from "../models/User.js";
import Token from "../models/Token.js";
const router = Router();
router.post("/", async (req, res) => {
const { username, password } = req.body;
if (!username || !password) {
return res.json({ error: 1 });
}
if (await User.exists({ username })) {
return res.json({ error: 2 });
}
const passwordHash = bcrypt.hashSync(password, 12);
if (!passwordHash) {
return res.json({ error: 3 });
}
const accessToken = jwt.sign({ username }, process.env.JWT_SECRET as Secret, {
expiresIn: "365d",
});
const user = await User.create({ username, password: passwordHash });
const userId = user.id;
await Token.create({ userId, accessToken });
res.json({ accessToken });
});
const registerRouter = router;
export default registerRouter;
+12
View File
@@ -0,0 +1,12 @@
import { Router } from "express";
import ScheduledSession from "../models/ScheduledSession.js";
const scheduledSessionsRouter = Router();
scheduledSessionsRouter.get("/", async (_req, res) => {
await ScheduledSession.find();
res.json({ ok: 1 });
});
export default scheduledSessionsRouter;
+20
View File
@@ -0,0 +1,20 @@
import { Router } from "express";
// import User from "../models/User.js";
const usersRouter = Router();
// usersRouter.get("/", async (_req, res) => {
// const users = await User.find();
// console.log(users);
// res.json(users);
// });
// usersRouter.get("/:id", async (req, res) => {
// const user = await User.findById(req.params.id);
// console.log(user);
// res.json(user);
// });
export default usersRouter;