mirror of
https://github.com/discourse/discourse.git
synced 2024-11-22 09:42:02 +08:00
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
|
||||
|
||||
if user.id == removed_by&.id
|
||||
removed_by = Discourse.system_user
|
||||
add_small_action(removed_by, "user_left", user.username)
|
||||
else
|
||||
add_small_action(removed_by, "removed_user", user.username)
|
||||
|
|
|
@ -431,7 +431,7 @@ class PostCreator
|
|||
|
||||
def ensure_in_allowed_users
|
||||
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
|
||||
|
|
|
@ -1041,6 +1041,21 @@ RSpec.describe PostCreator do
|
|||
)
|
||||
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
|
||||
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.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])
|
||||
end
|
||||
|
||||
|
@ -1156,7 +1156,7 @@ RSpec.describe Topic do
|
|||
admins.add(user1)
|
||||
|
||||
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
|
||||
|
@ -2817,7 +2817,7 @@ RSpec.describe Topic do
|
|||
|
||||
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.action_code).to eq('user_left')
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue
Block a user