sidekiq_adhoc_job 2.0.0 → 2.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/sidekiq_adhoc_job/services/schedule_adhoc_job.rb +21 -6
- data/lib/sidekiq_adhoc_job/strategies/active_job.rb +2 -2
- data/lib/sidekiq_adhoc_job/strategies/default.rb +2 -2
- data/lib/sidekiq_adhoc_job/strategies/rails_application_job.rb +2 -2
- data/lib/sidekiq_adhoc_job/utils/class_inspector.rb +9 -1
- data/lib/sidekiq_adhoc_job/version.rb +1 -1
- data/lib/sidekiq_adhoc_job/web/job_presenter.rb +19 -3
- data/lib/sidekiq_adhoc_job/web/locales/en.yml +3 -0
- data/lib/sidekiq_adhoc_job/web/routes/jobs/index.rb +1 -1
- data/lib/sidekiq_adhoc_job/web/templates/jobs/index.html.erb +6 -0
- data/lib/sidekiq_adhoc_job/web/templates/jobs/show.html.erb +27 -2
- data/lib/sidekiq_adhoc_job.rb +12 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e0eb1cd817107c67f9c597017c3fd7e0fc8e79cd783b934d3b6ebc0fb69f5224
|
4
|
+
data.tar.gz: deaae8c8f3de455976885dddd699fd29295cdcd0ae26a013bac38190d5d5e9a1
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a5955dc23c535cfe30380fb24dabfecaa95dfb8b1bdb251d9def1ddc47bd263f0dda19cca2a2dcbaa45edcf2c974d2bebd2a2fdd371e10e19d263be757478261
|
7
|
+
data.tar.gz: fdb6a47dc6c58d2054f6d6d21b6c10e67a9d38efe5bd76de5dca355df28125f569b6db1ddd4ca5c648faa948cfba2b8293541e1baa7685be6ec68b9984383843
|
@@ -10,28 +10,43 @@ module SidekiqAdhocJob
|
|
10
10
|
end
|
11
11
|
@worker_klass = WorkerClassesLoader.find_worker_klass(job_name)
|
12
12
|
@worker_klass_inspector = Utils::ClassInspector.new(worker_klass)
|
13
|
-
@allowed_params = worker_klass_inspector.required_parameters(:perform) + worker_klass_inspector.optional_parameters(:perform)
|
14
13
|
|
15
14
|
parse_params
|
16
15
|
end
|
17
16
|
|
18
17
|
def call
|
19
|
-
SidekiqAdhocJob.config.strategy.perform_async(worker_klass, *
|
18
|
+
SidekiqAdhocJob.config.strategy.perform_async(worker_klass, *worker_positional_params, **worker_keyword_params)
|
20
19
|
end
|
21
20
|
|
22
21
|
private
|
23
22
|
|
24
|
-
attr_reader :request_params, :worker_klass, :worker_klass_inspector,
|
25
|
-
:allowed_params, :worker_params
|
23
|
+
attr_reader :request_params, :worker_klass, :worker_klass_inspector, :worker_positional_params, :worker_keyword_params
|
26
24
|
|
27
25
|
def parse_params
|
28
|
-
@
|
26
|
+
@worker_positional_params = positional_params
|
29
27
|
.reject { |key| request_params[key].empty? }
|
30
28
|
.map { |key| StringUtil.parse(request_params[key], symbolize: true) }
|
29
|
+
@worker_keyword_params = keyword_params
|
30
|
+
.each_with_object({}) { |key, obj| obj[key.to_sym] = request_params[key] }
|
31
|
+
.compact
|
31
32
|
if !!request_params[:rest_args] && !request_params[:rest_args].empty?
|
32
|
-
@
|
33
|
+
@worker_positional_params << StringUtil.parse_json(request_params[:rest_args].strip, symbolize: true)
|
33
34
|
end
|
34
35
|
end
|
35
36
|
|
37
|
+
def allowed_params
|
38
|
+
worker_positional_params + worker_keyword_params
|
39
|
+
end
|
40
|
+
|
41
|
+
def positional_params
|
42
|
+
worker_klass_inspector.required_parameters(:perform) +
|
43
|
+
worker_klass_inspector.optional_parameters(:perform)
|
44
|
+
end
|
45
|
+
|
46
|
+
def keyword_params
|
47
|
+
worker_klass_inspector.required_kw_parameters(:perform) +
|
48
|
+
worker_klass_inspector.optional_kw_parameters(:perform)
|
49
|
+
end
|
50
|
+
|
36
51
|
end
|
37
52
|
end
|
@@ -11,8 +11,8 @@ module SidekiqAdhocJob
|
|
11
11
|
klass_name.sidekiq_options['queue']
|
12
12
|
end
|
13
13
|
|
14
|
-
def perform_async(klass, *params)
|
15
|
-
klass.perform_async(*params)
|
14
|
+
def perform_async(klass, *params, **kw_params)
|
15
|
+
klass.perform_async(*params, **kw_params)
|
16
16
|
end
|
17
17
|
end
|
18
18
|
end
|
@@ -35,12 +35,20 @@ module SidekiqAdhocJob
|
|
35
35
|
parameters(method_name)[:opt] || []
|
36
36
|
end
|
37
37
|
|
38
|
+
def required_kw_parameters(method_name)
|
39
|
+
parameters(method_name)[:keyreq] || []
|
40
|
+
end
|
41
|
+
|
42
|
+
def optional_kw_parameters(method_name)
|
43
|
+
parameters(method_name)[:key] || []
|
44
|
+
end
|
45
|
+
|
38
46
|
def has_rest_parameter?(method_name)
|
39
47
|
!!parameters(method_name)[:rest]
|
40
48
|
end
|
41
49
|
|
42
50
|
def klass_method(method)
|
43
|
-
return method
|
51
|
+
return method if method.owner == klass_name
|
44
52
|
|
45
53
|
klass_method(method.super_method)
|
46
54
|
end
|
@@ -4,18 +4,29 @@ module SidekiqAdhocJob
|
|
4
4
|
class JobPresenter
|
5
5
|
include Sidekiq::WebHelpers
|
6
6
|
|
7
|
-
attr_reader :name,
|
7
|
+
attr_reader :name,
|
8
|
+
:path_name,
|
9
|
+
:queue,
|
10
|
+
:required_args,
|
11
|
+
:optional_args,
|
12
|
+
:required_kw_args,
|
13
|
+
:optional_kw_args,
|
14
|
+
:has_rest_args,
|
15
|
+
:require_confirm
|
8
16
|
|
9
17
|
StringUtil ||= ::SidekiqAdhocJob::Utils::String
|
10
18
|
|
11
19
|
# args: { req: [], opt: [] }
|
12
|
-
def initialize(name, path_name, queue, args)
|
20
|
+
def initialize(name, path_name, queue, args, require_confirm)
|
13
21
|
@name = name
|
14
22
|
@path_name = path_name
|
15
23
|
@queue = queue
|
16
24
|
@required_args = args[:req] || []
|
17
25
|
@optional_args = args[:opt] || []
|
26
|
+
@required_kw_args = args[:keyreq] || []
|
27
|
+
@optional_kw_args = args[:key] || []
|
18
28
|
@has_rest_args = !!args[:rest]
|
29
|
+
@require_confirm = require_confirm
|
19
30
|
end
|
20
31
|
|
21
32
|
# Builds the presenter instances for the schedule hash
|
@@ -40,7 +51,12 @@ module SidekiqAdhocJob
|
|
40
51
|
queue = SidekiqAdhocJob.config.strategy.get_queue_name(klass_name)
|
41
52
|
class_inspector = SidekiqAdhocJob::Utils::ClassInspector.new(klass_name)
|
42
53
|
args = class_inspector.parameters(:perform)
|
43
|
-
|
54
|
+
require_confirm = SidekiqAdhocJob.config.require_confirmation?(klass_name.to_s)
|
55
|
+
new(klass_name, path_name, queue, args, require_confirm)
|
56
|
+
end
|
57
|
+
|
58
|
+
def no_arguments?
|
59
|
+
required_args.empty? && optional_args.empty? && required_kw_args.empty? && optional_kw_args.empty? && !has_rest_args
|
44
60
|
end
|
45
61
|
|
46
62
|
end
|
@@ -1,10 +1,13 @@
|
|
1
1
|
en:
|
2
2
|
adhoc_jobs: Adhoc Jobs
|
3
3
|
adhoc_jobs_actions: Actions
|
4
|
+
adhoc_jobs_required_keyword_arguments: Required Keyword Arguments
|
5
|
+
adhoc_jobs_optional_keyword_arguments: Optional Keyword Arguments
|
4
6
|
adhoc_jobs_required_arguments: Required Arguments
|
5
7
|
adhoc_jobs_optional_arguments: Optional Arguments
|
6
8
|
adhoc_jobs_go_back: Go Back
|
7
9
|
adhoc_jobs_has_rest_arguments: Has Rest Arguments
|
10
|
+
adhoc_jobs_confirm_required: Confirm Required
|
8
11
|
adhoc_jobs_name: Job Name
|
9
12
|
adhoc_jobs_queue: Job Queue
|
10
13
|
adhoc_jobs_run_job: Run Job
|
@@ -5,7 +5,7 @@ module SidekiqAdhocJob
|
|
5
5
|
|
6
6
|
def self.register(app)
|
7
7
|
app.get '/adhoc-jobs' do
|
8
|
-
@presented_jobs = SidekiqAdhocJob::Web::JobPresenter.build_collection
|
8
|
+
@presented_jobs = SidekiqAdhocJob::Web::JobPresenter.build_collection.sort_by { |j| j.name.to_s }
|
9
9
|
|
10
10
|
erb File.read(File.join(VIEW_PATH, 'jobs/index.html.erb'))
|
11
11
|
end
|
@@ -8,7 +8,10 @@
|
|
8
8
|
<th><%= t('adhoc_jobs_queue') %></th>
|
9
9
|
<th><%= t('adhoc_jobs_required_arguments') %></th>
|
10
10
|
<th><%= t('adhoc_jobs_optional_arguments') %></th>
|
11
|
+
<th><%= t('adhoc_jobs_required_keyword_arguments') %></th>
|
12
|
+
<th><%= t('adhoc_jobs_optional_keyword_arguments') %></th>
|
11
13
|
<th><%= t('adhoc_jobs_has_rest_arguments') %></th>
|
14
|
+
<th><%= t('adhoc_jobs_confirm_required') %></th>
|
12
15
|
<th><%= t('adhoc_jobs_actions') %></th>
|
13
16
|
</tr>
|
14
17
|
</thead>
|
@@ -20,7 +23,10 @@
|
|
20
23
|
<td><%= job.queue %></td>
|
21
24
|
<td><%= job.required_args.join(', ') %></td>
|
22
25
|
<td><%= job.optional_args.join(', ') %></td>
|
26
|
+
<td><%= job.required_kw_args.join(', ') %></td>
|
27
|
+
<td><%= job.optional_kw_args.join(', ') %></td>
|
23
28
|
<td><%= job.has_rest_args %></td>
|
29
|
+
<td><%= job.require_confirm %></td>
|
24
30
|
<td class="text-center">
|
25
31
|
<a class="btn btn-warn btn-xs" href="<%= root_path %>adhoc-jobs/<%= CGI.escape(job.path_name) %>">
|
26
32
|
<%= t('adhoc_jobs_view_job') %>
|
@@ -2,9 +2,9 @@
|
|
2
2
|
|
3
3
|
<h4><%= SidekiqAdhocJob::Utils::String.classify(@presented_job.path_name) %></h4>
|
4
4
|
|
5
|
-
<form method="POST" action="<%= root_path %>adhoc-jobs/<%= CGI.escape(@presented_job.path_name) %>/schedule">
|
5
|
+
<form method="POST" action="<%= root_path %>adhoc-jobs/<%= CGI.escape(@presented_job.path_name) %>/schedule" id="adhoc-jobs-submit-form">
|
6
6
|
<input type="hidden" name="authenticity_token" value="<%= @csrf_token %>" />
|
7
|
-
<% if @presented_job.
|
7
|
+
<% if @presented_job.no_arguments? %>
|
8
8
|
<p>No job arguments</p>
|
9
9
|
<% else %>
|
10
10
|
<% @presented_job.required_args.each do |arg| %>
|
@@ -23,6 +23,22 @@
|
|
23
23
|
</div>
|
24
24
|
</div>
|
25
25
|
<% end %>
|
26
|
+
<% @presented_job.required_kw_args.each do |arg| %>
|
27
|
+
<div class="form-group row">
|
28
|
+
<label class="col-sm-2 col-form-label" for="<%= arg %>"><%= arg %>:</label>
|
29
|
+
<div class="col-sm-4">
|
30
|
+
<input class="form-control" type="text" name="<%= arg %>" id="<%= arg %>" required/>
|
31
|
+
</div>
|
32
|
+
</div>
|
33
|
+
<% end %>
|
34
|
+
<% @presented_job.optional_kw_args.each do |arg| %>
|
35
|
+
<div class="form-group row">
|
36
|
+
<label class="col-sm-2 col-form-label" for="<%= arg %>"><%= arg %>:</label>
|
37
|
+
<div class="col-sm-4">
|
38
|
+
<input class="form-control" type="text" name="<%= arg %>" id="<%= arg %>"/>
|
39
|
+
</div>
|
40
|
+
</div>
|
41
|
+
<% end %>
|
26
42
|
<% if @presented_job.has_rest_args %>
|
27
43
|
<div class="form-group row">
|
28
44
|
<label class="col-sm-2 col-form-label" for="rest_args">Rest arguments (please provide a json string representing the arguments):</label>
|
@@ -39,3 +55,12 @@
|
|
39
55
|
</div>
|
40
56
|
</div>
|
41
57
|
</form>
|
58
|
+
|
59
|
+
<% if @presented_job.require_confirm %>
|
60
|
+
<script>
|
61
|
+
document.getElementById('adhoc-jobs-submit-form').addEventListener('submit', (event) => {
|
62
|
+
if (!confirm('Are you sure?'))
|
63
|
+
event.preventDefault();
|
64
|
+
})
|
65
|
+
</script>
|
66
|
+
<% end %>
|
data/lib/sidekiq_adhoc_job.rb
CHANGED
@@ -41,7 +41,10 @@ module SidekiqAdhocJob
|
|
41
41
|
end
|
42
42
|
|
43
43
|
class Configuration
|
44
|
-
attr_accessor :load_paths,
|
44
|
+
attr_accessor :load_paths,
|
45
|
+
:module_names,
|
46
|
+
:strategy_name,
|
47
|
+
:require_confirm_worker_names
|
45
48
|
|
46
49
|
def initialize
|
47
50
|
@load_paths = []
|
@@ -53,6 +56,14 @@ module SidekiqAdhocJob
|
|
53
56
|
Array(@module_names).map(&:to_s)
|
54
57
|
end
|
55
58
|
|
59
|
+
def require_confirm
|
60
|
+
@require_confirm ||= Array(@require_confirm_worker_names).map(&:to_s)
|
61
|
+
end
|
62
|
+
|
63
|
+
def require_confirmation?(worker_name)
|
64
|
+
require_confirm.include?(worker_name)
|
65
|
+
end
|
66
|
+
|
56
67
|
def strategy
|
57
68
|
@strategy ||= case strategy_name
|
58
69
|
when :default
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sidekiq_adhoc_job
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Goh Khoon Hiang
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-03-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: pry
|