Regression: Fix creation of self-DMs (#23015)

pull/20907/head^2
Diego Sampaio 4 years ago committed by GitHub
parent a6cc4b0142
commit 197c409387
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 2
      app/api/server/v1/im.js
  2. 28
      server/methods/createDirectMessage.js
  3. 20
      tests/end-to-end/api/04-direct-message.js

@ -43,7 +43,7 @@ API.v1.addRoute(['dm.create', 'im.create'], { authRequired: true }, {
throw new Meteor.Error('error-room-not-found', 'The required "username" or "usernames" param provided does not match any direct message');
}
const room = createDirectMessage(users, excludeSelf);
const room = createDirectMessage(users, this.userId, excludeSelf);
return API.v1.success({
room: { ...room, _id: room.rid },

@ -1,26 +1,25 @@
import { Meteor } from 'meteor/meteor';
import { check, Match } from 'meteor/check';
import { settings } from '../../app/settings';
import { hasPermission } from '../../app/authorization';
import { Users, Rooms } from '../../app/models';
import { RateLimiter } from '../../app/lib';
import { settings } from '../../app/settings/server';
import { hasPermission } from '../../app/authorization/server';
import { Users, Rooms } from '../../app/models/server';
import { createRoom, RateLimiter } from '../../app/lib/server';
import { addUser } from '../../app/federation/server/functions/addUser';
import { createRoom } from '../../app/lib/server';
export function createDirectMessage(usernames, excludeSelf) {
export function createDirectMessage(usernames, userId, excludeSelf = false) {
check(usernames, [String]);
check(userId, String);
check(excludeSelf, Match.Optional(Boolean));
if (!Meteor.userId()) {
if (!userId) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', {
method: 'createDirectMessage',
});
}
const me = Meteor.user();
if (!me.username) {
const me = Users.findOneById(userId, { fields: { username: 1 } });
if (!me?.username) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', {
method: 'createDirectMessage',
});
@ -50,15 +49,16 @@ export function createDirectMessage(usernames, excludeSelf) {
const roomUsers = excludeSelf ? users : [me, ...users];
if (roomUsers.length === 1) {
// allow self-DMs
if (roomUsers.length === 1 && roomUsers[0]._id !== me._id) {
throw new Meteor.Error('error-invalid-user', 'Invalid user', {
method: 'createDirectMessage',
});
}
if (!hasPermission(Meteor.userId(), 'create-d')) {
if (!hasPermission(userId, 'create-d')) {
// If the user can't create DMs but can access already existing ones
if (hasPermission(Meteor.userId(), 'view-d-room')) {
if (hasPermission(userId, 'view-d-room')) {
// Check if the direct room already exists, then return it
const uids = roomUsers.map(({ _id }) => _id).sort();
const room = Rooms.findOneDirectRoomContainingAllUserIDs(uids, { fields: { _id: 1 } });
@ -91,7 +91,7 @@ export function createDirectMessage(usernames, excludeSelf) {
Meteor.methods({
createDirectMessage(...usernames) {
return createDirectMessage(usernames, false);
return createDirectMessage(usernames, Meteor.userId());
},
});

@ -489,7 +489,9 @@ describe('[Direct Messages]', function() {
});
after(async () => {
await deleteRoom({ type: 'd', roomId });
if (roomId) {
await deleteRoom({ type: 'd', roomId });
}
await deleteUser(otherUser);
otherUser = undefined;
});
@ -528,6 +530,22 @@ describe('[Direct Messages]', function() {
})
.end(done);
});
it('should create a self-DM', (done) => {
request.post(api('im.create'))
.set(credentials)
.send({
username: adminUsername,
})
.expect(200)
.expect('Content-Type', 'application/json')
.expect((res) => {
expect(res.body).to.have.property('success', true);
expect(res.body).to.have.property('room').and.to.be.an('object');
expect(res.body.room).to.have.property('usernames').and.to.have.members([adminUsername]);
})
.end(done);
});
});
describe('/im.delete', () => {

Loading…
Cancel
Save