All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.jackrabbit.oak.api.jmx.QueryEngineSettingsMBean Maven / Gradle / Ivy

There is a newer version: 1.74.0
Show newest version
/*
 * 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.jackrabbit.oak.api.jmx;

import org.osgi.annotation.versioning.ProviderType;

@ProviderType
public interface QueryEngineSettingsMBean {
    String TYPE = "QueryEngineSettings";
    
    /**
     * Get the limit on how many nodes a query may read at most into memory, for
     * "order by" and "distinct" queries. If this limit is exceeded, the query
     * throws an exception.
     * 
     * @return the limit
     */
    @Description("Get the limit on how many nodes a query may read at most into memory, for " +
            "\"order by\" and \"distinct\" queries. If this limit is exceeded, the query throws an exception.")    
    long getLimitInMemory();
    
    /**
     * Change the limit.
     * 
     * @param limitInMemory the new limit
     */
    void setLimitInMemory(long limitInMemory);
    
    /**
     * Get the limit on how many nodes a query may read at most (raw read
     * operations, including skipped nodes). If this limit is exceeded, the
     * query throws an exception.
     * 
     * @return the limit
     */
    @Description("Get the limit on how many nodes a query may read at most (raw read " +
            "operations, including skipped nodes). If this limit is exceeded, the " +
            "query throws an exception.")    
    long getLimitReads();
    
    /**
     * Change the limit.
     * 
     * @param limitReads the new limit
     */
    void setLimitReads(long limitReads);
    
    /**
     * Whether queries that don't use an index will fail (throw an exception).
     * The default is false.
     * 
     * @return true if they fail
     */
    @Description("Whether queries that don't use an index will fail (throw an exception). " +
            "The default is false.")    
    boolean getFailTraversal();

    /**
     * Set whether queries that don't use an index will fail (throw an exception).
     * 
     * @param failTraversal the new value for this setting
     */
    void setFailTraversal(boolean failTraversal);

    /**
     * Whether the query result size should return an estimation for large queries.
     *
     * @return true if enabled
     */
    @Description("Whether the query result size should return an estimation for large queries.")    
    boolean isFastQuerySize();

    void setFastQuerySize(boolean fastQuerySize);

    /**
     * Whether Path restrictions are enabled while figuring out index plan
     *
     * @return true if enabled
     */
    String getStrictPathRestriction();

    /**
     *  Whether path restrictions of indexes (excludedPaths / includedPaths) are taken into account during query execution,
     *  for Lucene indexes. When enabled, only indexes are considered if the index path restriction is compatible with the
     *  query path restrictions. When disabled, only the queryPaths of the index is taken into account.
     *
     * @param pathRestriction Set path restriction: Expected value is either of ENABLE/DISABLE/WARN
     *                        ENABLE: enable path restriction- Index won't be used if index definition path restrictions are not compatible with query's path restriction
     *                        DISABLE: path restrictions are not taken into account while querying
     *                        WARN: path restrictions are not taken into account but a warning will be logged if query path restrictions are not compatible with index path restrictions 
     */
     @Description("Set path restriction: Expected value is either of ENABLE/DISABLE/WARN.   " +
                    "ENABLE: enable path restriction- Index won't be used if index definition path restrictions are not compatible with query's path restriction.  " +
                    "DISABLE: path restrictions are not taken into account while querying.  " +
                    "WARN: path restrictions are not taken into account but a warning will be logged if query path restrictions are not compatible with index path restrictions."
                    )
    void setStrictPathRestriction(
            @Name("pathRestriction")
                    String pathRestriction);

    /**
     * Set or remove a query validator pattern.
     *
     * @param key the key
     * @param pattern the regular expression pattern (empty to remove the
     *            pattern)
     * @param comment a comment
     * @param failQuery whether matching queries should fail (true) or just log
     *            a warning (false)
     */
    @Description("Set or remove a query validator pattern.")
    void setQueryValidatorPattern(
            @Description("the key")
            @Name("key")
            String key,
            @Description("the regular expression pattern (empty to remove the pattern)")
            @Name("pattern")
            String pattern,
            @Description("a comment")
            @Name("comment")
            String comment,
            @Description("whether matching queries should fail (true) or just log a warning (false)")
            @Name("failQuery")
            boolean failQuery);

    @Description("Get the query validator data as a JSON string.")
    String getQueryValidatorJson();

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy