mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-02 20:40:52 +00:00
857d867191
filesystem import manager uses the unlocked version
65 lines
2.7 KiB
CoffeeScript
65 lines
2.7 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: (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")
|
|
EditorController.addDocWithoutLock project_id, folder_id, name, lines, "upload", callback
|
|
|
|
addFile: (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: (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 project_id, new_folder._id, path, replace, (error) ->
|
|
return callback(error) if error?
|
|
callback null, new_folder
|
|
|
|
addFolderContents: (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 project_id, parent_folder_id, entry, "#{folderPath}/#{entry}", replace, callback
|
|
else
|
|
callback()
|
|
async.parallelLimit jobs, 5, callback
|
|
|
|
addEntity: (project_id, folder_id, name, path, replace, callback = (error, entity)-> ) ->
|
|
FileTypeManager.isDirectory path, (error, isDirectory) =>
|
|
return callback(error) if error?
|
|
if isDirectory
|
|
@addFolder project_id, folder_id, name, path, replace, callback
|
|
else
|
|
FileTypeManager.isBinary name, path, (error, isBinary) =>
|
|
return callback(error) if error?
|
|
if isBinary
|
|
@addFile project_id, folder_id, name, path, replace, callback
|
|
else
|
|
@addDoc project_id, folder_id, name, path, replace, callback
|
|
|