Package org.eclipse.rdf4j.sail.shacl
Class ShaclSailConnection
- java.lang.Object
- 
- org.eclipse.rdf4j.sail.helpers.SailConnectionWrapper
- 
- org.eclipse.rdf4j.sail.helpers.NotifyingSailConnectionWrapper
- 
- org.eclipse.rdf4j.sail.shacl.ShaclSailConnection
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- FederatedServiceResolverClient,- ThreadSafetyAware,- NotifyingSailConnection,- SailConnection,- SailConnectionListener
 
 public class ShaclSailConnection extends NotifyingSailConnectionWrapper implements SailConnectionListener - Author:
- Heshan Jayasinghe, HÃ¥vard Ottestad
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classShaclSailConnection.SettingsclassShaclSailConnection.ValidationContainer
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddConnectionListener(SailConnectionListener listener)Adds the given listener to the wrapped connection.voidaddStatement(Resource subj, IRI pred, Value obj, Resource... contexts)Adds a statement to the store.voidaddStatement(UpdateContext modify, Resource subj, IRI pred, Value obj, Resource... contexts)Adds a statement to the store.voidbegin()Begins a transaction requiringSailConnection.commit()orSailConnection.rollback()to be called to close the transaction.voidbegin(IsolationLevel level)Begins a transaction with the specifiedIsolationLevellevel, requiringSailConnection.commit()orSailConnection.rollback()to be called to close the transaction.voidclear(Resource... contexts)Removes all statements from the specified/all contexts.voidclose()Closes the connection.voidcommit()Commits any updates that have been performed since the last timeSailConnection.commit()orSailConnection.rollback()was called.RdfsSubClassOfReasonergetRdfsSubClassOfReasoner()CloseableIteration<? extends Statement,SailException>getStatements(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts)Gets all statements from the specified contexts that have a specific subject, predicate and/or object.booleanhasStatement(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts)Determines if the store contains any statements from the specified contexts that have a specific subject, predicate and/or object.voidprepare()Checks for an error state in the active transaction that would force the transaction to be rolled back.voidremoveConnectionListener(SailConnectionListener listener)Removes the given listener from the wrapped connection.voidremoveStatement(UpdateContext modify, Resource subj, IRI pred, Value obj, Resource... contexts)Removes all statements matching the specified subject, predicate and object from the repository.voidremoveStatements(Resource subj, IRI pred, Value obj, Resource... contexts)Removes all statements matching the specified subject, predicate and object from the repository.ValidationReportrevalidate()voidrollback()Rolls back the transaction, discarding any uncommitted changes that have been made in this SailConnection.voidsetTransactionSettings(TransactionSetting... settings)Pass any transaction-specific settings to the SailConnection.voidstatementAdded(Statement statement)Notifies the listener that a statement has been added in a transaction that it has registered itself with.voidstatementRemoved(Statement statement)Notifies the listener that a statement has been removed in a transaction that it has registered itself with.- 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.NotifyingSailConnectionWrappergetWrappedConnection
 - 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.SailConnectionWrapperclearNamespaces, endUpdate, evaluate, explain, flush, getContextIDs, getFederatedServiceResolver, getNamespace, getNamespaces, isActive, isOpen, pendingRemovals, prepareQuery, removeNamespace, setFederatedServiceResolver, setNamespace, size, size, startUpdate, supportsConcurrentReads
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.sail.SailConnectionclearNamespaces, endUpdate, evaluate, explain, flush, getContextIDs, getNamespace, getNamespaces, isActive, isOpen, pendingRemovals, prepareQuery, removeNamespace, setNamespace, size, startUpdate
 
- 
 
- 
- 
- 
Field Detail- 
sailpublic final ShaclSail sail 
 
- 
 - 
Method Detail- 
setTransactionSettingspublic void setTransactionSettings(TransactionSetting... settings) Description copied from interface:SailConnectionPass any transaction-specific settings to the SailConnection. This method needs to be called before the transaction isstarted.Sail implementations can override this method to receive the transaction settings (to inspect and/or pass them along to any wrapped sail objects). Remember to call super.setTransactionSettings(settings)if you override this method.- Specified by:
- setTransactionSettingsin interface- SailConnection
- Overrides:
- setTransactionSettingsin class- SailConnectionWrapper
- Parameters:
- settings- the transaction settings on which the next transaction operates. It may or may not contain the isolation level.
 
 - 
beginpublic void begin() throws SailExceptionDescription copied from interface:SailConnectionBegins a transaction requiringSailConnection.commit()orSailConnection.rollback()to be called to close the transaction. The transaction will use the defaultIsolationLevellevel for the SAIL, as returned bySail.getDefaultIsolationLevel().- Specified by:
- beginin interface- SailConnection
- Overrides:
- beginin class- SailConnectionWrapper
- Throws:
- SailException- If the connection could not start a transaction or if a transaction is already active on this connection.
 
 - 
beginpublic void begin(IsolationLevel level) throws SailException Description copied from interface:SailConnectionBegins a transaction with the specifiedIsolationLevellevel, requiringSailConnection.commit()orSailConnection.rollback()to be called to close the transaction.- Specified by:
- beginin interface- SailConnection
- Overrides:
- beginin class- SailConnectionWrapper
- Parameters:
- level- the transaction isolation level on which this transaction operates.
- Throws:
- UnknownSailTransactionStateException- If the IsolationLevel is not supported by this implementation
- SailException- If the connection could not start a transaction, if the supplied transaction isolation level is not supported, or if a transaction is already active on this connection.
 
 - 
addConnectionListenerpublic void addConnectionListener(SailConnectionListener listener) Description copied from class:NotifyingSailConnectionWrapperAdds the given listener to the wrapped connection.- Specified by:
- addConnectionListenerin interface- NotifyingSailConnection
- Overrides:
- addConnectionListenerin class- NotifyingSailConnectionWrapper
- Parameters:
- listener- A SailConnectionListener.
 
 - 
removeConnectionListenerpublic void removeConnectionListener(SailConnectionListener listener) Description copied from class:NotifyingSailConnectionWrapperRemoves the given listener from the wrapped connection.- Specified by:
- removeConnectionListenerin interface- NotifyingSailConnection
- Overrides:
- removeConnectionListenerin class- NotifyingSailConnectionWrapper
- Parameters:
- listener- A SailConnectionListener.
 
 - 
commitpublic void commit() throws SailExceptionDescription copied from interface:SailConnectionCommits any updates that have been performed since the last timeSailConnection.commit()orSailConnection.rollback()was called.- Specified by:
- commitin interface- SailConnection
- Overrides:
- commitin class- SailConnectionWrapper
- Throws:
- UnknownSailTransactionStateException- If the transaction state can not be determined (this can happen for instance when communication between client and server fails or times-out). It does not indicate a problem with the integrity of the store.
- SailException- If the SailConnection could not be committed.
 
 - 
addStatementpublic void addStatement(UpdateContext modify, Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from interface:SailConnectionAdds a statement to the store. Called when adding statements through aUpdateExproperation.- Specified by:
- addStatementin interface- SailConnection
- Overrides:
- addStatementin class- SailConnectionWrapper
- Parameters:
- modify- operation properties of the- UpdateExproperation producing these statements.
- subj- The subject of the statement to add.
- pred- The predicate of the statement to add.
- obj- The object of the statement to add.
- contexts- The context(s) to add the statement to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, a context-less statement will be added.
- Throws:
- SailException- If the statement could not be added, for example because no transaction is active.
 
 - 
removeStatementpublic void removeStatement(UpdateContext modify, Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from interface:SailConnectionRemoves all statements matching the specified subject, predicate and object from the repository. All three parameters may be null to indicate wildcards. Called when removing statements through aUpdateExproperation.- Specified by:
- removeStatementin interface- SailConnection
- Overrides:
- removeStatementin class- SailConnectionWrapper
- Parameters:
- modify- operation properties of the- UpdateExproperation removing these statements.
- subj- The subject of the statement that should be removed.
- pred- The predicate of the statement that should be removed.
- obj- The object of the statement that should be removed.
- contexts- The context(s) from which to remove the statement. Note that this parameter is a vararg and as such is optional. If no contexts are specified the method operates on the entire repository. A null value can be used to match context-less statements.
- Throws:
- SailException- If the statement could not be removed, for example because no transaction is active.
 
 - 
addStatementpublic void addStatement(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from interface:SailConnectionAdds a statement to the store.- Specified by:
- addStatementin interface- SailConnection
- Overrides:
- addStatementin class- SailConnectionWrapper
- Parameters:
- subj- The subject of the statement to add.
- pred- The predicate of the statement to add.
- obj- The object of the statement to add.
- contexts- The context(s) to add the statement to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, a context-less statement will be added.
- Throws:
- SailException- If the statement could not be added, for example because no transaction is active.
 
 - 
removeStatementspublic void removeStatements(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from interface:SailConnectionRemoves all statements matching the specified subject, predicate and object from the repository. All three parameters may be null to indicate wildcards.- Specified by:
- removeStatementsin interface- SailConnection
- Overrides:
- removeStatementsin class- SailConnectionWrapper
- Parameters:
- subj- The subject of the statement that should be removed, or null to indicate a wildcard.
- pred- The predicate of the statement that should be removed, or null to indicate a wildcard.
- obj- The object of the statement that should be removed , or null to indicate a wildcard. *
- contexts- The context(s) from which to remove the statement. Note that this parameter is a vararg and as such is optional. If no contexts are specified the method operates on the entire repository. A null value can be used to match context-less statements.
- Throws:
- SailException- If the statement could not be removed, for example because no transaction is active.
 
 - 
clearpublic void clear(Resource... contexts) throws SailException Description copied from interface:SailConnectionRemoves all statements from the specified/all contexts. If no contexts are specified the method operates on the entire repository.- Specified by:
- clearin interface- SailConnection
- Overrides:
- clearin class- SailConnectionWrapper
- Parameters:
- contexts- The context(s) from which to remove the statements. Note that this parameter is a vararg and as such is optional. If no contexts are specified the method operates on the entire repository. A null value can be used to match context-less statements.
- Throws:
- SailException- If the statements could not be removed.
 
 - 
rollbackpublic void rollback() throws SailExceptionDescription copied from interface:SailConnectionRolls back the transaction, discarding any uncommitted changes that have been made in this SailConnection.- Specified by:
- rollbackin interface- SailConnection
- Overrides:
- rollbackin class- SailConnectionWrapper
- Throws:
- UnknownSailTransactionStateException- If the transaction state can not be determined (this can happen for instance when communication between client and server fails or times-out). It does not indicate a problem with the integrity of the store.
- SailException- If the SailConnection could not be rolled back.
 
 - 
closepublic void close() throws SailExceptionDescription copied from interface:SailConnectionCloses the connection. Any updates that haven't been committed yet will be rolled back. The connection can no longer be used once it is closed.- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- SailConnection
- Overrides:
- closein class- SailConnectionWrapper
- Throws:
- SailException
 
 - 
preparepublic void prepare() throws SailExceptionDescription copied from interface:SailConnectionChecks for an error state in the active transaction that would force the transaction to be rolled back. This is an optional call; calling or not calling this method should have no effect on the outcome ofSailConnection.commit()orSailConnection.rollback(). A call to this method must be followed by (in the same thread) with a call toSailConnection.prepare(),SailConnection.commit(),SailConnection.rollback(), orSailConnection.close(). This method may be called multiple times within the same transaction by the same thread. If this method returns normally, the caller can reasonably expect that a subsequent call toSailConnection.commit()will also return normally. If this method returns with an exception the caller should treat the exception as if it came from a call toSailConnection.commit().- Specified by:
- preparein interface- SailConnection
- Overrides:
- preparein class- SailConnectionWrapper
- Throws:
- UnknownSailTransactionStateException- If the transaction state can not be determined (this can happen for instance when communication between client and server fails or times-out). It does not indicate a problem with the integrity of the store.
- SailException- If there is an active transaction and it cannot be committed.
 
 - 
statementAddedpublic void statementAdded(Statement statement) Description copied from interface:SailConnectionListenerNotifies the listener that a statement has been added in a transaction that it has registered itself with.- Specified by:
- statementAddedin interface- SailConnectionListener
- Parameters:
- statement- The statement that was added.
 
 - 
statementRemovedpublic void statementRemoved(Statement statement) Description copied from interface:SailConnectionListenerNotifies the listener that a statement has been removed in a transaction that it has registered itself with.- Specified by:
- statementRemovedin interface- SailConnectionListener
- Parameters:
- statement- The statement that was removed.
 
 - 
getRdfsSubClassOfReasonerpublic RdfsSubClassOfReasoner getRdfsSubClassOfReasoner() 
 - 
getStatementspublic CloseableIteration<? extends Statement,SailException> getStatements(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts) throws SailException Description copied from interface:SailConnectionGets all statements from the specified contexts that have a specific subject, predicate and/or object. All three parameters may be null to indicate wildcards. The includeInferred parameter can be used to control which statements are fetched: all statements or only the statements that have been added explicitly.- Specified by:
- getStatementsin interface- SailConnection
- Overrides:
- getStatementsin class- SailConnectionWrapper
- Parameters:
- subj- A Resource specifying the subject, or null for a wildcard.
- pred- A URI specifying the predicate, or null for a wildcard.
- obj- A Value specifying the object, or null for a wildcard.
- includeInferred- if false, no inferred statements are returned; if true, inferred statements are returned if available
- contexts- The context(s) to get the data from. Note that this parameter is a vararg and as such is optional. If no contexts are specified the method operates on the entire repository. A null value can be used to match context-less statements.
- Returns:
- The statements matching the specified pattern.
- Throws:
- SailException- If the Sail object encountered an error or unexpected situation internally.
 
 - 
hasStatementpublic boolean hasStatement(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts) throws SailException Description copied from interface:SailConnectionDetermines if the store contains any statements from the specified contexts that have a specific subject, predicate and/or object. All three parameters may be null to indicate wildcards. The includeInferred parameter can be used to control which statements are checked: all statements or only the statements that have been added explicitly.- Specified by:
- hasStatementin interface- SailConnection
- Overrides:
- hasStatementin class- SailConnectionWrapper
- Parameters:
- subj- A Resource specifying the subject, or null for a wildcard.
- pred- An IRI specifying the predicate, or null for a wildcard.
- obj- A Value specifying the object, or null for a wildcard.
- includeInferred- if false, no inferred statements are returned; if true, inferred statements are returned if available
- contexts- The context(s) to get the data from. Note that this parameter is a vararg and as such is optional. If no contexts are specified the method operates on the entire repository. A null value can be used to match context-less statements.
- Returns:
- trueiff the store contains any statements matching the supplied criteria,- falseotherwise.
- Throws:
- SailException- If the Sail object encountered an error or unexpected situation internally.
 
 - 
revalidatepublic ValidationReport revalidate() 
 
- 
 
-