Sha256: 7736b31bbd01539df41ff982726fd2fb779e56d6e18dc605735ff11ef3da1371

Contents?: true

Size: 1.91 KB

Versions: 15

Compression:

Stored size: 1.91 KB

Contents

local queue         = KEYS[1]
local schedule_set  = KEYS[2]
local retry_set     = KEYS[3]
local unique_digest = ARGV[1]

local function delete_from_sorted_set(name, digest)
  local per   = 50
  local total = redis.call('zcard', name)
  local index = 0
  local result
  -- redis.log(redis.LOG_DEBUG, "delete_from_sorted_set("..name..","..digest..")")
  while (index < total) do
    -- redis.log(redis.LOG_DEBUG, "delete_from_sorted_set("..name..","..digest..") - "..index.."-"..per)
    local items = redis.call('ZRANGE', name, index, index + per -1)
    for _, item in pairs(items) do
      -- redis.log(redis.LOG_DEBUG, "delete_from_sorted_set("..name..","..digest..") - current item: " .. item)
      if string.find(item, digest) then
        -- redis.log(redis.LOG_DEBUG, "delete_from_sorted_set("..name..","..digest..") - deleting item")
        redis.call('ZREM', name, item)
        result = item
        break
      end
    end
    index = index + per
  end
  return result
end

local per     = 50
local total   = redis.call('LLEN', queue)
local index   = 0
local result  = nil

-- redis.log(redis.LOG_DEBUG, "delete_job_by_digest.lua - looping through: " .. queue)
while (index < total) do
  -- redis.log(redis.LOG_DEBUG, "delete_job_by_digest.lua - " .. index .. "-" .. per)
  local items = redis.call('LRANGE', queue, index, index + per -1)
  for _, item in pairs(items) do
    -- redis.log(redis.LOG_DEBUG, "delete_job_by_digest.lua - item: " .. item)
    if string.find(item, unique_digest) then
      -- redis.log(redis.LOG_DEBUG, "delete_job_by_digest.lua - found item with digest: " .. unique_digest .. " in: " ..queue)
      redis.call('LREM', queue, 1, item)
      result = item
      break
    end
  end
  index = index + per
end

if result then
  return result
end

result = delete_from_sorted_set(schedule_set, unique_digest)
if result then
  return result
end

result = delete_from_sorted_set(retry_set, unique_digest)
return result

Version data entries

15 entries across 15 versions & 1 rubygems

Version Path
sidekiq-unique-jobs-6.0.25 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.24 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.23 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.22 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.21 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.20 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.16 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.19 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.13 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.12 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.11 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.10 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.9 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.8 redis/delete_job_by_digest.lua
sidekiq-unique-jobs-6.0.7 redis/delete_job_by_digest.lua