sidekiq 6.2.1 → 6.2.2
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of sidekiq might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Changes.md +10 -0
- data/LICENSE +1 -1
- data/lib/sidekiq/api.rb +79 -56
- data/lib/sidekiq/extensions/generic_proxy.rb +3 -1
- data/lib/sidekiq/fetch.rb +1 -1
- data/lib/sidekiq/job.rb +8 -0
- data/lib/sidekiq/job_logger.rb +1 -1
- data/lib/sidekiq/job_retry.rb +3 -7
- data/lib/sidekiq/launcher.rb +13 -17
- data/lib/sidekiq/middleware/chain.rb +5 -3
- data/lib/sidekiq/scheduled.rb +7 -1
- data/lib/sidekiq/testing.rb +1 -3
- data/lib/sidekiq/version.rb +1 -1
- data/lib/sidekiq/web/action.rb +1 -1
- data/lib/sidekiq/web/application.rb +3 -3
- data/lib/sidekiq/web/helpers.rb +8 -9
- data/lib/sidekiq/web.rb +4 -3
- data/web/assets/stylesheets/application-dark.css +11 -24
- data/web/assets/stylesheets/application.css +15 -131
- data/web/locales/ar.yml +8 -2
- data/web/locales/en.yml +3 -0
- data/web/locales/es.yml +18 -2
- data/web/locales/fr.yml +7 -0
- data/web/locales/ja.yml +3 -0
- data/web/locales/lt.yml +1 -1
- data/web/views/_job_info.erb +1 -1
- data/web/views/busy.erb +5 -5
- data/web/views/dashboard.erb +14 -6
- data/web/views/dead.erb +1 -1
- data/web/views/morgue.erb +6 -6
- data/web/views/queues.erb +3 -3
- data/web/views/retries.erb +7 -7
- data/web/views/retry.erb +1 -1
- data/web/views/scheduled.erb +1 -1
- metadata +3 -2
data/lib/sidekiq/testing.rb
CHANGED
@@ -338,7 +338,5 @@ module Sidekiq
|
|
338
338
|
end
|
339
339
|
|
340
340
|
if defined?(::Rails) && Rails.respond_to?(:env) && !Rails.env.test? && !$TESTING
|
341
|
-
|
342
|
-
puts("⛔️ WARNING: Sidekiq testing API enabled, but this is not the test environment. Your jobs will not go to Redis.")
|
343
|
-
puts("**************************************************")
|
341
|
+
warn("⛔️ WARNING: Sidekiq testing API enabled, but this is not the test environment. Your jobs will not go to Redis.", uplevel: 1)
|
344
342
|
end
|
data/lib/sidekiq/version.rb
CHANGED
data/lib/sidekiq/web/action.rb
CHANGED
@@ -68,7 +68,7 @@ module Sidekiq
|
|
68
68
|
end
|
69
69
|
|
70
70
|
def json(payload)
|
71
|
-
[200, {"Content-Type" => "application/json", "Cache-Control" => "no-
|
71
|
+
[200, {"Content-Type" => "application/json", "Cache-Control" => "private, no-store"}, [Sidekiq.dump_json(payload)]]
|
72
72
|
end
|
73
73
|
|
74
74
|
def initialize(env, block)
|
@@ -92,7 +92,7 @@ module Sidekiq
|
|
92
92
|
@count = (params["count"] || 25).to_i
|
93
93
|
@queue = Sidekiq::Queue.new(@name)
|
94
94
|
(@current_page, @total_size, @messages) = page("queue:#{@name}", params["page"], @count, reverse: params["direction"] == "asc")
|
95
|
-
@messages = @messages.map { |msg| Sidekiq::
|
95
|
+
@messages = @messages.map { |msg| Sidekiq::JobRecord.new(msg, @name) }
|
96
96
|
|
97
97
|
erb(:queue)
|
98
98
|
end
|
@@ -113,7 +113,7 @@ module Sidekiq
|
|
113
113
|
|
114
114
|
post "/queues/:name/delete" do
|
115
115
|
name = route_params[:name]
|
116
|
-
Sidekiq::
|
116
|
+
Sidekiq::JobRecord.new(params["key_val"], name).delete
|
117
117
|
|
118
118
|
redirect_with_query("#{root_path}queues/#{CGI.escape(name)}")
|
119
119
|
end
|
@@ -314,7 +314,7 @@ module Sidekiq
|
|
314
314
|
# rendered content goes here
|
315
315
|
headers = {
|
316
316
|
"Content-Type" => "text/html",
|
317
|
-
"Cache-Control" => "no-
|
317
|
+
"Cache-Control" => "private, no-store",
|
318
318
|
"Content-Language" => action.locale,
|
319
319
|
"Content-Security-Policy" => CSP_HEADER
|
320
320
|
}
|
data/lib/sidekiq/web/helpers.rb
CHANGED
@@ -10,14 +10,13 @@ module Sidekiq
|
|
10
10
|
module WebHelpers
|
11
11
|
def strings(lang)
|
12
12
|
@strings ||= {}
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
end
|
13
|
+
|
14
|
+
# Allow sidekiq-web extensions to add locale paths
|
15
|
+
# so extensions can be localized
|
16
|
+
@strings[lang] ||= settings.locales.each_with_object({}) do |path, global|
|
17
|
+
find_locale_files(lang).each do |file|
|
18
|
+
strs = YAML.load(File.open(file))
|
19
|
+
global.merge!(strs[lang])
|
21
20
|
end
|
22
21
|
end
|
23
22
|
end
|
@@ -126,7 +125,7 @@ module Sidekiq
|
|
126
125
|
# within is used by Sidekiq Pro
|
127
126
|
def display_tags(job, within = nil)
|
128
127
|
job.tags.map { |tag|
|
129
|
-
"<span class='
|
128
|
+
"<span class='label label-info jobtag'>#{::Rack::Utils.escape_html(tag)}</span>"
|
130
129
|
}.join(" ")
|
131
130
|
end
|
132
131
|
|
data/lib/sidekiq/web.rb
CHANGED
@@ -143,13 +143,14 @@ module Sidekiq
|
|
143
143
|
klass = self.class
|
144
144
|
m = middlewares
|
145
145
|
|
146
|
+
rules = []
|
147
|
+
rules = [[:all, {"Cache-Control" => "public, max-age=86400"}]] unless ENV["SIDEKIQ_WEB_TESTING"]
|
148
|
+
|
146
149
|
::Rack::Builder.new do
|
147
150
|
use Rack::Static, urls: ["/stylesheets", "/images", "/javascripts"],
|
148
151
|
root: ASSETS,
|
149
152
|
cascade: true,
|
150
|
-
header_rules:
|
151
|
-
[:all, {"Cache-Control" => "public, max-age=86400"}]
|
152
|
-
]
|
153
|
+
header_rules: rules
|
153
154
|
m.each { |middleware, block| use(*middleware, &block) }
|
154
155
|
use Sidekiq::Web::CsrfProtection unless $TESTING
|
155
156
|
run WebApplication.new(klass)
|
@@ -64,17 +64,20 @@ table {
|
|
64
64
|
background-color: #484;
|
65
65
|
}
|
66
66
|
|
67
|
+
.alert-danger {
|
68
|
+
background-color: #980035;
|
69
|
+
}
|
70
|
+
|
71
|
+
.alert-info {
|
72
|
+
background-color: #31708f;
|
73
|
+
}
|
74
|
+
|
67
75
|
a:link,
|
68
76
|
a:active,
|
69
|
-
a:hover
|
70
|
-
a:visited {
|
77
|
+
a:hover {
|
71
78
|
color: #ddd;
|
72
79
|
}
|
73
80
|
|
74
|
-
a.btn {
|
75
|
-
color: #000;
|
76
|
-
}
|
77
|
-
|
78
81
|
input {
|
79
82
|
background-color: #444;
|
80
83
|
color: #ccc;
|
@@ -85,8 +88,6 @@ input {
|
|
85
88
|
background-color: #222;
|
86
89
|
border: 1px solid #555;
|
87
90
|
|
88
|
-
-webkit-box-shadow: 0 0 5px rgba(255, 255, 255, 0.1);
|
89
|
-
-moz-box-shadow: 0 0 5px rgba(255, 255, 255, 0.1);
|
90
91
|
box-shadow: 0 0 5px rgba(255, 255, 255, 0.1);
|
91
92
|
}
|
92
93
|
|
@@ -128,14 +129,6 @@ input {
|
|
128
129
|
border: 1px solid rgba(255, 255, 255, 0.1);
|
129
130
|
}
|
130
131
|
|
131
|
-
#live-poll {
|
132
|
-
color: #ddd;
|
133
|
-
}
|
134
|
-
|
135
|
-
.btn-warn {
|
136
|
-
color: #444;
|
137
|
-
}
|
138
|
-
|
139
132
|
.rickshaw_graph .detail {
|
140
133
|
background: rgba(255, 255, 255, .1)
|
141
134
|
}
|
@@ -149,12 +142,6 @@ input {
|
|
149
142
|
}
|
150
143
|
|
151
144
|
.info-circle {
|
152
|
-
color: #
|
153
|
-
background-color: #
|
154
|
-
border-radius: 50%;
|
155
|
-
text-align: center;
|
156
|
-
vertical-align: middle;
|
157
|
-
padding: 3px 7px;
|
158
|
-
font-size: 0.7em;
|
159
|
-
margin-left: 5px;
|
145
|
+
color: #222;
|
146
|
+
background-color: #888;
|
160
147
|
}
|
@@ -6,7 +6,6 @@ body {
|
|
6
6
|
color: #585454;
|
7
7
|
padding: 0;
|
8
8
|
text-rendering: optimizeLegibility;
|
9
|
-
-webkit-font-smoothing: antialiased;
|
10
9
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
11
10
|
background: #f3f3f3 url();
|
12
11
|
}
|
@@ -22,15 +21,9 @@ body {
|
|
22
21
|
a {
|
23
22
|
color: #b1003e;
|
24
23
|
}
|
25
|
-
a:active, a:hover
|
24
|
+
a:active, a:hover {
|
26
25
|
color: #4b001a;
|
27
26
|
}
|
28
|
-
a.btn {
|
29
|
-
color: #585454;
|
30
|
-
}
|
31
|
-
a.btn-primary {
|
32
|
-
color: white;
|
33
|
-
}
|
34
27
|
|
35
28
|
h1, h2, h3, h4, h5, h6, strong {
|
36
29
|
font-weight: 700;
|
@@ -96,11 +89,7 @@ header.row .pagination {
|
|
96
89
|
.summary_bar .summary {
|
97
90
|
margin-top: 12px;
|
98
91
|
background-color: #fff;
|
99
|
-
-webkit-box-shadow: 0 0 5px rgba(50, 50, 50, 0.25);
|
100
|
-
-moz-box-shadow: 0 0 5px rgba(50, 50, 50, 0.25);
|
101
92
|
box-shadow: 0 0 5px rgba(50, 50, 50, 0.25);
|
102
|
-
-webkit-border-radius: 4px;
|
103
|
-
-moz-border-radius: 4px;
|
104
93
|
border-radius: 4px;
|
105
94
|
padding: 8px;
|
106
95
|
margin-bottom: 10px;
|
@@ -112,6 +101,9 @@ header.row .pagination {
|
|
112
101
|
#live-poll.active {
|
113
102
|
background-color: #009300;
|
114
103
|
}
|
104
|
+
#live-poll.active:hover {
|
105
|
+
background-color: #777;
|
106
|
+
}
|
115
107
|
.summary_bar ul {
|
116
108
|
margin: 0 0 38px 0;
|
117
109
|
}
|
@@ -151,16 +143,6 @@ header.row .pagination {
|
|
151
143
|
width: 96px !important;
|
152
144
|
}
|
153
145
|
}
|
154
|
-
/*@media (max-width: 1199px) and (min-width: 980px) {
|
155
|
-
.summary_bar ul li.col-sm-2 {
|
156
|
-
width: 130px !important;
|
157
|
-
}
|
158
|
-
}
|
159
|
-
@media (min-width: 1200px) {
|
160
|
-
.summary_bar ul li.col-sm-2 {
|
161
|
-
width: 154px !important;
|
162
|
-
}
|
163
|
-
}*/
|
164
146
|
.summary_bar ul .desc {
|
165
147
|
display: block;
|
166
148
|
font-size: 1em;
|
@@ -201,13 +183,8 @@ td form {
|
|
201
183
|
padding: 0;
|
202
184
|
}
|
203
185
|
|
204
|
-
.jobtag a {
|
205
|
-
color:
|
206
|
-
}
|
207
|
-
|
208
|
-
.jobtag a:hover {
|
209
|
-
color: white;
|
210
|
-
text-decoration: underline;
|
186
|
+
.jobtag, .jobtag a {
|
187
|
+
color: black;
|
211
188
|
}
|
212
189
|
|
213
190
|
table .table-checkbox label {
|
@@ -277,8 +254,7 @@ table .table-checkbox label {
|
|
277
254
|
|
278
255
|
.navbar .nav a {
|
279
256
|
text-align: center;
|
280
|
-
}
|
281
|
-
|
257
|
+
}
|
282
258
|
}
|
283
259
|
|
284
260
|
@media (width: 768px) {
|
@@ -356,51 +332,23 @@ img.smallogo {
|
|
356
332
|
.btn {
|
357
333
|
font-weight: 700;
|
358
334
|
border: none;
|
359
|
-
-webkit-border-radius: 3px;
|
360
|
-
-moz-border-radius: 3px;
|
361
|
-
-ms-border-radius: 3px;
|
362
|
-
-o-border-radius: 3px;
|
363
335
|
border-radius: 3px;
|
364
|
-
-webkit-box-shadow: 0 0 2px rgba(0, 0, 0, 0.4);
|
365
|
-
-moz-box-shadow: 0 0 2px rgba(0, 0, 0, 0.4);
|
366
336
|
box-shadow: 0 0 2px rgba(0, 0, 0, 0.4);
|
367
|
-
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #fafafa), color-stop(100%, #ededed));
|
368
|
-
background-image: -webkit-linear-gradient(#fafafa, #ededed);
|
369
|
-
background-image: -moz-linear-gradient(#fafafa, #ededed);
|
370
|
-
background-image: -o-linear-gradient(#fafafa, #ededed);
|
371
|
-
background-image: linear-gradient(#fafafa, #ededed);
|
372
|
-
}
|
373
|
-
.btn:hover {
|
374
|
-
background-color: #ededed;
|
375
|
-
}
|
376
|
-
|
377
|
-
.btn-primary {
|
378
|
-
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #b1003e), color-stop(100%, #980035));
|
379
|
-
background-image: -webkit-linear-gradient(#b1003e, #980035);
|
380
|
-
background-image: -moz-linear-gradient(#b1003e, #980035);
|
381
|
-
background-image: -o-linear-gradient(#b1003e, #980035);
|
382
337
|
background-image: linear-gradient(#b1003e, #980035);
|
383
|
-
}
|
384
|
-
.btn-primary:hover {
|
385
338
|
background-color: #980035;
|
339
|
+
color: #ddd;
|
386
340
|
}
|
387
|
-
|
388
|
-
|
389
|
-
background-image:
|
390
|
-
background-
|
391
|
-
background-image: -moz-linear-gradient(#b1003e, #980035);
|
392
|
-
background-image: -o-linear-gradient(#b1003e, #980035);
|
393
|
-
background-image: linear-gradient(#b1003e, #980035);
|
394
|
-
}
|
395
|
-
.btn-danger:hover {
|
396
|
-
background-color: #980035;
|
341
|
+
.btn:hover {
|
342
|
+
color: #000;
|
343
|
+
background-image: none;
|
344
|
+
background-color: #ddd;
|
397
345
|
}
|
398
346
|
|
399
347
|
.poll-status {
|
400
348
|
padding: 10px 0;
|
401
349
|
}
|
402
350
|
|
403
|
-
.
|
351
|
+
.stats-wrapper {
|
404
352
|
width: 100%;
|
405
353
|
text-align: center;
|
406
354
|
}
|
@@ -469,7 +417,6 @@ span.current-interval {
|
|
469
417
|
|
470
418
|
div.interval-slider input {
|
471
419
|
width: 160px;
|
472
|
-
-webkit-appearance: none;
|
473
420
|
height: 3px;
|
474
421
|
margin-top: 5px;
|
475
422
|
border-radius: 2px;
|
@@ -545,48 +492,14 @@ div.interval-slider input {
|
|
545
492
|
background-color: #80002d;
|
546
493
|
border-radius: 10px;
|
547
494
|
box-shadow: 0 0 9px #666;
|
548
|
-
-moz-box-shadow: 0 0 9px #666;
|
549
|
-
-webkit-box-shadow: 0 0 9px #666;
|
550
495
|
border: 3px solid transparent;
|
551
496
|
z-index: 10;
|
552
497
|
}
|
553
498
|
|
554
499
|
.beacon.pulse .dot {
|
555
|
-
-webkit-animation: beacon-dot-pulse 1s ease-out;
|
556
|
-
-moz-animation: beacon-dot-pulse 1s ease-out;
|
557
500
|
animation: beacon-dot-pulse 1s ease-out;
|
558
501
|
}
|
559
502
|
|
560
|
-
@-webkit-keyframes beacon-dot-pulse {
|
561
|
-
from {
|
562
|
-
background-color: #80002d;
|
563
|
-
-webkit-box-shadow: 0 0 9px #666;
|
564
|
-
}
|
565
|
-
50% {
|
566
|
-
background-color: #c90047;
|
567
|
-
-webkit-box-shadow: 0 0 18px #666;
|
568
|
-
}
|
569
|
-
to {
|
570
|
-
background-color: #80002d;
|
571
|
-
-webkit-box-shadow: 0 0 9px #666;
|
572
|
-
}
|
573
|
-
}
|
574
|
-
|
575
|
-
@-moz-keyframes beacon-dot-pulse {
|
576
|
-
from {
|
577
|
-
background-color: #80002d;
|
578
|
-
-moz-box-shadow: 0 0 9px #666;
|
579
|
-
}
|
580
|
-
50% {
|
581
|
-
background-color: #c90047;
|
582
|
-
-moz-box-shadow: 0 0 18px #666;
|
583
|
-
}
|
584
|
-
to {
|
585
|
-
background-color: #80002d;
|
586
|
-
-moz-box-shadow: 0 0 9px #666;
|
587
|
-
}
|
588
|
-
}
|
589
|
-
|
590
503
|
@keyframes beacon-dot-pulse {
|
591
504
|
from {
|
592
505
|
background-color: #80002d;
|
@@ -613,33 +526,9 @@ div.interval-slider input {
|
|
613
526
|
}
|
614
527
|
|
615
528
|
.beacon.pulse .ring {
|
616
|
-
-webkit-animation: beacon-ring-pulse 1s;
|
617
|
-
-moz-animation: beacon-ring-pulse 1s;
|
618
529
|
animation: beacon-ring-pulse 1s;
|
619
530
|
}
|
620
531
|
|
621
|
-
@-webkit-keyframes beacon-ring-pulse {
|
622
|
-
0% {
|
623
|
-
opacity: 1;
|
624
|
-
-webkit-transform: scale(0.3);
|
625
|
-
}
|
626
|
-
100% {
|
627
|
-
opacity: 0;
|
628
|
-
-webkit-transform: scale(1);
|
629
|
-
}
|
630
|
-
}
|
631
|
-
|
632
|
-
@-moz-keyframes beacon-ring-pulse {
|
633
|
-
0% {
|
634
|
-
opacity: 1;
|
635
|
-
-moz-transform: scale(0.3);
|
636
|
-
}
|
637
|
-
100% {
|
638
|
-
opacity: 0;
|
639
|
-
-moz-transform: scale(1);
|
640
|
-
}
|
641
|
-
}
|
642
|
-
|
643
532
|
@keyframes beacon-ring-pulse {
|
644
533
|
0% {
|
645
534
|
opacity: 1;
|
@@ -748,9 +637,6 @@ div.interval-slider input {
|
|
748
637
|
bottom: 0;
|
749
638
|
width: 1px;
|
750
639
|
transition: opacity .25s linear;
|
751
|
-
-moz-transition: opacity .25s linear;
|
752
|
-
-o-transition: opacity .25s linear;
|
753
|
-
-webkit-transition: opacity .25s linear
|
754
640
|
}
|
755
641
|
.rickshaw_graph .detail.inactive {
|
756
642
|
opacity: 0
|
@@ -832,7 +718,6 @@ div.interval-slider input {
|
|
832
718
|
position: absolute;
|
833
719
|
box-shadow: 0 0 2px rgba(0, 0, 0, .6);
|
834
720
|
box-sizing: content-box;
|
835
|
-
-moz-box-sizing: content-box;
|
836
721
|
background: #fff;
|
837
722
|
border-width: 2px;
|
838
723
|
border-style: solid;
|
@@ -1158,12 +1043,11 @@ div.interval-slider input {
|
|
1158
1043
|
}
|
1159
1044
|
|
1160
1045
|
.info-circle {
|
1161
|
-
color: #
|
1162
|
-
background-color: #
|
1046
|
+
color: #ccc;
|
1047
|
+
background-color: #000;
|
1163
1048
|
border-radius: 50%;
|
1164
1049
|
text-align: center;
|
1165
1050
|
vertical-align: middle;
|
1166
1051
|
padding: 3px 7px;
|
1167
|
-
font-size: 0.7em;
|
1168
1052
|
margin-left: 5px;
|
1169
1053
|
}
|
data/web/locales/ar.yml
CHANGED
@@ -8,6 +8,7 @@ ar:
|
|
8
8
|
Realtime: الزمن الفعلي
|
9
9
|
History: تاريخ
|
10
10
|
Busy: مشغول
|
11
|
+
Utilization: الاستخدام
|
11
12
|
Processed: تمت المعالجة
|
12
13
|
Failed: فشل
|
13
14
|
Scheduled: مجدول
|
@@ -65,11 +66,13 @@ ar:
|
|
65
66
|
DeadJobs: وظائف ميتة
|
66
67
|
NoDeadJobsFound: لاتوجد وظائف ميتة
|
67
68
|
Dead: ميتة
|
69
|
+
Process: عملية
|
68
70
|
Processes: عمليات
|
71
|
+
Name: الاسم
|
69
72
|
Thread: نيسب
|
70
73
|
Threads: نياسب
|
71
74
|
Jobs: وظائف
|
72
|
-
Paused:
|
75
|
+
Paused: موقفة مؤقتاً
|
73
76
|
Stop: إيقاف
|
74
77
|
Quiet: هدوء
|
75
78
|
StopAll: إيقاف الكل
|
@@ -78,4 +81,7 @@ ar:
|
|
78
81
|
Plugins: الإضافات
|
79
82
|
NotYetEnqueued: لم تدخل الرتل بعد
|
80
83
|
CreatedAt: أنشئت في
|
81
|
-
BackToApp: العودة إلى التطبيق
|
84
|
+
BackToApp: العودة إلى التطبيق
|
85
|
+
Latency: زمن الانتظار
|
86
|
+
Pause: إيقاف مؤقت
|
87
|
+
Unpause: متابعة
|