summaryrefslogtreecommitdiff
path: root/lib/web/imageRouter/imgur.js
diff options
context:
space:
mode:
authorSheogorath2018-03-18 02:14:50 +0100
committerSheogorath2018-03-20 11:00:11 +0100
commit1756e76dc31495d03c8792fa672ae6bb94d24ea8 (patch)
treecc6e8a8e946458e152e81806a5e5a3079fcc138f /lib/web/imageRouter/imgur.js
parent9cbe03d8a8eb503170b7b481e97c37d66447dd37 (diff)
Refactoring imageRouter to modularity
This should make the imageRouter more modular and easier to extent. Also a lot of code duplication was removed which should simplify maintenance in future. In the new setup we only need to provide a new module file which exports a function called `uploadImage` and takes a filePath and a callback as argument. The callback itself takes an error and an url as parameter. This eliminates the need of a try-catch-block around the statement and re-enabled the optimization in NodeJS. Signed-off-by: Sheogorath <sheogorath@shivering-isles.com>
Diffstat (limited to 'lib/web/imageRouter/imgur.js')
-rw-r--r--lib/web/imageRouter/imgur.js28
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/web/imageRouter/imgur.js b/lib/web/imageRouter/imgur.js
new file mode 100644
index 00000000..31d5f55c
--- /dev/null
+++ b/lib/web/imageRouter/imgur.js
@@ -0,0 +1,28 @@
+'use strict'
+const config = require('../../config')
+const logger = require('../../logger')
+
+const imgur = require('imgur')
+
+exports.uploadImage = function (imagePath, callback) {
+ if (!imagePath || typeof imagePath !== 'string') {
+ callback(new Error('Image path is missing or wrong'), null)
+ return
+ }
+
+ if (!callback || typeof callback !== 'function') {
+ callback(new Error('Callback has to be a function'), null)
+ return
+ }
+
+ imgur.setClientId(config.imgur.clientID)
+ imgur.uploadFile(imagePath)
+ .then(function (json) {
+ if (config.debug) {
+ logger.info('SERVER uploadimage success: ' + JSON.stringify(json))
+ }
+ callback(null, json.data.link.replace(/^http:\/\//i, 'https://'))
+ }).catch(function (err) {
+ callback(new Error(err), null)
+ })
+}