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 // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_desktop.hxx"
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #include "checkinstall.hxx"
32*cdf0e10cSrcweir #include <com/sun/star/beans/XExactName.hpp>
33*cdf0e10cSrcweir #include <com/sun/star/beans/XMaterialHolder.hpp>
34*cdf0e10cSrcweir #include <com/sun/star/container/XContentEnumerationAccess.hpp>
35*cdf0e10cSrcweir #include <com/sun/star/util/Date.hpp>
36*cdf0e10cSrcweir #include <com/sun/star/lang/XMultiServiceFactory.hpp>
37*cdf0e10cSrcweir #include <comphelper/processfactory.hxx>
38*cdf0e10cSrcweir #include <vcl/msgbox.hxx>
39*cdf0e10cSrcweir #include <tools/date.hxx>
40*cdf0e10cSrcweir 
41*cdf0e10cSrcweir using namespace rtl;
42*cdf0e10cSrcweir using namespace com::sun::star::uno;
43*cdf0e10cSrcweir using namespace com::sun::star::lang;
44*cdf0e10cSrcweir using namespace com::sun::star::beans;
45*cdf0e10cSrcweir 
46*cdf0e10cSrcweir namespace desktop
47*cdf0e10cSrcweir {
48*cdf0e10cSrcweir 
49*cdf0e10cSrcweir sal_Bool CheckInstallation( OUString& rTitle )
50*cdf0e10cSrcweir {
51*cdf0e10cSrcweir     try
52*cdf0e10cSrcweir     {
53*cdf0e10cSrcweir 	    Reference< XMultiServiceFactory > xSMgr = ::comphelper::getProcessServiceFactory();
54*cdf0e10cSrcweir 	    Reference< XExactName > xExactName( xSMgr->createInstance(
55*cdf0e10cSrcweir 								    ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM(
56*cdf0e10cSrcweir 									    "com.sun.star.comp.desktop.Evaluation" ))),
57*cdf0e10cSrcweir 								    UNO_QUERY );
58*cdf0e10cSrcweir 	    if ( xExactName.is() )
59*cdf0e10cSrcweir 	    {
60*cdf0e10cSrcweir 		    try
61*cdf0e10cSrcweir 		    {
62*cdf0e10cSrcweir 			    rTitle = xExactName->getExactName( rTitle );
63*cdf0e10cSrcweir 			    Reference< XMaterialHolder > xMaterialHolder( xExactName, UNO_QUERY );
64*cdf0e10cSrcweir 			    if ( xMaterialHolder.is() )
65*cdf0e10cSrcweir 			    {
66*cdf0e10cSrcweir 				    com::sun::star::util::Date aExpirationDate;
67*cdf0e10cSrcweir 				    Any a = xMaterialHolder->getMaterial();
68*cdf0e10cSrcweir 				    if ( a >>= aExpirationDate )
69*cdf0e10cSrcweir 				    {
70*cdf0e10cSrcweir 					    Date aToday;
71*cdf0e10cSrcweir 					    Date aTimeBombDate( aExpirationDate.Day, aExpirationDate.Month, aExpirationDate.Year );
72*cdf0e10cSrcweir 					    if ( aToday > aTimeBombDate )
73*cdf0e10cSrcweir 					    {
74*cdf0e10cSrcweir 						    InfoBox aInfoBox( NULL, String::CreateFromAscii( "This version has expired" ) );
75*cdf0e10cSrcweir 						    aInfoBox.Execute();
76*cdf0e10cSrcweir 						    return sal_False;
77*cdf0e10cSrcweir 					    }
78*cdf0e10cSrcweir 				    }
79*cdf0e10cSrcweir 
80*cdf0e10cSrcweir 				    return sal_True;
81*cdf0e10cSrcweir 			    }
82*cdf0e10cSrcweir 			    else
83*cdf0e10cSrcweir 			    {
84*cdf0e10cSrcweir 				    InfoBox aInfoBox( NULL, rTitle );
85*cdf0e10cSrcweir 				    aInfoBox.Execute();
86*cdf0e10cSrcweir 				    return sal_False;
87*cdf0e10cSrcweir 			    }
88*cdf0e10cSrcweir 		    }
89*cdf0e10cSrcweir 		    catch ( RuntimeException& )
90*cdf0e10cSrcweir 		    {
91*cdf0e10cSrcweir 			    // Evaluation version expired!
92*cdf0e10cSrcweir 			    return sal_False;
93*cdf0e10cSrcweir 		    }
94*cdf0e10cSrcweir 	    }
95*cdf0e10cSrcweir 	    else
96*cdf0e10cSrcweir 	    {
97*cdf0e10cSrcweir 		    Reference< com::sun::star::container::XContentEnumerationAccess > rContent( xSMgr , UNO_QUERY );
98*cdf0e10cSrcweir 		    if( rContent.is() )
99*cdf0e10cSrcweir 		    {
100*cdf0e10cSrcweir 			    OUString sEvalService = OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.office.Evaluation" ) );
101*cdf0e10cSrcweir 			    Reference < com::sun::star::container::XEnumeration > rEnum = rContent->createContentEnumeration( sEvalService );
102*cdf0e10cSrcweir 			    if ( rEnum.is() )
103*cdf0e10cSrcweir 			    {
104*cdf0e10cSrcweir 				    InfoBox aInfoBox( NULL, rTitle );
105*cdf0e10cSrcweir 				    aInfoBox.Execute();
106*cdf0e10cSrcweir 				    return sal_False;
107*cdf0e10cSrcweir 			    }
108*cdf0e10cSrcweir 		    }
109*cdf0e10cSrcweir 	    }
110*cdf0e10cSrcweir     }
111*cdf0e10cSrcweir     catch(Exception)
112*cdf0e10cSrcweir     {
113*cdf0e10cSrcweir     }
114*cdf0e10cSrcweir 
115*cdf0e10cSrcweir 	return sal_True;
116*cdf0e10cSrcweir }
117*cdf0e10cSrcweir 
118*cdf0e10cSrcweir } // namespace desktop
119