2018-02-14 15:12:46 +00:00
|
|
|
AuthenticationController = require '../Authentication/AuthenticationController'
|
|
|
|
EditorController = require '../Editor/EditorController'
|
2018-03-01 10:17:12 +00:00
|
|
|
Settings = require 'settings-sharelatex'
|
|
|
|
logger = require 'logger-sharelatex'
|
2018-02-14 15:12:46 +00:00
|
|
|
|
|
|
|
module.exports = LinkedFilesController = {
|
|
|
|
Agents: {
|
|
|
|
url: require('./UrlAgent')
|
|
|
|
}
|
|
|
|
|
|
|
|
createLinkedFile: (req, res, next) ->
|
|
|
|
{project_id} = req.params
|
|
|
|
{name, provider, data, parent_folder_id} = req.body
|
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
2018-03-01 10:17:12 +00:00
|
|
|
logger.log {project_id, name, provider, data, parent_folder_id, user_id}, 'create linked file request'
|
2018-02-14 15:12:46 +00:00
|
|
|
|
|
|
|
if !LinkedFilesController.Agents.hasOwnProperty(provider)
|
|
|
|
return res.send(400)
|
2018-03-01 10:17:12 +00:00
|
|
|
unless provider in Settings.enabledLinkedFileTypes
|
|
|
|
return res.send(400)
|
2018-02-14 15:12:46 +00:00
|
|
|
Agent = LinkedFilesController.Agents[provider]
|
|
|
|
|
|
|
|
linkedFileData = Agent.sanitizeData(data)
|
|
|
|
linkedFileData.provider = provider
|
|
|
|
Agent.writeIncomingFileToDisk project_id, linkedFileData, user_id, (error, fsPath) ->
|
2018-02-16 17:13:26 +00:00
|
|
|
if error?
|
2018-03-01 11:32:05 +00:00
|
|
|
logger.error {err: error, project_id, name, linkedFileData, parent_folder_id, user_id}, 'error writing linked file to disk'
|
2018-02-16 17:13:26 +00:00
|
|
|
return Agent.handleError(error, req, res, next)
|
2018-02-14 15:12:46 +00:00
|
|
|
EditorController.upsertFile project_id, parent_folder_id, name, fsPath, linkedFileData, "upload", user_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send(204) # created
|
|
|
|
}
|