diff options
Diffstat (limited to 'java/com/google/gerrit/server/query/change/OwnerinPredicate.java')
-rw-r--r-- | java/com/google/gerrit/server/query/change/OwnerinPredicate.java | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/java/com/google/gerrit/server/query/change/OwnerinPredicate.java b/java/com/google/gerrit/server/query/change/OwnerinPredicate.java new file mode 100644 index 0000000000..c48bdd5673 --- /dev/null +++ b/java/com/google/gerrit/server/query/change/OwnerinPredicate.java @@ -0,0 +1,47 @@ +// Copyright (C) 2011 The Android Open Source Project +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package com.google.gerrit.server.query.change; + +import com.google.gerrit.index.query.PostFilterPredicate; +import com.google.gerrit.reviewdb.client.AccountGroup; +import com.google.gerrit.reviewdb.client.Change; +import com.google.gerrit.server.IdentifiedUser; +import com.google.gwtorm.server.OrmException; + +public class OwnerinPredicate extends PostFilterPredicate<ChangeData> { + protected final IdentifiedUser.GenericFactory userFactory; + protected final AccountGroup.UUID uuid; + + public OwnerinPredicate(IdentifiedUser.GenericFactory userFactory, AccountGroup.UUID uuid) { + super(ChangeQueryBuilder.FIELD_OWNERIN, uuid.get()); + this.userFactory = userFactory; + this.uuid = uuid; + } + + @Override + public boolean match(ChangeData object) throws OrmException { + final Change change = object.change(); + if (change == null) { + return false; + } + final IdentifiedUser owner = userFactory.create(change.getOwner()); + return owner.getEffectiveGroups().contains(uuid); + } + + @Override + public int getCost() { + return 2; + } +} |