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/packages/rocketchat-lib/server/functions/createRoom.js

123 lines
3.4 KiB

import { Meteor } from 'meteor/meteor';
import { Users, Rooms, Subscriptions } from 'meteor/rocketchat:models';
import { callbacks } from 'meteor/rocketchat:callbacks';
import { hasPermission, addUserRoles } from 'meteor/rocketchat:authorization';
import { getValidRoomName } from 'meteor/rocketchat:utils';
import { Apps } from 'meteor/rocketchat:apps';
import _ from 'underscore';
import s from 'underscore.string';
export const createRoom = function(type, name, owner, members, readOnly, extraData = {}) {
name = s.trim(name);
owner = s.trim(owner);
members = [].concat(members);
if (!name) {
throw new Meteor.Error('error-invalid-name', 'Invalid name', { function: 'RocketChat.createRoom' });
}
owner = Users.findOneByUsername(owner, { fields: { username: 1 } });
if (!owner) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', { function: 'RocketChat.createRoom' });
}
if (!_.contains(members, owner.username)) {
members.push(owner.username);
}
if (extraData.broadcast) {
readOnly = true;
delete extraData.reactWhenReadOnly;
}
const now = new Date();
let room = Object.assign({
name: getValidRoomName(name),
fname: name,
t: type,
msgs: 0,
usersCount: 0,
u: {
_id: owner._id,
username: owner.username,
},
}, extraData, {
ts: now,
ro: readOnly === true,
sysMes: readOnly !== true,
});
if (type === 'd') {
room.usernames = members;
}
if (Apps && Apps.isLoaded()) {
const prevent = Promise.await(Apps.getBridges().getListenerBridge().roomEvent('IPreRoomCreatePrevent', room));
if (prevent) {
throw new Meteor.Error('error-app-prevented-creation', 'A Rocket.Chat App prevented the room creation.');
}
let result;
result = Promise.await(Apps.getBridges().getListenerBridge().roomEvent('IPreRoomCreateExtend', room));
result = Promise.await(Apps.getBridges().getListenerBridge().roomEvent('IPreRoomCreateModify', result));
if (typeof result === 'object') {
room = Object.assign(room, result);
}
}
if (type === 'c') {
callbacks.run('beforeCreateChannel', owner, room);
}
room = Rooms.createWithFullRoomData(room);
for (const username of members) {
const member = Users.findOneByUsername(username, { fields: { username: 1, 'settings.preferences': 1 } });
const isTheOwner = username === owner.username;
if (!member) {
continue;
}
// make all room members (Except the owner) muted by default, unless they have the post-readonly permission
if (readOnly === true && !hasPermission(member._id, 'post-readonly') && !isTheOwner) {
Rooms.muteUsernameByRoomId(room._id, username);
}
const extra = { open: true };
if (username === owner.username) {
extra.ls = now;
}
Subscriptions.createWithRoomAndUser(room, member, extra);
}
addUserRoles(owner._id, ['owner'], room._id);
if (type === 'c') {
Meteor.defer(() => {
callbacks.run('afterCreateChannel', owner, room);
});
} else if (type === 'p') {
Meteor.defer(() => {
callbacks.run('afterCreatePrivateGroup', owner, room);
});
}
Meteor.defer(() => {
callbacks.run('afterCreateRoom', owner, room);
});
if (Apps && Apps.isLoaded()) {
// This returns a promise, but it won't mutate anything about the message
// so, we don't really care if it is successful or fails
Apps.getBridges().getListenerBridge().roomEvent('IPostRoomCreate', room);
}
return {
rid: room._id,
name: room.name,
};
};
RocketChat.createRoom = createRoom;