Skip to content
Snippets Groups Projects
  • abcang's avatar
    1aad015b
    Revert unique retry job (#4937) · 1aad015b
    abcang authored
    * Revert "Enable UniqueRetryJobMiddleware even when called from sidekiq worker (#4836)"
    
    This reverts commit 6859d4c0.
    
    * Revert "Do not execute the job with the same arguments as the retry job (#4814)"
    
    This reverts commit be7ffa2d.
    1aad015b
    History
    Revert unique retry job (#4937)
    abcang authored
    * Revert "Enable UniqueRetryJobMiddleware even when called from sidekiq worker (#4836)"
    
    This reverts commit 6859d4c0.
    
    * Revert "Do not execute the job with the same arguments as the retry job (#4814)"
    
    This reverts commit be7ffa2d.
subscribe_worker.rb 874 B
# frozen_string_literal: true

class Pubsubhubbub::SubscribeWorker
  include Sidekiq::Worker

  sidekiq_options queue: 'push', retry: 10, unique: :until_executed, dead: false

  sidekiq_retry_in do |count|
    case count
    when 0
      30.minutes.seconds
    when 1
      2.hours.seconds
    when 2
      12.hours.seconds
    else
      24.hours.seconds * (count - 2)
    end
  end

  sidekiq_retries_exhausted do |msg, _e|
    account = Account.find(msg['args'].first)
    logger.error "PuSH subscription attempts for #{account.acct} exhausted. Unsubscribing"
    ::UnsubscribeService.new.call(account)
  end

  def perform(account_id)
    account = Account.find(account_id)
    logger.debug "PuSH re-subscribing to #{account.acct}"
    ::SubscribeService.new.call(account)
  rescue => e
    raise e.class, "Subscribe failed for #{account&.acct}: #{e.message}"
  end
end