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.

@@ -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
- puts("**************************************************")
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
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Sidekiq
4
- VERSION = "6.2.1"
4
+ VERSION = "6.2.2"
5
5
  end
@@ -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-cache"}, [Sidekiq.dump_json(payload)]]
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::Job.new(msg, @name) }
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::Job.new(params["key_val"], name).delete
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-cache",
317
+ "Cache-Control" => "private, no-store",
318
318
  "Content-Language" => action.locale,
319
319
  "Content-Security-Policy" => CSP_HEADER
320
320
  }
@@ -10,14 +10,13 @@ module Sidekiq
10
10
  module WebHelpers
11
11
  def strings(lang)
12
12
  @strings ||= {}
13
- @strings[lang] ||= begin
14
- # Allow sidekiq-web extensions to add locale paths
15
- # so extensions can be localized
16
- 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])
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='jobtag label label-info'>#{::Rack::Utils.escape_html(tag)}</span>"
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: #282828;
153
- background-color: #555555;
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, a:visited {
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: white;
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
- .btn-danger {
389
- background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #b1003e), color-stop(100%, #980035));
390
- background-image: -webkit-linear-gradient(#b1003e, #980035);
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
- .redis-wrapper {
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: #f3f3f3;
1162
- background-color: #dddddd;
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: متابعة