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