/*
* 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.exoplatform.services.jcr.impl.core.query;
import org.exoplatform.services.jcr.impl.core.SessionDataManager;
import org.exoplatform.services.jcr.impl.core.SessionImpl;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import javax.jcr.Node;
import javax.jcr.RepositoryException;
import javax.jcr.query.InvalidQueryException;
import javax.jcr.query.Query;
import javax.jcr.query.QueryManager;
/**
* This class implements the {@link QueryManager} interface.
*/
public class QueryManagerImpl implements QueryManager
{
/**
* Defines all supported query languages
*/
private static final String[] SUPPORTED_QUERIES = QueryTreeBuilderRegistry.getSupportedLanguages();
/**
* List of all supported query languages
*/
private static final List<String> SUPPORTED_QUERIES_LIST = Collections.unmodifiableList(Arrays.asList(SUPPORTED_QUERIES));
/**
* The <code>Session</code> for this QueryManager.
*/
private final SessionImpl session;
/**
* The <code>ItemManager</code> of for item retrieval in search results
*/
private final SessionDataManager itemMgr;
/**
* The <code>SearchManager</code> holding the search index.
*/
private final SearchManager searchMgr;
/**
* Creates a new <code>QueryManagerImpl</code> for the passed <code>session</code>
*
* @param session
* @param itemMgr
* @param searchMgr
*/
public QueryManagerImpl(SessionImpl session, SessionDataManager itemMgr, SearchManager searchMgr)
{
this.session = session;
this.itemMgr = itemMgr;
this.searchMgr = searchMgr;
}
/**
* {@inheritDoc}
*/
public Query createQuery(String statement, String language) throws InvalidQueryException, RepositoryException
{
sanityCheck();
return searchMgr.createQuery(session, itemMgr, statement, language);
}
/**
* {@inheritDoc}
*/
public Query getQuery(Node node) throws InvalidQueryException, RepositoryException
{
sanityCheck();
return searchMgr.createQuery(session, itemMgr, node);
}
/**
* {@inheritDoc}
*/
public String[] getSupportedQueryLanguages() throws RepositoryException
{
return (String[])SUPPORTED_QUERIES_LIST.toArray(new String[SUPPORTED_QUERIES.length]);
}
// ---------------------------< internal >-----------------------------------
/**
* Checks if this <code>QueryManagerImpl</code> instance is still usable, otherwise throws a
* {@link javax.jcr.RepositoryException}.
*
* @throws RepositoryException
* if this query manager is not usable anymore, e.g. the corresponding session is
* closed.
*/
private void sanityCheck() throws RepositoryException
{
if (!session.isLive() && !SessionImpl.ALLOW_CLOSED_SESSION_USAGE)
{
throw new RepositoryException("corresponding session has been closed");
}
}
//------------------------< testing only >----------------------------------
/**
* @return the query handler implementation.
*/
public QueryHandler getQueryHandler() {
return searchMgr.getHandler();
}
}