| LibreOffice
    LibreOffice 24.8 SDK API Reference | 
The XPackageManager interface is used to add or remove packages to a specific repository. More...
import "XPackageManager.idl";
 
  
| Exported Interfaces | |
| interface | com::sun::star::lang::XComponent | 
| interface to notify disposing | |
| interface | com::sun::star::util::XModifyBroadcaster | 
| interface to notify changes of the set of deployed packages of this manager | |
The XPackageManager interface is used to add or remove packages to a specific repository.
This interface represents a particular repository. Packages are deployable files, e.g. scripts or UNO components.
Adding a UNO package means that a copy of the package is stored in the repository.
Removing a UNO package means that the previously added package is removed from the repository.
All interface methods do neither register nor revoke an extension. This happens exclusively by XExtensionManager.
Objects of this interface are created using the XPackageManagerFactory service resp. the singleton 
/singletons/com.sun.star.deployment.thePackageManagerFactory
. 
| interface com::sun::star::lang::XComponent | 
interface to notify disposing
| interface com::sun::star::util::XModifyBroadcaster | 
interface to notify changes of the set of deployed packages of this manager
| XPackage addPackage | ( | [in] string | url, | |||
| [in] sequence< com::sun::star::beans::NamedValue > | properties, | |||||
| [in] string | mediaType, | |||||
| [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
adds a UNO package.
The properties argument is currently only used to suppress the license information for shared extensions.
| url | package URL, must be UCB conform | 
| properties | additional properties, for example, that the license is to be suppressed (if supported by the extension) | 
| mediaType | media-type of package, empty string if to be detected | 
| xAbortChannel | abort channel to asynchronously abort the adding process, or null | 
| xCmdEnv | command environment for error and progress handling | 
| long checkPrerequisites | ( | [in] XPackage | extension, | |||
| [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
checks if the extension can be used.
The extension must be managed by this package manager, that is, it must be recorded in its database. The package manager calls XPackage::checkPrerequisites and updates its data base with the result. The result, which is from Prerequisites will be returned.
| com::sun::star::task::XAbortChannel createAbortChannel | ( | ) | 
creates a command channel to be used to asynchronously abort a command.
| string getContext | ( | ) | 
returns the underlying deployment context, that is, the name of the repository.
| XPackage getDeployedPackage | ( | [in] string | identifier, | |||
| [in] string | fileName, | |||||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
gets a deployed package.
| identifier | package identifier | 
| fileName | package file name | 
| xCmdEnv | command environment for error and progress handling | 
| sequence< XPackage > getDeployedPackages | ( | [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
gets all currently deployed packages.
| xAbortChannel | abort channel to asynchronously abort the removing process, or null | 
| xCmdEnv | command environment for error and progress handling | 
| sequence< XPackage > getExtensionsWithUnacceptedLicenses | ( | [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv | ) | ||
| raises | ( | DeploymentException ) | ||||
returns all extensions which are currently not in use because the user did not accept the license.
The function will not return any object for the user repository, because a user extension will not be kept in the user repository if its license is declined. Only extensions which are registered at start-up of OOo, that is, shared and bundled extensions, can be returned.
Extensions which allow the license to be suppressed, that is, it does not need to be displayed, and which are installed with the corresponding option, are also not returned.
| sequence< XPackageTypeInfo > getSupportedPackageTypes | ( | ) | 
gets the supported XPackageTypeInfos.
| XPackage importExtension | ( | [in] XPackage | extension, | |||
| [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
adds an extension.
This copies the extension. If it was from the same repository, which is represented by this XPackageManager interface, then nothing happens.
| extension | |
| xAbortChannel | abort channel to asynchronously abort the adding process, or null | 
| xCmdEnv | command environment for error and progress handling | 
| boolean isReadOnly | ( | ) | 
indicates that this implementation cannot be used for tasks which require write access to the location where the extensions are installed.
Normally one would call a method and handle the exception if writing failed. However, a GUI interface may need to know beforehand if writing is allowed. For example, the Extensions dialog needs to enable / disable the Add button depending if the user has write permission. Only the XPackageManager implementation knows the location of the installed extensions. Therefore it is not possible to check "externally" for write permission.
| void reinstallDeployedPackages | ( | [in] boolean | force, | |||
| [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
Expert feature: erases the underlying registry cache and reinstalls all previously added packages.
Please keep in mind that all registration status get lost.
Please use this in case of suspected cache inconsistencies only.
| force | set to true when called during soffice bootstrap after cleaning old extension cache | 
| xAbortChannel | abort channel to asynchronously abort the adding process | 
| xCmdEnv | command environment for error and progress handling | 
| void removePackage | ( | [in] string | identifier, | |||
| [in] string | fileName, | |||||
| [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException, | ||||||
| com::sun::star::lang::IllegalArgumentException ) | ||||||
removes a UNO package.
| identifier | package identifier | 
| fileName | package file name | 
| xAbortChannel | abort channel to asynchronously abort the removing process, or null | 
| xCmdEnv | command environment for error and progress handling | 
| boolean synchronize | ( | [in] com::sun::star::task::XAbortChannel | xAbortChannel, | |||
| [in] com::sun::star::ucb::XCommandEnvironment | xCmdEnv ) | |||||
| raises | ( | DeploymentException, | ||||
| com::sun::star::ucb::ContentCreationException, | ||||||
| com::sun::star::ucb::CommandFailedException, | ||||||
| com::sun::star::ucb::CommandAbortedException ) | ||||||
synchronizes the extension database with the contents of the extensions folder.
Added extensions will be added to the database and removed extensions will be removed from the database.
| xAbortChannel | abort channel to asynchronously abort the adding process | 
| xCmdEnv | command environment for error and progress handling |