1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #include "precompiled_xmlsecurity.hxx"
25*b1cdbd2cSJim Jagielski #include <certificatecontainer.hxx>
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include <sal/config.h>
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski sal_Bool
searchMap(const::rtl::OUString & url,const::rtl::OUString & certificate_name,Map & _certMap)33*b1cdbd2cSJim Jagielski CertificateContainer::searchMap( const ::rtl::OUString & url, const ::rtl::OUString & certificate_name, Map &_certMap )
34*b1cdbd2cSJim Jagielski {
35*b1cdbd2cSJim Jagielski 	Map::iterator p = _certMap.find(url);
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski 	::sal_Bool ret = sal_False;
38*b1cdbd2cSJim Jagielski 
39*b1cdbd2cSJim Jagielski 	while( p != _certMap.end() )
40*b1cdbd2cSJim Jagielski 	{
41*b1cdbd2cSJim Jagielski 		ret = (sal_Bool) (*p).second.equals(certificate_name);
42*b1cdbd2cSJim Jagielski 		if( ret )
43*b1cdbd2cSJim Jagielski                     break;
44*b1cdbd2cSJim Jagielski 		p++;
45*b1cdbd2cSJim Jagielski 	}
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski 	return ret;
48*b1cdbd2cSJim Jagielski }
49*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------
50*b1cdbd2cSJim Jagielski 
51*b1cdbd2cSJim Jagielski sal_Bool
isTemporaryCertificate(const::rtl::OUString & url,const::rtl::OUString & certificate_name)52*b1cdbd2cSJim Jagielski CertificateContainer::isTemporaryCertificate ( const ::rtl::OUString & url, const ::rtl::OUString & certificate_name )
53*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski 	return searchMap( url, certificate_name, certMap);
56*b1cdbd2cSJim Jagielski }
57*b1cdbd2cSJim Jagielski 
58*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------
59*b1cdbd2cSJim Jagielski 
60*b1cdbd2cSJim Jagielski sal_Bool
isCertificateTrust(const::rtl::OUString & url,const::rtl::OUString & certificate_name)61*b1cdbd2cSJim Jagielski CertificateContainer::isCertificateTrust ( const ::rtl::OUString & url, const ::rtl::OUString & certificate_name )
62*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
63*b1cdbd2cSJim Jagielski {
64*b1cdbd2cSJim Jagielski 	return searchMap( url, certificate_name, certTrustMap);
65*b1cdbd2cSJim Jagielski }
66*b1cdbd2cSJim Jagielski 
67*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------
68*b1cdbd2cSJim Jagielski sal_Bool
addCertificate(const::rtl::OUString & url,const::rtl::OUString & certificate_name,::sal_Bool trust)69*b1cdbd2cSJim Jagielski CertificateContainer::addCertificate( const ::rtl::OUString & url, const ::rtl::OUString & certificate_name, ::sal_Bool trust )
70*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
71*b1cdbd2cSJim Jagielski {
72*b1cdbd2cSJim Jagielski 	certMap.insert( Map::value_type( url, certificate_name ) );
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski         //remember that the cert is trusted
75*b1cdbd2cSJim Jagielski         if (trust)
76*b1cdbd2cSJim Jagielski             certTrustMap.insert( Map::value_type( url, certificate_name ) );
77*b1cdbd2cSJim Jagielski 
78*b1cdbd2cSJim Jagielski         return true;
79*b1cdbd2cSJim Jagielski }
80*b1cdbd2cSJim Jagielski 
81*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
82*b1cdbd2cSJim Jagielski ::security::CertificateContainerStatus
hasCertificate(const::rtl::OUString & url,const::rtl::OUString & certificate_name)83*b1cdbd2cSJim Jagielski CertificateContainer::hasCertificate( const ::rtl::OUString & url, const ::rtl::OUString & certificate_name ) throw(::com::sun::star::uno::RuntimeException)
84*b1cdbd2cSJim Jagielski {
85*b1cdbd2cSJim Jagielski 	if ( isTemporaryCertificate( url, certificate_name ) )
86*b1cdbd2cSJim Jagielski 	{
87*b1cdbd2cSJim Jagielski 		if ( isCertificateTrust( url, certificate_name ) )
88*b1cdbd2cSJim Jagielski 			return security::CertificateContainerStatus( security::CertificateContainerStatus_TRUSTED );
89*b1cdbd2cSJim Jagielski 		else
90*b1cdbd2cSJim Jagielski 			return security::CertificateContainerStatus_UNTRUSTED;
91*b1cdbd2cSJim Jagielski 	} else
92*b1cdbd2cSJim Jagielski 	{
93*b1cdbd2cSJim Jagielski 		return security::CertificateContainerStatus_NOCERT;
94*b1cdbd2cSJim Jagielski 	}
95*b1cdbd2cSJim Jagielski }
96*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
97*b1cdbd2cSJim Jagielski 
98*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL
getImplementationName()99*b1cdbd2cSJim Jagielski CertificateContainer::getImplementationName( )
100*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
101*b1cdbd2cSJim Jagielski {
102*b1cdbd2cSJim Jagielski     return impl_getStaticImplementationName();
103*b1cdbd2cSJim Jagielski }
104*b1cdbd2cSJim Jagielski 
105*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL
supportsService(const::rtl::OUString & ServiceName)108*b1cdbd2cSJim Jagielski CertificateContainer::supportsService( const ::rtl::OUString& ServiceName )
109*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
110*b1cdbd2cSJim Jagielski {
111*b1cdbd2cSJim Jagielski     if ( ServiceName.compareToAscii("com.sun.star.security.CertificateContainer") == 0 )
112*b1cdbd2cSJim Jagielski         return sal_True;
113*b1cdbd2cSJim Jagielski     else
114*b1cdbd2cSJim Jagielski         return sal_False;
115*b1cdbd2cSJim Jagielski }
116*b1cdbd2cSJim Jagielski 
117*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
118*b1cdbd2cSJim Jagielski 
119*b1cdbd2cSJim Jagielski Sequence< ::rtl::OUString > SAL_CALL
getSupportedServiceNames()120*b1cdbd2cSJim Jagielski CertificateContainer::getSupportedServiceNames(  )
121*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
122*b1cdbd2cSJim Jagielski {
123*b1cdbd2cSJim Jagielski 	return impl_getStaticSupportedServiceNames();
124*b1cdbd2cSJim Jagielski }
125*b1cdbd2cSJim Jagielski 
126*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski Sequence< ::rtl::OUString > SAL_CALL
impl_getStaticSupportedServiceNames()129*b1cdbd2cSJim Jagielski CertificateContainer::impl_getStaticSupportedServiceNames(  )
130*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
131*b1cdbd2cSJim Jagielski {
132*b1cdbd2cSJim Jagielski     Sequence< ::rtl::OUString > aRet(1);
133*b1cdbd2cSJim Jagielski     *aRet.getArray() = ::rtl::OUString::createFromAscii("com.sun.star.security.CertificateContainer");
134*b1cdbd2cSJim Jagielski     return aRet;
135*b1cdbd2cSJim Jagielski }
136*b1cdbd2cSJim Jagielski 
137*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
138*b1cdbd2cSJim Jagielski 
139*b1cdbd2cSJim Jagielski ::rtl::OUString SAL_CALL
impl_getStaticImplementationName()140*b1cdbd2cSJim Jagielski CertificateContainer::impl_getStaticImplementationName()
141*b1cdbd2cSJim Jagielski     throw(::com::sun::star::uno::RuntimeException)
142*b1cdbd2cSJim Jagielski {
143*b1cdbd2cSJim Jagielski     return ::rtl::OUString::createFromAscii("com.sun.star.security.CertificateContainer");
144*b1cdbd2cSJim Jagielski }
145*b1cdbd2cSJim Jagielski 
146*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
147*b1cdbd2cSJim Jagielski 
impl_createInstance(const Reference<XMultiServiceFactory> & xServiceManager)148*b1cdbd2cSJim Jagielski Reference< XInterface > SAL_CALL CertificateContainer::impl_createInstance( const Reference< XMultiServiceFactory >& xServiceManager )
149*b1cdbd2cSJim Jagielski     throw( RuntimeException )
150*b1cdbd2cSJim Jagielski {
151*b1cdbd2cSJim Jagielski 	return Reference< XInterface >( *new CertificateContainer( xServiceManager ) );
152*b1cdbd2cSJim Jagielski }
153*b1cdbd2cSJim Jagielski 
154*b1cdbd2cSJim Jagielski //-------------------------------------------------------------------------
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski Reference< XSingleServiceFactory > SAL_CALL
impl_createFactory(const Reference<XMultiServiceFactory> & ServiceManager)157*b1cdbd2cSJim Jagielski CertificateContainer::impl_createFactory( const Reference< XMultiServiceFactory >& ServiceManager )
158*b1cdbd2cSJim Jagielski     throw(RuntimeException)
159*b1cdbd2cSJim Jagielski {
160*b1cdbd2cSJim Jagielski 	Reference< XSingleServiceFactory > xReturn( ::cppu::createOneInstanceFactory( ServiceManager,
161*b1cdbd2cSJim Jagielski 		CertificateContainer::impl_getStaticImplementationName(),
162*b1cdbd2cSJim Jagielski 		CertificateContainer::impl_createInstance,
163*b1cdbd2cSJim Jagielski 		CertificateContainer::impl_getStaticSupportedServiceNames()));
164*b1cdbd2cSJim Jagielski 
165*b1cdbd2cSJim Jagielski 	return xReturn;
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski 
168