diff --git a/app/controllers/reducers_controller.rb b/app/controllers/reducers_controller.rb
index 3afaabdd6..2a9154066 100644
--- a/app/controllers/reducers_controller.rb
+++ b/app/controllers/reducers_controller.rb
@@ -46,6 +46,8 @@ def create
filters['extractor_keys'] = JSON.parse(filters['extractor_keys'])
end
+ reset_config_reducer_keys(new_params)
+
@reducer = reducer_class.new(new_params)
respond_to do |format|
@@ -72,6 +74,8 @@ def update
filters['extractor_keys'] = JSON.parse(filters['extractor_keys'])
end
+ reset_config_reducer_keys(params)
+
@reducer.update(params)
respond_to do |format|
@@ -122,6 +126,8 @@ def reducer_params(klass)
params.require(:reducer).permit(
:key,
:topic,
+ :user_reducer_keys,
+ :subject_reducer_keys,
*klass.configuration_fields.keys,
filters: {},
grouping: {},
@@ -131,4 +137,15 @@ def reducer_params(klass)
def record_not_valid(exception)
render json: { error: exception.message }, status: 422
end
+
+ def reset_config_reducer_keys(param_object)
+ if param_object[:topic] == 'reduce_by_subject'
+ param_object[:subject_reducer_keys] = nil
+ elsif param_object[:topic] == 'reduce_by_user'
+ param_object[:user_reducer_keys] = nil
+ else
+ param_object[:subject_reducer_keys] = nil
+ param_object[:user_reducer_keys] = nil
+ end
+ end
end
diff --git a/app/views/reducers/_form.html.erb b/app/views/reducers/_form.html.erb
index 6045e10c5..16b3c5bbd 100644
--- a/app/views/reducers/_form.html.erb
+++ b/app/views/reducers/_form.html.erb
@@ -15,6 +15,15 @@
<%= f.input :reducible_type, :as => :hidden %>
+
+ <%= f.input :user_reducer_keys%>
+
+
+
+
+ <%= f.input :subject_reducer_keys%>
+
+
@@ -50,3 +59,25 @@
<%= link_to 'Back', project_path(@reducible, anchor: 'reducers'), class: 'btn btn-default' %>
<% end %>
<% end %>
+
+
\ No newline at end of file
diff --git a/spec/controllers/reducers_controller_spec.rb b/spec/controllers/reducers_controller_spec.rb
index b9547228b..5243d58ba 100644
--- a/spec/controllers/reducers_controller_spec.rb
+++ b/spec/controllers/reducers_controller_spec.rb
@@ -147,6 +147,44 @@
reducer: {key: nil, type: 'external'}}
expect(response.status).to eq(200)
end
+
+ context 'when topic is reduce_by_subject' do
+ it 'sets subject_reducer_keys to nil' do
+ put :update, params: {
+ workflow_id: workflow.id,
+ id: reducer.id,
+ reducer: {
+ url: 'https://example.org/2',
+ user_reducer_keys: 'user_reducer_keys_value',
+ subject_reducer_keys: 'subject_reducer_keys',
+ topic: 'reduce_by_subject'
+ }
+ }
+
+ reducer.reload
+ expect(reducer.subject_reducer_keys).to be_nil
+ expect(reducer.user_reducer_keys).to eq('user_reducer_keys_value')
+ end
+ end
+
+ context 'when topic is not reduce_by_subject' do
+ it 'sets user_reducer_keys to nil' do
+ put :update, params: {
+ workflow_id: workflow.id,
+ id: reducer.id,
+ reducer: {
+ url: 'https://example.org/2',
+ user_reducer_keys: 'user_reducer_keys_value',
+ subject_reducer_keys: 'subject_reducer_keys_value',
+ topic: 'reduce_by_user'
+ }
+ }
+
+ reducer.reload
+ expect(reducer.subject_reducer_keys).to eq('subject_reducer_keys_value')
+ expect(reducer.user_reducer_keys).to be_nil
+ end
+ end
end
end
end