From 2ffb9b785163044a87675c3ae82b68f93907d411 Mon Sep 17 00:00:00 2001 From: Paul Bienkowski Date: Tue, 1 Dec 2020 18:20:36 +0100 Subject: [PATCH] chore: use ObjectId.equals instead of toString() comparison --- src/models/Track.js | 2 +- src/routes/api/tracks.js | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/src/models/Track.js b/src/models/Track.js index c27713f..6ddda0b 100644 --- a/src/models/Track.js +++ b/src/models/Track.js @@ -42,7 +42,7 @@ class Track extends mongoose.Model { return false; } - if (user._id.toString() === this.author._id.toString()) { + if (user._id.equals(this.author._id)) { return true; } diff --git a/src/routes/api/tracks.js b/src/routes/api/tracks.js index 735dffb..53bfbcc 100644 --- a/src/routes/api/tracks.js +++ b/src/routes/api/tracks.js @@ -303,7 +303,7 @@ router.put( busboy(), auth.required, wrapRoute(async (req, res) => { - if (req.track.author._id.toString() !== req.user.id.toString()) { + if (!req.track.author._id.equals(req.user.id)) { return res.sendStatus(403); } @@ -348,7 +348,7 @@ router.delete( '/:track', auth.required, wrapRoute(async (req, res) => { - if (req.track.author._id.toString() === req.user.id.toString()) { + if (req.track.author._id.equals(req.user.id)) { await TrackData.findByIdAndDelete(req.track.trackData); await req.track.remove(); return res.sendStatus(204); @@ -411,7 +411,7 @@ router.delete( '/:track/comments/:comment', auth.required, wrapRoute(async (req, res) => { - if (req.comment.author.toString() === req.user.id.toString()) { + if (req.comment.author.equals(req.user.id)) { req.track.comments.remove(req.comment._id); await req.track.save(); await Comment.find({ _id: req.comment._id }).remove(); @@ -433,6 +433,7 @@ router.get( // console.log("requestTrackData"+req.track); const trackData = await TrackData.findById(req.track.trackData); + // console.log({trackData: trackData}); return res.json({ trackData: trackData }); }),