mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 08:36:12 +01:00
fix: #7519
This commit is contained in:
@@ -337,7 +337,11 @@ SocketUser.setModerationNote = function (socket, data, callback) {
|
|||||||
if (!socket.uid || !data || !data.uid || !data.note) {
|
if (!socket.uid || !data || !data.uid || !data.note) {
|
||||||
return callback(new Error('[[error:invalid-data]]'));
|
return callback(new Error('[[error:invalid-data]]'));
|
||||||
}
|
}
|
||||||
|
const noteData = {
|
||||||
|
uid: socket.uid,
|
||||||
|
note: data.note,
|
||||||
|
timestamp: Date.now(),
|
||||||
|
};
|
||||||
async.waterfall([
|
async.waterfall([
|
||||||
function (next) {
|
function (next) {
|
||||||
privileges.users.canEdit(socket.uid, data.uid, next);
|
privileges.users.canEdit(socket.uid, data.uid, next);
|
||||||
@@ -354,12 +358,10 @@ SocketUser.setModerationNote = function (socket, data, callback) {
|
|||||||
return next(new Error('[[error:no-privileges]]'));
|
return next(new Error('[[error:no-privileges]]'));
|
||||||
}
|
}
|
||||||
|
|
||||||
var note = {
|
db.sortedSetAdd('uid:' + data.uid + ':moderation:notes', noteData.timestamp, noteData.timestamp, next);
|
||||||
uid: socket.uid,
|
},
|
||||||
note: data.note,
|
function (next) {
|
||||||
timestamp: Date.now(),
|
db.setObject('uid:' + data.uid + ':moderation:note:' + noteData.timestamp, noteData, next);
|
||||||
};
|
|
||||||
db.sortedSetAdd('uid:' + data.uid + ':moderation:notes', note.timestamp, JSON.stringify(note), next);
|
|
||||||
},
|
},
|
||||||
], callback);
|
], callback);
|
||||||
};
|
};
|
||||||
|
|||||||
54
src/upgrades/1.12.1/moderation_notes_refactor.js
Normal file
54
src/upgrades/1.12.1/moderation_notes_refactor.js
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var async = require('async');
|
||||||
|
var db = require('../../database');
|
||||||
|
var batch = require('../../batch');
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'Update moderation notes to hashes',
|
||||||
|
timestamp: Date.UTC(2018, 3, 5),
|
||||||
|
method: function (callback) {
|
||||||
|
var progress = this.progress;
|
||||||
|
|
||||||
|
batch.processSortedSet('users:joindate', function (ids, next) {
|
||||||
|
async.each(ids, function (uid, next) {
|
||||||
|
progress.incr();
|
||||||
|
db.getSortedSetRevRange('uid:' + uid + ':moderation:notes', 0, -1, function (err, notes) {
|
||||||
|
if (err || !notes.length) {
|
||||||
|
return next(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
async.eachSeries(notes, function (note, next) {
|
||||||
|
var noteData;
|
||||||
|
async.waterfall([
|
||||||
|
function (next) {
|
||||||
|
try {
|
||||||
|
noteData = JSON.parse(note);
|
||||||
|
setImmediate(next);
|
||||||
|
} catch (err) {
|
||||||
|
next(err);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function (next) {
|
||||||
|
db.sortedSetRemove('uid:' + uid + ':moderation:notes', note, next);
|
||||||
|
},
|
||||||
|
function (next) {
|
||||||
|
db.setObject('uid:' + uid + ':moderation:note:' + noteData.timestamp, {
|
||||||
|
uid: noteData.uid,
|
||||||
|
timestamp: noteData.timestamp,
|
||||||
|
note: noteData.note,
|
||||||
|
}, next);
|
||||||
|
},
|
||||||
|
function (next) {
|
||||||
|
db.sortedSetAdd('uid:' + uid + ':moderation:notes', noteData.timestamp, noteData.timestamp, next);
|
||||||
|
},
|
||||||
|
], next);
|
||||||
|
}, next);
|
||||||
|
});
|
||||||
|
}, next);
|
||||||
|
}, {
|
||||||
|
progress: this.progress,
|
||||||
|
}, callback);
|
||||||
|
},
|
||||||
|
};
|
||||||
@@ -158,18 +158,19 @@ module.exports = function (User) {
|
|||||||
function (next) {
|
function (next) {
|
||||||
db.getSortedSetRevRange('uid:' + uid + ':moderation:notes', start, stop, next);
|
db.getSortedSetRevRange('uid:' + uid + ':moderation:notes', start, stop, next);
|
||||||
},
|
},
|
||||||
|
function (noteIds, next) {
|
||||||
|
const keys = noteIds.map(id => 'uid:' + uid + ':moderation:note:' + id);
|
||||||
|
db.getObjects(keys, next);
|
||||||
|
},
|
||||||
function (notes, next) {
|
function (notes, next) {
|
||||||
var uids = [];
|
var uids = [];
|
||||||
noteData = notes.map(function (note) {
|
noteData = notes.map(function (note) {
|
||||||
try {
|
if (note) {
|
||||||
var data = JSON.parse(note);
|
uids.push(note.uid);
|
||||||
uids.push(data.uid);
|
note.timestampISO = utils.toISOString(note.timestamp);
|
||||||
data.timestampISO = utils.toISOString(data.timestamp);
|
note.note = validator.escape(String(note.note));
|
||||||
data.note = validator.escape(String(data.note));
|
|
||||||
return data;
|
|
||||||
} catch (err) {
|
|
||||||
return next(err);
|
|
||||||
}
|
}
|
||||||
|
return note;
|
||||||
});
|
});
|
||||||
|
|
||||||
User.getUsersFields(uids, ['uid', 'username', 'userslug', 'picture'], next);
|
User.getUsersFields(uids, ['uid', 'username', 'userslug', 'picture'], next);
|
||||||
|
|||||||
Reference in New Issue
Block a user