1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #if ! defined INCLUDED_DP_UPDATE_HXX
29*cdf0e10cSrcweir #define INCLUDED_DP_UPDATE_HXX
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir 
32*cdf0e10cSrcweir #include "com/sun/star/deployment/XPackage.hpp"
33*cdf0e10cSrcweir #include "com/sun/star/deployment/XExtensionManager.hpp"
34*cdf0e10cSrcweir #include "com/sun/star/deployment/XUpdateInformationProvider.hpp"
35*cdf0e10cSrcweir #include "com/sun/star/uno/XComponentContext.hpp"
36*cdf0e10cSrcweir #include "com/sun/star/xml/dom/XNode.hpp"
37*cdf0e10cSrcweir 
38*cdf0e10cSrcweir #include "rtl/ustrbuf.hxx"
39*cdf0e10cSrcweir #include "dp_misc_api.hxx"
40*cdf0e10cSrcweir 
41*cdf0e10cSrcweir #include <map>
42*cdf0e10cSrcweir #include <vector>
43*cdf0e10cSrcweir 
44*cdf0e10cSrcweir namespace dp_misc {
45*cdf0e10cSrcweir 
46*cdf0e10cSrcweir /** returns the default update URL (for the update information) which
47*cdf0e10cSrcweir     is used when an extension does not provide its own URL.
48*cdf0e10cSrcweir */
49*cdf0e10cSrcweir DESKTOP_DEPLOYMENTMISC_DLLPUBLIC
50*cdf0e10cSrcweir ::rtl::OUString getExtensionDefaultUpdateURL();
51*cdf0e10cSrcweir 
52*cdf0e10cSrcweir enum UPDATE_SOURCE
53*cdf0e10cSrcweir {
54*cdf0e10cSrcweir     UPDATE_SOURCE_NONE,
55*cdf0e10cSrcweir     UPDATE_SOURCE_SHARED,
56*cdf0e10cSrcweir     UPDATE_SOURCE_BUNDLED,
57*cdf0e10cSrcweir     UPDATE_SOURCE_ONLINE
58*cdf0e10cSrcweir };
59*cdf0e10cSrcweir 
60*cdf0e10cSrcweir /* determine if an update is available which is installed in the
61*cdf0e10cSrcweir    user repository.
62*cdf0e10cSrcweir 
63*cdf0e10cSrcweir    If the return value is UPDATE_SOURCE_NONE, then no update is
64*cdf0e10cSrcweir    available, otherwise the return value determine from which the
65*cdf0e10cSrcweir    repository the update is used.
66*cdf0e10cSrcweir */
67*cdf0e10cSrcweir DESKTOP_DEPLOYMENTMISC_DLLPUBLIC
68*cdf0e10cSrcweir UPDATE_SOURCE isUpdateUserExtension(
69*cdf0e10cSrcweir     bool bReadOnlyShared,
70*cdf0e10cSrcweir     ::rtl::OUString const & userVersion,
71*cdf0e10cSrcweir     ::rtl::OUString const & sharedVersion,
72*cdf0e10cSrcweir     ::rtl::OUString const & bundledVersion,
73*cdf0e10cSrcweir     ::rtl::OUString const & onlineVersion);
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir /* determine if an update is available which is installed in the
76*cdf0e10cSrcweir    shared repository.
77*cdf0e10cSrcweir 
78*cdf0e10cSrcweir    If the return value is UPDATE_SOURCE_NONE, then no update is
79*cdf0e10cSrcweir    available, otherwise the return value determine from which the
80*cdf0e10cSrcweir    repository the update is used.
81*cdf0e10cSrcweir */
82*cdf0e10cSrcweir DESKTOP_DEPLOYMENTMISC_DLLPUBLIC
83*cdf0e10cSrcweir UPDATE_SOURCE isUpdateSharedExtension(
84*cdf0e10cSrcweir     bool bReadOnlyShared,
85*cdf0e10cSrcweir     ::rtl::OUString const & sharedVersion,
86*cdf0e10cSrcweir     ::rtl::OUString const & bundledVersion,
87*cdf0e10cSrcweir     ::rtl::OUString const & onlineVersion);
88*cdf0e10cSrcweir 
89*cdf0e10cSrcweir /* determines the extension with the highest identifier and returns it
90*cdf0e10cSrcweir 
91*cdf0e10cSrcweir  */
92*cdf0e10cSrcweir DESKTOP_DEPLOYMENTMISC_DLLPUBLIC
93*cdf0e10cSrcweir ::com::sun::star::uno::Reference< ::com::sun::star::deployment::XPackage>
94*cdf0e10cSrcweir getExtensionWithHighestVersion(
95*cdf0e10cSrcweir     ::com::sun::star::uno::Sequence<
96*cdf0e10cSrcweir     ::com::sun::star::uno::Reference<
97*cdf0e10cSrcweir     ::com::sun::star::deployment::XPackage> > const & seqExtensionsWithSameId);
98*cdf0e10cSrcweir 
99*cdf0e10cSrcweir 
100*cdf0e10cSrcweir struct UpdateInfo
101*cdf0e10cSrcweir {
102*cdf0e10cSrcweir     UpdateInfo( ::com::sun::star::uno::Reference< ::com::sun::star::deployment::XPackage> const & ext);
103*cdf0e10cSrcweir     ::com::sun::star::uno::Reference<
104*cdf0e10cSrcweir         ::com::sun::star::deployment::XPackage> extension;
105*cdf0e10cSrcweir //version of the update
106*cdf0e10cSrcweir     ::rtl::OUString version;
107*cdf0e10cSrcweir     ::com::sun::star::uno::Reference< ::com::sun::star::xml::dom::XNode > info;
108*cdf0e10cSrcweir };
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir typedef std::map< ::rtl::OUString, UpdateInfo > UpdateInfoMap;
111*cdf0e10cSrcweir 
112*cdf0e10cSrcweir /*
113*cdf0e10cSrcweir   @param extensionList
114*cdf0e10cSrcweir   List of extension for which online update information are to be obtained. If NULL, then
115*cdf0e10cSrcweir   for update information are obtained for all installed extension. There may be only one extension
116*cdf0e10cSrcweir   with a particular identifier contained in the list. If one extension is installed
117*cdf0e10cSrcweir   in several repositories, then the one with the highest version must be used, because it contains
118*cdf0e10cSrcweir   the more recent URLs for getting the update information (if at all).
119*cdf0e10cSrcweir   @param out_errors
120*cdf0e10cSrcweir   the first member of the pair is the extension  and the second the exception that was produced
121*cdf0e10cSrcweir   when processing the extension.
122*cdf0e10cSrcweir 
123*cdf0e10cSrcweir   @return
124*cdf0e10cSrcweir   A map of UpdateInfo instances. If the parameter extensionList was given, then the map contains
125*cdf0e10cSrcweir   at only information for those extensions.
126*cdf0e10cSrcweir  */
127*cdf0e10cSrcweir DESKTOP_DEPLOYMENTMISC_DLLPUBLIC
128*cdf0e10cSrcweir UpdateInfoMap getOnlineUpdateInfos(
129*cdf0e10cSrcweir     ::com::sun::star::uno::Reference< ::com::sun::star::uno::XComponentContext> const &xContext,
130*cdf0e10cSrcweir     ::com::sun::star::uno::Reference< ::com::sun::star::deployment::XExtensionManager> const & xExtMgr,
131*cdf0e10cSrcweir     ::com::sun::star::uno::Reference< ::com::sun::star::deployment::XUpdateInformationProvider > const & updateInformation,
132*cdf0e10cSrcweir     std::vector< ::com::sun::star::uno::Reference< ::com::sun::star::deployment::XPackage > > const * extensionList,
133*cdf0e10cSrcweir     ::std::vector< ::std::pair< ::com::sun::star::uno::Reference<
134*cdf0e10cSrcweir     ::com::sun::star::deployment::XPackage>, ::com::sun::star::uno::Any> > & out_errors);
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir /* retunrs the highest version from the provided arguments.
137*cdf0e10cSrcweir */
138*cdf0e10cSrcweir DESKTOP_DEPLOYMENTMISC_DLLPUBLIC
139*cdf0e10cSrcweir ::rtl::OUString getHighestVersion(
140*cdf0e10cSrcweir     ::rtl::OUString const & userVersion,
141*cdf0e10cSrcweir     ::rtl::OUString const & sharedVersion,
142*cdf0e10cSrcweir     ::rtl::OUString const & bundledVersion,
143*cdf0e10cSrcweir     ::rtl::OUString const & onlineVersion);
144*cdf0e10cSrcweir 
145*cdf0e10cSrcweir }
146*cdf0e10cSrcweir 
147*cdf0e10cSrcweir #endif
148