ProjectEntityHandler = require "../Project/ProjectEntityHandler" ProjectDeleter = require "../Project/ProjectDeleter" logger = require "logger-sharelatex" EditorRealTimeController = require "./EditorRealTimeController" EditorController = require "./EditorController" ProjectGetter = require('../Project/ProjectGetter') UserGetter = require('../User/UserGetter') AuthorizationManager = require("../Authorization/AuthorizationManager") ProjectEditorHandler = require('../Project/ProjectEditorHandler') Metrics = require('metrics-sharelatex') CollaboratorsHandler = require("../Collaborators/CollaboratorsHandler") CollaboratorsInviteHandler = require("../Collaborators/CollaboratorsInviteHandler") PrivilegeLevels = require "../Authorization/PrivilegeLevels" TokenAccessHandler = require '../TokenAccess/TokenAccessHandler' module.exports = EditorHttpController = joinProject: (req, res, next) -> project_id = req.params.Project_id user_id = req.query.user_id if user_id == "anonymous-user" user_id = null logger.log {user_id, project_id}, "join project request" Metrics.inc "editor.join-project" EditorHttpController._buildJoinProjectView req, project_id, user_id, (error, project, privilegeLevel) -> return next(error) if error? # Hide access tokens if this is not the project owner TokenAccessHandler.protectTokens(project, privilegeLevel) res.json { project: project privilegeLevel: privilegeLevel } # Only show the 'renamed or deleted' message once if project?.deletedByExternalDataSource ProjectDeleter.unmarkAsDeletedByExternalSource project_id _buildJoinProjectView: (req, project_id, user_id, callback = (error, project, privilegeLevel) ->) -> logger.log {project_id, user_id}, "building the joinProject view" ProjectGetter.getProjectWithoutDocLines project_id, (error, project) -> return callback(error) if error? return callback(new Error("not found")) if !project? CollaboratorsHandler.getInvitedMembersWithPrivilegeLevels project, (error, members) -> return callback(error) if error? CollaboratorsHandler.getTokenMembersWithPrivilegeLevels project, (error, tokenMembers) -> return callback(error) if error? UserGetter.getUser user_id, { isAdmin: true }, (error, user) -> return callback(error) if error? token = TokenAccessHandler.getRequestToken(req, project_id) AuthorizationManager.getPrivilegeLevelForProject user_id, project_id, token, (error, privilegeLevel) -> return callback(error) if error? 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) -> return callback(error) if error? logger.log {project_id, user_id, memberCount: members.length, inviteCount: invites.length, privilegeLevel}, "returning project model view" callback(null, ProjectEditorHandler.buildProjectModelView(project, members, invites, tokenMembers), privilegeLevel ) restoreDoc: (req, res, next) -> project_id = req.params.Project_id doc_id = req.params.doc_id name = req.body.name if !name? return res.sendStatus 400 # Malformed request logger.log project_id: project_id, doc_id: doc_id, "restoring doc" ProjectEntityHandler.restoreDoc project_id, doc_id, name, (err, doc, folder_id) => return next(error) if error? EditorRealTimeController.emitToRoom(project_id, 'reciveNewDoc', folder_id, doc) res.json { doc_id: doc._id } _nameIsAcceptableLength: (name)-> return name? and name.length < 150 and name.length != 0 addDoc: (req, res, next) -> project_id = req.params.Project_id name = req.body.name parent_folder_id = req.body.parent_folder_id logger.log project_id:project_id, name:name, parent_folder_id:parent_folder_id, "getting request to add doc to project" if !EditorHttpController._nameIsAcceptableLength(name) return res.sendStatus 400 EditorController.addDoc project_id, parent_folder_id, name, [], "editor", (error, doc) -> 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 addFolder: (req, res, next) -> project_id = req.params.Project_id name = req.body.name parent_folder_id = req.body.parent_folder_id if !EditorHttpController._nameIsAcceptableLength(name) return res.sendStatus 400 EditorController.addFolder project_id, parent_folder_id, name, "editor", (error, doc) -> if error == "project_has_to_many_files" res.status(400).json(req.i18n.translate("project_has_to_many_files")) else if error?.message == 'invalid element name' res.status(400).json(req.i18n.translate('invalid_file_name')) else if error? res.status(500).json(req.i18n.translate('generic_something_went_wrong')) else res.json doc 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 if !EditorHttpController._nameIsAcceptableLength(name) return res.sendStatus 400 EditorController.renameEntity project_id, entity_id, entity_type, name, (error) -> return next(error) if error? res.sendStatus 204 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 EditorController.moveEntity project_id, entity_id, folder_id, entity_type, (error) -> return next(error) if error? res.sendStatus 204 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) deleteEntity: (req, res, next) -> project_id = req.params.Project_id entity_id = req.params.entity_id entity_type = req.params.entity_type EditorController.deleteEntity project_id, entity_id, entity_type, "editor", (error) -> return next(error) if error? res.sendStatus 204