From a28b952eafc83ac6f6fc1a3d99805866bc41fde9 Mon Sep 17 00:00:00 2001 From: piotrruss Date: Sat, 4 Sep 2021 10:56:37 +0200 Subject: routes refactor --- pages/api/note/[id].js | 31 ----------------- pages/api/notes.js | 86 ------------------------------------------------ pages/api/notes/[id].js | 70 +++++++++++++++++++++++++++++++++++++++ pages/api/notes/index.js | 48 +++++++++++++++++++++++++++ 4 files changed, 118 insertions(+), 117 deletions(-) delete mode 100644 pages/api/note/[id].js delete mode 100644 pages/api/notes.js create mode 100644 pages/api/notes/[id].js create mode 100644 pages/api/notes/index.js (limited to 'pages') diff --git a/pages/api/note/[id].js b/pages/api/note/[id].js deleted file mode 100644 index 1781210..0000000 --- a/pages/api/note/[id].js +++ /dev/null @@ -1,31 +0,0 @@ -import dbConnect from 'configs/dbConnect' -import withSession from 'hocs/withSession' -import Note from 'models/Note' - -export default withSession(async (req, res) => { - const {id} = req.query - await dbConnect() - - switch (req.method) { - case 'GET': - try { - const user = req.session.get('user') - - if (!user || !user?.isVerified || !id ) { - throw new Error('Something went wrong') - } - - const note = await Note.getNote(id) - - if (!note) { - throw new Error('Something went wrong') - } - - res.status(200).json(note) - } catch (error) { - console.log(error) - res.status(400).json({error: true}) - } - break - } -}) diff --git a/pages/api/notes.js b/pages/api/notes.js deleted file mode 100644 index 0439a7a..0000000 --- a/pages/api/notes.js +++ /dev/null @@ -1,86 +0,0 @@ -import dbConnect from 'configs/dbConnect' -import withSession from 'hocs/withSession' -import NoteList from 'models/NoteList' -import Note from 'models/Note' - -export default withSession(async (req, res) => { - await dbConnect() - - switch (req.method) { - case 'GET': - try { - const user = req.session.get('user') - - if (!user || !user.isVerified) { - throw new Error('Something went wrong') - } - - const {notes} = await NoteList.getList(user.noteList) - - res.status(200).json(notes) - } catch (error) { - res.status(400).json([]) - } - break - case 'POST': - try { - const user = req.session.get('user') - const {title, content} = req.body - - if (!user || !user?.isVerified || !content) { - throw new Error('Something went wrong') - } - - const note = await Note.create({content}) - const {notes} = await NoteList.addNote(user.noteList, note._id, title) - - res.status(200).json(notes) - } catch (error) { - res.status(400).json([]) - } - break - case 'DELETE': - try { - const user = req.session.get('user') - const {_id} = req.body - - if (!user || !user?.isVerified || !_id) { - throw new Error('Something went wrong') - } - - const noteId = await NoteList.getNoteId(user.noteList, _id) - if ( !noteId) throw new Error('Something went wrong') - - await Note.findByIdAndDelete(noteId) - const {notes} = await NoteList.removeNote(user.noteList, _id) - - res.status(200).json(notes) - } catch (error) { - res.status(400).json([]) - } - break - case 'PUT': - try { - const user = req.session.get('user') - const {_id, title, noteId, content} = req.body - - if (!user || !user?.isVerified || !_id || !content) { - throw new Error('Something went wrong') - } - - await Note.updateNote(noteId, content) - const {notes} = await NoteList.updateList(user.noteList, noteId, title) - - res.status(200).json(notes) - } catch (error) { - console.log(error) - res.status(400).json([]) - } - break - default: - res.status(400).send() - break - } -}) - - diff --git a/pages/api/notes/[id].js b/pages/api/notes/[id].js new file mode 100644 index 0000000..58e458f --- /dev/null +++ b/pages/api/notes/[id].js @@ -0,0 +1,70 @@ +import dbConnect from 'configs/dbConnect' +import withSession from 'hocs/withSession' +import NoteList from 'models/NoteList' +import Note from 'models/Note' + +export default withSession(async (req, res) => { + const {id: _id} = req.query + await dbConnect() + + switch (req.method) { + case 'GET': + try { + const user = req.session.get('user') + + if (!user || !user?.isVerified || !_id ) { + throw new Error('Something went wrong') + } + + const note = await Note.getNote(_id) + + if (!note) { + throw new Error('Something went wrong') + } + + res.status(200).json(note) + } catch (error) { + console.log(error) + res.status(400).json({error: true}) + } + break + case 'DELETE': + try { + const user = req.session.get('user') + + if (!user || !user?.isVerified || !_id) { + throw new Error('Something went wrong') + } + + const noteId = await NoteList.getNoteId(user.noteList, _id) + if ( !noteId) throw new Error('Something went wrong') + + await Note.findByIdAndDelete(noteId) + const {notes} = await NoteList.removeNote(user.noteList, _id) + + res.status(200).json(notes) + } catch (error) { + console.log(error) + res.status(400).json([]) + } + break + case 'PUT': + try { + const user = req.session.get('user') + const {title, noteId, content} = req.body + + if (!user || !user?.isVerified || !_id || !content) { + throw new Error('Something went wrong') + } + + await Note.updateNote(noteId, content) + const {notes} = await NoteList.updateList(user.noteList, noteId, title) + + res.status(200).json(notes) + } catch (error) { + console.log(error) + res.status(400).json([]) + } + break + } +}) diff --git a/pages/api/notes/index.js b/pages/api/notes/index.js new file mode 100644 index 0000000..f62f849 --- /dev/null +++ b/pages/api/notes/index.js @@ -0,0 +1,48 @@ +import dbConnect from 'configs/dbConnect' +import withSession from 'hocs/withSession' +import NoteList from 'models/NoteList' +import Note from 'models/Note' + +export default withSession(async (req, res) => { + await dbConnect() + + switch (req.method) { + case 'GET': + try { + const user = req.session.get('user') + + if (!user || !user.isVerified) { + throw new Error('Something went wrong') + } + + const {notes} = await NoteList.getList(user.noteList) + + res.status(200).json(notes) + } catch (error) { + res.status(400).json([]) + } + break + case 'POST': + try { + const user = req.session.get('user') + const {title, content} = req.body + + if (!user || !user?.isVerified || !content) { + throw new Error('Something went wrong') + } + + const note = await Note.create({content}) + const {notes} = await NoteList.addNote(user.noteList, note._id, title) + + res.status(200).json(notes) + } catch (error) { + res.status(400).json([]) + } + break + default: + res.status(400).send() + break + } +}) + + -- cgit v1.2.3