1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
13 #include <com/sun/star/security/CertificateContainer.hpp>
14 #include <com/sun/star/security/XCertificate.hpp>
15 #include <com/sun/star/security/XCertificateContainer.hpp>
16 #include <com/sun/star/xml/crypto/SEInitializer.hpp>
17 #include <com/sun/star/xml/crypto/XSecurityEnvironment.hpp>
19 #include <rtl/ref.hxx>
20 #include <comphelper/sequence.hxx>
21 #include <ucbhelper/simplecertificatevalidationrequest.hxx>
23 #include "certvalidation_handler.hxx"
25 #define STD_TO_OUSTR( str ) OUString( str.c_str(), str.length( ), RTL_TEXTENCODING_UTF8 )
28 using namespace com::sun::star
;
32 bool CertValidationHandler::validateCertificate( vector
< string
> aCertificates
)
34 bool bValidate
= false;
35 if ( !aCertificates
.empty() && m_xEnv
.is() )
37 uno::Reference
< xml::crypto::XSEInitializer
> xSEInitializer
;
40 xSEInitializer
= xml::crypto::SEInitializer::create( m_xContext
);
42 catch ( uno::Exception
const & )
46 if ( xSEInitializer
.is() )
48 uno::Reference
< xml::crypto::XXMLSecurityContext
> xSecurityContext(
49 xSEInitializer
->createSecurityContext( OUString() ) );
51 uno::Reference
< xml::crypto::XSecurityEnvironment
> xSecurityEnv(
52 xSecurityContext
->getSecurityEnvironment() );
54 vector
< string
>::iterator pIt
= aCertificates
.begin();
56 // We need to get rid of the PEM header/footer lines
57 OUString sCleanCert
= STD_TO_OUSTR( sCert
);
58 sCleanCert
= sCleanCert
.replaceAll( "-----BEGIN CERTIFICATE-----", "" );
59 sCleanCert
= sCleanCert
.replaceAll( "-----END CERTIFICATE-----", "" );
60 uno::Reference
< security::XCertificate
> xCert(
61 xSecurityEnv
->createCertificateFromAscii(
64 uno::Reference
< security::XCertificateContainer
> xCertificateContainer
;
67 xCertificateContainer
= security::CertificateContainer::create( m_xContext
);
69 catch ( uno::Exception
const & )
73 if ( xCertificateContainer
.is( ) )
75 security::CertificateContainerStatus
status(
76 xCertificateContainer
->hasCertificate(
77 m_sHostname
, xCert
->getSubjectName() ) );
79 if ( status
!= security::CertificateContainerStatus_NOCERT
)
80 return status
== security::CertificateContainerStatus_TRUSTED
;
83 // If we had no certificate, ask what to do
84 std::vector
< uno::Reference
< security::XCertificate
> > vecCerts
;
86 for ( ++pIt
; pIt
!= aCertificates
.end(); ++pIt
)
89 uno::Reference
< security::XCertificate
> xImCert(
90 xSecurityEnv
->createCertificateFromAscii(
91 STD_TO_OUSTR( sCert
) ) );
93 vecCerts
.push_back( xImCert
);
96 sal_Int64 certValidity
= xSecurityEnv
->verifyCertificate( xCert
,
97 ::comphelper::containerToSequence( vecCerts
) );
99 uno::Reference
< task::XInteractionHandler
> xIH(
100 m_xEnv
->getInteractionHandler() );
103 rtl::Reference
< ucbhelper::SimpleCertificateValidationRequest
>
104 xRequest( new ucbhelper::SimpleCertificateValidationRequest(
105 sal_Int32( certValidity
), xCert
, m_sHostname
) );
106 xIH
->handle( xRequest
);
107 rtl::Reference
< ucbhelper::InteractionContinuation
> xSelection
108 = xRequest
->getSelection();
110 if ( xSelection
.is() )
112 uno::Reference
< task::XInteractionApprove
> xApprove(
113 xSelection
.get(), uno::UNO_QUERY
);
114 bValidate
= xApprove
.is();
116 // Store the decision in the container
117 xCertificateContainer
->addCertificate(
118 m_sHostname
, xCert
->getSubjectName(), bValidate
);
127 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */