fix: username, email history disappering if content was deleted
parent
074d7dfd86
commit
91d9333a50
@ -0,0 +1,37 @@
|
||||
'use strict';
|
||||
|
||||
const db = require('../../database');
|
||||
const batch = require('../../batch');
|
||||
const posts = require('../../posts');
|
||||
|
||||
module.exports = {
|
||||
name: 'Add target uid to flag objects',
|
||||
timestamp: Date.UTC(2020, 7, 22),
|
||||
method: async function () {
|
||||
const progress = this.progress;
|
||||
|
||||
await batch.processSortedSet('flags:datetime', async function (flagIds) {
|
||||
progress.incr(flagIds.length);
|
||||
const flagData = await db.getObjects(flagIds.map(id => 'flag:' + id));
|
||||
for (const flagObj of flagData) {
|
||||
/* eslint-disable no-await-in-loop */
|
||||
if (flagObj) {
|
||||
const targetId = flagObj.targetId;
|
||||
if (targetId) {
|
||||
if (flagObj.type === 'post') {
|
||||
const targetUid = await posts.getPostField(targetId, 'uid');
|
||||
if (targetUid) {
|
||||
await db.setObjectField('flag:' + flagObj.flagId, 'targetUid', targetUid);
|
||||
}
|
||||
} else if (flagObj.type === 'user') {
|
||||
await db.setObjectField('flag:' + flagObj.flagId, 'targetUid', targetId);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, {
|
||||
progress: progress,
|
||||
batch: 500,
|
||||
});
|
||||
},
|
||||
};
|
Loading…
Reference in New Issue