The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/app/lib/server/methods/getMessages.js

22 lines
605 B

import { Meteor } from 'meteor/meteor';
import { check } from 'meteor/check';
import { canAccessRoom } from '../../../authorization/server';
import { Messages } from '../../../models/server';
Meteor.methods({
getMessages(messages) {
check(messages, [String]);
const msgs = Messages.findVisibleByIds(messages).fetch();
const user = { _id: Meteor.userId() };
const rids = [...new Set(msgs.map((m) => m.rid))];
if (!rids.every((_id) => canAccessRoom({ _id }, user))) {
throw new Meteor.Error('error-not-allowed', 'Not allowed', { method: 'getSingleMessage' });
}
return msgs;
},
});