2020-03-21 15:07:14 +00:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
2020-03-21 22:27:00 +00:00
|
|
|
const logger = require('../lib/logger')
|
2020-03-21 15:07:14 +00:00
|
|
|
const models = require('../lib/models')
|
|
|
|
|
2020-03-21 22:27:00 +00:00
|
|
|
logger.info('Cleaning up notes that should already have been removed. Sorry.')
|
2020-03-21 15:07:14 +00:00
|
|
|
|
2020-03-21 22:27:00 +00:00
|
|
|
async function cleanup () {
|
2020-03-21 15:07:14 +00:00
|
|
|
await models.Note.findAll({
|
|
|
|
include: [{
|
|
|
|
model: models.User,
|
2020-03-21 18:27:02 +00:00
|
|
|
as: 'owner',
|
|
|
|
attributes: ['id']
|
|
|
|
}],
|
|
|
|
attributes: ['id', 'ownerId']
|
2020-03-21 22:27:00 +00:00
|
|
|
}).then(async function (notes) {
|
|
|
|
for (let i = 0, noteCount = notes.length; i < noteCount; i++) {
|
2020-03-21 15:07:14 +00:00
|
|
|
const item = notes[i]
|
2020-03-21 22:27:00 +00:00
|
|
|
if (item.ownerId != null && !item.owner) {
|
2020-03-21 15:07:14 +00:00
|
|
|
await models.Note.destroy({
|
|
|
|
where: {
|
|
|
|
id: item.id
|
2020-03-21 22:27:00 +00:00
|
|
|
}
|
|
|
|
})
|
2020-03-21 15:07:14 +00:00
|
|
|
await models.Revision.destroy({
|
|
|
|
where: {
|
|
|
|
noteId: item.id
|
|
|
|
}
|
|
|
|
})
|
|
|
|
await models.Author.destroy({
|
|
|
|
where: {
|
|
|
|
noteId: item.id
|
|
|
|
}
|
|
|
|
})
|
|
|
|
logger.info(`Deleted note ${item.id} from user ${item.ownerId}`)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
await models.Author.findAll({
|
|
|
|
include: [{
|
|
|
|
model: models.User,
|
2020-03-21 18:27:02 +00:00
|
|
|
as: 'user',
|
|
|
|
attributes: ['id']
|
|
|
|
}],
|
|
|
|
attributes: ['id', 'userId']
|
2020-03-21 22:27:00 +00:00
|
|
|
}).then(async function (authors) {
|
|
|
|
for (let i = 0, authorCount = authors.length; i < authorCount; i++) {
|
2020-03-21 15:07:14 +00:00
|
|
|
const item = authors[i]
|
2020-03-21 22:27:00 +00:00
|
|
|
if (item.userId != null && !item.user) {
|
2020-03-21 15:07:14 +00:00
|
|
|
await models.Author.destroy({
|
|
|
|
where: {
|
|
|
|
id: item.id
|
2020-03-21 22:27:00 +00:00
|
|
|
}
|
|
|
|
})
|
2020-03-21 15:07:14 +00:00
|
|
|
logger.info(`Deleted authorship ${item.id} from user ${item.userId}`)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
2020-03-21 18:27:02 +00:00
|
|
|
|
2020-03-21 20:03:52 +00:00
|
|
|
await models.Author.findAll({
|
|
|
|
include: [{
|
|
|
|
model: models.Note,
|
|
|
|
as: 'note',
|
|
|
|
attributes: ['id']
|
|
|
|
}],
|
|
|
|
attributes: ['id', 'noteId']
|
2020-03-21 22:27:00 +00:00
|
|
|
}).then(async function (authors) {
|
|
|
|
for (let i = 0, authorCount = authors.length; i < authorCount; i++) {
|
2020-03-21 20:03:52 +00:00
|
|
|
const item = authors[i]
|
2020-03-21 22:27:00 +00:00
|
|
|
if (item.noteId != null && !item.note) {
|
2020-03-21 20:03:52 +00:00
|
|
|
await models.Author.destroy({
|
|
|
|
where: {
|
|
|
|
id: item.id
|
2020-03-21 22:27:00 +00:00
|
|
|
}
|
|
|
|
})
|
2020-03-21 20:03:52 +00:00
|
|
|
logger.info(`Deleted authorship ${item.id} from note ${item.noteId}`)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2020-03-21 17:13:20 +00:00
|
|
|
await models.Revision.findAll({
|
|
|
|
include: [{
|
|
|
|
model: models.Note,
|
2020-03-21 18:27:02 +00:00
|
|
|
as: 'note',
|
|
|
|
attributes: ['id']
|
|
|
|
}],
|
|
|
|
attributes: ['id', 'noteId']
|
2020-03-21 22:27:00 +00:00
|
|
|
}).then(async function (revisions) {
|
|
|
|
for (let i = 0, revisionCount = revisions.length; i < revisionCount; i++) {
|
2020-03-21 17:13:20 +00:00
|
|
|
const item = revisions[i]
|
2020-03-21 22:27:00 +00:00
|
|
|
if (item.noteId != null && !item.note) {
|
2020-03-21 17:13:20 +00:00
|
|
|
await models.Revision.destroy({
|
|
|
|
where: {
|
|
|
|
id: item.id
|
2020-03-21 22:27:00 +00:00
|
|
|
}
|
|
|
|
})
|
2020-03-21 17:13:20 +00:00
|
|
|
logger.info(`Deleted revision ${item.id} from note ${item.userId}`)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
2020-03-21 15:07:14 +00:00
|
|
|
process.exit(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
cleanup()
|