Skip to content

Commit

Permalink
Add scopes for MiqRequest
Browse files Browse the repository at this point in the history
  • Loading branch information
tumido committed Feb 5, 2018
1 parent c047155 commit 1ead08f
Show file tree
Hide file tree
Showing 5 changed files with 156 additions and 192 deletions.
6 changes: 3 additions & 3 deletions app/assets/javascripts/controllers/report_data_controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@
} else if (event.type === TOOLBAR_CLICK_FINISH && (tileViewSelector() || tableViewSelector())) {
this.setExtraClasses(this.initObject.gtlType);
} else if (event.refreshData && event.refreshData.name === CONTROLLER_NAME) {
this.refreshData();
this.refreshData(event.data);
}

if (event.controller === CONTROLLER_NAME && this.apiFunctions && this.apiFunctions[event.action]) {
Expand Down Expand Up @@ -143,8 +143,8 @@
vm.perPage = defaultPaging();
};

ReportDataController.prototype.refreshData = function() {
this.initController(this.initObject);
ReportDataController.prototype.refreshData = function(data) {
this.initController(_.merge(this.initObject, data));
};

ReportDataController.prototype.setSort = function(headerId, isAscending) {
Expand Down
2 changes: 0 additions & 2 deletions app/controllers/application_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -373,8 +373,6 @@ def process_params_options(params)
# handle exceptions
if params[:model_name]
options = case params[:model_name]
when 'MiqRequest'
page_display_options
when 'miq_tasks'
jobs_info
when 'physical_servers_with_host'
Expand Down
83 changes: 21 additions & 62 deletions app/controllers/miq_request_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -52,19 +52,11 @@ def request_copy
end

def page_display_options
resource_type = request_tab_type
time_period = 7
if is_approver && (!@sb[:prov_options] || (@sb[:prov_options] && !@sb[:prov_options].key?(resource_type.to_sym)))
gv_options = {:filter => prov_condition(:resource_type => resource_type, :time_period => time_period)}
elsif @sb[:prov_options] && @sb[:prov_options].key?(resource_type.to_sym) # added this here so grid can be drawn when page redraws, when there were no records on initial load.
prov_set_default_options if @sb[:def_prov_options][:applied_states].blank? && !params[:button] == "apply" # no filter statuses selected, setting to default
gv_options = {:filter => prov_condition(@sb[:def_prov_options][resource_type.to_sym])}
if @sb[:prov_options] && @sb[:prov_options].key?(request_tab_type.to_sym)
{:named_scope => prov_scope(@sb[:def_prov_options][request_tab_type.to_sym])}
else
gv_options = {:filter => prov_condition(:resource_type => resource_type,
:time_period => time_period,
:requester_id => current_user.try(:id))}
{}
end
gv_options
end

# Show the main Requests list view
Expand Down Expand Up @@ -326,9 +318,10 @@ def prov_button
end
show_list

options = {"additionalOptions" => page_display_options}
render :update do |js|
js << javascript_prologue
js << 'sendDataWithRx({refreshData: {name: "reportDataController"}});'
js << "sendDataWithRx({refreshData: {name: \"reportDataController\"}, data: #{options.to_json}});"
end
end

Expand Down Expand Up @@ -396,47 +389,21 @@ def request_tab_type
end
end

def remote_and_global_requestors(requestor)
condition = []
requestors = User.where(:userid => requestor.try(:userid))
if requestors.count > 1
condition.push("or" => requestors.collect { |user| {"=" => {"value" => user.id, "field" => "MiqRequest-requester_id"}} })
else
condition.push("=" => {"value" => requestor.try(:id), "field" => "MiqRequest-requester_id"})
end
end

# Create a condition from the passed in options
def prov_condition(opts)
cond = [{"AFTER" => {"value" => "#{opts[:time_period].to_i} Days Ago", "field" => "MiqRequest-created_on"}}] # Start with setting time

unless is_approver
cond.push(*remote_and_global_requestors(current_user))
end

if opts[:user_choice] && opts[:user_choice] != "all"
cond.push(*remote_and_global_requestors(User.find_by(:id => opts[:user_choice])))
end

if (a_s = opts[:applied_states].presence)
cond.push("or" => a_s.collect { |s| {"=" => {"value" => s, "field" => "MiqRequest-approval_state"}} })
end
def prov_scope(opts)
scope = []
# Request date (created since X days ago)
scope << [:created_recently, opts[:time_period].to_i] if opts[:time_period].present?
# Select requester user across regions
scope << [:with_requester, current_user.id] unless is_approver
scope << [:with_requester, opts[:user_choice]] if opts[:user_choice] && opts[:user_choice] != "all"

cond.push("or" => request_types_for_model.keys.collect { |k| {"=" => {"value" => k.to_s, "field" => "MiqRequest-type"}} })
scope << [:with_approval_state, opts[:applied_states]] if opts[:applied_states].present?
scope << [:with_type, MiqRequest::MODEL_REQUEST_TYPES[model_request_type_from_layout].keys]
scope << [:with_request_type, opts[:type_choice]] if opts[:type_choice] && opts[:type_choice] != "all"
scope << [:with_reason_like, opts[:reason_text]] if opts[:reason_text].present?

if opts[:type_choice] && opts[:type_choice] != "all" # Add request_type filter, if selected
cond.push("=" => {"value" => opts[:type_choice], "field" => "MiqRequest-request_type"})
end

if (text = opts[:reason_text].presence)
cond.push(prov_condition_reason_text_expression_key(text) => {"value" => prov_condition_reason_text_sanitized(text), "field" => "MiqRequest-reason"})
end

MiqExpression.new("and" => cond)
end

def request_types_for_model
MiqRequest::MODEL_REQUEST_TYPES[model_request_type_from_layout].map { |k, v| [k, v.map { |x, y| [x, _(y)] }.to_h] }.to_h
scope
end

def model_request_type_from_layout
Expand All @@ -447,18 +414,10 @@ def model_request_type_from_layout
end
end

def prov_condition_reason_text_sanitized(text)
text.sub(/\A\*?(.+?)\*?\z/, '\1') # Remove leading and/or trailing "*"
end

def prov_condition_reason_text_expression_key(text)
return "STARTS WITH" if text =~ /\A\*(.+?)[^*]\z/ # Starts with and does not end with "*"
return "ENDS WITH" if text =~ /\A[^*](.+?)\*\z/ # Ends with and does not start with "*"
"INCLUDES"
end

def request_types_for_dropdown
request_types_for_model.values.each_with_object({}) { |t, h| t.each { |k, v| h[k] = v } }
MiqRequest::MODEL_REQUEST_TYPES[model_request_type_from_layout].values.reduce({}) do |hash, item|
hash.merge(item) { |_key, val| _(val) }
end
end

# Set all task options to default
Expand All @@ -470,7 +429,7 @@ def prov_set_default_options
opts[:types] = request_types_for_dropdown

opts[:users] = Rbac::Filterer.filtered(MiqRequest.where(
:type => request_types_for_model.keys,
:type => MiqRequest::MODEL_REQUEST_TYPES[model_request_type_from_layout].keys,
:created_on => (30.days.ago.utc)..(Time.now.utc)
)).each_with_object({}) do |r, h|
h[r.requester_id] = if r.requester.nil?
Expand Down
Loading

0 comments on commit 1ead08f

Please sign in to comment.