summaryrefslogtreecommitdiff
path: root/lib/web/imageRouter/index.js
diff options
context:
space:
mode:
authorChristoph (Sheogorath) Kern2018-03-21 14:13:32 +0100
committerGitHub2018-03-21 14:13:32 +0100
commit6485f9665976adfc3dc17233c1922efb89e5d43a (patch)
tree9b5356ada5cda0e1a5cf0a1eb7e81398622e139b /lib/web/imageRouter/index.js
parent6e6a98b392f78567e98a9b49ff0dd193f885e242 (diff)
parent1756e76dc31495d03c8792fa672ae6bb94d24ea8 (diff)
Merge pull request #771 from SISheogorath/refactor/imageRouter
Refactoring imageRouter to modularity
Diffstat (limited to '')
-rw-r--r--lib/web/imageRouter/index.js42
1 files changed, 42 insertions, 0 deletions
diff --git a/lib/web/imageRouter/index.js b/lib/web/imageRouter/index.js
new file mode 100644
index 00000000..59f19253
--- /dev/null
+++ b/lib/web/imageRouter/index.js
@@ -0,0 +1,42 @@
+'use strict'
+
+const Router = require('express').Router
+const formidable = require('formidable')
+
+const config = require('../../config')
+const logger = require('../../logger')
+const response = require('../../response')
+
+const imageRouter = module.exports = Router()
+
+// upload image
+imageRouter.post('/uploadimage', function (req, res) {
+ var form = new formidable.IncomingForm()
+
+ form.keepExtensions = true
+
+ if (config.imageuploadtype === 'filesystem') {
+ form.uploadDir = 'public/uploads'
+ }
+
+ form.parse(req, function (err, fields, files) {
+ if (err || !files.image || !files.image.path) {
+ response.errorForbidden(res)
+ } else {
+ if (config.debug) {
+ logger.info('SERVER received uploadimage: ' + JSON.stringify(files.image))
+ }
+
+ const uploadProvider = require('./' + config.imageuploadtype)
+ uploadProvider.uploadImage(files.image.path, function (err, url) {
+ if (err !== null) {
+ logger.error(err)
+ return res.status(500).end('upload image error')
+ }
+ res.send({
+ link: url
+ })
+ })
+ }
+ })
+})