FIX: Skip topic allowed user for small actions (#18075)
Topic allowed user records were created for small actions, which lead to the system user being invited in many private topics when the user removed themselves or if a group was invited but some members already had access. This commits skips creating topic allowed user. They are already skipped for the whisper posts.
This commit is contained in:
parent
0d8ecab362
commit
33ea8b4756
|
@ -976,7 +976,6 @@ class Topic < ActiveRecord::Base
|
||||||
topic_user.destroy
|
topic_user.destroy
|
||||||
|
|
||||||
if user.id == removed_by&.id
|
if user.id == removed_by&.id
|
||||||
removed_by = Discourse.system_user
|
|
||||||
add_small_action(removed_by, "user_left", user.username)
|
add_small_action(removed_by, "user_left", user.username)
|
||||||
else
|
else
|
||||||
add_small_action(removed_by, "removed_user", user.username)
|
add_small_action(removed_by, "removed_user", user.username)
|
||||||
|
|
|
@ -431,7 +431,7 @@ class PostCreator
|
||||||
|
|
||||||
def ensure_in_allowed_users
|
def ensure_in_allowed_users
|
||||||
return unless @topic.private_message? && @topic.id
|
return unless @topic.private_message? && @topic.id
|
||||||
return if @post.whisper?
|
return if @post.whisper? || @post.post_type == Post.types[:small_action]
|
||||||
return if @topic.topic_allowed_users.exists?(user_id: @user.id)
|
return if @topic.topic_allowed_users.exists?(user_id: @user.id)
|
||||||
|
|
||||||
return if @topic
|
return if @topic
|
||||||
|
|
|
@ -1041,6 +1041,21 @@ RSpec.describe PostCreator do
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'does not add whisperers to allowed users of the topic' do
|
||||||
|
unrelated_user.update!(admin: true)
|
||||||
|
|
||||||
|
PostCreator.create!(
|
||||||
|
unrelated_user,
|
||||||
|
raw: "This is a whisper that I am testing",
|
||||||
|
topic_id: post.topic_id,
|
||||||
|
post_type: Post.types[:small_action],
|
||||||
|
)
|
||||||
|
|
||||||
|
expect(post.topic.topic_allowed_users.map(&:user_id)).to contain_exactly(
|
||||||
|
target_user1.id, target_user2.id, user.id
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
it 'does not increase posts count for small actions' do
|
it 'does not increase posts count for small actions' do
|
||||||
topic = Fabricate(:private_message_topic, user: Fabricate(:user))
|
topic = Fabricate(:private_message_topic, user: Fabricate(:user))
|
||||||
|
|
||||||
|
|
|
@ -1138,7 +1138,7 @@ RSpec.describe Topic do
|
||||||
|
|
||||||
expect(topic.invite_group(topic.user, admins)).to eq(true)
|
expect(topic.invite_group(topic.user, admins)).to eq(true)
|
||||||
expect(topic.posts.last.action_code).to eq("removed_user")
|
expect(topic.posts.last.action_code).to eq("removed_user")
|
||||||
expect(topic.allowed_users).to match_array([user0, user3, Discourse.system_user])
|
expect(topic.allowed_users).to match_array([user0, user3])
|
||||||
expect(other_topic.allowed_users).to match_array([user1])
|
expect(other_topic.allowed_users).to match_array([user1])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1156,7 +1156,7 @@ RSpec.describe Topic do
|
||||||
admins.add(user1)
|
admins.add(user1)
|
||||||
|
|
||||||
expect(topic.invite_group(topic.user, admins)).to eq(true)
|
expect(topic.invite_group(topic.user, admins)).to eq(true)
|
||||||
expect(topic.allowed_users).to match_array([topic.user, Discourse.system_user])
|
expect(topic.allowed_users).to match_array([topic.user])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -2817,7 +2817,7 @@ RSpec.describe Topic do
|
||||||
|
|
||||||
post = Post.last
|
post = Post.last
|
||||||
|
|
||||||
expect(post.user).to eq(Discourse.system_user)
|
expect(post.user).to eq(user1)
|
||||||
expect(post.post_type).to eq(Post.types[:small_action])
|
expect(post.post_type).to eq(Post.types[:small_action])
|
||||||
expect(post.action_code).to eq('user_left')
|
expect(post.action_code).to eq('user_left')
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue