first commit
This commit is contained in:
@@ -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;
|
||||
@@ -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;
|
||||
@@ -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;
|
||||
@@ -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;
|
||||
@@ -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;
|
||||
@@ -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;
|
||||
@@ -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;
|
||||
Reference in New Issue
Block a user