refactor: show note

Signed-off-by: BoHong Li <raccoon@hackmd.io>
This commit is contained in:
BoHong Li 2020-01-05 06:58:40 +08:00
parent b4ec353fcd
commit 66edff87c5
No known key found for this signature in database
GPG Key ID: 06770355DC9ECD38
4 changed files with 93 additions and 13 deletions

View File

@ -186,6 +186,16 @@ module.exports = function (sequelize, DataTypes) {
var result = id.match(uuidRegex) var result = id.match(uuidRegex)
if (result && result.length === 1) { return true } else { return false } if (result && result.length === 1) { return true } else { return false }
} }
Note.parseNoteIdAsync = function (noteId) {
return new Promise((resolve, reject) => {
Note.parseNoteId(noteId, (err, id) => {
if (err) {
return reject(err)
}
resolve(id)
})
})
}
Note.parseNoteId = function (noteId, callback) { Note.parseNoteId = function (noteId, callback) {
async.series({ async.series({
parseNoteIdByAlias: function (_callback) { parseNoteIdByAlias: function (_callback) {

63
lib/note/index.js Normal file
View File

@ -0,0 +1,63 @@
'use strict'
const config = require('../config')
const { Note } = require('../models')
const { newCheckViewPermission, errorForbidden, responseCodiMD, errorNotFound } = require('../response')
const { updateHistory } = require('../history')
async function getNoteById (noteId) {
const id = await Note.parseNoteIdAsync(noteId)
const note = await Note.findOne({
where: {
id: id
}
})
return note
}
async function createNote (userId, noteAlias) {
if (!config.allowAnonymous && !!userId) {
throw new Error('can not create note')
}
const note = await Note.create({
ownerId: userId,
alias: noteAlias,
})
if (userId) {
updateHistory(userId, note)
}
return note
}
// controller
async function showNote (req, res) {
const noteId = req.params.noteId
const userId = req.user ? req.user.id : null
let note = await getNoteById(noteId)
if (!note) {
// if allow free url enable, auto create note
if (!config.allowFreeURL || config.forbiddenNoteIDs.includes(noteId)) {
return errorNotFound(res)
}
note = await createNote(userId, noteId)
}
if (!newCheckViewPermission(note, req.isAuthenticated(), userId)) {
return errorForbidden(res)
}
// force to use note id
const id = Note.encodeNoteId(note.id)
if ((note.alias && noteId !== note.alias) || (!note.alias && noteId !== id)) {
return res.redirect(config.serverURL + '/' + (note.alias || id))
}
return responseCodiMD(res, note)
}
exports.showNote = showNote

View File

@ -25,7 +25,6 @@ exports.errorTooLong = errorTooLong
exports.errorInternalError = errorInternalError exports.errorInternalError = errorInternalError
exports.errorServiceUnavailable = errorServiceUnavailable exports.errorServiceUnavailable = errorServiceUnavailable
exports.newNote = newNote exports.newNote = newNote
exports.showNote = showNote
exports.showPublishNote = showPublishNote exports.showPublishNote = showPublishNote
exports.showPublishSlide = showPublishSlide exports.showPublishSlide = showPublishSlide
exports.showIndex = showIndex exports.showIndex = showIndex
@ -35,6 +34,8 @@ exports.publishSlideActions = publishSlideActions
exports.githubActions = githubActions exports.githubActions = githubActions
exports.gitlabActions = gitlabActions exports.gitlabActions = gitlabActions
exports.checkViewPermission = checkViewPermission exports.checkViewPermission = checkViewPermission
exports.newCheckViewPermission = newCheckViewPermission
exports.responseCodiMD = responseCodiMD
function errorForbidden (res) { function errorForbidden (res) {
const { req } = res const { req } = res
@ -45,20 +46,25 @@ function errorForbidden (res) {
res.redirect(config.serverURL + '/') res.redirect(config.serverURL + '/')
} }
} }
function errorNotFound (res) { function errorNotFound (res) {
responseError(res, '404', 'Not Found', 'oops.') responseError(res, '404', 'Not Found', 'oops.')
} }
function errorBadRequest (res) { function errorBadRequest (res) {
responseError(res, '400', 'Bad Request', 'something not right.') responseError(res, '400', 'Bad Request', 'something not right.')
} }
function errorTooLong (res) { function errorTooLong (res) {
responseError(res, '413', 'Payload Too Large', 'Shorten your note!') responseError(res, '413', 'Payload Too Large', 'Shorten your note!')
} }
function errorInternalError (res) { function errorInternalError (res) {
responseError(res, '500', 'Internal Error', 'wtf.') responseError(res, '500', 'Internal Error', 'wtf.')
} }
function errorServiceUnavailable (res) { function errorServiceUnavailable (res) {
res.status(503).send("I'm busy right now, try again later.") res.status(503).send('I\'m busy right now, try again later.')
} }
function responseError (res, code, detail, msg) { function responseError (res, code, detail, msg) {
@ -150,6 +156,16 @@ function newNote (req, res, next) {
}) })
} }
function newCheckViewPermission (note, isLogin, userId) {
if (note.permission === 'private') {
return note.ownerId === userId
}
if (note.permission === 'limited' || note.permission === 'protected') {
return isLogin
}
return true
}
function checkViewPermission (req, note) { function checkViewPermission (req, note) {
if (note.permission === 'private') { if (note.permission === 'private') {
if (!req.isAuthenticated() || note.ownerId !== req.user.id) { return false } else { return true } if (!req.isAuthenticated() || note.ownerId !== req.user.id) { return false } else { return true }
@ -194,16 +210,6 @@ function findNote (req, res, callback, include) {
}) })
} }
function showNote (req, res, next) {
findNote(req, res, function (note) {
// force to use note id
var noteId = req.params.noteId
var id = models.Note.encodeNoteId(note.id)
if ((note.alias && noteId !== note.alias) || (!note.alias && noteId !== id)) { return res.redirect(config.serverURL + '/' + (note.alias || id)) }
return responseCodiMD(res, note)
})
}
function showPublishNote (req, res, next) { function showPublishNote (req, res, next) {
var include = [{ var include = [{
model: models.User, model: models.User,

View File

@ -10,6 +10,7 @@ const errorPageController = require('./errorPage')
const statusController = require('./status') const statusController = require('./status')
const historyController = require('./history') const historyController = require('./history')
const userController = require('./user') const userController = require('./user')
const noteController = require('./note')
const response = require('./response') const response = require('./response')
const appRouter = Router() const appRouter = Router()
@ -71,7 +72,7 @@ appRouter.get('/p/:shortid', response.showPublishSlide)
// publish slide actions // publish slide actions
appRouter.get('/p/:shortid/:action', response.publishSlideActions) appRouter.get('/p/:shortid/:action', response.publishSlideActions)
// get note by id // get note by id
appRouter.get('/:noteId', response.showNote) appRouter.get('/:noteId', wrap(noteController.showNote))
// note actions // note actions
appRouter.get('/:noteId/:action', response.noteActions) appRouter.get('/:noteId/:action', response.noteActions)
// note actions with action id // note actions with action id