Il plugin Digest Email si è rotto in DistributedMutex.synchronize durante l'aggiornamento

Abbiamo un plugin personalizzato per le email digest che si è rotto quando sono passato da 2.9.0 beta 7 a beta 9. Mi rendo conto che Discourse non supporta plugin personalizzati, ma hai qualche suggerimento su cosa posso fare prima di rivolgermi a Marketplace?

Log Errori
/var/www/discourse/plugins/discourse-506investor-digest-plugin/plugin.rb:27:in `block in execute'
/var/www/discourse/lib/distributed_mutex.rb:57:in `block in synchronize'
/var/www/discourse/lib/distributed_mutex.rb:53:in `synchronize'
/var/www/discourse/lib/distributed_mutex.rb:53:in `synchronize'
/var/www/discourse/lib/distributed_mutex.rb:38:in `synchronize'
/var/www/discourse/plugins/discourse-506investor-digest-plugin/plugin.rb:12:in `execute'
/var/www/discourse/app/jobs/base.rb:237:in `block (2 levels) in perform'
rails_multisite-4.0.1/lib/rails_multisite/connection_management.rb:80:in `with_connection'
/var/www/discourse/app/jobs/base.rb:226:in `block in perform'
/var/www/discourse/app/jobs/base.rb:222:in `each'
/var/www/discourse/app/jobs/base.rb:222:in `perform'
/var/www/discourse/app/jobs/base.rb:284:in `perform'
mini_scheduler-0.14.0/lib/mini_scheduler/manager.rb:93:in `process_queue'
mini_scheduler-0.14.0/lib/mini_scheduler/manager.rb:37:in `block (2 levels) in initialize'
Codice Rilevante
after_initialize {
  class ::Jobs::EnqueueDigestEmails
    def execute(args)
      return if SiteSetting.disable_digest_emails? || SiteSetting.private_email?

      DistributedMutex.synchronize("custom_digest", validity: 180.minutes) {  # <<<<<<<<<<<< riga incriminata 12
        users = User.where(id: target_user_ids)
        return if users.blank?
        
        connection = CustomDigest.create_connection

Forse dai un’occhiata al job che stai sovrascrivendo in core e guarda “blame” per vedere se qualcosa è cambiato di recente. Questa sarebbe la prima cosa che controllerei.

1 Mi Piace