2016-12-16 11:42:41 -05:00
|
|
|
ChatApiHandler = require("../Chat/ChatApiHandler")
|
|
|
|
EditorRealTimeController = require("../Editor/EditorRealTimeController")
|
|
|
|
logger = require("logger-sharelatex")
|
|
|
|
AuthenticationController = require('../Authentication/AuthenticationController')
|
2017-01-06 07:41:58 -05:00
|
|
|
UserInfoManager = require('../User/UserInfoManager')
|
|
|
|
UserInfoController = require('../User/UserInfoController')
|
|
|
|
async = require "async"
|
2016-12-16 11:42:41 -05:00
|
|
|
|
|
|
|
module.exports = CommentsController =
|
|
|
|
sendComment: (req, res, next) ->
|
|
|
|
{project_id, thread_id} = req.params
|
|
|
|
content = req.body.content
|
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
|
|
if !user_id?
|
|
|
|
err = new Error('no logged-in user')
|
|
|
|
return next(err)
|
|
|
|
logger.log {project_id, thread_id, user_id, content}, "sending comment"
|
|
|
|
ChatApiHandler.sendComment project_id, thread_id, user_id, content, (err, comment) ->
|
|
|
|
return next(err) if err?
|
2017-01-06 07:41:58 -05:00
|
|
|
UserInfoManager.getPersonalInfo comment.user_id, (err, user) ->
|
|
|
|
return next(err) if err?
|
|
|
|
comment.user = UserInfoController.formatPersonalInfo(user)
|
|
|
|
EditorRealTimeController.emitToRoom project_id, "new-comment", thread_id, comment, (err) ->
|
|
|
|
res.send 204
|
2016-12-16 11:42:41 -05:00
|
|
|
|
|
|
|
getThreads: (req, res, next) ->
|
|
|
|
{project_id} = req.params
|
|
|
|
logger.log {project_id}, "getting comment threads for project"
|
|
|
|
ChatApiHandler.getThreads project_id, (err, threads) ->
|
|
|
|
return next(err) if err?
|
2017-01-06 07:41:58 -05:00
|
|
|
CommentsController._injectUserInfoIntoThreads threads, (error, threads) ->
|
|
|
|
return next(err) if err?
|
|
|
|
res.json threads
|
|
|
|
|
2017-01-04 10:26:02 -05:00
|
|
|
resolveThread: (req, res, next) ->
|
|
|
|
{project_id, thread_id} = req.params
|
|
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
|
|
logger.log {project_id, thread_id, user_id}, "resolving comment thread"
|
2017-01-06 07:41:58 -05:00
|
|
|
ChatApiHandler.resolveThread project_id, thread_id, user_id, (err) ->
|
2017-01-04 10:26:02 -05:00
|
|
|
return next(err) if err?
|
2017-01-06 07:41:58 -05:00
|
|
|
UserInfoManager.getPersonalInfo user_id, (err, user) ->
|
|
|
|
return next(err) if err?
|
|
|
|
EditorRealTimeController.emitToRoom project_id, "resolve-thread", thread_id, UserInfoController.formatPersonalInfo(user), (err)->
|
|
|
|
res.send 204
|
|
|
|
|
2017-01-04 10:26:02 -05:00
|
|
|
reopenThread: (req, res, next) ->
|
|
|
|
{project_id, thread_id} = req.params
|
|
|
|
logger.log {project_id, thread_id}, "reopening comment thread"
|
|
|
|
ChatApiHandler.reopenThread project_id, thread_id, (err, threads) ->
|
|
|
|
return next(err) if err?
|
|
|
|
EditorRealTimeController.emitToRoom project_id, "reopen-thread", thread_id, (err)->
|
2017-01-06 07:41:58 -05:00
|
|
|
res.send 204
|
|
|
|
|
|
|
|
_injectUserInfoIntoThreads: (threads, callback = (error, threads) ->) ->
|
|
|
|
userCache = {}
|
|
|
|
getUserDetails = (user_id, callback = (error, user) ->) ->
|
|
|
|
return callback(null, userCache[user_id]) if userCache[user_id]?
|
|
|
|
UserInfoManager.getPersonalInfo user_id, (err, user) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
user = UserInfoController.formatPersonalInfo user
|
|
|
|
userCache[user_id] = user
|
|
|
|
callback null, user
|
|
|
|
|
|
|
|
jobs = []
|
2017-01-09 11:25:06 -05:00
|
|
|
for thread_id, thread of threads
|
2017-01-06 07:41:58 -05:00
|
|
|
do (thread) ->
|
|
|
|
if thread.resolved
|
|
|
|
jobs.push (cb) ->
|
|
|
|
getUserDetails thread.resolved_by_user_id, (error, user) ->
|
|
|
|
cb(error) if error?
|
|
|
|
thread.resolved_by_user = user
|
|
|
|
cb()
|
|
|
|
for message in thread.messages
|
|
|
|
do (message) ->
|
|
|
|
jobs.push (cb) ->
|
|
|
|
getUserDetails message.user_id, (error, user) ->
|
|
|
|
cb(error) if error?
|
|
|
|
message.user = user
|
|
|
|
cb()
|
|
|
|
|
|
|
|
async.series jobs, (error) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
return callback null, threads
|