summary refs log tree commit diff
path: root/src/api/middlewares/errorMiddleware.js
diff options
context:
space:
mode:
authorRory& <root@rory.gay>2025-06-01 04:40:09 +0200
committerRory& <root@rory.gay>2025-06-01 04:40:09 +0200
commita22c00fcefa10a99505c05393106fb3a655de243 (patch)
tree417757b1e5aa9f44702ed963569e0edf6209043d /src/api/middlewares/errorMiddleware.js
parentAdd some tests (diff)
downloadnodejs-final-assignment-a22c00fcefa10a99505c05393106fb3a655de243.tar.xz
Add register with validation
Diffstat (limited to 'src/api/middlewares/errorMiddleware.js')
-rw-r--r--src/api/middlewares/errorMiddleware.js39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/api/middlewares/errorMiddleware.js b/src/api/middlewares/errorMiddleware.js
new file mode 100644

index 0000000..b8de68e --- /dev/null +++ b/src/api/middlewares/errorMiddleware.js
@@ -0,0 +1,39 @@ +import { SafeNSoundError } from '#util/error.js'; +import { MongoServerError } from 'mongodb'; + +export function handleErrors(err, req, res, _next) { + if (err instanceof MongoServerError) { + if (err.code === 11000) { + // Duplicate key error + const newErr = new SafeNSoundError({ + errCode: 'DUPLICATE_KEY_ERROR', + message: 'A duplicate key error occurred.', + key: Object.keys(err.keyPattern)[0], + value: err.keyValue[Object.keys(err.keyValue)[0]] + }); + + err = newErr; + } + } + + if (err instanceof SafeNSoundError) { + console.log('meow'); + console.error(err.stack); + res.status(500).json(err); + } else { + // log and handle uncaught exceptions + console.error( + 'Unhandled error:', + Object.getPrototypeOf(err), + JSON.stringify(err, null, 2) + ); + console.error(err.stack); + res.status(500).json( + new SafeNSoundError({ + errCode: 'INTERNAL_SERVER_ERROR', + message: null, + err + }) + ); + } +}