Skip to content

Commit

Permalink
Merge pull request #18114 from gtanzillo/fix-tag-expression-on-not-ta…
Browse files Browse the repository at this point in the history
…ggable-class

Check if class is taggable before attempting to process tag expression

(cherry picked from commit 6fa29c2)

Fixes https://bugzilla.redhat.com/show_bug.cgi?id=1641012
  • Loading branch information
jrafanie authored and simaishi committed Oct 22, 2018
1 parent b310e6f commit 371a21f
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/rbac/filterer.rb
Original file line number Diff line number Diff line change
Expand Up @@ -489,9 +489,9 @@ def get_belongsto_filter_object_ids(klass, filter)
end

def get_managed_filter_object_ids(scope, filter)
return scope.where(filter.to_sql.first) if filter.kind_of?(MiqExpression)
klass = scope.respond_to?(:klass) ? scope.klass : scope
return nil if !TAGGABLE_FILTER_CLASSES.include?(safe_base_class(klass).name) || filter.blank?
return scope.where(filter.to_sql.first) if filter.kind_of?(MiqExpression)
scope.find_tags_by_grouping(filter, :ns => '*').reorder(nil)
end

Expand Down
18 changes: 18 additions & 0 deletions spec/lib/rbac/filterer_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,24 @@
expect(actual).to match(expected)
end

it "doesn't filter by tags on classes that are not taggable" do
filter = MiqExpression.new(
"AND" => [
{"CONTAINS" => {"tag" => "managed-environment", "value" => "prod"}},
{"CONTAINS" => {"tag" => "managed-environment", "value" => "test"}}
]
)
group = create_group_with_expression(filter)
user = FactoryGirl.create(:user, :miq_groups => [group])
request = FactoryGirl.create(:miq_provision_request, :tenant => owner_tenant, :requester => user)

actual, = Rbac::Filterer.search(:targets => MiqProvisionRequest, :user => user)

expect(request.class.include?(ActsAsTaggable)).to be_falsey
expected = [request]
expect(actual).to match(expected)
end

def create_group_with_expression(expression)
role = FactoryGirl.create(:miq_user_role)
group = FactoryGirl.create(:miq_group, :tenant => Tenant.root_tenant, :miq_user_role => role)
Expand Down

0 comments on commit 371a21f

Please sign in to comment.