From 66d53956c4043773e5769fe80400516b0e10f605 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Tue, 21 Jul 2020 00:09:44 +0800 Subject: [PATCH 01/11] Add delete note api Signed-off-by: James Tsai --- lib/note/index.js | 30 ++++++++++- lib/routes.js | 2 + package-lock.json | 134 +++++++++++++++++++++++----------------------- 3 files changed, 98 insertions(+), 68 deletions(-) diff --git a/lib/note/index.js b/lib/note/index.js index a387b59d..eac2845a 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -5,7 +5,7 @@ const logger = require('../logger') const { Note, User } = require('../models') const { newCheckViewPermission, errorForbidden, responseCodiMD, errorNotFound, errorInternalError } = require('../response') -const { updateHistory } = require('../history') +const { updateHistory, historyDelete } = require('../history') const { actionPublish, actionSlide, actionInfo, actionDownload, actionPDF, actionGist, actionRevision, actionPandoc } = require('./noteActions') async function getNoteById (noteId, { includeUser } = { includeUser: false }) { @@ -232,7 +232,35 @@ function listMyNotes (req, res) { } } +const deleteNote = async (req, res) => { + if(req.isAuthenticated()) { + const noteId = await Note.parseNoteIdAsync(req.params.noteId) + try { + const destroyed = await Note.destroy({ + where: { + id: noteId, + ownerId: req.user.id + } + }) + if (!destroyed) { + logger.error('Delete note failed: Make sure the noteId and ownerId are correct.') + return errorNotFound(req, res) + } + historyDelete(req, res) + res.send({ + status: 'ok' + }) + } catch (err) { + logger.error('Delete note failed: Internal Error.') + return errorInternalError(req, res) + } + } else { + return errorForbidden(req, res) + } +} + exports.showNote = showNote exports.showPublishNote = showPublishNote exports.noteActions = noteActions exports.listMyNotes = listMyNotes +exports.deleteNote = deleteNote diff --git a/lib/routes.js b/lib/routes.js index 48ac61f3..d36d3cdf 100644 --- a/lib/routes.js +++ b/lib/routes.js @@ -72,6 +72,8 @@ appRouter.get('/p/:shortid', response.showPublishSlide) appRouter.get('/p/:shortid/:action', response.publishSlideActions) // gey my note list appRouter.get('/api/notes/myNotes', noteController.listMyNotes) +// delete note by id +appRouter.delete('/api/notes/:noteId', noteController.deleteNote) // get note by id appRouter.get('/:noteId', wrap(noteController.showNote)) // note actions diff --git a/package-lock.json b/package-lock.json index 59bce698..c5ceaba2 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7434,28 +7434,28 @@ "dependencies": { "abbrev": { "version": "1.1.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", "dev": true, "optional": true }, "ansi-regex": { "version": "2.1.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", "dev": true, "optional": true }, "aproba": { "version": "1.2.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", "dev": true, "optional": true }, "are-we-there-yet": { "version": "1.1.5", - "resolved": false, + "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", "dev": true, "optional": true, @@ -7466,14 +7466,14 @@ }, "balanced-match": { "version": "1.0.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", "dev": true, "optional": true }, "brace-expansion": { "version": "1.1.11", - "resolved": false, + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", "dev": true, "optional": true, @@ -7484,42 +7484,42 @@ }, "chownr": { "version": "1.1.3", - "resolved": false, + "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.3.tgz", "integrity": "sha512-i70fVHhmV3DtTl6nqvZOnIjbY0Pe4kAUjwHj8z0zAdgBtYrJyYwLKCCuRBQ5ppkyL0AkN7HKRnETdmdp1zqNXw==", "dev": true, "optional": true }, "code-point-at": { "version": "1.1.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", "dev": true, "optional": true }, "concat-map": { "version": "0.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", "dev": true, "optional": true }, "console-control-strings": { "version": "1.1.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=", "dev": true, "optional": true }, "core-util-is": { "version": "1.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", "dev": true, "optional": true }, "debug": { "version": "3.2.6", - "resolved": false, + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", "dev": true, "optional": true, @@ -7529,28 +7529,28 @@ }, "deep-extend": { "version": "0.6.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", "dev": true, "optional": true }, "delegates": { "version": "1.0.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", "dev": true, "optional": true }, "detect-libc": { "version": "1.0.3", - "resolved": false, + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", "dev": true, "optional": true }, "fs-minipass": { "version": "1.2.7", - "resolved": false, + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", "dev": true, "optional": true, @@ -7560,14 +7560,14 @@ }, "fs.realpath": { "version": "1.0.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", "dev": true, "optional": true }, "gauge": { "version": "2.7.4", - "resolved": false, + "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", "dev": true, "optional": true, @@ -7584,7 +7584,7 @@ }, "glob": { "version": "7.1.6", - "resolved": false, + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", "dev": true, "optional": true, @@ -7599,14 +7599,14 @@ }, "has-unicode": { "version": "2.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=", "dev": true, "optional": true }, "iconv-lite": { "version": "0.4.24", - "resolved": false, + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", "dev": true, "optional": true, @@ -7616,7 +7616,7 @@ }, "ignore-walk": { "version": "3.0.3", - "resolved": false, + "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", "dev": true, "optional": true, @@ -7626,7 +7626,7 @@ }, "inflight": { "version": "1.0.6", - "resolved": false, + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", "dev": true, "optional": true, @@ -7637,21 +7637,21 @@ }, "inherits": { "version": "2.0.4", - "resolved": false, + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", "dev": true, "optional": true }, "ini": { "version": "1.3.5", - "resolved": false, + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", "dev": true, "optional": true }, "is-fullwidth-code-point": { "version": "1.0.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", "dev": true, "optional": true, @@ -7661,14 +7661,14 @@ }, "isarray": { "version": "1.0.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", "dev": true, "optional": true }, "minimatch": { "version": "3.0.4", - "resolved": false, + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", "dev": true, "optional": true, @@ -7678,14 +7678,14 @@ }, "minimist": { "version": "0.0.8", - "resolved": false, + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", "dev": true, "optional": true }, "minipass": { "version": "2.9.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", "dev": true, "optional": true, @@ -7696,7 +7696,7 @@ }, "minizlib": { "version": "1.3.3", - "resolved": false, + "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", "dev": true, "optional": true, @@ -7706,7 +7706,7 @@ }, "mkdirp": { "version": "0.5.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", "dev": true, "optional": true, @@ -7716,14 +7716,14 @@ }, "ms": { "version": "2.1.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", "dev": true, "optional": true }, "needle": { "version": "2.4.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/needle/-/needle-2.4.0.tgz", "integrity": "sha512-4Hnwzr3mi5L97hMYeNl8wRW/Onhy4nUKR/lVemJ8gJedxxUyBLm9kkrDColJvoSfwi0jCNhD+xCdOtiGDQiRZg==", "dev": true, "optional": true, @@ -7735,7 +7735,7 @@ }, "node-pre-gyp": { "version": "0.14.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.14.0.tgz", "integrity": "sha512-+CvDC7ZttU/sSt9rFjix/P05iS43qHCOOGzcr3Ry99bXG7VX953+vFyEuph/tfqoYu8dttBkE86JSKBO2OzcxA==", "dev": true, "optional": true, @@ -7754,7 +7754,7 @@ }, "nopt": { "version": "4.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", "dev": true, "optional": true, @@ -7765,7 +7765,7 @@ }, "npm-bundled": { "version": "1.1.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", "dev": true, "optional": true, @@ -7775,14 +7775,14 @@ }, "npm-normalize-package-bin": { "version": "1.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==", "dev": true, "optional": true }, "npm-packlist": { "version": "1.4.7", - "resolved": false, + "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.7.tgz", "integrity": "sha512-vAj7dIkp5NhieaGZxBJB8fF4R0078rqsmhJcAfXZ6O7JJhjhPK96n5Ry1oZcfLXgfun0GWTZPOxaEyqv8GBykQ==", "dev": true, "optional": true, @@ -7793,7 +7793,7 @@ }, "npmlog": { "version": "4.1.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", "dev": true, "optional": true, @@ -7806,21 +7806,21 @@ }, "number-is-nan": { "version": "1.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", "dev": true, "optional": true }, "object-assign": { "version": "4.1.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", "dev": true, "optional": true }, "once": { "version": "1.4.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", "dev": true, "optional": true, @@ -7830,21 +7830,21 @@ }, "os-homedir": { "version": "1.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", "dev": true, "optional": true }, "os-tmpdir": { "version": "1.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", "dev": true, "optional": true }, "osenv": { "version": "0.1.5", - "resolved": false, + "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", "dev": true, "optional": true, @@ -7855,21 +7855,21 @@ }, "path-is-absolute": { "version": "1.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", "dev": true, "optional": true }, "process-nextick-args": { "version": "2.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", "dev": true, "optional": true }, "rc": { "version": "1.2.8", - "resolved": false, + "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", "dev": true, "optional": true, @@ -7882,7 +7882,7 @@ "dependencies": { "minimist": { "version": "1.2.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", "dev": true, "optional": true @@ -7891,7 +7891,7 @@ }, "readable-stream": { "version": "2.3.6", - "resolved": false, + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", "dev": true, "optional": true, @@ -7907,7 +7907,7 @@ }, "rimraf": { "version": "2.7.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", "dev": true, "optional": true, @@ -7917,49 +7917,49 @@ }, "safe-buffer": { "version": "5.1.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", "dev": true, "optional": true }, "safer-buffer": { "version": "2.1.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", "dev": true, "optional": true }, "sax": { "version": "1.2.4", - "resolved": false, + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", "dev": true, "optional": true }, "semver": { "version": "5.7.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", "dev": true, "optional": true }, "set-blocking": { "version": "2.0.0", - "resolved": false, + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", "dev": true, "optional": true }, "signal-exit": { "version": "3.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", "dev": true, "optional": true }, "string-width": { "version": "1.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", "dev": true, "optional": true, @@ -7971,7 +7971,7 @@ }, "string_decoder": { "version": "1.1.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", "dev": true, "optional": true, @@ -7981,7 +7981,7 @@ }, "strip-ansi": { "version": "3.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", "dev": true, "optional": true, @@ -7991,14 +7991,14 @@ }, "strip-json-comments": { "version": "2.0.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", "dev": true, "optional": true }, "tar": { "version": "4.4.13", - "resolved": false, + "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", "dev": true, "optional": true, @@ -8014,14 +8014,14 @@ }, "util-deprecate": { "version": "1.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", "dev": true, "optional": true }, "wide-align": { "version": "1.1.3", - "resolved": false, + "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", "dev": true, "optional": true, @@ -8031,14 +8031,14 @@ }, "wrappy": { "version": "1.0.2", - "resolved": false, + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", "dev": true, "optional": true }, "yallist": { "version": "3.1.1", - "resolved": false, + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", "dev": true, "optional": true From b597dc981195607a9f9f4c3f80c7275b4724bc59 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Tue, 21 Jul 2020 09:14:02 +0800 Subject: [PATCH 02/11] Add update note api Signed-off-by: James Tsai --- lib/note/index.js | 34 ++++++++++++++++++++++++++++++++++ lib/routes.js | 2 ++ 2 files changed, 36 insertions(+) diff --git a/lib/note/index.js b/lib/note/index.js index eac2845a..f0e5de20 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -259,8 +259,42 @@ const deleteNote = async (req, res) => { } } +const updateNote = async (req, res) => { + if(req.isAuthenticated()) { + const noteId = await Note.parseNoteIdAsync(req.params.noteId) + try { + const note = await Note.findOne({ + where: { + id: noteId, + } + }) + if (!note) { + logger.error('Update note failed: Can\'t find the note.') + return errorNotFound(req, res) + } + + const updated = await note.update({ + content: req.body.content, + }) + if (!updated) { + logger.error('Update note failed: Write data error.') + return errorInternalError(req, res) + } + res.send({ + status: 'ok' + }) + } catch (err) { + logger.error('Update note failed: Internal Error.') + return errorInternalError(req, res) + } + } else { + return errorForbidden(req, res) + } +} + exports.showNote = showNote exports.showPublishNote = showPublishNote exports.noteActions = noteActions exports.listMyNotes = listMyNotes exports.deleteNote = deleteNote +exports.updateNote = updateNote diff --git a/lib/routes.js b/lib/routes.js index d36d3cdf..744339e5 100644 --- a/lib/routes.js +++ b/lib/routes.js @@ -74,6 +74,8 @@ appRouter.get('/p/:shortid/:action', response.publishSlideActions) appRouter.get('/api/notes/myNotes', noteController.listMyNotes) // delete note by id appRouter.delete('/api/notes/:noteId', noteController.deleteNote) +// update note content by id +appRouter.put('/api/notes/:noteId', urlencodedParser, noteController.updateNote) // get note by id appRouter.get('/:noteId', wrap(noteController.showNote)) // note actions From b3cf98b329ae07f8af4536e0675123cff4bf770b Mon Sep 17 00:00:00 2001 From: James Tsai Date: Tue, 21 Jul 2020 09:16:32 +0800 Subject: [PATCH 03/11] Fix linter Signed-off-by: James Tsai --- lib/note/index.js | 10 +++++----- public/js/extra.js | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/lib/note/index.js b/lib/note/index.js index f0e5de20..664ad465 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -233,7 +233,7 @@ function listMyNotes (req, res) { } const deleteNote = async (req, res) => { - if(req.isAuthenticated()) { + if (req.isAuthenticated()) { const noteId = await Note.parseNoteIdAsync(req.params.noteId) try { const destroyed = await Note.destroy({ @@ -260,21 +260,21 @@ const deleteNote = async (req, res) => { } const updateNote = async (req, res) => { - if(req.isAuthenticated()) { + if (req.isAuthenticated()) { const noteId = await Note.parseNoteIdAsync(req.params.noteId) try { const note = await Note.findOne({ where: { - id: noteId, + id: noteId } }) if (!note) { logger.error('Update note failed: Can\'t find the note.') return errorNotFound(req, res) } - + const updated = await note.update({ - content: req.body.content, + content: req.body.content }) if (!updated) { logger.error('Update note failed: Write data error.') diff --git a/public/js/extra.js b/public/js/extra.js index 954a161c..8870b57b 100644 --- a/public/js/extra.js +++ b/public/js/extra.js @@ -516,7 +516,7 @@ export function finishView (view) { $value.unwrap() try { const data = transform(content) - $elem.html(`
`) + $elem.html('
') markmap($elem.find('svg')[0], data, { duration: 0 }) From cf1a25a62773f7631f32b290b2b4d7b932dd4fc7 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Wed, 22 Jul 2020 22:41:53 +0800 Subject: [PATCH 04/11] Fix package-lock dependencies config Signed-off-by: James Tsai --- package-lock.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package-lock.json b/package-lock.json index c5ceaba2..130b5ec1 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7434,7 +7434,7 @@ "dependencies": { "abbrev": { "version": "1.1.1", - "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", + "resolved": false, "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", "dev": true, "optional": true From 96f8f06b008a66927794c8cb3f27a2d2386bc01e Mon Sep 17 00:00:00 2001 From: James Tsai Date: Thu, 23 Jul 2020 00:24:58 +0800 Subject: [PATCH 05/11] Disconnect online users by delete API Signed-off-by: James Tsai --- lib/note/index.js | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/lib/note/index.js b/lib/note/index.js index 664ad465..d020b46f 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -7,6 +7,7 @@ const { Note, User } = require('../models') const { newCheckViewPermission, errorForbidden, responseCodiMD, errorNotFound, errorInternalError } = require('../response') const { updateHistory, historyDelete } = require('../history') const { actionPublish, actionSlide, actionInfo, actionDownload, actionPDF, actionGist, actionRevision, actionPandoc } = require('./noteActions') +const realtime = require('../realtime/realtime') async function getNoteById (noteId, { includeUser } = { includeUser: false }) { const id = await Note.parseNoteIdAsync(noteId) @@ -246,7 +247,14 @@ const deleteNote = async (req, res) => { logger.error('Delete note failed: Make sure the noteId and ownerId are correct.') return errorNotFound(req, res) } + historyDelete(req, res) + + if (realtime.isNoteExistsInPool(noteId)) { + const note = realtime.getNoteFromNotePool(noteId) + realtime.disconnectSocketOnNote(note) + } + res.send({ status: 'ok' }) From 53526c154a6c9bed6a635266ca9f8d3f3539f55d Mon Sep 17 00:00:00 2001 From: James Tsai Date: Mon, 27 Jul 2020 17:59:51 +0800 Subject: [PATCH 06/11] Check online users, update authorships, save revisions in update note content API Signed-off-by: James Tsai --- lib/note/index.js | 31 ++++++++++++++++++++++++++++--- 1 file changed, 28 insertions(+), 3 deletions(-) diff --git a/lib/note/index.js b/lib/note/index.js index d020b46f..9ae7a160 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -2,12 +2,13 @@ const config = require('../config') const logger = require('../logger') -const { Note, User } = require('../models') +const { Note, User, Revision } = require('../models') const { newCheckViewPermission, errorForbidden, responseCodiMD, errorNotFound, errorInternalError } = require('../response') const { updateHistory, historyDelete } = require('../history') const { actionPublish, actionSlide, actionInfo, actionDownload, actionPDF, actionGist, actionRevision, actionPandoc } = require('./noteActions') const realtime = require('../realtime/realtime') +const moment = require('moment') async function getNoteById (noteId, { includeUser } = { includeUser: false }) { const id = await Note.parseNoteIdAsync(noteId) @@ -281,13 +282,37 @@ const updateNote = async (req, res) => { return errorNotFound(req, res) } + if (realtime.isNoteExistsInPool(noteId)) { + logger.error('Update note failed: There are online users opening this note.') + return res.status('403').send({ status: 'error', message: 'Update API can only be used when no users is online' }) + } + + const now = Date.now() + const content = req.body.content const updated = await note.update({ - content: req.body.content + content: content, + lastchangeAt: moment(now).format('YYYY-MM-DD HH:mm:ss'), + authorship: [ + [ + req.user.id, + 0, + content.length, + now, + now + ] + ] }) + if (!updated) { - logger.error('Update note failed: Write data error.') + logger.error('Update note failed: Write note content error.') return errorInternalError(req, res) } + + Revision.saveNoteRevision(note, (err, revision) => { + if (err) return errorInternalError(req, res) + if (!revision) return errorNotFound(req, res) + }) + res.send({ status: 'ok' }) From 04fe74d52011fa73bff74762a722dad98be11305 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Thu, 30 Jul 2020 18:13:35 +0800 Subject: [PATCH 07/11] Refactor, use body parser, adjust update api content column Signed-off-by: James Tsai --- lib/note/index.js | 16 +++++++++------- lib/routes.js | 3 ++- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/lib/note/index.js b/lib/note/index.js index 9ae7a160..de401883 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -8,7 +8,6 @@ const { newCheckViewPermission, errorForbidden, responseCodiMD, errorNotFound, e const { updateHistory, historyDelete } = require('../history') const { actionPublish, actionSlide, actionInfo, actionDownload, actionPDF, actionGist, actionRevision, actionPandoc } = require('./noteActions') const realtime = require('../realtime/realtime') -const moment = require('moment') async function getNoteById (noteId, { includeUser } = { includeUser: false }) { const id = await Note.parseNoteIdAsync(noteId) @@ -291,7 +290,7 @@ const updateNote = async (req, res) => { const content = req.body.content const updated = await note.update({ content: content, - lastchangeAt: moment(now).format('YYYY-MM-DD HH:mm:ss'), + lastchangeAt: now, authorship: [ [ req.user.id, @@ -309,14 +308,17 @@ const updateNote = async (req, res) => { } Revision.saveNoteRevision(note, (err, revision) => { - if (err) return errorInternalError(req, res) + if (err) { + logger.error(err) + return errorInternalError(req, res) + } if (!revision) return errorNotFound(req, res) - }) - - res.send({ - status: 'ok' + res.send({ + status: 'ok' + }) }) } catch (err) { + logger.error(err) logger.error('Update note failed: Internal Error.') return errorInternalError(req, res) } diff --git a/lib/routes.js b/lib/routes.js index 744339e5..9d15c349 100644 --- a/lib/routes.js +++ b/lib/routes.js @@ -12,6 +12,7 @@ const historyController = require('./history') const userController = require('./user') const noteController = require('./note') const response = require('./response') +const bodyParser = require('body-parser') const appRouter = Router() // register route @@ -75,7 +76,7 @@ appRouter.get('/api/notes/myNotes', noteController.listMyNotes) // delete note by id appRouter.delete('/api/notes/:noteId', noteController.deleteNote) // update note content by id -appRouter.put('/api/notes/:noteId', urlencodedParser, noteController.updateNote) +appRouter.put('/api/notes/:noteId', bodyParser.json(), noteController.updateNote) // get note by id appRouter.get('/:noteId', wrap(noteController.showNote)) // note actions From 091c77bdb1f05263543f85f5c6f04f5bfaf3c722 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Thu, 30 Jul 2020 18:55:36 +0800 Subject: [PATCH 08/11] Refactor, change response type to json in update-api user online checking Signed-off-by: James Tsai --- lib/note/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/note/index.js b/lib/note/index.js index de401883..be4f8ace 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -283,7 +283,7 @@ const updateNote = async (req, res) => { if (realtime.isNoteExistsInPool(noteId)) { logger.error('Update note failed: There are online users opening this note.') - return res.status('403').send({ status: 'error', message: 'Update API can only be used when no users is online' }) + return res.status('403').json({ status: 'error', message: 'Update API can only be used when no users is online' }) } const now = Date.now() From e7a4996cbe7b962a54233bfa2d3b53d39ad336e5 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Tue, 4 Aug 2020 16:47:57 +0800 Subject: [PATCH 09/11] Update note title and history in update api Signed-off-by: James Tsai --- lib/note/index.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/lib/note/index.js b/lib/note/index.js index be4f8ace..8f41876f 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -289,6 +289,7 @@ const updateNote = async (req, res) => { const now = Date.now() const content = req.body.content const updated = await note.update({ + title: Note.parseNoteTitle(content), content: content, lastchangeAt: now, authorship: [ @@ -307,6 +308,8 @@ const updateNote = async (req, res) => { return errorInternalError(req, res) } + updateHistory(req.user.id, note) + Revision.saveNoteRevision(note, (err, revision) => { if (err) { logger.error(err) From 47929081699041aecba2de8ab62caee34d1e5ad9 Mon Sep 17 00:00:00 2001 From: James Tsai Date: Tue, 4 Aug 2020 17:10:45 +0800 Subject: [PATCH 10/11] Fix linter Signed-off-by: James Tsai --- lib/note/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/note/index.js b/lib/note/index.js index 8f41876f..68ca792a 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -308,7 +308,7 @@ const updateNote = async (req, res) => { return errorInternalError(req, res) } - updateHistory(req.user.id, note) + updateHistory(req.user.id, note) Revision.saveNoteRevision(note, (err, revision) => { if (err) { From ab0ac83582ff8a09f3e5b0a9ad461e99129eaeef Mon Sep 17 00:00:00 2001 From: Yukai Huang Date: Wed, 12 Aug 2020 18:10:39 +0800 Subject: [PATCH 11/11] Fix updateHistory parameter Signed-off-by: Yukai Huang --- lib/note/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/note/index.js b/lib/note/index.js index 68ca792a..0a20238e 100644 --- a/lib/note/index.js +++ b/lib/note/index.js @@ -308,7 +308,7 @@ const updateNote = async (req, res) => { return errorInternalError(req, res) } - updateHistory(req.user.id, note) + updateHistory(req.user.id, note.id, content) Revision.saveNoteRevision(note, (err, revision) => { if (err) {