mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-13 01:15:47 +01:00
#6431 add private upload info
This commit is contained in:
@@ -3,5 +3,7 @@
|
||||
"select-file-to-upload": "Select a file to upload!",
|
||||
"upload-success": "File uploaded successfully!",
|
||||
"maximum-file-size": "Maximum %1 kb",
|
||||
"no-uploads-found": "No uploads found"
|
||||
"no-uploads-found": "No uploads found",
|
||||
"public-uploads-info": "Uploads are public, all visitors can see them.",
|
||||
"private-uploads": "Uploads are private, only logged in users can see them."
|
||||
}
|
||||
@@ -10,7 +10,7 @@ define('forum/account/uploads', ['forum/account/header'], function (header) {
|
||||
var el = $(this).parents('[data-url]');
|
||||
var url = el.attr('data-url');
|
||||
|
||||
socket.emit('user.deleteUpload', url, function (err) {
|
||||
socket.emit('user.deleteUpload', { url: url, uid: ajaxify.data.uid }, function (err) {
|
||||
if (err) {
|
||||
return app.alertError(err.message);
|
||||
}
|
||||
|
||||
@@ -5,6 +5,7 @@ var async = require('async');
|
||||
|
||||
var db = require('../../database');
|
||||
var helpers = require('../helpers');
|
||||
var meta = require('../../meta');
|
||||
var pagination = require('../../pagination');
|
||||
var accountHelpers = require('./helpers');
|
||||
|
||||
@@ -45,6 +46,7 @@ uploadsController.get = function (req, res, callback) {
|
||||
});
|
||||
var pageCount = Math.ceil(results.itemCount / itemsPerPage);
|
||||
userData.pagination = pagination.create(page, pageCount, req.query);
|
||||
userData.privateUploads = parseInt(meta.config.privateUploads, 10) === 1;
|
||||
userData.title = '[[pages:account/uploads, ' + userData.username + ']]';
|
||||
userData.breadcrumbs = helpers.buildBreadcrumbs([{ text: userData.username, url: '/user/' + userData.userslug }, { text: '[[global:uploads]]' }]);
|
||||
res.render('account/uploads', userData);
|
||||
|
||||
@@ -341,11 +341,11 @@ SocketUser.setModerationNote = function (socket, data, callback) {
|
||||
], callback);
|
||||
};
|
||||
|
||||
SocketUser.deleteUpload = function (socket, url, callback) {
|
||||
if (!url) {
|
||||
SocketUser.deleteUpload = function (socket, data, callback) {
|
||||
if (!data || !data.url || !data.uid) {
|
||||
return callback(new Error('[[error:invalid-data]]'));
|
||||
}
|
||||
user.deleteUpload(socket.uid, url, callback);
|
||||
user.deleteUpload(socket.uid, data.uid, data.url, callback);
|
||||
};
|
||||
|
||||
SocketUser.gdpr = {};
|
||||
|
||||
@@ -6,15 +6,15 @@ var db = require('../database');
|
||||
var file = require('../file');
|
||||
|
||||
module.exports = function (User) {
|
||||
User.deleteUpload = function (uid, url, callback) {
|
||||
User.deleteUpload = function (callerUid, uid, url, callback) {
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
async.parallel({
|
||||
isUsersUpload: function (next) {
|
||||
db.isSortedSetMember('uid:' + uid + ':uploads', url, next);
|
||||
db.isSortedSetMember('uid:' + callerUid + ':uploads', url, next);
|
||||
},
|
||||
isAdminOrGlobalMod: function (next) {
|
||||
User.isAdminOrGlobalMod(uid, next);
|
||||
User.isAdminOrGlobalMod(callerUid, next);
|
||||
},
|
||||
}, next);
|
||||
},
|
||||
@@ -25,6 +25,9 @@ module.exports = function (User) {
|
||||
|
||||
file.delete(file.uploadUrlToPath(url), next);
|
||||
},
|
||||
function (next) {
|
||||
db.sortedSetRemove('uid:' + uid + ':uploads', url, next);
|
||||
},
|
||||
], callback);
|
||||
};
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user