From 21a9d293b63f1302064b700271745ebb063f9e25 Mon Sep 17 00:00:00 2001 From: Elizabeth Louie <37051992+elouiestudent@users.noreply.github.com> Date: Tue, 22 Nov 2022 15:51:50 -0800 Subject: [PATCH] Add archiver field to items (#191) * Add archiver field to items Co-authored-by: James <79486681+JamesN3@users.noreply.github.com> --- api/models/Item.ts | 4 ++++ api/routes/items.ts | 24 ++++++++++++++++++++++-- 2 files changed, 26 insertions(+), 2 deletions(-) diff --git a/api/models/Item.ts b/api/models/Item.ts index 0ccdcd3..1950667 100644 --- a/api/models/Item.ts +++ b/api/models/Item.ts @@ -28,6 +28,7 @@ export interface IItem extends Document { modified: string[]; approver: string; returner: string; + archiver: string; } const ItemSchema = new Schema( @@ -116,6 +117,9 @@ const ItemSchema = new Schema( returner: { type: String, }, + archiver: { + type: String, + }, }, { toJSON: { virtuals: true }, diff --git a/api/routes/items.ts b/api/routes/items.ts index 0657214..6819556 100644 --- a/api/routes/items.ts +++ b/api/routes/items.ts @@ -26,6 +26,12 @@ router.post("/all", isUser, async (req: Request, res: Response) => { else console.log(docs); }); const onlyArchived = req.body.onlyArchived ?? false; + Item.updateMany({ archiver: { $exists: false } }, [ + { $set: { archiver: null } }, + ]).exec(function (err, docs) { + if (err) console.log(err); + else console.log(docs); + }); Item.find({ archived: onlyArchived }) .populate("whereToRetrieve") .sort({ dateFound: -1, timeFound: -1 }) @@ -94,6 +100,7 @@ router.post("/add", isUser, async (req: Request, res: Response) => { modified: [user.username], approver: approved ? user.username : null, returner: null, + archiver: null, }); item.save((err) => { if (err) { @@ -161,7 +168,11 @@ router.post("/archive", isUser, async (req: Request, res: Response) => { ) { const updatedItem = await Item.findByIdAndUpdate( id, - { archived: archived, dateArchived: new Date() }, + { + archived: archived, + archiver: user.username, + dateArchived: new Date(), + }, { runValidators: true, useFindAndModify: false } ); updatedItems.push(updatedItem); @@ -188,6 +199,7 @@ router.post("/archiveByDays", isAdmin, async (req: Request, res: Response) => { const days = req.body.days; // eslint-disable-next-line @typescript-eslint/no-var-requires const ObjectID = require("mongodb").ObjectID; + const user = req.body.user; Item.updateMany( { $and: [ @@ -203,7 +215,15 @@ router.post("/archiveByDays", isAdmin, async (req: Request, res: Response) => { }, ], }, - [{ $set: { archived: true, dateArchived: new Date() } }] + [ + { + $set: { + archived: true, + archiver: user.username, + dateArchived: new Date(), + }, + }, + ] ).exec(function (err, docs) { if (err) { console.log(err);