mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-30 23:22:41 +00:00
79 lines
3.4 KiB
CoffeeScript
79 lines
3.4 KiB
CoffeeScript
async = require "async"
|
|
fs = require "fs"
|
|
_ = require "underscore"
|
|
FileTypeManager = require "./FileTypeManager"
|
|
EditorController = require "../Editor/EditorController"
|
|
ProjectLocator = require "../Project/ProjectLocator"
|
|
|
|
module.exports = FileSystemImportManager =
|
|
addDoc: (user_id, project_id, folder_id, name, path, replace, callback = (error, doc)-> )->
|
|
fs.readFile path, "utf8", (error, content = "") ->
|
|
return callback(error) if error?
|
|
content = content.replace(/\r/g, "")
|
|
lines = content.split("\n")
|
|
if replace
|
|
ProjectLocator.findElement project_id: project_id, element_id: folder_id, type: "folder", (error, folder) ->
|
|
return callback(error) if error?
|
|
return callback(new Error("Couldn't find folder")) if !folder?
|
|
existingDoc = null
|
|
for doc in folder.docs
|
|
if doc.name == name
|
|
existingDoc = doc
|
|
break
|
|
if existingDoc?
|
|
EditorController.setDoc project_id, existingDoc._id, user_id, lines, "upload", callback
|
|
else
|
|
EditorController.addDocWithoutLock project_id, folder_id, name, lines, "upload", callback
|
|
else
|
|
EditorController.addDocWithoutLock project_id, folder_id, name, lines, "upload", callback
|
|
|
|
addFile: (user_id, project_id, folder_id, name, path, replace, callback = (error, file)-> )->
|
|
if replace
|
|
ProjectLocator.findElement project_id: project_id, element_id: folder_id, type: "folder", (error, folder) ->
|
|
return callback(error) if error?
|
|
return callback(new Error("Couldn't find folder")) if !folder?
|
|
existingFile = null
|
|
for fileRef in folder.fileRefs
|
|
if fileRef.name == name
|
|
existingFile = fileRef
|
|
break
|
|
if existingFile?
|
|
EditorController.replaceFile project_id, existingFile._id, path, "upload", callback
|
|
else
|
|
EditorController.addFileWithoutLock project_id, folder_id, name, path, "upload", callback
|
|
else
|
|
EditorController.addFileWithoutLock project_id, folder_id, name, path, "upload", callback
|
|
|
|
addFolder: (user_id, project_id, folder_id, name, path, replace, callback = (error)-> ) ->
|
|
EditorController.addFolderWithoutLock project_id, folder_id, name, "upload", (error, new_folder) =>
|
|
return callback(error) if error?
|
|
@addFolderContents user_id, project_id, new_folder._id, path, replace, (error) ->
|
|
return callback(error) if error?
|
|
callback null, new_folder
|
|
|
|
addFolderContents: (user_id, project_id, parent_folder_id, folderPath, replace, callback = (error)-> ) ->
|
|
fs.readdir folderPath, (error, entries = []) =>
|
|
return callback(error) if error?
|
|
jobs = _.map entries, (entry) =>
|
|
(callback) =>
|
|
FileTypeManager.shouldIgnore entry, (error, ignore) =>
|
|
return callback(error) if error?
|
|
if !ignore
|
|
@addEntity user_id, project_id, parent_folder_id, entry, "#{folderPath}/#{entry}", replace, callback
|
|
else
|
|
callback()
|
|
async.parallelLimit jobs, 5, callback
|
|
|
|
addEntity: (user_id, project_id, folder_id, name, path, replace, callback = (error, entity)-> ) ->
|
|
FileTypeManager.isDirectory path, (error, isDirectory) =>
|
|
return callback(error) if error?
|
|
if isDirectory
|
|
@addFolder user_id, project_id, folder_id, name, path, replace, callback
|
|
else
|
|
FileTypeManager.isBinary name, path, (error, isBinary) =>
|
|
return callback(error) if error?
|
|
if isBinary
|
|
@addFile user_id, project_id, folder_id, name, path, replace, callback
|
|
else
|
|
@addDoc user_id, project_id, folder_id, name, path, replace, callback
|
|
|