mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2025-01-11 17:23:12 +02:00
80 lines
2 KiB
JavaScript
80 lines
2 KiB
JavaScript
const chalk = require('chalk');
|
|
const log = require('single-line-log').stdout;
|
|
const sequential = require('promise-sequential');
|
|
const { default: DriveFile, deleteDriveFile } = require('../built/models/drive-file');
|
|
const { default: Note } = require('../built/models/note');
|
|
const { default: MessagingMessage } = require('../built/models/messaging-message');
|
|
const { default: User } = require('../built/models/user');
|
|
|
|
async function main() {
|
|
const promiseGens = [];
|
|
|
|
const count = await DriveFile.count({});
|
|
|
|
let prev;
|
|
|
|
for (let i = 0; i < count; i++) {
|
|
promiseGens.push(() => {
|
|
const promise = new Promise(async (res, rej) => {
|
|
const file = await DriveFile.findOne(prev ? {
|
|
_id: { $lt: prev._id }
|
|
} : {}, {
|
|
sort: {
|
|
_id: -1
|
|
}
|
|
});
|
|
|
|
prev = file;
|
|
|
|
function skip() {
|
|
res([i, file, false]);
|
|
}
|
|
|
|
if (file == null) return skip();
|
|
|
|
log(chalk`{gray ${i}} scanning {bold ${file._id}} ${file.filename} ...`);
|
|
|
|
const attachingUsersCount = await User.count({
|
|
$or: [{
|
|
avatarId: file._id
|
|
}, {
|
|
bannerId: file._id
|
|
}]
|
|
}, { limit: 1 });
|
|
if (attachingUsersCount !== 0) return skip();
|
|
|
|
const attachingNotesCount = await Note.count({
|
|
mediaIds: file._id
|
|
}, { limit: 1 });
|
|
if (attachingNotesCount !== 0) return skip();
|
|
|
|
const attachingMessagesCount = await MessagingMessage.count({
|
|
fileId: file._id
|
|
}, { limit: 1 });
|
|
if (attachingMessagesCount !== 0) return skip();
|
|
|
|
deleteDriveFile(file).then(() => {
|
|
res([i, file, true]);
|
|
}).catch(rej);
|
|
});
|
|
|
|
promise.then(([i, file, deleted]) => {
|
|
if (deleted) {
|
|
log(chalk`{gray ${i}} {red deleted: {bold ${file._id}} ${file.filename}}`);
|
|
} else {
|
|
log(chalk`{gray ${i}} {green skipped: {bold ${file._id}} ${file.filename}}`);
|
|
}
|
|
log.clear();
|
|
console.log();
|
|
});
|
|
|
|
return promise;
|
|
});
|
|
}
|
|
|
|
return await sequential(promiseGens);
|
|
}
|
|
|
|
main().then(() => {
|
|
console.log('done');
|
|
}).catch(console.error);
|