mirror of
https://github.com/discourse/discourse.git
synced 2024-11-23 03:16:41 +08:00
DEV: New option to always destroy posts. (#11898)
This commit is contained in:
parent
4b3d34d3d4
commit
e040de0c2c
|
@ -35,32 +35,9 @@ class UserDestroyer
|
||||||
category_topic_ids = Category.where("topic_id IS NOT NULL").pluck(:topic_id)
|
category_topic_ids = Category.where("topic_id IS NOT NULL").pluck(:topic_id)
|
||||||
|
|
||||||
if opts[:delete_posts]
|
if opts[:delete_posts]
|
||||||
user.posts.each do |post|
|
agree_with_flags(user) if opts[:delete_as_spammer]
|
||||||
|
block_external_urls(user) if opts[:block_urls]
|
||||||
# agree with flags
|
delete_posts(user, category_topic_ids, opts)
|
||||||
if opts[:delete_as_spammer] && reviewable = post.reviewable_flag
|
|
||||||
reviewable.perform(@actor, :agree_and_keep)
|
|
||||||
end
|
|
||||||
|
|
||||||
# block all external urls
|
|
||||||
if opts[:block_urls]
|
|
||||||
post.topic_links.each do |link|
|
|
||||||
next if link.internal
|
|
||||||
next if Oneboxer.engine(link.url) != Onebox::Engine::AllowlistedGenericOnebox
|
|
||||||
ScreenedUrl.watch(link.url, link.domain, ip_address: user.ip_address)&.record_match!
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if post.is_first_post? && category_topic_ids.include?(post.topic_id)
|
|
||||||
post.update!(user: Discourse.system_user)
|
|
||||||
else
|
|
||||||
PostDestroyer.new(@actor.staff? ? @actor : Discourse.system_user, post).destroy
|
|
||||||
end
|
|
||||||
|
|
||||||
if post.topic && post.is_first_post?
|
|
||||||
Topic.unscoped.where(id: post.topic_id).update_all(user_id: nil)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
user.post_actions.each do |post_action|
|
user.post_actions.each do |post_action|
|
||||||
|
@ -131,6 +108,33 @@ class UserDestroyer
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
|
def block_external_urls(user)
|
||||||
|
TopicLink.where(user: user, internal: false).find_each do |link|
|
||||||
|
next if Oneboxer.engine(link.url) != Onebox::Engine::AllowlistedGenericOnebox
|
||||||
|
ScreenedUrl.watch(link.url, link.domain, ip_address: user.ip_address)&.record_match!
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def agree_with_flags(user)
|
||||||
|
ReviewableFlaggedPost.where(target_created_by: user).find_each do |reviewable|
|
||||||
|
reviewable.perform(@actor, :agree_and_keep)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete_posts(user, category_topic_ids, opts)
|
||||||
|
user.posts.find_each do |post|
|
||||||
|
if post.is_first_post? && category_topic_ids.include?(post.topic_id)
|
||||||
|
post.update!(user: Discourse.system_user)
|
||||||
|
else
|
||||||
|
PostDestroyer.new(@actor.staff? ? @actor : Discourse.system_user, post).destroy
|
||||||
|
end
|
||||||
|
|
||||||
|
if post.topic && post.is_first_post?
|
||||||
|
Topic.unscoped.where(id: post.topic_id).update_all(user_id: nil)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def prepare_for_destroy(user)
|
def prepare_for_destroy(user)
|
||||||
PostAction.where(user_id: user.id).delete_all
|
PostAction.where(user_id: user.id).delete_all
|
||||||
UserAction.where('user_id = :user_id OR target_user_id = :user_id OR acting_user_id = :user_id', user_id: user.id).delete_all
|
UserAction.where('user_id = :user_id OR target_user_id = :user_id OR acting_user_id = :user_id', user_id: user.id).delete_all
|
||||||
|
|
|
@ -186,7 +186,7 @@ class PostDestroyer
|
||||||
end
|
end
|
||||||
|
|
||||||
def permanent?
|
def permanent?
|
||||||
@opts[:permanent] && @user == @post.user && @post.topic.private_message?
|
@opts[:force_destroy] || (@opts[:permanent] && @user == @post.user && @post.topic.private_message?)
|
||||||
end
|
end
|
||||||
|
|
||||||
# When a user 'deletes' their own post. We just change the text.
|
# When a user 'deletes' their own post. We just change the text.
|
||||||
|
@ -247,9 +247,10 @@ class PostDestroyer
|
||||||
end
|
end
|
||||||
|
|
||||||
def make_previous_post_the_last_one
|
def make_previous_post_the_last_one
|
||||||
last_post = Post
|
last_post = Post.where("topic_id = ? and id <> ?", @post.topic_id, @post.id)
|
||||||
.select(:created_at, :user_id, :post_number)
|
.select(:created_at, :user_id, :post_number)
|
||||||
.where("topic_id = ? and id <> ?", @post.topic_id, @post.id)
|
.where("topic_id = ? and id <> ?", @post.topic_id, @post.id)
|
||||||
|
.where.not(user_id: nil)
|
||||||
.order('created_at desc')
|
.order('created_at desc')
|
||||||
.limit(1)
|
.limit(1)
|
||||||
.first
|
.first
|
||||||
|
|
|
@ -967,6 +967,7 @@ describe PostDestroyer do
|
||||||
fab!(:private_post) { Fabricate(:private_message_post, topic: private_message_topic) }
|
fab!(:private_post) { Fabricate(:private_message_post, topic: private_message_topic) }
|
||||||
fab!(:post_action) { Fabricate(:post_action, post: private_post) }
|
fab!(:post_action) { Fabricate(:post_action, post: private_post) }
|
||||||
fab!(:reply) { Fabricate(:private_message_post, topic: private_message_topic) }
|
fab!(:reply) { Fabricate(:private_message_post, topic: private_message_topic) }
|
||||||
|
|
||||||
it "destroys the post and topic if deleting first post" do
|
it "destroys the post and topic if deleting first post" do
|
||||||
PostDestroyer.new(reply.user, reply, permanent: true).destroy
|
PostDestroyer.new(reply.user, reply, permanent: true).destroy
|
||||||
expect { reply.reload }.to raise_error(ActiveRecord::RecordNotFound)
|
expect { reply.reload }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
@ -985,5 +986,14 @@ describe PostDestroyer do
|
||||||
PostDestroyer.new(post.user, post, permanent: true).destroy
|
PostDestroyer.new(post.user, post, permanent: true).destroy
|
||||||
expect(post.user_deleted).to be true
|
expect(post.user_deleted).to be true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'always destroy the post when the force_destroy option is passed' do
|
||||||
|
PostDestroyer.new(moderator, reply, force_destroy: true).destroy
|
||||||
|
expect { reply.reload }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
|
||||||
|
regular_post = Fabricate(:post)
|
||||||
|
PostDestroyer.new(moderator, regular_post, force_destroy: true).destroy
|
||||||
|
expect { regular_post.reload }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -290,7 +290,7 @@ describe UserDestroyer do
|
||||||
before do
|
before do
|
||||||
@post = Fabricate(:post_with_external_links, user: user)
|
@post = Fabricate(:post_with_external_links, user: user)
|
||||||
TopicLink.extract_from(@post)
|
TopicLink.extract_from(@post)
|
||||||
TopicLink.any_instance.stubs(:internal).returns(true)
|
TopicLink.where(user: user).update_all(internal: true)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't add ScreenedUrl records" do
|
it "doesn't add ScreenedUrl records" do
|
||||||
|
|
Loading…
Reference in New Issue
Block a user