/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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 org.apache.camel.component.hbase.filters; import java.util.List; import org.apache.camel.CamelContext; import org.apache.camel.component.hbase.model.HBaseRow; import org.apache.hadoop.hbase.filter.Filter; import org.apache.hadoop.hbase.filter.FilterList; public class ModelAwareFilterList implements ModelAwareFilter<FilterList> { FilterList fl; /** * Default constructor, filters nothing. Required though for RPC deserialization. */ public ModelAwareFilterList() { fl = new FilterList(); //it's worth to prevent the class against null pointer on fl } /** * Constructor that takes a set of {@link org.apache.hadoop.hbase.filter.Filter}s. The default operator * MUST_PASS_ALL is assumed. * * @param rowFilters list of filters */ public ModelAwareFilterList(List<Filter> rowFilters) { fl = new FilterList(rowFilters); } /** * Constructor that takes an operator. * * @param operator Operator to process filter set with. */ public ModelAwareFilterList(FilterList.Operator operator) { fl = new FilterList(operator); } /** * Constructor that takes a set of {@link org.apache.hadoop.hbase.filter.Filter}s and an operator. * * @param operator Operator to process filter set with. * @param rowFilters Set of row filters. */ public ModelAwareFilterList(FilterList.Operator operator, List<Filter> rowFilters) { fl = new FilterList(operator, rowFilters); } /** * Applies the message to {@link org.apache.hadoop.hbase.filter.Filter} to context. */ @Override public void apply(CamelContext context, HBaseRow rowModel) { for (Filter filter : getFilters()) { if (ModelAwareFilter.class.isAssignableFrom(filter.getClass())) { //probably and is assignable from filter ((ModelAwareFilter<?>) filter).apply(context, rowModel); } } } /** * Wraps an existing {@link FilterList} filter into a {@link ModelAwareFilterList}. */ public static ModelAwareFilterList wrap(FilterList filter) { return new ModelAwareFilterList(filter.getOperator(), filter.getFilters()); } public List<Filter> getFilters() { return fl.getFilters(); } public void addFilter(Filter filter) { getFilters().add(filter); } @Override public FilterList getFilteredList() { return fl; } }