sidekiq-unique-jobs 8.0.1 → 8.0.3
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of sidekiq-unique-jobs might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +30 -0
- data/README.md +11 -11
- data/lib/sidekiq_unique_jobs/job.rb +6 -1
- data/lib/sidekiq_unique_jobs/lock/until_executed.rb +1 -0
- data/lib/sidekiq_unique_jobs/lock/while_executing.rb +1 -2
- data/lib/sidekiq_unique_jobs/lock.rb +5 -2
- data/lib/sidekiq_unique_jobs/lock_type.rb +37 -0
- data/lib/sidekiq_unique_jobs/locksmith.rb +5 -2
- data/lib/sidekiq_unique_jobs/lua/delete.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/delete_by_digest.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/delete_job_by_digest.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/find_digest_in_queues.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/lock.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/lock_until_expired.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/locked.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/queue.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/reap_orphans.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/shared/_common.lua +0 -5
- data/lib/sidekiq_unique_jobs/lua/unlock.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/update_version.lua +1 -1
- data/lib/sidekiq_unique_jobs/lua/upgrade.lua +1 -1
- data/lib/sidekiq_unique_jobs/options_with_fallback.rb +1 -1
- data/lib/sidekiq_unique_jobs/orphans/manager.rb +2 -2
- data/lib/sidekiq_unique_jobs/sidekiq_unique_jobs.rb +3 -3
- data/lib/sidekiq_unique_jobs/version.rb +1 -1
- data/lib/sidekiq_unique_jobs/web/helpers.rb +2 -0
- data/lib/sidekiq_unique_jobs/web/views/changelogs.erb +1 -1
- data/lib/sidekiq_unique_jobs/web/views/lock.erb +5 -3
- data/lib/sidekiq_unique_jobs.rb +1 -0
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2462acb2448a07c45eb8a1789239f859a09e079cff316fe61dc205d9ea8856a4
|
4
|
+
data.tar.gz: 57449a594cd034c79001815883806098e04a92869c41cbe6044c90ab6f1fa3ae
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b200d3544047b6080147b19b71ffd83a0ac42087ed29f1d84fb35b226b1418f50e37c94b309a946504c32d26b11b5fd173ade85e77c568931d33b948f1c656f9
|
7
|
+
data.tar.gz: 9d12cbf3317acd4e5bd6d934616622e5ac3336ecba4e51b2b29fbf6782deab2b1af291af1471e16da7271fef42b33804b7a3c7f3475016de88bd75e2d0668684
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,35 @@
|
|
1
1
|
# Changelog
|
2
2
|
|
3
|
+
## [v8.0.2](https://github.com/mhenrixon/sidekiq-unique-jobs/tree/v8.0.2) (2023-03-13)
|
4
|
+
|
5
|
+
[Full Changelog](https://github.com/mhenrixon/sidekiq-unique-jobs/compare/v8.0.1...v8.0.2)
|
6
|
+
|
7
|
+
**Closed issues:**
|
8
|
+
|
9
|
+
- Missing v7.1 branch? [\#757](https://github.com/mhenrixon/sidekiq-unique-jobs/issues/757)
|
10
|
+
- Allow one running job but at most one job in the queue [\#748](https://github.com/mhenrixon/sidekiq-unique-jobs/issues/748)
|
11
|
+
|
12
|
+
**Merged pull requests:**
|
13
|
+
|
14
|
+
- update debug\_lua check to match passed in arg type [\#765](https://github.com/mhenrixon/sidekiq-unique-jobs/pull/765) ([JeremiahChurch](https://github.com/JeremiahChurch))
|
15
|
+
- fix rubocop [\#764](https://github.com/mhenrixon/sidekiq-unique-jobs/pull/764) ([JeremiahChurch](https://github.com/JeremiahChurch))
|
16
|
+
- Hide lock info debug suggestion on lock page if it's already enabled. [\#763](https://github.com/mhenrixon/sidekiq-unique-jobs/pull/763) ([JeremiahChurch](https://github.com/JeremiahChurch))
|
17
|
+
- fix lock & changelog times on web interface [\#762](https://github.com/mhenrixon/sidekiq-unique-jobs/pull/762) ([JeremiahChurch](https://github.com/JeremiahChurch))
|
18
|
+
|
19
|
+
## [v8.0.1](https://github.com/mhenrixon/sidekiq-unique-jobs/tree/v8.0.1) (2023-02-14)
|
20
|
+
|
21
|
+
[Full Changelog](https://github.com/mhenrixon/sidekiq-unique-jobs/compare/v8.0.0...v8.0.1)
|
22
|
+
|
23
|
+
**Closed issues:**
|
24
|
+
|
25
|
+
- TypeError: Unsupported command argument type: ActiveSupport::Duration [\#754](https://github.com/mhenrixon/sidekiq-unique-jobs/issues/754)
|
26
|
+
- Incompatibility with Sidekiq 7 [\#736](https://github.com/mhenrixon/sidekiq-unique-jobs/issues/736)
|
27
|
+
|
28
|
+
**Merged pull requests:**
|
29
|
+
|
30
|
+
- Fix active worker detection by using correct keys [\#756](https://github.com/mhenrixon/sidekiq-unique-jobs/pull/756) ([dodo121](https://github.com/dodo121))
|
31
|
+
- Fix minor typo in drift\_reaper\_interval comment [\#755](https://github.com/mhenrixon/sidekiq-unique-jobs/pull/755) ([lazyatom](https://github.com/lazyatom))
|
32
|
+
|
3
33
|
## [v8.0.0](https://github.com/mhenrixon/sidekiq-unique-jobs/tree/v8.0.0) (2023-01-30)
|
4
34
|
|
5
35
|
[Full Changelog](https://github.com/mhenrixon/sidekiq-unique-jobs/compare/v7.1.29...v8.0.0)
|
data/README.md
CHANGED
@@ -45,11 +45,11 @@ Want to show me some ❤️ for the hard work I do on this gem? You can use the
|
|
45
45
|
- [reschedule_failed](#reschedule_failed)
|
46
46
|
- [rescheduled](#rescheduled)
|
47
47
|
- [timeout](#timeout)
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
48
|
+
- [unlock_failed](#unlock_failed)
|
49
|
+
- [unlocked](#unlocked)
|
50
|
+
- [unknown_sidekiq_worker](#unknown_sidekiq_worker)
|
51
|
+
- [Show Locks](#show-locks)
|
52
|
+
- [Show Lock](#show-lock)
|
53
53
|
- [Testing](#testing)
|
54
54
|
- [Validating Worker Configuration](#validating-worker-configuration)
|
55
55
|
- [Uniqueness](#uniqueness)
|
@@ -545,23 +545,23 @@ For when a job was successfully rescheduled
|
|
545
545
|
|
546
546
|
This is also mostly useful for reporting/metrics purposes. What this reflection does is signal that the job was configured to wait (`lock_timeout` was configured), but we couldn't retrieve a lock even though we waited for some time.
|
547
547
|
|
548
|
-
|
548
|
+
#### unlock_failed
|
549
549
|
|
550
|
-
This
|
550
|
+
This means that the server middleware could not unlock your job and the lock is kept (potentially preventing subsequent jobs from being pushed or processed).
|
551
551
|
|
552
|
-
|
552
|
+
#### unlocked
|
553
553
|
|
554
554
|
Also mostly useful for reporting purposes. The job was successfully unlocked.
|
555
555
|
|
556
|
-
|
556
|
+
#### unknown_sidekiq_worker
|
557
557
|
|
558
558
|
The reason this happens is that the server couldn't find a valid sidekiq worker class. Most likely, that worker isn't intended to be processed by this sidekiq server instance.
|
559
559
|
|
560
|
-
|
560
|
+
### Show Locks
|
561
561
|
|
562
562
|
![Locks](assets/unique_digests_1.png)
|
563
563
|
|
564
|
-
|
564
|
+
### Show Lock
|
565
565
|
|
566
566
|
![Lock](assets/unique_digests_2.png)
|
567
567
|
|
@@ -7,10 +7,11 @@ module SidekiqUniqueJobs
|
|
7
7
|
module Job
|
8
8
|
extend self
|
9
9
|
|
10
|
-
# Adds timeout, expiration, lock_args, lock_prefix and lock_digest to the sidekiq job hash
|
10
|
+
# Adds lock, timeout, expiration, lock_args, lock_prefix, and lock_digest to the sidekiq job hash
|
11
11
|
# @return [Hash] the job hash
|
12
12
|
def prepare(item)
|
13
13
|
stringify_on_conflict_hash(item)
|
14
|
+
add_lock_type(item)
|
14
15
|
add_lock_timeout(item)
|
15
16
|
add_lock_ttl(item)
|
16
17
|
add_digest(item)
|
@@ -54,5 +55,9 @@ module SidekiqUniqueJobs
|
|
54
55
|
def add_lock_prefix(item)
|
55
56
|
item[LOCK_PREFIX] ||= SidekiqUniqueJobs.config.lock_prefix
|
56
57
|
end
|
58
|
+
|
59
|
+
def add_lock_type(item)
|
60
|
+
item[LOCK] ||= SidekiqUniqueJobs::LockType.call(item)
|
61
|
+
end
|
57
62
|
end
|
58
63
|
end
|
@@ -46,8 +46,11 @@ module SidekiqUniqueJobs
|
|
46
46
|
# @param [Timstamp, Float] time nil optional timestamp to initiate this lock with
|
47
47
|
#
|
48
48
|
def initialize(key, time: nil)
|
49
|
-
@key
|
50
|
-
|
49
|
+
@key = get_key(key)
|
50
|
+
time = time.is_a?(Float) ? time : time.to_f
|
51
|
+
return unless time.nonzero?
|
52
|
+
|
53
|
+
@created_at = time
|
51
54
|
end
|
52
55
|
|
53
56
|
#
|
@@ -0,0 +1,37 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module SidekiqUniqueJobs
|
4
|
+
# Calculates the lock type
|
5
|
+
#
|
6
|
+
class LockType
|
7
|
+
# includes "SidekiqUniqueJobs::SidekiqWorkerMethods"
|
8
|
+
# @!parse include SidekiqUniqueJobs::SidekiqWorkerMethods
|
9
|
+
include SidekiqUniqueJobs::SidekiqWorkerMethods
|
10
|
+
|
11
|
+
#
|
12
|
+
# Computes lock type from job arguments, sidekiq_options.
|
13
|
+
#
|
14
|
+
# @return [Symbol] the lock type
|
15
|
+
# @return [NilClass] if no lock type is found.
|
16
|
+
#
|
17
|
+
def self.call(item)
|
18
|
+
new(item).call
|
19
|
+
end
|
20
|
+
|
21
|
+
# @!attribute [r] item
|
22
|
+
# @return [Hash] the Sidekiq job hash
|
23
|
+
attr_reader :item
|
24
|
+
|
25
|
+
# @param [Hash] item the Sidekiq job hash
|
26
|
+
# @option item [Symbol, nil] :lock the type of lock to use.
|
27
|
+
# @option item [String] :class the class of the sidekiq worker
|
28
|
+
def initialize(item)
|
29
|
+
@item = item
|
30
|
+
self.job_class = item[CLASS]
|
31
|
+
end
|
32
|
+
|
33
|
+
def call
|
34
|
+
item[LOCK] || job_options[LOCK] || default_job_options[LOCK]
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -127,7 +127,10 @@ module SidekiqUniqueJobs
|
|
127
127
|
#
|
128
128
|
def unlock!(conn = nil)
|
129
129
|
call_script(:unlock, key.to_a, argv, conn) do |unlocked_jid|
|
130
|
-
|
130
|
+
if unlocked_jid == job_id
|
131
|
+
reflect(:debug, :unlocked, item, unlocked_jid)
|
132
|
+
reflect(:unlocked, item)
|
133
|
+
end
|
131
134
|
|
132
135
|
unlocked_jid
|
133
136
|
end
|
@@ -312,7 +315,7 @@ module SidekiqUniqueJobs
|
|
312
315
|
# @api private
|
313
316
|
#
|
314
317
|
def rpoplpush(conn)
|
315
|
-
conn.
|
318
|
+
conn.lmove(key.queued, key.primed, "RIGHT", "LEFT")
|
316
319
|
end
|
317
320
|
|
318
321
|
#
|
@@ -17,7 +17,7 @@ local limit = tonumber(ARGV[4])
|
|
17
17
|
|
18
18
|
-------- BEGIN injected arguments --------
|
19
19
|
local current_time = tonumber(ARGV[5])
|
20
|
-
local debug_lua = tostring(ARGV[6]) == "
|
20
|
+
local debug_lua = tostring(ARGV[6]) == "1"
|
21
21
|
local max_history = tonumber(ARGV[7])
|
22
22
|
local script_name = tostring(ARGV[8]) .. ".lua"
|
23
23
|
local redisversion = tostring(ARGV[9])
|
@@ -12,7 +12,7 @@ local digests = KEYS[9]
|
|
12
12
|
|
13
13
|
-------- BEGIN injected arguments --------
|
14
14
|
local current_time = tonumber(ARGV[1])
|
15
|
-
local debug_lua = ARGV[2] == "
|
15
|
+
local debug_lua = tostring(ARGV[2]) == "1"
|
16
16
|
local max_history = tonumber(ARGV[3])
|
17
17
|
local script_name = tostring(ARGV[4]) .. ".lua"
|
18
18
|
local redisversion = tostring(ARGV[5])
|
@@ -10,7 +10,7 @@ local digest = ARGV[1]
|
|
10
10
|
|
11
11
|
-------- BEGIN injected arguments --------
|
12
12
|
local current_time = tonumber(ARGV[2])
|
13
|
-
local debug_lua = ARGV[3] == "
|
13
|
+
local debug_lua = tostring(ARGV[3]) == "1"
|
14
14
|
local max_history = tonumber(ARGV[4])
|
15
15
|
local script_name = tostring(ARGV[5]) .. ".lua"
|
16
16
|
--------- END injected arguments ---------
|
@@ -4,7 +4,7 @@ local digest = KEYS[1]
|
|
4
4
|
|
5
5
|
-------- BEGIN injected arguments --------
|
6
6
|
local current_time = tonumber(ARGV[2])
|
7
|
-
local debug_lua = ARGV[3] == "
|
7
|
+
local debug_lua = tostring(ARGV[3]) == "1"
|
8
8
|
local max_history = tonumber(ARGV[4])
|
9
9
|
local script_name = tostring(ARGV[5]) .. ".lua"
|
10
10
|
--------- END injected arguments ---------
|
@@ -20,7 +20,7 @@ local limit = tonumber(ARGV[4])
|
|
20
20
|
|
21
21
|
-------- BEGIN injected arguments --------
|
22
22
|
local current_time = tonumber(ARGV[5])
|
23
|
-
local debug_lua = ARGV[6] == "
|
23
|
+
local debug_lua = tostring(ARGV[6]) == "1"
|
24
24
|
local max_history = tonumber(ARGV[7])
|
25
25
|
local script_name = tostring(ARGV[8]) .. ".lua"
|
26
26
|
local redisversion = ARGV[9]
|
@@ -20,7 +20,7 @@ local limit = tonumber(ARGV[4])
|
|
20
20
|
|
21
21
|
-------- BEGIN injected arguments --------
|
22
22
|
local current_time = tonumber(ARGV[5])
|
23
|
-
local debug_lua = ARGV[6] == "
|
23
|
+
local debug_lua = tostring(ARGV[6]) == "1"
|
24
24
|
local max_history = tonumber(ARGV[7])
|
25
25
|
local script_name = tostring(ARGV[8]) .. ".lua"
|
26
26
|
local redisversion = ARGV[9]
|
@@ -14,7 +14,7 @@ local job_id = ARGV[1]
|
|
14
14
|
|
15
15
|
-------- BEGIN injected arguments --------
|
16
16
|
local current_time = tonumber(ARGV[2])
|
17
|
-
local debug_lua = ARGV[3] == "
|
17
|
+
local debug_lua = tostring(ARGV[3]) == "1"
|
18
18
|
local max_history = tonumber(ARGV[4])
|
19
19
|
local script_name = tostring(ARGV[5]) .. ".lua"
|
20
20
|
--------- END injected arguments ---------
|
@@ -19,7 +19,7 @@ local limit = tonumber(ARGV[4])
|
|
19
19
|
|
20
20
|
-------- BEGIN injected arguments --------
|
21
21
|
local current_time = tonumber(ARGV[5])
|
22
|
-
local debug_lua = ARGV[6] == "
|
22
|
+
local debug_lua = tostring(ARGV[6]) == "1"
|
23
23
|
local max_history = tonumber(ARGV[7])
|
24
24
|
local script_name = tostring(ARGV[8]) .. ".lua"
|
25
25
|
--------- END injected arguments ---------
|
@@ -14,7 +14,7 @@ local threshold = tonumber(ARGV[2])
|
|
14
14
|
|
15
15
|
-------- BEGIN injected arguments --------
|
16
16
|
local current_time = tonumber(ARGV[3])
|
17
|
-
local debug_lua = ARGV[4] == "
|
17
|
+
local debug_lua = tostring(ARGV[4]) == "1"
|
18
18
|
local max_history = tonumber(ARGV[5])
|
19
19
|
local script_name = ARGV[6] .. ".lua"
|
20
20
|
local redisversion = ARGV[7]
|
@@ -19,7 +19,7 @@ local limit = tonumber(ARGV[4])
|
|
19
19
|
|
20
20
|
-------- BEGIN injected arguments --------
|
21
21
|
local current_time = tonumber(ARGV[5])
|
22
|
-
local debug_lua = ARGV[6] == "
|
22
|
+
local debug_lua = tostring(ARGV[6]) == "1"
|
23
23
|
local max_history = tonumber(ARGV[7])
|
24
24
|
local script_name = tostring(ARGV[8]) .. ".lua"
|
25
25
|
local redisversion = ARGV[9]
|
@@ -9,7 +9,7 @@ local version = ARGV[1]
|
|
9
9
|
|
10
10
|
-------- BEGIN injected arguments --------
|
11
11
|
local current_time = tonumber(ARGV[2])
|
12
|
-
local debug_lua = ARGV[3] == "
|
12
|
+
local debug_lua = tostring(ARGV[3]) == "1"
|
13
13
|
local max_history = tonumber(ARGV[4])
|
14
14
|
local script_name = tostring(ARGV[5]) .. ".lua"
|
15
15
|
--------- END injected arguments ---------
|
@@ -6,7 +6,7 @@ local dead_version = KEYS[2]
|
|
6
6
|
|
7
7
|
-------- BEGIN injected arguments --------
|
8
8
|
local current_time = tonumber(ARGV[5])
|
9
|
-
local debug_lua = ARGV[6] == "
|
9
|
+
local debug_lua = tostring(ARGV[6]) == "1"
|
10
10
|
local max_history = tonumber(ARGV[7])
|
11
11
|
local script_name = tostring(ARGV[8]) .. ".lua"
|
12
12
|
local redisversion = ARGV[9]
|
@@ -72,7 +72,7 @@ module SidekiqUniqueJobs
|
|
72
72
|
# @return [<type>] <description>
|
73
73
|
#
|
74
74
|
def task
|
75
|
-
@task ||= default_task
|
75
|
+
@task ||= default_task # rubocop:disable ThreadSafety/InstanceVariableInClassMethod
|
76
76
|
end
|
77
77
|
|
78
78
|
#
|
@@ -100,7 +100,7 @@ module SidekiqUniqueJobs
|
|
100
100
|
# @return [void]
|
101
101
|
#
|
102
102
|
def task=(task)
|
103
|
-
@task = task
|
103
|
+
@task = task # rubocop:disable ThreadSafety/InstanceVariableInClassMethod
|
104
104
|
end
|
105
105
|
|
106
106
|
#
|
@@ -17,7 +17,7 @@ module SidekiqUniqueJobs # rubocop:disable Metrics/ModuleLength
|
|
17
17
|
# @return [SidekiqUniqueJobs::Config] the gem configuration
|
18
18
|
#
|
19
19
|
def config
|
20
|
-
@config ||= reset!
|
20
|
+
@config ||= reset! # rubocop:disable ThreadSafety/InstanceVariableInClassMethod
|
21
21
|
end
|
22
22
|
|
23
23
|
#
|
@@ -108,7 +108,7 @@ module SidekiqUniqueJobs # rubocop:disable Metrics/ModuleLength
|
|
108
108
|
# @return [SidekiqUniqueJobs::Config] a default gem configuration
|
109
109
|
#
|
110
110
|
def reset!
|
111
|
-
@config = SidekiqUniqueJobs::Config.default
|
111
|
+
@config = SidekiqUniqueJobs::Config.default # rubocop:disable ThreadSafety/InstanceVariableInClassMethod
|
112
112
|
end
|
113
113
|
|
114
114
|
#
|
@@ -288,7 +288,7 @@ module SidekiqUniqueJobs # rubocop:disable Metrics/ModuleLength
|
|
288
288
|
# @return [Reflections]
|
289
289
|
#
|
290
290
|
def reflections
|
291
|
-
@reflections ||= Reflections.new
|
291
|
+
@reflections ||= Reflections.new # rubocop:disable ThreadSafety/InstanceVariableInClassMethod
|
292
292
|
end
|
293
293
|
|
294
294
|
#
|
@@ -42,7 +42,7 @@
|
|
42
42
|
<tbody>
|
43
43
|
<% @changelogs.each do |changelog| %>
|
44
44
|
<tr class="changelog-row">
|
45
|
-
<td><%= "bogus" %></td>
|
45
|
+
<td><%= safe_relative_time(changelog['time']) || "bogus" %></td>
|
46
46
|
<td><%= changelog["digest"] %></td>
|
47
47
|
<td><%= changelog["script"] %></td>
|
48
48
|
<td><%= changelog["job_id"] %></td>
|
@@ -7,9 +7,11 @@
|
|
7
7
|
<div class="col-sm-7 table-responsive">
|
8
8
|
<% if @lock.info.none? %>
|
9
9
|
<h3>No Lock Information Available</h3>
|
10
|
-
|
11
|
-
<
|
12
|
-
|
10
|
+
<% unless SidekiqUniqueJobs.config.lock_info %>
|
11
|
+
<p>To use it turn the following setting on:
|
12
|
+
<code>SidekiqUniqueJobs.config.lock_info = true</code>
|
13
|
+
</p>
|
14
|
+
<% end %>
|
13
15
|
<% else %>
|
14
16
|
<table class="table table-striped table-bordered table-white table-hover">
|
15
17
|
<caption>Information about lock</caption>
|
data/lib/sidekiq_unique_jobs.rb
CHANGED
@@ -49,6 +49,7 @@ require "sidekiq_unique_jobs/cli"
|
|
49
49
|
require "sidekiq_unique_jobs/core_ext"
|
50
50
|
require "sidekiq_unique_jobs/lock_timeout"
|
51
51
|
require "sidekiq_unique_jobs/lock_ttl"
|
52
|
+
require "sidekiq_unique_jobs/lock_type"
|
52
53
|
require "sidekiq_unique_jobs/lock_args"
|
53
54
|
require "sidekiq_unique_jobs/lock_digest"
|
54
55
|
require "sidekiq_unique_jobs/unlockable"
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sidekiq-unique-jobs
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 8.0.
|
4
|
+
version: 8.0.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Mikael Henriksson
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-07-10 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: brpoplpush-redis_script
|
@@ -137,6 +137,7 @@ files:
|
|
137
137
|
- lib/sidekiq_unique_jobs/lock_info.rb
|
138
138
|
- lib/sidekiq_unique_jobs/lock_timeout.rb
|
139
139
|
- lib/sidekiq_unique_jobs/lock_ttl.rb
|
140
|
+
- lib/sidekiq_unique_jobs/lock_type.rb
|
140
141
|
- lib/sidekiq_unique_jobs/locksmith.rb
|
141
142
|
- lib/sidekiq_unique_jobs/logging.rb
|
142
143
|
- lib/sidekiq_unique_jobs/logging/middleware_context.rb
|
@@ -233,7 +234,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
233
234
|
- !ruby/object:Gem::Version
|
234
235
|
version: '0'
|
235
236
|
requirements: []
|
236
|
-
rubygems_version: 3.4.
|
237
|
+
rubygems_version: 3.4.15
|
237
238
|
signing_key:
|
238
239
|
specification_version: 4
|
239
240
|
summary: Sidekiq middleware that prevents duplicates jobs
|