about summary refs log tree commit diff
path: root/app/workers/distribution_worker.rb
blob: 474b4daafa02c42d32f59e62a22f2e074a62d042 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# frozen_string_literal: true

class DistributionWorker
  include Sidekiq::Worker
  include Redisable

  def perform(status_id, options = {})
    RedisLock.acquire(redis: redis, key: "distribute:#{status_id}", autorelease: 5.minutes.seconds) do |lock|
      if lock.acquired?
        FanOutOnWriteService.new.call(Status.find(status_id), **options.symbolize_keys)
      else
        raise Mastodon::RaceConditionError
      end
    end
  rescue ActiveRecord::RecordNotFound
    true
  end
end