delete users uploads on account delete

store uid:<uid>:uploads
v1.18.x
Barış Soner Uşaklı 7 years ago
parent ddd3dfc7f0
commit 04979f86a8

@ -5,13 +5,14 @@ var async = require('async');
var nconf = require('nconf'); var nconf = require('nconf');
var validator = require('validator'); var validator = require('validator');
var db = require('../database');
var meta = require('../meta'); var meta = require('../meta');
var file = require('../file'); var file = require('../file');
var plugins = require('../plugins'); var plugins = require('../plugins');
var image = require('../image'); var image = require('../image');
var privileges = require('../privileges'); var privileges = require('../privileges');
var uploadsController = {}; var uploadsController = module.exports;
uploadsController.upload = function (req, res, filesIterator) { uploadsController.upload = function (req, res, filesIterator) {
var files = req.files.files; var files = req.files.files;
@ -192,7 +193,7 @@ uploadsController.uploadGroupCover = function (uid, uploadedFile, callback) {
file.isFileTypeAllowed(uploadedFile.path, next); file.isFileTypeAllowed(uploadedFile.path, next);
}, },
function (next) { function (next) {
saveFileToLocal(uploadedFile, next); saveFileToLocal(uid, uploadedFile, next);
}, },
], callback); ], callback);
}; };
@ -220,27 +221,30 @@ uploadsController.uploadFile = function (uid, uploadedFile, callback) {
return callback(new Error('[[error:invalid-file-type, ' + allowed.join('&#44; ') + ']]')); return callback(new Error('[[error:invalid-file-type, ' + allowed.join('&#44; ') + ']]'));
} }
saveFileToLocal(uploadedFile, callback); saveFileToLocal(uid, uploadedFile, callback);
}; };
function saveFileToLocal(uploadedFile, callback) { function saveFileToLocal(uid, uploadedFile, callback) {
var filename = uploadedFile.name || 'upload'; var filename = uploadedFile.name || 'upload';
var extension = path.extname(filename) || ''; var extension = path.extname(filename) || '';
filename = Date.now() + '-' + validator.escape(filename.substr(0, filename.length - extension.length)).substr(0, 255) + extension; filename = Date.now() + '-' + validator.escape(filename.substr(0, filename.length - extension.length)).substr(0, 255) + extension;
var storedFile;
async.waterfall([ async.waterfall([
function (next) { function (next) {
file.saveFileToLocal(filename, 'files', uploadedFile.path, next); file.saveFileToLocal(filename, 'files', uploadedFile.path, next);
}, },
function (upload, next) { function (upload, next) {
var storedFile = { storedFile = {
url: nconf.get('relative_path') + upload.url, url: nconf.get('relative_path') + upload.url,
path: upload.path, path: upload.path,
name: uploadedFile.name, name: uploadedFile.name,
}; };
plugins.fireHook('filter:uploadStored', { uploadedFile: uploadedFile, storedFile: storedFile }, next); db.sortedSetAdd('uid:' + uid + ':uploads', Date.now(), upload.url, next);
},
function (next) {
plugins.fireHook('filter:uploadStored', { uid: uid, uploadedFile: uploadedFile, storedFile: storedFile }, next);
}, },
function (data, next) { function (data, next) {
next(null, data.storedFile); next(null, data.storedFile);
@ -254,5 +258,3 @@ function deleteTempFiles(files) {
next(); next();
}); });
} }
module.exports = uploadsController;

@ -141,8 +141,9 @@ file.exists = function (path, callback) {
if (err.code === 'ENOENT') { if (err.code === 'ENOENT') {
return callback(null, false); return callback(null, false);
} }
return callback(err);
} }
callback(err, true); callback(null, true);
}); });
}; };
@ -159,14 +160,17 @@ file.existsSync = function (path) {
return true; return true;
}; };
file.delete = function (path) { file.delete = function (path, callback) {
if (path) { callback = callback || function () {};
fs.unlink(path, function (err) { if (!path) {
if (err) { return callback();
winston.error(err);
}
});
} }
fs.unlink(path, function (err) {
if (err) {
winston.error(err);
}
callback();
});
}; };
file.link = function link(filePath, destPath, relative, callback) { file.link = function link(filePath, destPath, relative, callback) {

@ -2,6 +2,8 @@
var async = require('async'); var async = require('async');
var _ = require('lodash'); var _ = require('lodash');
var path = require('path');
var nconf = require('nconf');
var db = require('../database'); var db = require('../database');
var posts = require('../posts'); var posts = require('../posts');
@ -10,6 +12,7 @@ var groups = require('../groups');
var messaging = require('../messaging'); var messaging = require('../messaging');
var plugins = require('../plugins'); var plugins = require('../plugins');
var batch = require('../batch'); var batch = require('../batch');
var file = require('../file');
module.exports = function (User) { module.exports = function (User) {
User.delete = function (callerUid, uid, callback) { User.delete = function (callerUid, uid, callback) {
@ -24,6 +27,9 @@ module.exports = function (User) {
function (next) { function (next) {
deleteTopics(callerUid, uid, next); deleteTopics(callerUid, uid, next);
}, },
function (next) {
deleteUploads(uid, next);
},
function (next) { function (next) {
User.deleteAccount(uid, next); User.deleteAccount(uid, next);
}, },
@ -46,6 +52,22 @@ module.exports = function (User) {
}, { alwaysStartAt: 0 }, callback); }, { alwaysStartAt: 0 }, callback);
} }
function deleteUploads(uid, callback) {
batch.processSortedSet('uid:' + uid + ':uploads', function (urls, next) {
async.waterfall([
function (next) {
async.each(urls, function (url, next) {
var filePath = path.join(nconf.get('upload_path'), url.replace(nconf.get('upload_url'), ''));
file.delete(filePath, next);
}, next);
},
function (next) {
db.sortedSetRemove('uid:' + uid + ':uploads', urls, next);
},
], next);
}, { alwaysStartAt: 0 }, callback);
}
User.deleteAccount = function (uid, callback) { User.deleteAccount = function (uid, callback) {
var userData; var userData;
async.waterfall([ async.waterfall([

@ -159,6 +159,41 @@ describe('Upload Controllers', function () {
done(); done();
}); });
}); });
it('should delete users uploads if account is deleted', function (done) {
var jar;
var uid;
var url;
var file = require('../src/file');
async.waterfall([
function (next) {
user.create({ username: 'uploader', password: 'barbar' }, next);
},
function (_uid, next) {
uid = _uid;
helpers.loginUser('uploader', 'barbar', next);
},
function (jar, csrf_token, next) {
helpers.uploadFile(nconf.get('url') + '/api/post/upload', path.join(__dirname, '../test/files/test.png'), {}, jar, csrf_token, next);
},
function (res, body, next) {
assert(body);
assert(body[0].url);
url = body[0].url;
user.delete(1, uid, next);
},
function (next) {
var filePath = path.join(nconf.get('upload_path'), url.replace('/assets/uploads', ''));
file.exists(filePath, next);
},
function (exists, next) {
assert(!exists);
done();
},
], done);
});
}); });
describe('admin uploads', function () { describe('admin uploads', function () {

Loading…
Cancel
Save