/*
* Copyright 2008 Alin Dreghiciu.
*
* 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 org.qi4j.index.rdf.query;
import java.util.HashMap;
import java.util.Map;
import org.openrdf.model.Value;
import org.openrdf.model.impl.ValueFactoryImpl;
import org.openrdf.query.QueryLanguage;
import org.qi4j.api.entity.EntityReference;
import org.qi4j.api.injection.scope.Service;
import org.qi4j.api.injection.scope.This;
import org.qi4j.api.mixin.Mixins;
import org.qi4j.api.query.grammar.BooleanExpression;
import org.qi4j.api.query.grammar.OrderBy;
import org.qi4j.api.service.ServiceComposite;
import org.qi4j.spi.query.EntityFinder;
import org.qi4j.spi.query.EntityFinderException;
import org.qi4j.spi.query.NamedEntityFinder;
import org.qi4j.spi.query.NamedQueryDescriptor;
/**
* JAVADOC Add JavaDoc
*/
@Mixins( { RdfQueryService.RdfEntityFinderMixin.class, RdfQueryService.RdfNamedEntityFinderMixin.class } )
public interface RdfQueryService
extends EntityFinder, NamedEntityFinder, RdfQueryParserFactory, ServiceComposite
{
/**
* JAVADOC Add JavaDoc
* JAVADOC shall we support different implementation as SERQL?
*/
public static class RdfEntityFinderMixin
implements EntityFinder
{
private static final QueryLanguage language = QueryLanguage.SPARQL;
@Service
private RdfQueryParserFactory queryParserFactory;
@This
TupleQueryExecutor tupleExecutor;
public Iterable<EntityReference> findEntities( Class<?> resultType,
BooleanExpression whereClause,
OrderBy[] orderBySegments,
Integer firstResult,
Integer maxResults
)
throws EntityFinderException
{
CollectingQualifiedIdentityResultCallback collectingCallback = new CollectingQualifiedIdentityResultCallback();
RdfQueryParser rdfQueryParser = queryParserFactory.newQueryParser( language );
String query = rdfQueryParser.getQuery( resultType, whereClause, orderBySegments, firstResult, maxResults );
tupleExecutor.performTupleQuery( language, query, null, collectingCallback );
return collectingCallback.getEntities();
}
public EntityReference findEntity( Class<?> resultType, BooleanExpression whereClause )
throws EntityFinderException
{
final SingleQualifiedIdentityResultCallback singleCallback = new SingleQualifiedIdentityResultCallback();
RdfQueryParser rdfQueryParser = queryParserFactory.newQueryParser( language );
String query = rdfQueryParser.getQuery( resultType, whereClause, null, null, null );
tupleExecutor.performTupleQuery( language, query, null, singleCallback );
return singleCallback.getQualifiedIdentity();
}
public long countEntities( Class<?> resultType, BooleanExpression whereClause )
throws EntityFinderException
{
RdfQueryParser rdfQueryParser = queryParserFactory.newQueryParser( language );
String query = rdfQueryParser.getQuery( resultType, whereClause, null, null, null );
return tupleExecutor.performTupleQuery( language, query, null, null );
}
}
public static class RdfNamedEntityFinderMixin
implements NamedEntityFinder
{
@Service
private RdfQueryParserFactory queryParserFactory;
@This
private TupleQueryExecutor tupleExecutor;
public Iterable<EntityReference> findEntities( NamedQueryDescriptor descriptor,
String resultType,
Map<String, Object> variables,
OrderBy[] orderBySegments,
Integer firstResult,
Integer maxResults
)
throws EntityFinderException
{
Map<String, Value> bindings = getBindings(variables);
QueryLanguage queryLanguage = QueryLanguage.valueOf( descriptor.language() );
String query = descriptor.compose( variables, orderBySegments, firstResult, maxResults );
CollectingQualifiedIdentityResultCallback callback = new CollectingQualifiedIdentityResultCallback();
tupleExecutor.performTupleQuery( queryLanguage, query, bindings, callback );
return callback.getEntities();
}
public EntityReference findEntity( NamedQueryDescriptor descriptor,
String resultType,
Map<String, Object> variables
)
throws EntityFinderException
{
Map<String, Value> bindings = getBindings(variables);
QueryLanguage queryLanguage = QueryLanguage.valueOf( descriptor.language() );
String query = descriptor.compose( variables, null, null, 1 );
SingleQualifiedIdentityResultCallback callback = new SingleQualifiedIdentityResultCallback();
tupleExecutor.performTupleQuery( queryLanguage, query, bindings, callback );
return callback.getQualifiedIdentity();
}
public long countEntities( NamedQueryDescriptor descriptor, String resultType, Map<String, Object> variables )
throws EntityFinderException
{
Map<String, Value> bindings = getBindings(variables);
QueryLanguage queryLanguage = QueryLanguage.valueOf( descriptor.language() );
return tupleExecutor.performTupleQuery( queryLanguage, descriptor.compose( null, null, null, null ), bindings, null );
}
public String showQuery( NamedQueryDescriptor descriptor )
{
return descriptor.compose( null, null, null, null );
}
private Map<String, Value> getBindings(Map<String, Object> variables)
{
Map<String, Value> bindings = new HashMap<String, Value>();
for (Map.Entry<String, Object> stringObjectEntry : variables.entrySet())
{
if (!stringObjectEntry.getValue().getClass().equals(Object.class))
bindings.put(stringObjectEntry.getKey(), ValueFactoryImpl.getInstance().createLiteral(stringObjectEntry.getValue().toString()));
}
return bindings;
}
}
}