2018-12-20 14:13:53 -05:00
|
|
|
/*
|
|
|
|
* decaffeinate suggestions:
|
|
|
|
* 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 MessageManager;
|
|
|
|
const mongojs = require("../../mongojs");
|
|
|
|
const { db } = mongojs;
|
|
|
|
const { ObjectId } = mongojs;
|
|
|
|
const async = require("async");
|
|
|
|
const metrics = require('metrics-sharelatex');
|
|
|
|
const logger = require('logger-sharelatex');
|
2014-08-15 05:50:36 -04:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
module.exports = (MessageManager = {
|
|
|
|
createMessage(room_id, user_id, content, timestamp, callback) {
|
|
|
|
if (callback == null) { callback = function(error, message) {}; }
|
|
|
|
let newMessageOpts = {
|
|
|
|
content,
|
|
|
|
room_id,
|
|
|
|
user_id,
|
|
|
|
timestamp
|
|
|
|
};
|
|
|
|
newMessageOpts = this._ensureIdsAreObjectIds(newMessageOpts);
|
|
|
|
return db.messages.save(newMessageOpts, callback);
|
|
|
|
},
|
2014-08-15 05:50:36 -04:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
getMessages(room_id, limit, before, callback) {
|
|
|
|
if (callback == null) { callback = function(error, messages) {}; }
|
|
|
|
let query =
|
|
|
|
{room_id};
|
|
|
|
if (before != null) {
|
|
|
|
query.timestamp = { $lt: before };
|
|
|
|
}
|
|
|
|
query = this._ensureIdsAreObjectIds(query);
|
|
|
|
const cursor = db.messages.find(query).sort({ timestamp: -1 }).limit(limit);
|
|
|
|
return cursor.toArray(callback);
|
|
|
|
},
|
2016-12-16 11:52:50 -05:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
findAllMessagesInRooms(room_ids, callback) {
|
|
|
|
if (callback == null) { callback = function(error, messages) {}; }
|
|
|
|
return db.messages.find({
|
2016-12-16 11:52:50 -05:00
|
|
|
room_id: { $in: room_ids }
|
2018-12-20 14:13:53 -05:00
|
|
|
}, callback);
|
|
|
|
},
|
2014-08-15 05:50:36 -04:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
deleteAllMessagesInRoom(room_id, callback) {
|
|
|
|
if (callback == null) { callback = function(error) {}; }
|
|
|
|
return db.messages.remove({
|
|
|
|
room_id
|
|
|
|
}, callback);
|
|
|
|
},
|
2017-01-24 09:44:32 -05:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
updateMessage(room_id, message_id, content, timestamp, callback) {
|
|
|
|
if (callback == null) { callback = function(error, message) {}; }
|
|
|
|
const query = this._ensureIdsAreObjectIds({
|
|
|
|
_id: message_id,
|
|
|
|
room_id
|
|
|
|
});
|
|
|
|
return db.messages.update(query, {
|
|
|
|
$set: {
|
|
|
|
content,
|
2017-01-24 09:44:32 -05:00
|
|
|
edited_at: timestamp
|
2018-12-20 14:13:53 -05:00
|
|
|
}
|
|
|
|
}, function(error) {
|
|
|
|
if (error != null) { return callback(error); }
|
|
|
|
return callback();
|
|
|
|
});
|
|
|
|
},
|
2017-01-24 09:44:32 -05:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
deleteMessage(room_id, message_id, callback) {
|
|
|
|
if (callback == null) { callback = function(error) {}; }
|
|
|
|
const query = this._ensureIdsAreObjectIds({
|
|
|
|
_id: message_id,
|
|
|
|
room_id
|
|
|
|
});
|
|
|
|
return db.messages.remove(query, function(error) {
|
|
|
|
if (error != null) { return callback(error); }
|
|
|
|
return callback();
|
|
|
|
});
|
|
|
|
},
|
2017-01-24 09:44:32 -05:00
|
|
|
|
2018-12-20 14:13:53 -05:00
|
|
|
_ensureIdsAreObjectIds(query) {
|
|
|
|
if ((query.user_id != null) && !(query.user_id instanceof ObjectId)) {
|
|
|
|
query.user_id = ObjectId(query.user_id);
|
|
|
|
}
|
|
|
|
if ((query.room_id != null) && !(query.room_id instanceof ObjectId)) {
|
|
|
|
query.room_id = ObjectId(query.room_id);
|
|
|
|
}
|
|
|
|
if ((query._id != null) && !(query._id instanceof ObjectId)) {
|
|
|
|
query._id = ObjectId(query._id);
|
|
|
|
}
|
|
|
|
return query;
|
|
|
|
}
|
|
|
|
});
|
2017-03-16 12:08:57 -04:00
|
|
|
|
2017-03-17 11:16:38 -04:00
|
|
|
|
|
|
|
[
|
|
|
|
'createMessage',
|
|
|
|
'getMessages',
|
|
|
|
'findAllMessagesInRooms',
|
|
|
|
'updateMessage',
|
|
|
|
'deleteMessage'
|
2018-12-20 14:13:53 -05:00
|
|
|
].map(method => metrics.timeAsyncMethod(MessageManager, method, 'mongo.MessageManager', logger));
|