merge the formfield patch from ooo-build
[ooovba.git] / xmlsecurity / source / xmlsec / mscrypt / xsec_mscrypt.cxx
blobf6e186b405fb29bf9690c71d8ded118dd1c66d04
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: xsec_mscrypt.cxx,v $
10 * $Revision: 1.5 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 // MARKER(update_precomp.py): autogen include statement, do not remove
32 #include "precompiled_xmlsecurity.hxx"
34 #include <sal/config.h>
35 #include <stdio.h>
37 #include <osl/mutex.hxx>
38 #include <osl/thread.h>
39 #include <cppuhelper/factory.hxx>
40 #include <com/sun/star/lang/XSingleServiceFactory.hpp>
42 #include "seinitializer_mscryptimpl.hxx"
43 #include "xmlsignature_mscryptimpl.hxx"
44 #include "xmlencryption_mscryptimpl.hxx"
45 #include "xmlsecuritycontext_mscryptimpl.hxx"
46 #include "securityenvironment_mscryptimpl.hxx"
48 using namespace ::rtl;
49 using namespace ::cppu;
50 using namespace ::com::sun::star::uno;
51 using namespace ::com::sun::star::lang;
52 using namespace ::com::sun::star::registry;
54 extern "C"
57 sal_Bool SAL_CALL mscrypt_component_writeInfo( void* /*pServiceManager*/ , void* pRegistryKey )
59 sal_Bool result = sal_False;
60 sal_Int32 i ;
61 OUString sKeyName ;
62 Reference< XRegistryKey > xNewKey ;
63 Sequence< OUString > seqServices ;
64 Reference< XRegistryKey > xKey( reinterpret_cast< XRegistryKey* >( pRegistryKey ) ) ;
66 if( xKey.is() ) {
67 // try {
68 // XMLSignature_MSCryptImpl
69 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
70 sKeyName += XMLSignature_MSCryptImpl::impl_getImplementationName() ;
71 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
73 xNewKey = xKey->createKey( sKeyName ) ;
74 if( xNewKey.is() ) {
75 seqServices = XMLSignature_MSCryptImpl::impl_getSupportedServiceNames() ;
76 for( i = seqServices.getLength() ; i -- ; )
77 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
80 // XMLEncryption_MSCryptImpl
81 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
82 sKeyName += XMLEncryption_MSCryptImpl::impl_getImplementationName() ;
83 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
85 xNewKey = xKey->createKey( sKeyName ) ;
86 if( xNewKey.is() ) {
87 seqServices = XMLEncryption_MSCryptImpl::impl_getSupportedServiceNames() ;
88 for( i = seqServices.getLength() ; i -- ; )
89 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
92 // XMLSecurityContext_MSCryptImpl
93 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
94 sKeyName += XMLSecurityContext_MSCryptImpl::impl_getImplementationName() ;
95 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
97 xNewKey = xKey->createKey( sKeyName ) ;
98 if( xNewKey.is() ) {
99 seqServices = XMLSecurityContext_MSCryptImpl::impl_getSupportedServiceNames() ;
100 for( i = seqServices.getLength() ; i -- ; )
101 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
104 // SecurityEnvironment_MSCryptImpl
105 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
106 sKeyName += SecurityEnvironment_MSCryptImpl::impl_getImplementationName() ;
107 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
109 xNewKey = xKey->createKey( sKeyName ) ;
110 if( xNewKey.is() ) {
111 seqServices = SecurityEnvironment_MSCryptImpl::impl_getSupportedServiceNames() ;
112 for( i = seqServices.getLength() ; i -- ; )
113 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
116 // SEInitializer_MSCryptImpl
117 sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
118 sKeyName += SEInitializer_MSCryptImpl_getImplementationName() ;
119 sKeyName += OUString::createFromAscii( "/UNO/SERVICES" ) ;
121 xNewKey = xKey->createKey( sKeyName ) ;
122 if( xNewKey.is() ) {
123 seqServices = SEInitializer_MSCryptImpl_getSupportedServiceNames() ;
124 for( i = seqServices.getLength() ; i -- ; )
125 xNewKey->createKey( seqServices.getConstArray()[i] ) ;
128 return sal_True;
129 //} catch( InvalidRegistryException & ) {
130 // //we should not ignore exceptions
131 // return sal_False ;
134 return result;
137 void* SAL_CALL mscrypt_component_getFactory( const sal_Char* pImplName , void* pServiceManager , void* /*pRegistryKey*/ )
139 void* pRet = 0;
140 Reference< XSingleServiceFactory > xFactory ;
142 if( pImplName != NULL && pServiceManager != NULL ) {
143 if( XMLSignature_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
144 xFactory = XMLSignature_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
145 } else if( XMLSecurityContext_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
146 xFactory = XMLSecurityContext_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
147 } else if( SecurityEnvironment_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
148 xFactory = SecurityEnvironment_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
149 } else if( XMLEncryption_MSCryptImpl::impl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
150 xFactory = XMLEncryption_MSCryptImpl::impl_createFactory( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ;
151 } else if( SEInitializer_MSCryptImpl_getImplementationName().equals( OUString::createFromAscii( pImplName ) ) ) {
152 xFactory = Reference< XSingleServiceFactory >( createSingleFactory(
153 reinterpret_cast< XMultiServiceFactory * >( pServiceManager ),
154 OUString::createFromAscii( pImplName ),
155 SEInitializer_MSCryptImpl_createInstance, SEInitializer_MSCryptImpl_getSupportedServiceNames() ) );
159 if( xFactory.is() ) {
160 xFactory->acquire() ;
161 pRet = xFactory.get() ;
164 return pRet ;