
com.metreeca.rdf4j.RDF4JSPARQL Maven / Gradle / Ivy
/*
* Copyright © 2013-2019 Metreeca srl. All rights reserved.
*
* This file is part of Metreeca/Link.
*
* Metreeca/Link is free software: you can redistribute it and/or modify it under the terms
* of the GNU Affero General Public License as published by the Free Software Foundation,
* either version 3 of the License, or(at your option) any later version.
*
* Metreeca/Link is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License along with Metreeca/Link.
* If not, see .
*/
package com.metreeca.rdf4j;
import com.metreeca.rdf.services.Graph;
import org.eclipse.rdf4j.IsolationLevel;
import org.eclipse.rdf4j.repository.sparql.SPARQLRepository;
import static org.eclipse.rdf4j.IsolationLevels.NONE;
/**
* RDF4J SPARQL graph store.
*
* Manages task execution on an RDF4J {@link SPARQLRepository}.
*
* Warning / the {@linkplain Graph#isolation(IsolationLevel) isolation level} is set to {@code
* IsolationLevels.NONE}; setting the isolation level to anything different will cause a runtime exception on update
* transactions.
*/
public final class RDF4JSPARQL extends Graph { // ;( namespace ops silently ignored
{ isolation(NONE); } // ;( no transaction support
/**
* Creates an RDF4J SPARQL graph.
*
* @param url the URL of a remote SPARQL endpoint supporting SPARQL
* 1.1 Protocol query/update operations
*
* @throws NullPointerException if {@code url} is null
*/
public RDF4JSPARQL(final String url) {
if ( url == null ) {
throw new NullPointerException("null endpoint url");
}
repository(new SPARQLRepository(url));
}
/**
* Creates an RDF4J SPARQL graph.
*
* @param query the URL of a remote SPARQL endpoint supporting SPARQL
* 1.1 Protocol query operations
* @param update the URL of a remote SPARQL endpoint supporting SPARQL
* 1.1 Protocol update operations
*
* @throws NullPointerException if either {@code query} or {@code update} is null
*/
public RDF4JSPARQL(final String query, final String update) {
if ( query == null ) {
throw new NullPointerException("null query endpoint URL");
}
if ( update == null ) {
throw new NullPointerException("null update endpoint URL");
}
repository(new SPARQLRepository(query, update));
}
/**
* Configures the credentials for accessing the remote RDF repository.
*
* @param usr the username of the account on the remote RDF repository
* @param pwd the password of the account on the remote RDF repository
*
* @return this graph store
*
* @throws NullPointerException if either {@code usr} or {@code pwd} is {@code null}
* @throws IllegalStateException if the backing remote repository was already initialized
*/
public RDF4JSPARQL credentials(final String usr, final String pwd) {
if ( usr == null ) {
throw new NullPointerException("null usr");
}
if ( pwd == null ) {
throw new NullPointerException("null pwd");
}
final SPARQLRepository repository=(SPARQLRepository)repository();
if ( repository.isInitialized() ) {
throw new IllegalStateException("active repository");
}
if ( !usr.isEmpty() || !pwd.isEmpty() ) {
repository.setUsernameAndPassword(usr, pwd);
}
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy