summaryrefslogtreecommitdiff
path: root/lib/web/note
diff options
context:
space:
mode:
Diffstat (limited to 'lib/web/note')
-rw-r--r--lib/web/note/controller.js (renamed from lib/web/note/actions.js)39
-rw-r--r--lib/web/note/router.js12
2 files changed, 31 insertions, 20 deletions
diff --git a/lib/web/note/actions.js b/lib/web/note/controller.js
index a124277a..c89cc5de 100644
--- a/lib/web/note/actions.js
+++ b/lib/web/note/controller.js
@@ -11,6 +11,17 @@ const moment = require('moment')
const querystring = require('querystring')
const noteUtil = require('./util')
+exports.createFromPOST = function (req, res, next) {
+ let body = ''
+ if (req.body && req.body.length > config.documentMaxLength) {
+ return errors.errorTooLong(res)
+ } else if (req.body) {
+ body = req.body
+ }
+ body = body.replace(/[\r]/g, '')
+ return noteUtil.newNote(req, res, body)
+}
+
exports.doAction = function (req, res, next) {
const noteId = req.params.noteId
noteUtil.findNote(req, res, function (note) {
@@ -18,30 +29,30 @@ exports.doAction = function (req, res, next) {
switch (action) {
case 'publish':
case 'pretty': // pretty deprecated
- actionPublish(req, res, note)
+ publish(req, res, note)
break
case 'slide':
- actionSlide(req, res, note)
+ slide(req, res, note)
break
case 'download':
- exports.actionDownload(req, res, note)
+ exports.downloadMarkdown(req, res, note)
break
case 'info':
- actionInfo(req, res, note)
+ getInfo(req, res, note)
break
case 'pdf':
if (config.allowPDFExport) {
- actionPDF(req, res, note)
+ createPDF(req, res, note)
} else {
logger.error('PDF export failed: Disabled by config. Set "allowPDFExport: true" to enable. Check the documentation for details')
errors.errorForbidden(res)
}
break
case 'gist':
- actionGist(req, res, note)
+ createGist(req, res, note)
break
case 'revision':
- actionRevision(req, res, note)
+ getRevision(req, res, note)
break
default:
return res.redirect(config.serverURL + '/' + noteId)
@@ -49,15 +60,15 @@ exports.doAction = function (req, res, next) {
})
}
-function actionPublish (req, res, note) {
+function publish (req, res, note) {
res.redirect(config.serverURL + '/s/' + (note.alias || note.shortid))
}
-function actionSlide (req, res, note) {
+function slide (req, res, note) {
res.redirect(config.serverURL + '/p/' + (note.alias || note.shortid))
}
-exports.actionDownload = function (req, res, note) {
+exports.downloadMarkdown = function (req, res, note) {
const body = note.content
let filename = models.Note.decodeTitle(note.title)
filename = encodeURIComponent(filename)
@@ -73,7 +84,7 @@ exports.actionDownload = function (req, res, note) {
res.send(body)
}
-function actionInfo (req, res, note) {
+function getInfo (req, res, note) {
const body = note.content
const extracted = models.Note.extractMeta(body)
const markdown = extracted.markdown
@@ -98,7 +109,7 @@ function actionInfo (req, res, note) {
res.send(data)
}
-function actionPDF (req, res, note) {
+function createPDF (req, res, note) {
const url = config.serverURL || 'http://' + req.get('host')
const body = note.content
const extracted = models.Note.extractMeta(body)
@@ -129,7 +140,7 @@ function actionPDF (req, res, note) {
})
}
-function actionGist (req, res, note) {
+function createGist (req, res, note) {
const data = {
client_id: config.github.clientID,
redirect_uri: config.serverURL + '/auth/github/callback/' + models.Note.encodeNoteId(note.id) + '/gist',
@@ -140,7 +151,7 @@ function actionGist (req, res, note) {
res.redirect('https://github.com/login/oauth/authorize?' + query)
}
-function actionRevision (req, res, note) {
+function getRevision (req, res, note) {
const actionId = req.params.actionId
if (actionId) {
const time = moment(parseInt(actionId))
diff --git a/lib/web/note/router.js b/lib/web/note/router.js
index 2a6bf2aa..39da4c2c 100644
--- a/lib/web/note/router.js
+++ b/lib/web/note/router.js
@@ -8,15 +8,15 @@ const { markdownParser } = require('../utils')
const router = module.exports = Router()
-const noteActions = require('./actions')
+const noteController = require('./controller')
const slide = require('./slide')
// get new note
-router.get('/new', response.postNote)
+router.get('/new', noteController.createFromPOST)
// post new note with content
-router.post('/new', markdownParser, response.postNote)
+router.post('/new', markdownParser, noteController.createFromPOST)
// post new note with content and alias
-router.post('/new/:noteId', markdownParser, response.postNote)
+router.post('/new/:noteId', markdownParser, noteController.createFromPOST)
// get publish note
router.get('/s/:shortid', response.showPublishNote)
// publish note actions
@@ -28,6 +28,6 @@ router.get('/p/:shortid/:action', slide.publishSlideActions)
// get note by id
router.get('/:noteId', response.showNote)
// note actions
-router.get('/:noteId/:action', noteActions.doAction)
+router.get('/:noteId/:action', noteController.doAction)
// note actions with action id
-router.get('/:noteId/:action/:actionId', noteActions.doAction)
+router.get('/:noteId/:action/:actionId', noteController.doAction)