mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-31 21:21:03 -04:00
2ff1cf43d6
Upgrade and configure ESLint GitOrigin-RevId: ad5aeaf85e72c847a125ff3a9db99a12855e38aa
136 lines
3.9 KiB
JavaScript
136 lines
3.9 KiB
JavaScript
/* eslint-disable
|
|
camelcase,
|
|
node/handle-callback-err,
|
|
max-len,
|
|
no-undef,
|
|
no-unused-vars,
|
|
*/
|
|
// TODO: This file was created by bulk-decaffeinate.
|
|
// Fix any style issues and re-enable lint.
|
|
/*
|
|
* decaffeinate suggestions:
|
|
* DS101: Remove unnecessary use of Array.from
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* DS207: Consider shorter variations of null checks
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
let ChatController
|
|
const ChatApiHandler = require('./ChatApiHandler')
|
|
const EditorRealTimeController = require('../Editor/EditorRealTimeController')
|
|
const logger = require('logger-sharelatex')
|
|
const AuthenticationController = require('../Authentication/AuthenticationController')
|
|
const UserInfoManager = require('../User/UserInfoManager')
|
|
const UserInfoController = require('../User/UserInfoController')
|
|
const async = require('async')
|
|
|
|
module.exports = ChatController = {
|
|
sendMessage(req, res, next) {
|
|
const { project_id } = req.params
|
|
const { content } = req.body
|
|
const user_id = AuthenticationController.getLoggedInUserId(req)
|
|
if (user_id == null) {
|
|
const err = new Error('no logged-in user')
|
|
return next(err)
|
|
}
|
|
return ChatApiHandler.sendGlobalMessage(
|
|
project_id,
|
|
user_id,
|
|
content,
|
|
function(err, message) {
|
|
if (err != null) {
|
|
return next(err)
|
|
}
|
|
return UserInfoManager.getPersonalInfo(message.user_id, function(
|
|
err,
|
|
user
|
|
) {
|
|
if (err != null) {
|
|
return next(err)
|
|
}
|
|
message.user = UserInfoController.formatPersonalInfo(user)
|
|
EditorRealTimeController.emitToRoom(
|
|
project_id,
|
|
'new-chat-message',
|
|
message
|
|
)
|
|
return res.sendStatus(204)
|
|
})
|
|
}
|
|
)
|
|
},
|
|
|
|
getMessages(req, res, next) {
|
|
const { project_id } = req.params
|
|
const { query } = req
|
|
return ChatApiHandler.getGlobalMessages(
|
|
project_id,
|
|
query.limit,
|
|
query.before,
|
|
function(err, messages) {
|
|
if (err != null) {
|
|
return next(err)
|
|
}
|
|
return ChatController._injectUserInfoIntoThreads(
|
|
{ global: { messages } },
|
|
function(err) {
|
|
if (err != null) {
|
|
return next(err)
|
|
}
|
|
return res.json(messages)
|
|
}
|
|
)
|
|
}
|
|
)
|
|
},
|
|
|
|
_injectUserInfoIntoThreads(threads, callback) {
|
|
// There will be a lot of repitition of user_ids, so first build a list
|
|
// of unique ones to perform db look ups on, then use these to populate the
|
|
// user fields
|
|
let message, thread, thread_id, user_id
|
|
if (callback == null) {
|
|
callback = function(error, threads) {}
|
|
}
|
|
const user_ids = {}
|
|
for (thread_id in threads) {
|
|
thread = threads[thread_id]
|
|
if (thread.resolved) {
|
|
user_ids[thread.resolved_by_user_id] = true
|
|
}
|
|
for (message of Array.from(thread.messages)) {
|
|
user_ids[message.user_id] = true
|
|
}
|
|
}
|
|
|
|
const jobs = []
|
|
const users = {}
|
|
for (user_id in user_ids) {
|
|
const _ = user_ids[user_id]
|
|
;(user_id =>
|
|
jobs.push(cb =>
|
|
UserInfoManager.getPersonalInfo(user_id, function(error, user) {
|
|
if (error != null) return cb(error)
|
|
user = UserInfoController.formatPersonalInfo(user)
|
|
users[user_id] = user
|
|
cb()
|
|
})
|
|
))(user_id)
|
|
}
|
|
|
|
return async.series(jobs, function(error) {
|
|
if (error != null) {
|
|
return callback(error)
|
|
}
|
|
for (thread_id in threads) {
|
|
thread = threads[thread_id]
|
|
if (thread.resolved) {
|
|
thread.resolved_by_user = users[thread.resolved_by_user_id]
|
|
}
|
|
for (message of Array.from(thread.messages)) {
|
|
message.user = users[message.user_id]
|
|
}
|
|
}
|
|
return callback(null, threads)
|
|
})
|
|
}
|
|
}
|