diff --git a/backend/prisma/schema.prisma b/backend/prisma/schema.prisma index de7552b..11c0658 100644 --- a/backend/prisma/schema.prisma +++ b/backend/prisma/schema.prisma @@ -31,7 +31,7 @@ model Drill { title String description String observations String - image String @default("") + image String @default("") classPlanId String classPlan ClassPlan @relation(fields: [classPlanId], references: [id]) drillElements DrillElement[] diff --git a/backend/src/controllers/classPlanController.ts b/backend/src/controllers/classPlanController.ts index f2f60ba..83a072c 100644 --- a/backend/src/controllers/classPlanController.ts +++ b/backend/src/controllers/classPlanController.ts @@ -130,12 +130,48 @@ export default class classPlanController { delete = async (req: Request, res: Response) => { try { const { id } = req.params + const data = await prisma.classPlan.findMany({ + where: { + id, + }, + select: { + id: true, + drills: { + select: { + id: true, + drillElements: { + select: { + id: true, + }, + }, + }, + }, + }, + }) - const classPlan = await prisma.classPlan.delete({ - where: { id }, + data.map(async (item) => { + item.drills.map(async (drill) => { + drill.drillElements.map(async (drillElement) => { + await prisma.drillElement.delete({ + where: { + id: drillElement.id, + }, + }) + }) + await prisma.drill.delete({ + where: { + id: drill.id, + }, + }) + }) }) - res.status(200).json(classPlan) + const plan = await prisma.classPlan.delete({ + where: { + id, + }, + }) + res.status(200).json(plan) } catch (err) { err as Prisma.PrismaClientKnownRequestError res.status(500).json({ errors: { server: "Server error" } }) diff --git a/backend/src/controllers/drillController.ts b/backend/src/controllers/drillController.ts index 821c203..721995f 100644 --- a/backend/src/controllers/drillController.ts +++ b/backend/src/controllers/drillController.ts @@ -93,12 +93,36 @@ export default class drillController { deleteById = async (req: Request, res: Response) => { try { const id = req.params.id - const deletedDrill = await prisma.drill.deleteMany({ + + const drills = await prisma.drill.findMany({ where: { id, }, + select: { + drillElements: { + select: { + id: true, + }, + }, + }, + }) + + drills.map(async (drill) => { + drill.drillElements.map(async (drillElement) => { + await prisma.drillElement.delete({ + where: { + id: drillElement.id, + }, + }) + }) + await prisma.drill.delete({ + where: { + id, + }, + }) }) - res.status(204).json(deletedDrill) + + res.status(204).json({ message: "Drill deleted" }) } catch (err) { console.log(err) res.status(500).json({ error: "Internal Server Error" }) diff --git a/backend/src/middleware/authUser.ts b/backend/src/middleware/authUser.ts index dd8d6aa..cc3adc2 100644 --- a/backend/src/middleware/authUser.ts +++ b/backend/src/middleware/authUser.ts @@ -1,4 +1,5 @@ -import { sign } from "jsonwebtoken" +import { sign, verify } from "jsonwebtoken" +import { Request, Response, NextFunction } from "express" interface Idata { id: string @@ -11,4 +12,22 @@ export default class AuthUser { expiresIn: "30d", }) } + + async auth( + request: Request, + response: Response, + next: NextFunction, + ): Promise { + let token + try { + token = request.headers.authorization?.split(" ")[1] + verify(token as string, process.env.AUTH_CONFIG_SECRET as string) + } catch (err) { + return response.status(401).json({ + message: "Token inválido!", + }) + } + next() + return null + } } diff --git a/backend/src/routes/classPlanRouters.ts b/backend/src/routes/classPlanRouters.ts index 0d35afc..0f9bf74 100644 --- a/backend/src/routes/classPlanRouters.ts +++ b/backend/src/routes/classPlanRouters.ts @@ -1,17 +1,20 @@ import { Router } from "express" import classPlanController from "../controllers/classPlanController" +import AuthUser from "../middleware/authUser" const classPlanRouters = Router() +const authenticateUser = new AuthUser() const classPlan = new classPlanController() -classPlanRouters.post("/", classPlan.create) -classPlanRouters.get("/:id", classPlan.show) +classPlanRouters.post("/", authenticateUser.auth, classPlan.create) +classPlanRouters.get("/:id", authenticateUser.auth, classPlan.show) classPlanRouters.get( "/pesquisa-data-titulo/:userId/:title/:startDate/:finalDate", + authenticateUser.auth, classPlan.searchByCreatedAtOrTitle, ) classPlanRouters.get("/planos-usuario/:userId", classPlan.list) -classPlanRouters.put("/:id", classPlan.updateById) -classPlanRouters.delete("/:id", classPlan.delete) +classPlanRouters.put("/:id", authenticateUser.auth, classPlan.updateById) +classPlanRouters.delete("/:id", authenticateUser.auth, classPlan.delete) export default classPlanRouters diff --git a/backend/src/routes/drillElementRouters.ts b/backend/src/routes/drillElementRouters.ts index c2e2835..b7bac00 100644 --- a/backend/src/routes/drillElementRouters.ts +++ b/backend/src/routes/drillElementRouters.ts @@ -1,12 +1,22 @@ import { Router } from "express" import drillElementController from "@/controllers/drillElementController" +import AuthUser from "../middleware/authUser" const drillElementRouters = Router() +const authenticateUser = new AuthUser() const drillElement = new drillElementController() -drillElementRouters.post("/", drillElement.create) -drillElementRouters.get("/:drillId", drillElement.getManyByDrillId) -drillElementRouters.put("/:id", drillElement.updateById) -drillElementRouters.delete("/:id", drillElement.deleteById) +drillElementRouters.post("/", authenticateUser.auth, drillElement.create) +drillElementRouters.get( + "/:drillId", + authenticateUser.auth, + drillElement.getManyByDrillId, +) +drillElementRouters.put("/:id", authenticateUser.auth, drillElement.updateById) +drillElementRouters.delete( + "/:id", + authenticateUser.auth, + drillElement.deleteById, +) export default drillElementRouters diff --git a/backend/src/routes/drillRouters.ts b/backend/src/routes/drillRouters.ts index 169cf22..360a3d5 100644 --- a/backend/src/routes/drillRouters.ts +++ b/backend/src/routes/drillRouters.ts @@ -1,14 +1,20 @@ import { Router } from "express" import drillController from "../controllers/drillController" +import AuthUser from "../middleware/authUser" +const authenticateUser = new AuthUser() const drillRouters = Router() const drill = new drillController() -drillRouters.post("/", drill.create) -drillRouters.get("/:classPlanId", drill.getManyByClassPlanId) -drillRouters.get("/drill/:id", drill.show) -drillRouters.put("/:id", drill.updateById) -drillRouters.put("/image/:id", drill.updateImage) -drillRouters.delete("/:id", drill.deleteById) +drillRouters.post("/", authenticateUser.auth, drill.create) +drillRouters.get( + "/:classPlanId", + authenticateUser.auth, + drill.getManyByClassPlanId, +) +drillRouters.get("/drill/:id", authenticateUser.auth, drill.show) +drillRouters.put("/:id", authenticateUser.auth, drill.updateById) +drillRouters.put("/image/:id", authenticateUser.auth, drill.updateImage) +drillRouters.delete("/:id", authenticateUser.auth, drill.deleteById) export default drillRouters diff --git a/frontend/src/components/Header.tsx b/frontend/src/components/Header.tsx index 5c342e1..2f52090 100644 --- a/frontend/src/components/Header.tsx +++ b/frontend/src/components/Header.tsx @@ -1,4 +1,5 @@ import { Icon } from '@iconify/react/dist/iconify.js'; +import { useEffect, useState } from 'react'; const Header = (props: { hasReturnArrow: boolean; @@ -10,6 +11,14 @@ const Header = (props: { window.location.href = '/login'; }; + useEffect(() => { + console.log("Aqui"); + const user = localStorage.getItem('user'); + if(!user){ + logout(); + } + }, []); + return (