Unsere Community hat mehrere tausend private Nachrichten, die zwischen Benutzern gesendet wurden. Gibt es eine Möglichkeit, private Nachrichten mit mehr als 100 Antworten vollständig aus der Datenbank zu entfernen (ohne Wiederherstellung)?
Well, I think that this will do what you asked. It will delete any private messages that were not created by a system user or discobot. It will still delete any other private messages, including those from admins.
It’s not tested. I’m not saying that it’s a good idea. I won’t promise that it won’t do something bad.
cd /var/discourse
discourse backup
./launcher enter app
rails s
Topic.where(archetype: 'private_message').where("user_id > 0").destroy_all
exit
discourse enable_restore
discourse restore
If something bad does not happen, you can omit the last two steps. If something bad does happen, you’ll want to copy/paste the most recent backup printed by the discourse restore command to restore the backup.
You can remove all message at once.
rake destroy:private_messages
Reference:
Nice work, @IAmGav! I swear i looked there and didn’t see.
Thanks Jay,
Running batch delete query directly on the database is so Scary ![]()
I took a brief look at how this function works. As it turns out, after running it, all private messages will be deleted.
def destroy_private_messages
Topic.where(archetype: "private_message").find_each do |pm|
@io.puts "Destroying #{pm.slug} pm"
first_post = pm.ordered_posts.first
@io.puts PostDestroyer.new(Discourse.system_user, first_post).destroy
end
end
I think I have to choose the scary way that @pfaffman pointed out to filter messages. or try to define custom rake function and use PostDestroyer.new(Discourse.system_user, first_post).destroy
Dieses alte Thema noch einmal aufgreifend, da keine der Antworten zu 100 % korrekt ist.
Die Rake-Aufgabe rake destroy:private_messages löscht private Nachrichten nicht endgültig, sondern weich. Sie können immer noch von einem Administrator eingesehen und wiederhergestellt werden.
Der Rails-Code Topic.where(archetype: 'private_message').where("user_id > 0").destroy_all löscht die Themen, aber nicht die eigentlichen Nachrichten. Sie befinden sich immer noch in der Datenbank und können beispielsweise mit dem Data Explorer Plugin eingesehen werden.
Dieser Code löscht alle privaten Nachrichtenbeiträge und -themen dauerhaft:
Warnung: scharfes Messer hier!
Post.where(topic_id: Topic.where(archetype: 'private_message').where("user_id > 0")).destroy_all
Topic.where(archetype: 'private_message').where("user_id > 0").destroy_all
(und um dies auf Themen mit 100 oder mehr Antworten zu beschränken, müssen Sie Topic.where in beiden Zeilen um where("posts_count > 100") erweitern)