merged tag ooo/OOO330_m14
[LibreOffice.git] / xmlsecurity / source / xmlsec / mscrypt / xsec_mscrypt.cxx
blob87b7bf035cc5d0c533d000eaeff6c1acab8b9c8f
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * This file is part of OpenOffice.org.
11 * OpenOffice.org is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License version 3
13 * only, as published by the Free Software Foundation.
15 * OpenOffice.org is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License version 3 for more details
19 * (a copy is included in the LICENSE file that accompanied this code).
21 * You should have received a copy of the GNU Lesser General Public License
22 * version 3 along with OpenOffice.org. If not, see
23 * <http://www.openoffice.org/license.html>
24 * for a copy of the LGPLv3 License.
26 ************************************************************************/
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_xmlsecurity.hxx"
31 #include <sal/config.h>
32 #include <stdio.h>
34 #include <osl/mutex.hxx>
35 #include <osl/thread.h>
36 #include <cppuhelper/factory.hxx>
37 #include <com/sun/star/lang/XSingleServiceFactory.hpp>
39 #include "seinitializer_mscryptimpl.hxx"
40 #include "xmlsignature_mscryptimpl.hxx"
41 #include "xmlencryption_mscryptimpl.hxx"
42 #include "xmlsecuritycontext_mscryptimpl.hxx"
43 #include "securityenvironment_mscryptimpl.hxx"
45 using namespace ::rtl;
46 using namespace ::cppu;
47 using namespace ::com::sun::star::uno;
48 using namespace ::com::sun::star::lang;
49 using namespace ::com::sun::star::registry;
51 extern "C"
54 sal_Bool SAL_CALL mscrypt_component_writeInfo( void* /*pServiceManager*/ , void* pRegistryKey )
56 sal_Bool result = sal_False;
57 sal_Int32 i ;
58 OUString sKeyName ;
59 Reference< XRegistryKey > xNewKey ;
60 Sequence< OUString > seqServices ;
61 Reference< XRegistryKey > xKey( reinterpret_cast< XRegistryKey* >( pRegistryKey ) ) ;
63 if( xKey.is() ) {
64 // try {
65 // XMLSignature_MSCryptImpl
66 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
67 sKeyName += XMLSignature_MSCryptImpl::impl_getImplementationName() ;
68 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
70 xNewKey = xKey->createKey( sKeyName ) ;
71 if( xNewKey.is() ) {
72 seqServices = XMLSignature_MSCryptImpl::impl_getSupportedServiceNames() ;
73 for( i = seqServices.getLength() ; i -- ; )
74 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
77 // XMLEncryption_MSCryptImpl
78 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
79 sKeyName += XMLEncryption_MSCryptImpl::impl_getImplementationName() ;
80 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
82 xNewKey = xKey->createKey( sKeyName ) ;
83 if( xNewKey.is() ) {
84 seqServices = XMLEncryption_MSCryptImpl::impl_getSupportedServiceNames() ;
85 for( i = seqServices.getLength() ; i -- ; )
86 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
89 // XMLSecurityContext_MSCryptImpl
90 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
91 sKeyName += XMLSecurityContext_MSCryptImpl::impl_getImplementationName() ;
92 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
94 xNewKey = xKey->createKey( sKeyName ) ;
95 if( xNewKey.is() ) {
96 seqServices = XMLSecurityContext_MSCryptImpl::impl_getSupportedServiceNames() ;
97 for( i = seqServices.getLength() ; i -- ; )
98 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
101 // SecurityEnvironment_MSCryptImpl
102 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
103 sKeyName += SecurityEnvironment_MSCryptImpl::impl_getImplementationName() ;
104 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
106 xNewKey = xKey->createKey( sKeyName ) ;
107 if( xNewKey.is() ) {
108 seqServices = SecurityEnvironment_MSCryptImpl::impl_getSupportedServiceNames() ;
109 for( i = seqServices.getLength() ; i -- ; )
110 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
113 // SEInitializer_MSCryptImpl
114 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
115 sKeyName += SEInitializer_MSCryptImpl_getImplementationName() ;
116 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
118 xNewKey = xKey->createKey( sKeyName ) ;
119 if( xNewKey.is() ) {
120 seqServices = SEInitializer_MSCryptImpl_getSupportedServiceNames() ;
121 for( i = seqServices.getLength() ; i -- ; )
122 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
125 return sal_True;
126 //} catch( InvalidRegistryException & ) {
127 // //we should not ignore exceptions
128 // return sal_False ;
131 return result;
134 void* SAL_CALL mscrypt_component_getFactory( const sal_Char* pImplName , void* pServiceManager , void* /*pRegistryKey*/ )
136 void* pRet = 0;
137 Reference< XSingleServiceFactory > xFactory ;
139 if( pImplName != NULL && pServiceManager != NULL ) {
140 if( XMLSignature_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
141 xFactory = XMLSignature_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
142 } else if( XMLSecurityContext_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
143 xFactory = XMLSecurityContext_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
144 } else if( SecurityEnvironment_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
145 xFactory = SecurityEnvironment_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
146 } else if( XMLEncryption_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
147 xFactory = XMLEncryption_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
148 } else if( SEInitializer_MSCryptImpl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
149 xFactory = Reference< XSingleServiceFactory >( createSingleFactory(
150 reinterpret_cast< XMultiServiceFactory * >( pServiceManager ),
151 OUString::createFromAscii( pImplName ),
152 SEInitializer_MSCryptImpl_createInstance, SEInitializer_MSCryptImpl_getSupportedServiceNames() ) );
156 if( xFactory.is() ) {
157 xFactory->acquire() ;
158 pRet = xFactory.get() ;
161 return pRet ;