From 7cf8b6899df0a41961b4007f62cafe7ba507c761 Mon Sep 17 00:00:00 2001 From: Pitu Date: Mon, 13 Feb 2017 21:55:07 -0300 Subject: [PATCH] Added ability to see who uploaded a file as root --- controllers/uploadController.js | 116 +++++++++++++++++++------------- public/js/dashboard.js | 16 ++++- 2 files changed, 82 insertions(+), 50 deletions(-) diff --git a/controllers/uploadController.js b/controllers/uploadController.js index e819790..229134e 100644 --- a/controllers/uploadController.js +++ b/controllers/uploadController.js @@ -231,6 +231,7 @@ uploadsController.list = function(req, res){ .orderBy('id', 'DESC') .limit(25) .offset(25 * offset) + .select('id', 'albumid', 'timestamp', 'name', 'userid') .then((files) => { db.table('albums').then((albums) => { @@ -240,6 +241,8 @@ uploadsController.list = function(req, res){ if(domain.hasOwnProperty('resolve')) basedomain = domain.resolve + let userids = [] + for(let file of files){ file.file = basedomain + '/' + file.name file.date = new Date(file.timestamp * 1000) @@ -252,62 +255,79 @@ uploadsController.list = function(req, res){ if(file.albumid === album.id) file.album = album.name - if(config.uploads.generateThumbnails === true){ + // Only push usernames if we are root + if(user[0].username === 'root') + if(file.userid !== undefined && file.userid !== null && file.userid !== '') + userids.push(file.userid) - 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) - }) - } - } - }) - } - } - } + uploadsController.generateThumbs(file, basedomain) } - return res.json({ - success: true, - files - }) + // If we are a normal user, send response + if(user[0].username !== 'root') return res.json({ success: true, files }) + // If we are root but there are no uploads attached to a user, send response + if(userids.length === 0) return res.json({ success: true, files }) + + db.table('users').whereIn('id', userids).then((users) => { + for(let user of users) + for(let file of files) + if(file.userid === user.id) + file.username = user.username + + return res.json({ success: true, 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'}) }) }).catch(function(error) { console.log(error); res.json({success: false, description: 'error'}) }) }) } +uploadsController.generateThumbs = function(file, basedomain){ + if(config.uploads.generateThumbnails !== true) return + + let extensions = ['.jpg', '.jpeg', '.bmp', '.gif', '.png', '.webm', '.mp4'] + for(let ext of extensions){ + if(path.extname(file.name).toLowerCase() === 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) + }) + } + } + }) + } + } +} + module.exports = uploadsController diff --git a/public/js/dashboard.js b/public/js/dashboard.js index 3024d62..76b8ec4 100644 --- a/public/js/dashboard.js +++ b/public/js/dashboard.js @@ -151,6 +151,10 @@ panel.getUploads = function(album = undefined, page = undefined){ }else{ + var albumOrUser = 'Album'; + if(panel.username === 'root') + albumOrUser = 'User'; + container.innerHTML = ` ${pagination}
@@ -159,7 +163,7 @@ panel.getUploads = function(album = undefined, page = undefined){ File - Album + ${albumOrUser} Date @@ -177,10 +181,18 @@ panel.getUploads = function(album = undefined, page = undefined){ for(var item of response.data.files){ var tr = document.createElement('tr'); + + var displayAlbumOrUser = item.album; + if(panel.username === 'root'){ + displayAlbumOrUser = ''; + if(item.username !== undefined) + displayAlbumOrUser = item.username; + } + tr.innerHTML = ` ${item.file} - ${item.album} + ${displayAlbumOrUser} ${item.date}