2014-08-15 09:50:36 +00:00
|
|
|
logger = require "logger-sharelatex"
|
2015-11-19 16:00:12 +00:00
|
|
|
metrics = require "metrics-sharelatex"
|
2014-08-15 09:50:36 +00:00
|
|
|
MessageManager = require "./MessageManager"
|
|
|
|
MessageFormatter = require "./MessageFormatter"
|
2016-12-16 16:52:50 +00:00
|
|
|
ThreadManager = require "../Threads/ThreadManager"
|
|
|
|
{ObjectId} = require "../../mongojs"
|
2014-08-15 09:50:36 +00:00
|
|
|
|
|
|
|
module.exports = MessageHttpController =
|
|
|
|
DEFAULT_MESSAGE_LIMIT: 50
|
2017-02-14 10:43:50 +00:00
|
|
|
MAX_MESSAGE_LENGTH: 10 * 1024 # 10kb, about 1,500 words
|
2016-12-16 16:52:50 +00:00
|
|
|
|
|
|
|
getGlobalMessages: (req, res, next) ->
|
|
|
|
MessageHttpController._getMessages(ThreadManager.GLOBAL_THREAD, req, res, next)
|
2014-08-15 09:50:36 +00:00
|
|
|
|
2016-12-16 16:52:50 +00:00
|
|
|
sendGlobalMessage: (req, res, next) ->
|
|
|
|
MessageHttpController._sendMessage(ThreadManager.GLOBAL_THREAD, req, res, next)
|
|
|
|
|
|
|
|
sendThreadMessage: (req, res, next) ->
|
|
|
|
MessageHttpController._sendMessage(req.params.thread_id, req, res, next)
|
|
|
|
|
|
|
|
getAllThreads: (req, res, next) ->
|
2014-08-15 09:50:36 +00:00
|
|
|
{project_id} = req.params
|
2016-12-16 16:52:50 +00:00
|
|
|
logger.log {project_id}, "getting all threads"
|
|
|
|
ThreadManager.findAllThreadRooms project_id, (error, rooms) ->
|
|
|
|
return next(error) if error?
|
|
|
|
room_ids = rooms.map (r) -> r._id
|
|
|
|
MessageManager.findAllMessagesInRooms room_ids, (error, messages) ->
|
|
|
|
return next(error) if error?
|
2017-01-06 13:14:47 +00:00
|
|
|
threads = MessageFormatter.groupMessagesByThreads rooms, messages
|
|
|
|
res.json threads
|
2017-01-04 13:51:08 +00:00
|
|
|
|
|
|
|
resolveThread: (req, res, next) ->
|
|
|
|
{project_id, thread_id} = req.params
|
|
|
|
{user_id} = req.body
|
|
|
|
logger.log {user_id, project_id, thread_id}, "marking thread as resolved"
|
|
|
|
ThreadManager.resolveThread project_id, thread_id, user_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send 204 # No content
|
|
|
|
|
|
|
|
reopenThread: (req, res, next) ->
|
|
|
|
{project_id, thread_id} = req.params
|
|
|
|
logger.log {project_id, thread_id}, "reopening thread"
|
|
|
|
ThreadManager.reopenThread project_id, thread_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send 204 # No content
|
2017-01-24 14:44:32 +00:00
|
|
|
|
|
|
|
deleteThread: (req, res, next) ->
|
|
|
|
{project_id, thread_id} = req.params
|
|
|
|
logger.log {project_id, thread_id}, "deleting thread"
|
|
|
|
ThreadManager.deleteThread project_id, thread_id, (error, room_id) ->
|
|
|
|
return next(error) if error?
|
|
|
|
MessageManager.deleteAllMessagesInRoom room_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send 204 # No content
|
|
|
|
|
|
|
|
editMessage: (req, res, next) ->
|
|
|
|
{content} = req?.body
|
|
|
|
{project_id, thread_id, message_id} = req.params
|
|
|
|
logger.log {project_id, thread_id, message_id, content}, "editing message"
|
|
|
|
ThreadManager.findOrCreateThread project_id, thread_id, (error, room) ->
|
|
|
|
return next(error) if error?
|
|
|
|
MessageManager.updateMessage room._id, message_id, content, Date.now(), (error) ->
|
|
|
|
return next(error) if error?
|
2017-01-25 13:47:45 +00:00
|
|
|
res.send(204)
|
2017-01-24 14:44:32 +00:00
|
|
|
|
|
|
|
deleteMessage: (req, res, next) ->
|
|
|
|
{project_id, thread_id, message_id} = req.params
|
|
|
|
logger.log {project_id, thread_id, message_id}, "deleting message"
|
|
|
|
ThreadManager.findOrCreateThread project_id, thread_id, (error, room) ->
|
|
|
|
return next(error) if error?
|
|
|
|
MessageManager.deleteMessage room._id, message_id, (error, message) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send(204)
|
2014-08-15 09:50:36 +00:00
|
|
|
|
2016-12-16 16:52:50 +00:00
|
|
|
_sendMessage: (client_thread_id, req, res, next) ->
|
|
|
|
{user_id, content} = req?.body
|
|
|
|
{project_id} = req.params
|
|
|
|
if !ObjectId.isValid(user_id)
|
|
|
|
return res.send(400, "Invalid user_id")
|
2017-02-14 10:43:50 +00:00
|
|
|
if !content?
|
|
|
|
return res.send(400, "No content provided")
|
|
|
|
if content.length > @MAX_MESSAGE_LENGTH
|
|
|
|
return res.send(400, "Content too long (> #{@MAX_MESSAGE_LENGTH} bytes)")
|
2016-12-16 16:52:50 +00:00
|
|
|
logger.log {client_thread_id, project_id, user_id, content}, "new message received"
|
|
|
|
ThreadManager.findOrCreateThread project_id, client_thread_id, (error, thread) ->
|
2014-08-15 09:50:36 +00:00
|
|
|
return next(error) if error?
|
2016-12-16 16:52:50 +00:00
|
|
|
MessageManager.createMessage thread._id, user_id, content, Date.now(), (error, message) ->
|
|
|
|
return next(error) if error?
|
2017-01-06 13:14:47 +00:00
|
|
|
message = MessageFormatter.formatMessageForClientSide(message)
|
|
|
|
message.room_id = project_id
|
|
|
|
res.send(201, message)
|
2014-08-15 09:50:36 +00:00
|
|
|
|
2016-12-16 16:52:50 +00:00
|
|
|
_getMessages: (client_thread_id, req, res, next) ->
|
2014-08-15 09:50:36 +00:00
|
|
|
{project_id} = req.params
|
|
|
|
if req.query?.before?
|
2016-12-16 16:52:50 +00:00
|
|
|
before = parseInt(req.query.before, 10)
|
|
|
|
else
|
|
|
|
before = null
|
2014-08-15 09:50:36 +00:00
|
|
|
if req.query?.limit?
|
|
|
|
limit = parseInt(req.query.limit, 10)
|
|
|
|
else
|
|
|
|
limit = MessageHttpController.DEFAULT_MESSAGE_LIMIT
|
2016-12-16 16:52:50 +00:00
|
|
|
logger.log {limit, before, project_id, client_thread_id}, "get message request received"
|
|
|
|
ThreadManager.findOrCreateThread project_id, client_thread_id, (error, thread) ->
|
2014-08-15 09:50:36 +00:00
|
|
|
return next(error) if error?
|
2016-12-16 16:52:50 +00:00
|
|
|
thread_object_id = thread._id
|
|
|
|
logger.log {limit, before, project_id, client_thread_id, thread_object_id}, "found or created thread"
|
|
|
|
MessageManager.getMessages thread_object_id, limit, before, (error, messages) ->
|
|
|
|
return next(error) if error?
|
2017-01-06 13:14:47 +00:00
|
|
|
messages = MessageFormatter.formatMessagesForClientSide messages
|
|
|
|
logger.log {project_id, messages}, "got messages"
|
|
|
|
res.send 200, messages
|