Skip to content

Commit

Permalink
chore: Move bad words filter callback to service (#30241)
Browse files Browse the repository at this point in the history
  • Loading branch information
sampaiodiego authored and MartinSchoeler committed Sep 26, 2023
1 parent fbc73a1 commit 7b34131
Show file tree
Hide file tree
Showing 17 changed files with 180 additions and 179 deletions.
5 changes: 2 additions & 3 deletions apps/meteor/app/api/server/v1/channels.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Team } from '@rocket.chat/core-services';
import { Team, Room } from '@rocket.chat/core-services';
import type { IRoom, ISubscription, IUser, RoomType } from '@rocket.chat/core-typings';
import { Integrations, Messages, Rooms, Subscriptions, Uploads, Users } from '@rocket.chat/models';
import {
Expand Down Expand Up @@ -31,7 +31,6 @@ import { saveRoomSettings } from '../../../channel-settings/server/methods/saveR
import { mountIntegrationQueryBasedOnPermissions } from '../../../integrations/server/lib/mountQueriesBasedOnPermission';
import { addUsersToRoomMethod } from '../../../lib/server/methods/addUsersToRoom';
import { createChannelMethod } from '../../../lib/server/methods/createChannel';
import { joinRoomMethod } from '../../../lib/server/methods/joinRoom';
import { leaveRoomMethod } from '../../../lib/server/methods/leaveRoom';
import { settings } from '../../../settings/server';
import { normalizeMessagesForUser } from '../../../utils/server/lib/normalizeMessagesForUser';
Expand Down Expand Up @@ -209,7 +208,7 @@ API.v1.addRoute(
const { joinCode, ...params } = this.bodyParams;
const findResult = await findChannelByIdOrName({ params });

await joinRoomMethod(this.userId, findResult._id, joinCode);
await Room.join({ room: findResult, user: this.user, joinCode });

return API.v1.success({
channel: await findChannelByIdOrName({ params, userId: this.userId }),
Expand Down
29 changes: 0 additions & 29 deletions apps/meteor/app/discussion/server/hooks/joinDiscussionOnMessage.ts

This file was deleted.

5 changes: 0 additions & 5 deletions apps/meteor/app/lib/server/functions/notifications/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import { escapeRegExp } from '@rocket.chat/string-helpers';
import { callbacks } from '../../../../../lib/callbacks';
import { i18n } from '../../../../../server/lib/i18n';
import { settings } from '../../../../settings/server';
import { joinRoomMethod } from '../../methods/joinRoom';

/**
* This function returns a string ready to be shown in the notification
Expand Down Expand Up @@ -66,7 +65,3 @@ export function messageContainsHighlight(message: IMessage, highlights: string[]
return regexp.test(message.msg);
});
}

export async function callJoinRoom(userId: string, rid: string): Promise<void> {
await joinRoomMethod(userId, rid);
}
3 changes: 3 additions & 0 deletions apps/meteor/app/lib/server/functions/sendMessage.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { Message } from '@rocket.chat/core-services';
import { Messages } from '@rocket.chat/models';
import { Match, check } from 'meteor/check';

Expand Down Expand Up @@ -247,6 +248,8 @@ export const sendMessage = async function (user, message, room, upsert = false,

parseUrlsInMessage(message, previewUrls);

message = await Message.beforeSave({ message, room, user });

message = await callbacks.run('beforeSaveMessage', message, room);
if (message) {
if (message.t === 'otr') {
Expand Down
15 changes: 9 additions & 6 deletions apps/meteor/app/lib/server/functions/updateMessage.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { Message } from '@rocket.chat/core-services';
import type { IEditedMessage, IMessage, IUser, AtLeast } from '@rocket.chat/core-typings';
import { Messages, Rooms } from '@rocket.chat/models';
import { Meteor } from 'meteor/meteor';
Expand Down Expand Up @@ -48,6 +49,14 @@ export const updateMessage = async function (

parseUrlsInMessage(message, previewUrls);

const room = await Rooms.findOneById(message.rid);
if (!room) {
return;
}

// TODO remove type cast
message = await Message.beforeSave({ message: message as IMessage, room, user });

message = await callbacks.run('beforeSaveMessage', message);

const { _id, ...editedMessage } = message;
Expand All @@ -67,12 +76,6 @@ export const updateMessage = async function (
},
);

const room = await Rooms.findOneById(message.rid);

if (!room) {
return;
}

if (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
Expand Down
1 change: 0 additions & 1 deletion apps/meteor/app/lib/server/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ import './methods/deleteUserOwnAccount';
import './methods/executeSlashCommandPreview';
import './startup/filterATAllTag';
import './startup/filterATHereTag';
import './methods/filterBadWords';
import './methods/getChannelHistory';
import './methods/getRoomJoinCode';
import './methods/getRoomRoles';
Expand Down
10 changes: 3 additions & 7 deletions apps/meteor/app/lib/server/lib/sendNotificationsOnMessage.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { Room } from '@rocket.chat/core-services';
import { Subscriptions, Users } from '@rocket.chat/models';
import { Meteor } from 'meteor/meteor';
import moment from 'moment';
Expand All @@ -7,12 +8,7 @@ import { roomCoordinator } from '../../../../server/lib/rooms/roomCoordinator';
import { hasPermissionAsync } from '../../../authorization/server/functions/hasPermission';
import { Notification } from '../../../notification-queue/server/NotificationQueue';
import { settings } from '../../../settings/server';
import {
callJoinRoom,
messageContainsHighlight,
parseMessageTextPerUser,
replaceMentionedUsernamesWithFullNames,
} from '../functions/notifications';
import { messageContainsHighlight, parseMessageTextPerUser, replaceMentionedUsernamesWithFullNames } from '../functions/notifications';
import { notifyDesktopUser, shouldNotifyDesktop } from '../functions/notifications/desktop';
import { getEmailData, shouldNotifyEmail } from '../functions/notifications/email';
import { getPushData, shouldNotifyMobile } from '../functions/notifications/mobile';
Expand Down Expand Up @@ -365,7 +361,7 @@ export async function sendAllNotifications(message, room) {

const users = await Promise.all(
mentions.map(async (userId) => {
await callJoinRoom(userId, room._id);
await Room.join({ room, user: { _id: userId } });

return userId;
}),
Expand Down
65 changes: 0 additions & 65 deletions apps/meteor/app/lib/server/methods/filterBadWords.ts

This file was deleted.

52 changes: 10 additions & 42 deletions apps/meteor/app/lib/server/methods/joinRoom.ts
Original file line number Diff line number Diff line change
@@ -1,63 +1,31 @@
import type { IRoom, IRoomWithJoinCode, IUser } from '@rocket.chat/core-typings';
import { Rooms, Users } from '@rocket.chat/models';
import { Room } from '@rocket.chat/core-services';
import type { IRoom } from '@rocket.chat/core-typings';
import { Rooms } from '@rocket.chat/models';
import type { ServerMethods } from '@rocket.chat/ui-contexts';
import { check } from 'meteor/check';
import { Meteor } from 'meteor/meteor';

import { RoomMemberActions } from '../../../../definition/IRoomTypeConfig';
import { roomCoordinator } from '../../../../server/lib/rooms/roomCoordinator';
import { canAccessRoomAsync } from '../../../authorization/server';
import { hasPermissionAsync } from '../../../authorization/server/functions/hasPermission';
import { addUserToRoom } from '../functions/addUserToRoom';

declare module '@rocket.chat/ui-contexts' {
// eslint-disable-next-line @typescript-eslint/naming-convention
interface ServerMethods {
joinRoom(rid: IRoom['_id'], code?: unknown): boolean | undefined;
joinRoom(rid: IRoom['_id'], code?: string): boolean | undefined;
}
}

export const joinRoomMethod = async (userId: IUser['_id'], rid: IRoom['_id'], code?: unknown): Promise<boolean | undefined> => {
check(rid, String);

const user = await Users.findOneById(userId);

if (!user) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', { method: 'joinRoom' });
}

const room = await Rooms.findOneById<IRoomWithJoinCode>(rid);

if (!room) {
throw new Meteor.Error('error-invalid-room', 'Invalid room', { method: 'joinRoom' });
}

if (!(await roomCoordinator.getRoomDirectives(room.t)?.allowMemberAction(room, RoomMemberActions.JOIN, user._id))) {
throw new Meteor.Error('error-not-allowed', 'Not allowed', { method: 'joinRoom' });
}

if (!(await canAccessRoomAsync(room, user))) {
throw new Meteor.Error('error-not-allowed', 'Not allowed', { method: 'joinRoom' });
}
if (room.joinCodeRequired === true && code !== room.joinCode && !(await hasPermissionAsync(user._id, 'join-without-join-code'))) {
throw new Meteor.Error('error-code-invalid', 'Invalid Room Password', {
method: 'joinRoom',
});
}

return addUserToRoom(rid, user);
};

Meteor.methods<ServerMethods>({
async joinRoom(rid, code) {
check(rid, String);

const userId = await Meteor.userId();

if (!userId) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', { method: 'joinRoom' });
}

return joinRoomMethod(userId, rid, code);
const room = await Rooms.findOneById(rid);
if (!room) {
throw new Meteor.Error('error-invalid-room', 'Invalid room', { method: 'joinRoom' });
}

return Room.join({ room, user: { _id: userId }, ...(code ? { joinCode: code } : {}) });
},
});
23 changes: 12 additions & 11 deletions apps/meteor/app/message-pin/server/pinMessage.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { Message } from '@rocket.chat/core-services';
import { isQuoteAttachment } from '@rocket.chat/core-typings';
import type { IMessage, IUser, MessageAttachment, MessageQuoteAttachment } from '@rocket.chat/core-typings';
import { isQuoteAttachment, isRegisterUser } from '@rocket.chat/core-typings';
import type { IMessage, MessageAttachment, MessageQuoteAttachment } from '@rocket.chat/core-typings';
import { Messages, Rooms, Subscriptions, Users, ReadReceipts } from '@rocket.chat/models';
import type { ServerMethods } from '@rocket.chat/ui-contexts';
import { check } from 'meteor/check';
Expand Down Expand Up @@ -82,15 +82,13 @@ Meteor.methods<ServerMethods>({
throw new Meteor.Error('not-authorized', 'Not Authorized', { method: 'pinMessage' });
}

const me = await Users.findOneById<Required<Pick<IUser, '_id' | 'username' | 'name'>>>(userId, {
projection: { username: 1, name: 1 },
});
const me = await Users.findOneById(userId);
if (!me) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', { method: 'pinMessage' });
}

// If we keep history of edits, insert a new message to store history information
if (settings.get('Message_KeepHistory') && me.username) {
if (settings.get('Message_KeepHistory') && isRegisterUser(me)) {
await Messages.cloneAndSaveAsHistoryById(message._id, me);
}

Expand All @@ -110,6 +108,8 @@ Meteor.methods<ServerMethods>({
username: me.username,
};

originalMessage = await Message.beforeSave({ message: originalMessage, room, user: me });

originalMessage = await callbacks.run('beforeSaveMessage', originalMessage);

await Messages.setPinnedByIdAndUserId(originalMessage._id, originalMessage.pinnedBy, originalMessage.pinned);
Expand Down Expand Up @@ -186,15 +186,13 @@ Meteor.methods<ServerMethods>({
throw new Meteor.Error('not-authorized', 'Not Authorized', { method: 'unpinMessage' });
}

const me = await Users.findOneById<Required<Pick<IUser, '_id' | 'username' | 'name'>>>(userId, {
projection: { username: 1, name: 1 },
});
const me = await Users.findOneById(userId);
if (!me) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', { method: 'unpinMessage' });
}

// If we keep history of edits, insert a new message to store history information
if (settings.get('Message_KeepHistory') && me.username) {
if (settings.get('Message_KeepHistory') && isRegisterUser(me)) {
await Messages.cloneAndSaveAsHistoryById(originalMessage._id, me);
}

Expand All @@ -203,7 +201,6 @@ Meteor.methods<ServerMethods>({
_id: userId,
username: me.username,
};
originalMessage = await callbacks.run('beforeSaveMessage', originalMessage);

const room = await Rooms.findOneById(originalMessage.rid, { projection: { ...roomAccessAttributes, lastMessage: 1 } });
if (!room) {
Expand All @@ -214,6 +211,10 @@ Meteor.methods<ServerMethods>({
throw new Meteor.Error('not-authorized', 'Not Authorized', { method: 'unpinMessage' });
}

originalMessage = await Message.beforeSave({ message: originalMessage, room, user: me });

originalMessage = await callbacks.run('beforeSaveMessage', originalMessage);

if (isTheLastMessage(room, message)) {
await Rooms.setLastMessagePinned(room._id, originalMessage.pinnedBy, originalMessage.pinned);
}
Expand Down
Loading

0 comments on commit 7b34131

Please sign in to comment.