diaspora/app/workers/send_base.rb
2016-06-26 06:20:58 +02:00

29 lines
773 B
Ruby

module Workers
class SendBase < Base
sidekiq_options queue: :http, retry: 0
MAX_RETRIES = AppConfig.environment.sidekiq.retry.get.to_i
protected
def schedule_retry(retry_count, sender_id, obj_str, failed_urls)
if retry_count < MAX_RETRIES
yield(seconds_to_delay(retry_count), retry_count)
else
logger.warn "status=abandon sender=#{sender_id} obj=#{obj_str} failed_urls='[#{failed_urls.join(', ')}]'"
raise MaxRetriesReached
end
end
private
# based on Sidekiq::Middleware::Server::RetryJobs#seconds_to_delay
def seconds_to_delay(count)
((count + 3)**4) + (rand(30) * (count + 1))
end
# send job to the dead job queue
class MaxRetriesReached < RuntimeError
end
end
end