Class RemoteRepositoryManager
- java.lang.Object
- 
- org.eclipse.rdf4j.repository.manager.RepositoryManager
- 
- org.eclipse.rdf4j.repository.manager.RemoteRepositoryManager
 
 
- 
- All Implemented Interfaces:
- HttpClientDependent,- RepositoryResolver
 
 public class RemoteRepositoryManager extends RepositoryManager A manager forRepositorys that reside on a remote server. This repository manager allows one to access repositories over HTTP similar to how local repositories are accessed using theLocalRepositoryManager.- Author:
- Arjohn Kampman
 
- 
- 
Field Summary- 
Fields inherited from class org.eclipse.rdf4j.repository.manager.RepositoryManagerinitializedRepositories, logger, NAMESPACE, PROXIED_ID
 
- 
 - 
Constructor SummaryConstructors Constructor Description RemoteRepositoryManager(String serverURL)Creates a new RepositoryManager that operates on the specified base directory.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddRepositoryConfig(RepositoryConfig config)Adds or updates the configuration of a repository to the manager's system repository.protected RepositorycreateRepository(String id)Creates and initializes the repository with the specified ID.protected RepositorycreateSystemRepository()Deprecated.Collection<RepositoryInfo>getAllRepositoryInfos(boolean skipSystemRepo)org.apache.http.client.HttpClientgetHttpClient()HttpClientthat has been assigned or has been used by this object.static RemoteRepositoryManagergetInstance(String serverURL)Creates an initializedRemoteRepositoryManagerwith the specified server URL.static RemoteRepositoryManagergetInstance(String serverURL, String username, String password)Creates an initializedRemoteRepositoryManagerwith the specified server URL and credentials.URLgetLocation()Gets the URL of the remote server, e.g.RepositoryConfiggetRepositoryConfig(String id)StringgetServerURL()Gets the URL of the remote server, e.g.protected SharedHttpClientSessionManagergetSharedHttpClientSessionManager()booleanremoveRepository(String repositoryID)Removes the specified repository by deleting its configuration from the manager's system repository if such a configuration is present, and removing any persistent data associated with the repository.voidsetHttpClient(org.apache.http.client.HttpClient protocolSession)Should be called beforeRepositoryManager.init().voidsetUsernameAndPassword(String username, String password)Set the username and password for authenication with the remote server.voidshutDown()Shuts down all initialized repositories, including the SYSTEM repository.- 
Methods inherited from class org.eclipse.rdf4j.repository.manager.RepositoryManagercleanUpRepository, getAllRepositories, getAllRepositoryInfos, getAllUserRepositoryInfos, getInitializedRepositories, getInitializedRepositoryIDs, getModelFactory, getNewRepositoryID, getRepository, getRepositoryIDs, getRepositoryInfo, getSystemRepository, hasRepositoryConfig, init, initialize, isInitialized, isSafeToRemove, refresh, removeRepositoryConfig, setInitializedRepositories, setModelFactory, updateInitializedRepositories
 
- 
 
- 
- 
- 
Constructor Detail- 
RemoteRepositoryManagerpublic RemoteRepositoryManager(String serverURL) Creates a new RepositoryManager that operates on the specified base directory.- Parameters:
- serverURL- The URL of the server.
 
 
- 
 - 
Method Detail- 
getInstancepublic static RemoteRepositoryManager getInstance(String serverURL) throws RepositoryException Creates an initializedRemoteRepositoryManagerwith the specified server URL.- Throws:
- RepositoryException
 
 - 
getInstancepublic static RemoteRepositoryManager getInstance(String serverURL, String username, String password) throws RepositoryException Creates an initializedRemoteRepositoryManagerwith the specified server URL and credentials.- Throws:
- RepositoryException
 
 - 
getSharedHttpClientSessionManagerprotected SharedHttpClientSessionManager getSharedHttpClientSessionManager() - Returns:
- Returns the SharedHttpClientSessionManager
 
 - 
getHttpClientpublic org.apache.http.client.HttpClient getHttpClient() Description copied from interface:HttpClientDependentHttpClientthat has been assigned or has been used by this object. The life cycle might not be or might be tied to this object, depending on whetherHttpClientwas passed to or created by this object respectively.- Specified by:
- getHttpClientin interface- HttpClientDependent
- Specified by:
- getHttpClientin class- RepositoryManager
- Returns:
- Returns the httpClient passed to Repositoryconstruction.
 
 - 
setHttpClientpublic void setHttpClient(org.apache.http.client.HttpClient protocolSession) Description copied from class:RepositoryManagerShould be called beforeRepositoryManager.init().- Specified by:
- setHttpClientin interface- HttpClientDependent
- Specified by:
- setHttpClientin class- RepositoryManager
- Parameters:
- protocolSession- The httpClient to use for remote/service calls.
 
 - 
shutDownpublic void shutDown() Description copied from class:RepositoryManagerShuts down all initialized repositories, including the SYSTEM repository.- Overrides:
- shutDownin class- RepositoryManager
- See Also:
- RepositoryManager.refresh()
 
 - 
setUsernameAndPasswordpublic void setUsernameAndPassword(String username, String password) Set the username and password for authenication with the remote server.- Parameters:
- username- the username
- password- the password
 
 - 
createSystemRepository@Deprecated protected Repository createSystemRepository() throws RepositoryException Deprecated.- Overrides:
- createSystemRepositoryin class- RepositoryManager
- Throws:
- RepositoryException
 
 - 
getLocationpublic URL getLocation() throws MalformedURLException Gets the URL of the remote server, e.g. "http://localhost:8080/rdf4j-server/".- Specified by:
- getLocationin class- RepositoryManager
- Throws:
- MalformedURLException- If serverURL cannot be parsed
 
 - 
getServerURLpublic String getServerURL() Gets the URL of the remote server, e.g. "http://localhost:8080/rdf4j-server/".
 - 
createRepositoryprotected Repository createRepository(String id) throws RepositoryConfigException, RepositoryException Creates and initializes the repository with the specified ID.- Specified by:
- createRepositoryin class- RepositoryManager
- Parameters:
- id- A repository ID.
- Returns:
- The created repository, or null if no such repository exists.
- Throws:
- RepositoryConfigException- If no repository could be created due to invalid or incomplete configuration data.
- RepositoryException- If the repository could not be initialized.
 
 - 
getRepositoryConfigpublic RepositoryConfig getRepositoryConfig(String id) throws RepositoryException - Overrides:
- getRepositoryConfigin class- RepositoryManager
- Throws:
- RepositoryException
 
 - 
getAllRepositoryInfospublic Collection<RepositoryInfo> getAllRepositoryInfos(boolean skipSystemRepo) throws RepositoryException - Specified by:
- getAllRepositoryInfosin class- RepositoryManager
- Throws:
- RepositoryException- When not able to retrieve existing configurations
 
 - 
addRepositoryConfigpublic void addRepositoryConfig(RepositoryConfig config) throws RepositoryException, RepositoryConfigException Description copied from class:RepositoryManagerAdds or updates the configuration of a repository to the manager's system repository. The system repository may already contain a configuration for a repository with the same ID as specified by config, in which case all previous configuration data for that repository will be cleared before the new configuration is added.- Overrides:
- addRepositoryConfigin class- RepositoryManager
- Parameters:
- config- The repository configuration that should be added to or updated in the system repository.
- Throws:
- RepositoryException- If the manager failed to update it's system repository.
- RepositoryConfigException- If the manager doesn't know how to update a configuration due to inconsistent configuration data in the system repository. For example, this happens when there are multiple existing configurations with the concerning ID.
 
 - 
removeRepositorypublic boolean removeRepository(String repositoryID) throws RepositoryException, RepositoryConfigException Description copied from class:RepositoryManagerRemoves the specified repository by deleting its configuration from the manager's system repository if such a configuration is present, and removing any persistent data associated with the repository. Returns true if the system repository actually contained the specified repository configuration. NB this operation can not be undone!- Overrides:
- removeRepositoryin class- RepositoryManager
- Parameters:
- repositoryID- The ID of the repository that needs to be removed.
- Throws:
- RepositoryException- If the manager failed to update its system repository.
- RepositoryConfigException- If the manager doesn't know how to remove a repository due to inconsistent configuration data in the system repository. For example, this happens when there are multiple existing configurations with the concerning ID.
 
 
- 
 
-