Hallo,
wir suspendieren Profile automatisch, die mit dem Plugin discourse-auto-suspend mindestens ein Jahr lang nicht genutzt wurden.
Später löschen wir diese Profile zusammen mit allen ihren Beiträgen und Themen.
(Wir haben delete user max post age = 3700 und delete all posts max = 999 eingestellt.)
Bisher habe ich in den letzten Monaten bereits über 1500 Benutzer mit mehreren tausend Beiträgen und wahrscheinlich mehr als tausend Themen gelöscht.
Aber jetzt gibt es einen Benutzer, bei dem das System zwar begonnen hat, die Beiträge zu löschen, der Benutzer aber trotz wiederholtem Klicken auf den Button zum Löschen der Beiträge und Threads weiterhin 68 Beiträge und 63 Themen aufweist.
Im Log unter /logs erscheint folgende Warnung:
Failed to process hijacked response correctly : Couldn't find Topic with 'id'=569
Wenn ich mit dem Data Explorer-Plugin in die Tabelle topics schaue, existiert dort kein Thema mit der ID 569.
Die ID 568 existiert vom 22.05.2017 14:01:35.419842 und die ID 570 vom 22.05.2017 14:20:27.610993.
Wenn ich jedoch in die Tabelle posts schaue, sehe ich dort einen Eintrag mit topic_id 569 und 9 Beiträgen.
Es scheint also eine Datenbankinkonsistenz vorzuliegen. Im Mai 2017 war ich noch nicht Administrator, daher weiß ich nicht, ob es damals möglicherweise Systemprobleme gab.
Gibt es eine Möglichkeit, das Problem so zu lösen, dass der Löschen-Button weiterhin die Einträge entfernt?
Hier ist der Backtrace dieser Warnung:
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activerecord-5.2.0/lib/active_record/relation/finder_methods.rb:346:in `raise_record_not_found_exception!'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activerecord-5.2.0/lib/active_record/relation/finder_methods.rb:454:in `find_one'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activerecord-5.2.0/lib/active_record/relation/finder_methods.rb:433:in `find_with_ids'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activerecord-5.2.0/lib/active_record/relation/finder_methods.rb:69:in `find'
/var/www/discourse/app/serializers/post_serializer.rb:397:in `topic'
/var/www/discourse/app/serializers/post_serializer.rb:87:in `topic_slug'
(eval):22:in `_fast_attributes'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/active_model_serializers-0.8.4/lib/active_model/serializer.rb:468:in `rescue in attributes'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/active_model_serializers-0.8.4/lib/active_model/serializer.rb:455:in `attributes'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/active_model_serializers-0.8.4/lib/active_model/serializer.rb:480:in `_serializable_hash'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/active_model_serializers-0.8.4/lib/active_model/serializer.rb:359:in `serializable_hash'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/active_model_serializers-0.8.4/lib/active_model/serializer.rb:347:in `as_json'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activesupport-5.2.0/lib/active_support/json/encoding.rb:35:in `encode'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activesupport-5.2.0/lib/active_support/json/encoding.rb:22:in `encode'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activesupport-5.2.0/lib/active_support/core_ext/object/json.rb:41:in `to_json'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/active_model_serializers-0.8.4/lib/active_model/serializer.rb:331:in `to_json'
/var/www/discourse/app/models/web_hook.rb:95:in `generate_payload'
/var/www/discourse/lib/post_destroyer.rb:48:in `destroy'
/var/www/discourse/app/models/user.rb:789:in `block in delete_all_posts!'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activerecord-5.2.0/lib/active_record/relation/delegation.rb:41:in `each'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/activerecord-5.2.0/lib/active_record/relation/delegation.rb:41:in `each'
/var/www/discourse/app/models/user.rb:788:in `delete_all_posts!'
/var/www/discourse/app/controllers/admin/users_controller.rb:51:in `block in delete_all_posts'
/var/www/discourse/lib/hijack.rb:56:in `instance_eval'
/var/www/discourse/lib/hijack.rb:56:in `block in hijack'
/var/www/discourse/lib/scheduler/defer.rb:94:in `block in do_work'
/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/rails_multisite-2.0.4/lib/rails_multisite/connection_management.rb:63:in `with_connection'
/var/www/discourse/lib/scheduler/defer.rb:89:in `do_work'
/var/www/discourse/lib/scheduler/defer.rb:79:in `block (2 levels) in start_thread'








