Merge pull request #5417 from overleaf/hb-restore-doc-from-admin

Restore soft deleted docs from admin

GitOrigin-RevId: 5c94539ae950c401225d2cfe7c0bc978ed258e22
This commit is contained in:
Brian Gough
2021-10-25 14:57:16 +01:00
committed by Copybot
parent 2037adf808
commit 3c780c65e8
4 changed files with 138 additions and 38 deletions

View File

@@ -1,8 +1,6 @@
const { waitForDb } = require('../app/src/infrastructure/mongodb')
const ProjectEntityUpdateHandler = require('../app/src/Features/Project/ProjectEntityUpdateHandler')
const ProjectEntityHandler = require('../app/src/Features/Project/ProjectEntityHandler')
const ProjectEntityRestoreHandler = require('../app/src/Features/Project/ProjectEntityRestoreHandler')
const DocstoreManager = require('../app/src/Features/Docstore/DocstoreManager')
const Path = require('path')
const ARGV = process.argv.slice(2)
const DEVELOPER_USER_ID = ARGV.shift()
@@ -17,41 +15,12 @@ async function main() {
FILE_NAMES_TO_RESTORE.includes(doc.name)
)
for (const deletedDoc of docsToRestore) {
const doc = await new Promise((resolve, reject) => {
ProjectEntityHandler.getDoc(
PROJECT_ID,
deletedDoc._id,
{
include_deleted: true,
},
(err, lines, rev, version, ranges) => {
if (err) return reject(err)
resolve({ lines, ranges })
}
)
})
const formattedTimestamp = new Date()
.toISOString()
.replace('T', '-')
.replace(/[^0-9-]/g, '')
const extension = Path.extname(deletedDoc.name)
const basename = Path.basename(deletedDoc.name, extension)
const deletedDocName = `${basename}-${formattedTimestamp}${extension}`
const newDoc = await new Promise((resolve, reject) => {
ProjectEntityUpdateHandler.addDocWithRanges(
PROJECT_ID,
null,
`${deletedDocName}`,
doc.lines,
doc.ranges,
DEVELOPER_USER_ID,
(err, doc, folderId) => {
if (err) return reject(err)
resolve({ doc, folderId })
}
)
})
const newDoc = await ProjectEntityRestoreHandler.restoreDeletedDoc(
PROJECT_ID,
deletedDoc._id,
deletedDoc.id,
DEVELOPER_USER_ID
)
console.log(newDoc)
}
}