Package weka.core.packageManagement
Class PackageManager
java.lang.Object
weka.core.packageManagement.PackageManager
- Direct Known Subclasses:
DefaultPackageManager
Abstract base class for package managers. Contains methods to manage the
location of the central package repository, the home directory for installing
packages, the name and version of the base software system and a http proxy.
- Version:
- $Revision: 52568 $
- Author:
- Mark Hall (mhall{[at]}pentaho{[dot]}com)
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
applySettings
(Settings settings) Apply the supplied settings.static PackageManager
create()
void
Tries to configure a Proxy object for use in an Authenticator if there is a proxy defined by the properties http.proxyHost and http.proxyPort, and if the user has set values for the properties (note, these are not standard java properties) http.proxyUser and http.proxyPassword.abstract List<Dependency>
getAllDependenciesForPackage
(Package target, Map<String, List<Dependency>> conflicts) Gets a full list of packages (encapsulated in Dependency objects) that are required by directly and indirectly by the named target package.getAllPackages
(PrintStream... progress) Get all packages that the system knows about (i.e.Get a list of packages that are not currently installed.Get the name of the main software system for which we manage packages.Get the current installed version of the main system for which we manage packages.Get the default settings of this package manager.abstract Package
getInstalledPackageInfo
(String packageName) Get package information on the named installed package.Get a list of installed packages.abstract Package
getPackageArchiveInfo
(String packageArchivePath) Get package information from the supplied package archive file.Get the location (directory) of installed packagesGet the URL to the repository of package meta data.getProxy()
Get the proxy in use.abstract Package
getRepositoryPackageInfo
(String packageName) Get package information on the named package from the repository.abstract Package
getRepositoryPackageInfo
(String packageName, Object version) Get package information on the named package from the repository.abstract byte[]
getRepositoryPackageMetaDataOnlyAsZip
(PrintStream... progress) Gets an array of bytes containing a zip of all the repository meta data and supporting files.getRepositoryPackageVersions
(String packageName) Get a list of available versions of the named package.abstract Package
getURLPackageInfo
(URL packageURL) Get package information on the package at the given URL.abstract String
installPackageFromArchive
(String packageArchivePath, PrintStream... progress) Install a package from an archive on the local file system.abstract void
installPackageFromRepository
(String packageName, Object version, PrintStream... progress) Install a package sourced from the repository.abstract String
installPackageFromURL
(URL packageURL, PrintStream... progress) Install a package sourced from a given URL.abstract void
installPackages
(List<Package> toInstall, PrintStream... progress) Installs all the packages in the supplied list.void
setBaseSystemName
(String baseS) Set the name of the main software system for which we manage packages.void
setBaseSystemVersion
(Object systemV) Set the current version of the base system for which we manage packages.void
setPackageHome
(File packageHome) Set the location (directory) of installed packages.void
setPackageRepositoryURL
(URL repositoryURL) Set the URL to the repository of package meta data.void
Set a proxy to use for accessing the internet (default is no proxy).boolean
setProxyAuthentication
(URL urlToConnectTo) Sets an new default Authenticator that will return the values set through setProxyUsername() and setProxyPassword() (if applicable).void
setProxyPassword
(String proxyPassword) Set the password for authentication with the proxy.void
setProxyUsername
(String proxyUsername) Set the user name for authentication with the proxy.abstract void
uninstallPackage
(String packageName, PrintStream... progress) Uninstall a package.
-
Constructor Details
-
PackageManager
public PackageManager()
-
-
Method Details
-
create
-
establishProxy
public void establishProxy()Tries to configure a Proxy object for use in an Authenticator if there is a proxy defined by the properties http.proxyHost and http.proxyPort, and if the user has set values for the properties (note, these are not standard java properties) http.proxyUser and http.proxyPassword. -
setProxyAuthentication
Sets an new default Authenticator that will return the values set through setProxyUsername() and setProxyPassword() (if applicable).- Returns:
- true if a proxy is to be used and (if applicable) the Authenticator was set successfully.
-
setPackageHome
Set the location (directory) of installed packages.- Parameters:
packageHome
- the file system location of installed packages.
-
getPackageHome
Get the location (directory) of installed packages- Returns:
- the directory containing installed packages.
-
setBaseSystemName
Set the name of the main software system for which we manage packages.- Parameters:
baseS
- the name of the base software system
-
getBaseSystemName
Get the name of the main software system for which we manage packages.- Returns:
- the name of the base software system.
-
setBaseSystemVersion
Set the current version of the base system for which we manage packages.- Parameters:
systemV
- the current version of the main software system.
-
getBaseSystemVersion
Get the current installed version of the main system for which we manage packages.- Returns:
- the installed version of the base system.
-
setPackageRepositoryURL
Set the URL to the repository of package meta data.- Parameters:
repositoryURL
- the URL to the repository of package meta data.
-
getPackageRepositoryURL
Get the URL to the repository of package meta data.- Returns:
- the URL to the repository of package meta data.
-
setProxy
Set a proxy to use for accessing the internet (default is no proxy).- Parameters:
proxyToUse
- a proxy to use.
-
getProxy
Get the proxy in use.- Returns:
- the proxy in use or null if no proxy is being used.
-
setProxyUsername
Set the user name for authentication with the proxy.- Parameters:
proxyUsername
- the user name to use for proxy authentication.
-
setProxyPassword
Set the password for authentication with the proxy.- Parameters:
proxyPassword
- the password to use for proxy authentication.
-
getDefaultSettings
Get the default settings of this package manager. Default implementation returns null. Subclasses to override if they have default settings- Returns:
- the default settings of this package manager
-
applySettings
Apply the supplied settings. Default implementation does nothing. Subclasses should override to take note of settings changes.- Parameters:
settings
- the settings to apply
-
getRepositoryPackageMetaDataOnlyAsZip
public abstract byte[] getRepositoryPackageMetaDataOnlyAsZip(PrintStream... progress) throws Exception Gets an array of bytes containing a zip of all the repository meta data and supporting files. Does *not* contain any package archives etc., only a snapshot of the meta data. Could be used by clients to establish a cache of meta data.- Parameters:
progress
- optional varargs parameter, that, if supplied, is expected to contain one or more PrintStream objects to write progress to.- Returns:
- a zip compressed array of bytes.
- Throws:
Exception
- if the repository meta data can't be returned as a zip
-
getPackageArchiveInfo
Get package information from the supplied package archive file.- Parameters:
packageArchivePath
- the path to the package archive file- Returns:
- a Package object encapsulating the package meta data.
- Throws:
Exception
- if the package meta data can't be retrieved.
-
getInstalledPackageInfo
Get package information on the named installed package.- Parameters:
packageName
- the name of the package to get information about.- Returns:
- a Package object encapsulating the package meta data or null if the package is not installed.
- Throws:
Exception
- if the package meta data can't be retrieved.
-
getRepositoryPackageInfo
Get package information on the named package from the repository. If multiple versions of the package are available, it assumes that the most recent is required.- Parameters:
packageName
- the name of the package to get information about.- Returns:
- a Package object encapsulating the package meta data.
- Throws:
Exception
- if the package meta data can't be retrieved.
-
getRepositoryPackageInfo
public abstract Package getRepositoryPackageInfo(String packageName, Object version) throws Exception Get package information on the named package from the repository.- Parameters:
packageName
- the name of the package to get information about.version
- the version of the package to retrieve (may be null if not applicable).- Returns:
- a Package object encapsulating the package meta data.
- Throws:
Exception
- if the package meta data can't be retrieved.
-
getRepositoryPackageVersions
Get a list of available versions of the named package.- Parameters:
packageName
- the name of the package to get versions.- Returns:
- a list of available versions (or null if not applicable)
- Throws:
Exception
- if something goes wrong while trying to retrieve the list of versions.
-
getURLPackageInfo
Get package information on the package at the given URL.- Parameters:
packageURL
- the URL to the package.- Returns:
- a Package object encapsulating the package meta data
- Throws:
Exception
- if the package meta data can't be retrieved.
-
installPackageFromArchive
public abstract String installPackageFromArchive(String packageArchivePath, PrintStream... progress) throws Exception Install a package from an archive on the local file system.- Parameters:
packageArchivePath
- the path to the package archive file.progress
- optional varargs parameter, that, if supplied, is expected to contain one or more PrintStream objects to write progress to.- Returns:
- the name of the package installed
- Throws:
Exception
- if the package can't be installed for some reason.
-
installPackageFromRepository
public abstract void installPackageFromRepository(String packageName, Object version, PrintStream... progress) throws Exception Install a package sourced from the repository.- Parameters:
packageName
- the name of the package to installversion
- the version of the package to install (may be null if not applicable).progress
- optional varargs parameter, that, if supplied, is expected to contain one or more PrintStream objects to write progress to.- Throws:
Exception
- if the package can't be installed for some reason.
-
installPackageFromURL
public abstract String installPackageFromURL(URL packageURL, PrintStream... progress) throws Exception Install a package sourced from a given URL.- Parameters:
packageURL
- the URL to the package.progress
- optional varargs parameter, that, if supplied, is expected to contain one or more PrintStream objects to write progress to.- Returns:
- the name of the package installed
- Throws:
Exception
- if the package can't be installed for some reason.
-
installPackages
public abstract void installPackages(List<Package> toInstall, PrintStream... progress) throws Exception Installs all the packages in the supplied list.- Parameters:
toInstall
- a list of Packages to install.progress
- optional varargs parameter, that, if supplied, is expected to contain one or more PrintStream objects to write progress to.- Throws:
Exception
- if something goes wrong during the installation process.
-
uninstallPackage
Uninstall a package.- Parameters:
packageName
- the package to uninstall.progress
- optional varargs parameter, that, if supplied, is expected to contain one or more PrintStream objects to write progress to.- Throws:
Exception
- if the named package could not be removed for some reason.
-
getInstalledPackages
Get a list of installed packages.- Returns:
- a list of installed packages.
- Throws:
Exception
- if a list of packages can't be determined.
-
getAllPackages
Get all packages that the system knows about (i.e. all packages contained in the repository).- Parameters:
progress
- optional varargs parameter, that, if supplied is expected to contain one or more PrintStream objects to write progress to.- Returns:
- a list of all packages.
- Throws:
Exception
- if a list of packages can't be determined.
-
getAvailablePackages
Get a list of packages that are not currently installed.- Returns:
- a list of packages that are not currently installed.
- Throws:
Exception
- if a list of packages can't be determined.
-
getAllDependenciesForPackage
public abstract List<Dependency> getAllDependenciesForPackage(Package target, Map<String, List<Dependency>> conflicts) throws ExceptionGets a full list of packages (encapsulated in Dependency objects) that are required by directly and indirectly by the named target package. Also builds a Map of any packages that are required by more than one package and where there is a conflict of some sort (e.g. multiple conflicting versions). The keys of this map are package names (strings), and each associated value is a list of Dependency objects.- Parameters:
target
- the package for which a list of dependencies is required.conflicts
- will hold any conflicts that are discovered while building the full dependency list.- Returns:
- a list of packages that are directly and indirectly required by the named target package.
- Throws:
Exception
- if a problem occurs while building the dependency list.
-