diff options
| author | Pitu <[email protected]> | 2017-02-07 04:32:55 -0300 |
|---|---|---|
| committer | Pitu <[email protected]> | 2017-02-07 04:32:55 -0300 |
| commit | e05a7c751e499f8b5c347d1ad71692ffa5848442 (patch) | |
| tree | f2c1cd31749684ca9fa18995a58fd0fbea8bc184 /controllers | |
| parent | Merge pull request #11 from PascalTemel/master (diff) | |
| download | host.fuwn.me-e05a7c751e499f8b5c347d1ad71692ffa5848442.tar.xz host.fuwn.me-e05a7c751e499f8b5c347d1ad71692ffa5848442.zip | |
Added public album sharing :ok_hand:
Diffstat (limited to 'controllers')
| -rw-r--r-- | controllers/albumsController.js | 86 |
1 files changed, 85 insertions, 1 deletions
diff --git a/controllers/albumsController.js b/controllers/albumsController.js index 79e3ab8..238275d 100644 --- a/controllers/albumsController.js +++ b/controllers/albumsController.js @@ -1,5 +1,10 @@ const config = require('../config.js') const db = require('knex')(config.database) +const randomstring = require('randomstring') +const path = require('path') +const fs = require('fs') +const ffmpeg = require('fluent-ffmpeg') +const gm = require('gm') let albumsController = {} @@ -67,6 +72,7 @@ albumsController.create = function(req, res, next){ name: name, enabled: 1, userid: user[0].id, + identifier: randomstring.generate(8), timestamp: Math.floor(Date.now() / 1000) }).then(() => { return res.json({ success: true }) @@ -74,7 +80,6 @@ albumsController.create = function(req, res, next){ }).catch(function(error) { console.log(error); res.json({success: false, description: 'error'}) }) }).catch(function(error) { console.log(error); res.json({success: false, description: 'error'}) }) - } albumsController.delete = function(req, res, next){ @@ -120,4 +125,83 @@ albumsController.rename = function(req, res, next){ } +albumsController.get = function(req, res, next){ + let identifier = req.params.identifier + if(identifier === undefined) return res.status(401).json({ success: false, description: 'No identifier provided' }) + + db.table('albums') + .where('identifier', identifier) + .then((albums) => { + if(albums.length === 0) return res.json({ success: false, description: 'Album not found' }) + + let title = albums[0].name + db.table('files').select('name').where('albumid', albums[0].id).orderBy('id', 'DESC').then((files) => { + + let basedomain = req.get('host') + for(let domain of config.domains) + if(domain.host === req.get('host')) + if(domain.hasOwnProperty('resolve')) + basedomain = domain.resolve + + for(let file of files){ + file.file = basedomain + '/' + file.name + + if(config.uploads.generateThumbnails === true){ + + let extensions = ['.jpg', '.jpeg', '.bmp', '.gif', '.png', '.webm', '.mp4'] + for(let ext of extensions){ + if(path.extname(file.name) === ext){ + + file.thumb = basedomain + '/thumbs/' + file.name.slice(0, -ext.length) + '.png' + + let thumbname = path.join(__dirname, '..', config.uploads.folder, 'thumbs') + '/' + file.name.slice(0, -ext.length) + '.png' + fs.access(thumbname, function(err) { + if (err && err.code === 'ENOENT') { + // File doesnt exist + + if (ext === '.webm' || ext === '.mp4') { + ffmpeg('./' + config.uploads.folder + '/' + file.name) + .thumbnail({ + timestamps: [0], + filename: '%b.png', + folder: './' + config.uploads.folder + '/thumbs', + size: '200x?' + }) + .on('error', function(error) { + console.log('Error - ', error.message) + }) + } + else { + let size = { + width: 200, + height: 200 + } + + gm('./' + config.uploads.folder + '/' + file.name) + .resize(size.width, size.height + '>') + .gravity('Center') + .extent(size.width, size.height) + .background('transparent') + .write(thumbname, function (error) { + if (error) console.log('Error - ', error) + }) + } + } + }) + } + } + } + } + + return res.json({ + success: true, + title: title, + files + }) + + }).catch(function(error) { console.log(error); res.json({success: false, description: 'error'}) }) + }).catch(function(error) { console.log(error); res.json({success: false, description: 'error'}) }) + +} + module.exports = albumsController
\ No newline at end of file |