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

class DistributionWorker
  include Sidekiq::Worker

  def perform(status_id, options = {})
    RedisLock.acquire(redis: Redis.current, 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