mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
add missing locking to copyFileFromExistingProject
This commit is contained in:
parent
d3ae276091
commit
c4f3a12ce5
1 changed files with 33 additions and 30 deletions
|
@ -45,37 +45,40 @@ wrapWithLock = (methodWithoutLock) ->
|
||||||
methodWithLock
|
methodWithLock
|
||||||
|
|
||||||
module.exports = ProjectEntityUpdateHandler = self =
|
module.exports = ProjectEntityUpdateHandler = self =
|
||||||
# this doesn't need any locking because it's only called by ProjectDuplicator
|
copyFileFromExistingProjectWithProject: wrapWithLock
|
||||||
copyFileFromExistingProjectWithProject: (project, folder_id, originalProject_id, origonalFileRef, userId, callback = (error, fileRef, folder_id) ->)->
|
beforeLock: (next) ->
|
||||||
project_id = project._id
|
(project, folder_id, originalProject_id, origonalFileRef, userId, callback = (error, fileRef, folder_id) ->)->
|
||||||
projectHistoryId = project.overleaf?.history?.id
|
project_id = project._id
|
||||||
logger.log { project_id, folder_id, originalProject_id, origonalFileRef }, "copying file in s3 with project"
|
logger.log { project_id, folder_id, originalProject_id, origonalFileRef }, "copying file in s3 with project"
|
||||||
return callback(err) if err?
|
ProjectEntityMongoUpdateHandler._confirmFolder project, folder_id, (folder_id) ->
|
||||||
ProjectEntityMongoUpdateHandler._confirmFolder project, folder_id, (folder_id)=>
|
if !origonalFileRef?
|
||||||
if !origonalFileRef?
|
logger.err { project_id, folder_id, originalProject_id, origonalFileRef }, "file trying to copy is null"
|
||||||
logger.err { project_id, folder_id, originalProject_id, origonalFileRef }, "file trying to copy is null"
|
return callback()
|
||||||
return callback()
|
# convert any invalid characters in original file to '_'
|
||||||
# convert any invalid characters in original file to '_'
|
fileRef = new File name : SafePath.clean(origonalFileRef.name)
|
||||||
fileRef = new File name : SafePath.clean(origonalFileRef.name)
|
FileStoreHandler.copyFile originalProject_id, origonalFileRef._id, project._id, fileRef._id, (err, fileStoreUrl)->
|
||||||
FileStoreHandler.copyFile originalProject_id, origonalFileRef._id, project._id, fileRef._id, (err, fileStoreUrl)->
|
|
||||||
if err?
|
|
||||||
logger.err { err, project_id, folder_id, originalProject_id, origonalFileRef }, "error coping file in s3"
|
|
||||||
return callback(err)
|
|
||||||
ProjectEntityMongoUpdateHandler._putElement project, folder_id, fileRef, "file", (err, result)=>
|
|
||||||
if err?
|
|
||||||
logger.err { err, project_id, folder_id }, "error putting element as part of copy"
|
|
||||||
return callback(err)
|
|
||||||
TpdsUpdateSender.addFile { project_id, file_id:fileRef._id, path:result?.path?.fileSystem, rev:fileRef.rev, project_name:project.name}, (err) ->
|
|
||||||
if err?
|
if err?
|
||||||
logger.err { err, project_id, folder_id, originalProject_id, origonalFileRef }, "error sending file to tpds worker"
|
logger.err { err, project_id, folder_id, originalProject_id, origonalFileRef }, "error coping file in s3"
|
||||||
newFiles = [
|
return callback(err)
|
||||||
file: fileRef
|
next(project, folder_id, originalProject_id, origonalFileRef, userId, fileRef, fileStoreUrl, callback)
|
||||||
path: result?.path?.fileSystem
|
withLock: (project, folder_id, originalProject_id, origonalFileRef, userId, fileRef, fileStoreUrl, callback = (error, fileRef, folder_id) ->)->
|
||||||
url: fileStoreUrl
|
project_id = project._id
|
||||||
]
|
projectHistoryId = project.overleaf?.history?.id
|
||||||
DocumentUpdaterHandler.updateProjectStructure project_id, projectHistoryId, userId, {newFiles}, (error) ->
|
ProjectEntityMongoUpdateHandler._putElement project, folder_id, fileRef, "file", (err, result, newProject) ->
|
||||||
return callback(error) if error?
|
if err?
|
||||||
callback null, fileRef, folder_id
|
logger.err { err, project_id, folder_id }, "error putting element as part of copy"
|
||||||
|
return callback(err)
|
||||||
|
TpdsUpdateSender.addFile { project_id, file_id:fileRef._id, path:result?.path?.fileSystem, rev:fileRef.rev, project_name:project.name}, (err) ->
|
||||||
|
if err?
|
||||||
|
logger.err { err, project_id, folder_id, originalProject_id, origonalFileRef }, "error sending file to tpds worker"
|
||||||
|
newFiles = [
|
||||||
|
file: fileRef
|
||||||
|
path: result?.path?.fileSystem
|
||||||
|
url: fileStoreUrl
|
||||||
|
]
|
||||||
|
DocumentUpdaterHandler.updateProjectStructure project_id, projectHistoryId, userId, {newFiles, newProject}, (error) ->
|
||||||
|
return callback(error) if error?
|
||||||
|
callback null, fileRef, folder_id
|
||||||
|
|
||||||
updateDocLines: (project_id, doc_id, lines, version, ranges, callback = (error) ->)->
|
updateDocLines: (project_id, doc_id, lines, version, ranges, callback = (error) ->)->
|
||||||
ProjectGetter.getProjectWithoutDocLines project_id, (err, project)->
|
ProjectGetter.getProjectWithoutDocLines project_id, (err, project)->
|
||||||
|
|
Loading…
Reference in a new issue