/*
* Copyright DataStax, Inc.
*
* 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.datastax.oss.driver.internal.core.metadata.schema.queries;
import edu.umd.cs.findbugs.annotations.NonNull;
import java.util.List;
Filters keyspaces during schema metadata queries.
Depending on the circumstances, we do it either on the server side with a WHERE IN clause that
will be appended to every query, or on the client side with a predicate that will be applied to
every fetched row.
/**
* Filters keyspaces during schema metadata queries.
*
* <p>Depending on the circumstances, we do it either on the server side with a WHERE IN clause that
* will be appended to every query, or on the client side with a predicate that will be applied to
* every fetched row.
*/
public interface KeyspaceFilter {
static KeyspaceFilter newInstance(@NonNull String logPrefix, @NonNull List<String> specs) {
if (specs.isEmpty()) {
return INCLUDE_ALL;
} else {
return new RuleBasedKeyspaceFilter(logPrefix, specs);
}
}
The WHERE IN clause, or an empty string if there is no server-side filtering. /** The WHERE IN clause, or an empty string if there is no server-side filtering. */
@NonNull
String getWhereClause();
The predicate that will be invoked for client-side filtering. /** The predicate that will be invoked for client-side filtering. */
boolean includes(@NonNull String keyspace);
KeyspaceFilter INCLUDE_ALL =
new KeyspaceFilter() {
@NonNull
@Override
public String getWhereClause() {
return "";
}
@Override
public boolean includes(@NonNull String keyspace) {
return true;
}
};
}