Package org.apache.jackrabbit.core.query

Source Code of org.apache.jackrabbit.core.query.AbstractQueryHandler

/*
* 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.core.query;

import org.apache.commons.io.IOExceptionWithCause;
import org.apache.jackrabbit.core.fs.FileSystem;
import org.apache.jackrabbit.core.fs.FileSystemException;
import org.apache.jackrabbit.core.id.NodeId;
import org.apache.jackrabbit.core.state.NodeState;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.jcr.RepositoryException;
import java.io.IOException;
import java.util.Iterator;

/**
* Implements default behaviour for some methods of {@link QueryHandler}.
*/
public abstract class AbstractQueryHandler implements QueryHandler {

    /**
     * Logger instance for this class
     */
    private static final Logger log = LoggerFactory.getLogger(AbstractQueryHandler.class);

    /**
     * Search index file system, or <code>null</code>
     */
    protected FileSystem fs;

    /**
     * The context for this query handler.
     */
    private QueryHandlerContext context;

    /**
     * The {@link OnWorkspaceInconsistency} handler. Defaults to 'fail'.
     */
    private OnWorkspaceInconsistency owi = OnWorkspaceInconsistency.FAIL;

    /**
     * The name of a class that extends {@link AbstractQueryImpl}.
     */
    private String queryClass = QueryImpl.class.getName();

    /**
     * The max idle time for this query handler until it is stopped. This
     * property is actually not used anymore.
     */
    private String idleTime;

    /**
     * Initializes this query handler by setting all properties in this class
     * with appropriate parameter values.
     *
     * @param fs search index file system, or <code>null</code>
     * @param context the context for this query handler.
     */
    public final void init(FileSystem fs, QueryHandlerContext context)
            throws IOException {
        this.fs = fs;
        this.context = context;
        doInit();
    }

    public void close() throws IOException {
        if (fs != null) {
            try {
                fs.close();
            } catch (FileSystemException e) {
                throw new IOExceptionWithCause(
                        "Unable to close search index file system: " + fs, e);
            }
        }
    }

    /**
     * This method must be implemented by concrete sub classes and will be
     * called from {@link #init}.
     *
     * @throws IOException If an error occurs.
     */
    protected abstract void doInit() throws IOException;

    /**
     * Returns the context for this query handler.
     *
     * @return the <code>QueryHandlerContext</code> instance for this
     *         <code>QueryHandler</code>.
     */
    public QueryHandlerContext getContext() {
        return context;
    }

    /**
     * This default implementation calls the individual {@link #deleteNode(org.apache.jackrabbit.core.NodeId)}
     * and {@link #addNode(org.apache.jackrabbit.core.state.NodeState)} methods
     * for each entry in the iterators. First the nodes to remove are processed
     * then the nodes to add.
     *
     * @param remove uuids of nodes to remove.
     * @param add NodeStates to add.
     * @throws RepositoryException if an error occurs while indexing a node.
     * @throws IOException if an error occurs while updating the index.
     */
    public synchronized void updateNodes(
            Iterator<NodeId> remove, Iterator<NodeState> add)
            throws RepositoryException, IOException {
        while (remove.hasNext()) {
            deleteNode(remove.next());
        }
        while (add.hasNext()) {
            addNode(add.next());
        }
    }

    /**
     * @return the {@link OnWorkspaceInconsistency} handler.
     */
    public OnWorkspaceInconsistency getOnWorkspaceInconsistencyHandler() {
        return owi;
    }

    //--------------------------< properties >----------------------------------

    /**
     * Sets the {@link OnWorkspaceInconsistency} handler with the given name.
     * Currently the only valid name is:
     * <ul>
     * <li><code>fail</code></li>
     * </ul>
     *
     * @param name the name of a {@link OnWorkspaceInconsistency} handler.
     */
    public void setOnWorkspaceInconsistency(String name) {
        owi = OnWorkspaceInconsistency.fromString(name);
    }

    /**
     * @return the name of the currently set {@link OnWorkspaceInconsistency}.
     */
    public String getOnWorkspaceInconsistency() {
        return owi.getName();
    }

    /**
     * Sets the name of the query class to use.
     *
     * @param queryClass the name of the query class to use.
     */
    public void setQueryClass(String queryClass) {
        this.queryClass = queryClass;
    }

    /**
     * @return the name of the query class to use.
     */
    public String getQueryClass() {
        return queryClass;
    }

    /**
     * Sets the query handler idle time.
     * @deprecated
     * This parameter is not supported any more.
     * Please use 'maxIdleTime' in the repository configuration.
     *
     * @param idleTime the query handler idle time.
     */
    public void setIdleTime(String idleTime) {
        log.warn("Parameter 'idleTime' is not supported anymore. "
                + "Please use 'maxIdleTime' in the repository configuration.");
        this.idleTime = idleTime;
    }

    /**
     * @return the query handler idle time.
     */
    public String getIdleTime() {
        return idleTime;
    }

}
TOP

Related Classes of org.apache.jackrabbit.core.query.AbstractQueryHandler

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.