2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler = require "../Project/ProjectEntityUpdateHandler"
|
2014-11-07 12:31:47 +00:00
|
|
|
ProjectDeleter = require "../Project/ProjectDeleter"
|
2014-06-05 15:18:25 +00:00
|
|
|
logger = require "logger-sharelatex"
|
|
|
|
EditorRealTimeController = require "./EditorRealTimeController"
|
2014-06-22 11:10:42 +00:00
|
|
|
EditorController = require "./EditorController"
|
2015-02-05 16:37:37 +00:00
|
|
|
ProjectGetter = require('../Project/ProjectGetter')
|
|
|
|
UserGetter = require('../User/UserGetter')
|
2016-03-10 17:17:26 +00:00
|
|
|
AuthorizationManager = require("../Authorization/AuthorizationManager")
|
2015-02-05 16:37:37 +00:00
|
|
|
ProjectEditorHandler = require('../Project/ProjectEditorHandler')
|
2017-04-03 15:18:30 +00:00
|
|
|
Metrics = require('metrics-sharelatex')
|
2016-03-07 15:25:10 +00:00
|
|
|
CollaboratorsHandler = require("../Collaborators/CollaboratorsHandler")
|
2016-08-01 16:05:37 +00:00
|
|
|
CollaboratorsInviteHandler = require("../Collaborators/CollaboratorsInviteHandler")
|
2016-03-15 14:39:27 +00:00
|
|
|
PrivilegeLevels = require "../Authorization/PrivilegeLevels"
|
2017-10-13 10:20:57 +00:00
|
|
|
TokenAccessHandler = require '../TokenAccess/TokenAccessHandler'
|
2017-11-01 18:21:05 +00:00
|
|
|
AuthenticationController = require "../Authentication/AuthenticationController"
|
2014-06-05 15:18:25 +00:00
|
|
|
|
|
|
|
module.exports = EditorHttpController =
|
2014-11-07 12:31:47 +00:00
|
|
|
joinProject: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
user_id = req.query.user_id
|
2016-03-22 09:53:47 +00:00
|
|
|
if user_id == "anonymous-user"
|
|
|
|
user_id = null
|
2014-11-07 12:31:47 +00:00
|
|
|
logger.log {user_id, project_id}, "join project request"
|
|
|
|
Metrics.inc "editor.join-project"
|
2017-09-27 13:01:52 +00:00
|
|
|
EditorHttpController._buildJoinProjectView req, project_id, user_id, (error, project, privilegeLevel) ->
|
2014-11-07 12:31:47 +00:00
|
|
|
return next(error) if error?
|
2017-10-05 12:18:30 +00:00
|
|
|
# Hide access tokens if this is not the project owner
|
2017-10-19 15:26:01 +00:00
|
|
|
TokenAccessHandler.protectTokens(project, privilegeLevel)
|
2014-11-07 12:31:47 +00:00
|
|
|
res.json {
|
|
|
|
project: project
|
|
|
|
privilegeLevel: privilegeLevel
|
|
|
|
}
|
|
|
|
# Only show the 'renamed or deleted' message once
|
2014-12-12 10:27:14 +00:00
|
|
|
if project?.deletedByExternalDataSource
|
2014-11-07 12:31:47 +00:00
|
|
|
ProjectDeleter.unmarkAsDeletedByExternalSource project_id
|
|
|
|
|
2017-09-27 13:01:52 +00:00
|
|
|
_buildJoinProjectView: (req, project_id, user_id, callback = (error, project, privilegeLevel) ->) ->
|
2016-08-16 10:17:45 +00:00
|
|
|
logger.log {project_id, user_id}, "building the joinProject view"
|
2015-02-05 16:37:37 +00:00
|
|
|
ProjectGetter.getProjectWithoutDocLines project_id, (error, project) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
return callback(new Error("not found")) if !project?
|
2018-02-15 12:18:43 +00:00
|
|
|
CollaboratorsHandler.getInvitedMembersWithPrivilegeLevels project_id, (error, members) ->
|
2015-02-05 16:37:37 +00:00
|
|
|
return callback(error) if error?
|
2018-09-13 16:14:28 +00:00
|
|
|
token = TokenAccessHandler.getRequestToken(req, project_id)
|
|
|
|
AuthorizationManager.getPrivilegeLevelForProject user_id, project_id, token, (error, privilegeLevel) ->
|
2015-02-05 16:37:37 +00:00
|
|
|
return callback(error) if error?
|
2018-09-13 16:14:28 +00:00
|
|
|
if !privilegeLevel? or privilegeLevel == PrivilegeLevels.NONE
|
|
|
|
logger.log {project_id, user_id, privilegeLevel}, "not an acceptable privilege level, returning null"
|
|
|
|
return callback null, null, false
|
|
|
|
CollaboratorsInviteHandler.getAllInvites project_id, (error, invites) ->
|
2015-02-05 16:37:37 +00:00
|
|
|
return callback(error) if error?
|
2018-09-13 16:14:28 +00:00
|
|
|
logger.log {project_id, user_id, memberCount: members.length, inviteCount: invites.length, privilegeLevel}, "returning project model view"
|
|
|
|
callback(null,
|
|
|
|
ProjectEditorHandler.buildProjectModelView(project, members, invites),
|
|
|
|
privilegeLevel
|
|
|
|
)
|
2015-02-05 16:37:37 +00:00
|
|
|
|
2015-03-02 12:46:02 +00:00
|
|
|
_nameIsAcceptableLength: (name)->
|
|
|
|
return name? and name.length < 150 and name.length != 0
|
|
|
|
|
2014-06-22 11:10:42 +00:00
|
|
|
addDoc: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
name = req.body.name
|
|
|
|
parent_folder_id = req.body.parent_folder_id
|
2017-11-23 15:40:14 +00:00
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
2016-02-29 19:01:46 +00:00
|
|
|
logger.log project_id:project_id, name:name, parent_folder_id:parent_folder_id, "getting request to add doc to project"
|
2015-03-02 12:46:02 +00:00
|
|
|
if !EditorHttpController._nameIsAcceptableLength(name)
|
2015-07-08 15:56:38 +00:00
|
|
|
return res.sendStatus 400
|
2017-11-23 15:40:14 +00:00
|
|
|
EditorController.addDoc project_id, parent_folder_id, name, [], "editor", user_id, (error, doc) ->
|
2016-02-29 13:05:17 +00:00
|
|
|
if error == "project_has_to_many_files"
|
|
|
|
res.status(400).json(req.i18n.translate("project_has_to_many_files"))
|
|
|
|
else if error?
|
|
|
|
next(error)
|
|
|
|
else
|
|
|
|
res.json doc
|
2014-06-22 13:39:38 +00:00
|
|
|
|
|
|
|
addFolder: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
name = req.body.name
|
|
|
|
parent_folder_id = req.body.parent_folder_id
|
2015-03-02 12:46:02 +00:00
|
|
|
if !EditorHttpController._nameIsAcceptableLength(name)
|
2015-07-08 15:56:38 +00:00
|
|
|
return res.sendStatus 400
|
2014-10-16 10:26:57 +00:00
|
|
|
EditorController.addFolder project_id, parent_folder_id, name, "editor", (error, doc) ->
|
2016-02-29 13:05:17 +00:00
|
|
|
if error == "project_has_to_many_files"
|
|
|
|
res.status(400).json(req.i18n.translate("project_has_to_many_files"))
|
2017-03-31 09:46:13 +00:00
|
|
|
else if error?.message == 'invalid element name'
|
2017-03-31 09:31:03 +00:00
|
|
|
res.status(400).json(req.i18n.translate('invalid_file_name'))
|
2016-02-29 13:05:17 +00:00
|
|
|
else if error?
|
2018-01-17 12:11:02 +00:00
|
|
|
next(error)
|
2016-02-29 13:05:17 +00:00
|
|
|
else
|
|
|
|
res.json doc
|
2014-06-22 19:08:56 +00:00
|
|
|
|
|
|
|
renameEntity: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
entity_id = req.params.entity_id
|
|
|
|
entity_type = req.params.entity_type
|
|
|
|
name = req.body.name
|
2015-03-02 12:46:02 +00:00
|
|
|
if !EditorHttpController._nameIsAcceptableLength(name)
|
2015-07-08 15:56:38 +00:00
|
|
|
return res.sendStatus 400
|
2017-11-23 15:40:14 +00:00
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
2017-11-01 18:21:05 +00:00
|
|
|
EditorController.renameEntity project_id, entity_id, entity_type, name, user_id, (error) ->
|
2014-06-22 19:08:56 +00:00
|
|
|
return next(error) if error?
|
2015-07-08 15:56:38 +00:00
|
|
|
res.sendStatus 204
|
2014-06-22 19:08:56 +00:00
|
|
|
|
|
|
|
moveEntity: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
entity_id = req.params.entity_id
|
|
|
|
entity_type = req.params.entity_type
|
|
|
|
folder_id = req.body.folder_id
|
2017-11-02 09:44:23 +00:00
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
|
|
EditorController.moveEntity project_id, entity_id, folder_id, entity_type, user_id, (error) ->
|
2018-01-31 10:26:31 +00:00
|
|
|
return next(error) if error?
|
|
|
|
res.sendStatus 204
|
2014-06-22 19:08:56 +00:00
|
|
|
|
2014-10-24 11:01:35 +00:00
|
|
|
deleteDoc: (req, res, next)->
|
|
|
|
req.params.entity_type = "doc"
|
|
|
|
EditorHttpController.deleteEntity(req, res, next)
|
|
|
|
|
|
|
|
deleteFile: (req, res, next)->
|
|
|
|
req.params.entity_type = "file"
|
|
|
|
EditorHttpController.deleteEntity(req, res, next)
|
|
|
|
|
|
|
|
deleteFolder: (req, res, next)->
|
|
|
|
req.params.entity_type = "folder"
|
|
|
|
EditorHttpController.deleteEntity(req, res, next)
|
|
|
|
|
2014-06-22 19:08:56 +00:00
|
|
|
deleteEntity: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
entity_id = req.params.entity_id
|
|
|
|
entity_type = req.params.entity_type
|
2017-12-15 10:53:38 +00:00
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
|
|
EditorController.deleteEntity project_id, entity_id, entity_type, "editor", user_id, (error) ->
|
2014-06-22 19:08:56 +00:00
|
|
|
return next(error) if error?
|
2015-07-08 15:56:38 +00:00
|
|
|
res.sendStatus 204
|