mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 16:46:12 +01:00
fix: #10006, dont allow new rooms or adding to a room if target is blocked
This commit is contained in:
@@ -187,32 +187,35 @@ Messaging.getLatestUndeletedMessage = async (uid, roomId) => {
|
||||
};
|
||||
|
||||
Messaging.canMessageUser = async (uid, toUid) => {
|
||||
if (meta.config.disableChat || uid <= 0 || uid === toUid) {
|
||||
if (meta.config.disableChat || uid <= 0) {
|
||||
throw new Error('[[error:chat-disabled]]');
|
||||
}
|
||||
|
||||
if (parseInt(uid, 10) === parseInt(toUid, 10)) {
|
||||
throw new Error('[[error:cant-chat-with-yourself');
|
||||
throw new Error('[[error:cant-chat-with-yourself]]');
|
||||
}
|
||||
const [exists, canChat] = await Promise.all([
|
||||
user.exists(toUid),
|
||||
privileges.global.can('chat', uid),
|
||||
]);
|
||||
|
||||
const exists = await user.exists(toUid);
|
||||
if (!exists) {
|
||||
throw new Error('[[error:no-user]]');
|
||||
}
|
||||
|
||||
const canChat = await privileges.global.can('chat', uid);
|
||||
if (!canChat) {
|
||||
throw new Error('[[error:no-privileges]]');
|
||||
}
|
||||
|
||||
const results = await utils.promiseParallel({
|
||||
settings: user.getSettings(toUid),
|
||||
isAdmin: user.isAdministrator(uid),
|
||||
isModerator: user.isModeratorOfAnyCategory(uid),
|
||||
isFollowing: user.isFollowing(toUid, uid),
|
||||
});
|
||||
const [settings, isAdmin, isModerator, isFollowing, isBlocked] = await Promise.all([
|
||||
user.getSettings(toUid),
|
||||
user.isAdministrator(uid),
|
||||
user.isModeratorOfAnyCategory(uid),
|
||||
user.isFollowing(toUid, uid),
|
||||
user.blocks.is(uid, toUid),
|
||||
]);
|
||||
|
||||
if (results.settings.restrictChat && !results.isAdmin && !results.isModerator && !results.isFollowing) {
|
||||
if (isBlocked || (settings.restrictChat && !isAdmin && !isModerator && !isFollowing)) {
|
||||
throw new Error('[[error:chat-restricted]]');
|
||||
}
|
||||
|
||||
|
||||
@@ -146,19 +146,7 @@ SocketModules.chats.addUserToRoom = async function (socket, data) {
|
||||
if (!uid) {
|
||||
throw new Error('[[error:no-user]]');
|
||||
}
|
||||
if (socket.uid === parseInt(uid, 10)) {
|
||||
throw new Error('[[error:cant-chat-with-yourself]]');
|
||||
}
|
||||
const [settings, isAdminOrGlobalMod, isFollowing] = await Promise.all([
|
||||
user.getSettings(uid),
|
||||
user.isAdminOrGlobalMod(socket.uid),
|
||||
user.isFollowing(uid, socket.uid),
|
||||
]);
|
||||
|
||||
if (settings.restrictChat && !isAdminOrGlobalMod && !isFollowing) {
|
||||
throw new Error('[[error:chat-restricted]]');
|
||||
}
|
||||
|
||||
await Messaging.canMessageUser(socket.uid, uid);
|
||||
await Messaging.addUsersToRoom(socket.uid, [uid], data.roomId);
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user