1*06b3ce53SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*06b3ce53SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*06b3ce53SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*06b3ce53SAndrew Rist * distributed with this work for additional information 6*06b3ce53SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*06b3ce53SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*06b3ce53SAndrew Rist * "License"); you may not use this file except in compliance 9*06b3ce53SAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 11*06b3ce53SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 13*06b3ce53SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*06b3ce53SAndrew Rist * software distributed under the License is distributed on an 15*06b3ce53SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*06b3ce53SAndrew Rist * KIND, either express or implied. See the License for the 17*06b3ce53SAndrew Rist * specific language governing permissions and limitations 18*06b3ce53SAndrew Rist * under the License. 19cdf0e10cSrcweir * 20*06b3ce53SAndrew Rist *************************************************************/ 21*06b3ce53SAndrew Rist 22*06b3ce53SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 25cdf0e10cSrcweir #include "precompiled_xmlsecurity.hxx" 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "encryptorimpl.hxx" 28cdf0e10cSrcweir #include <com/sun/star/xml/crypto/XXMLEncryptionTemplate.hpp> 29cdf0e10cSrcweir #include <com/sun/star/xml/wrapper/XXMLElementWrapper.hpp> 30cdf0e10cSrcweir #include <com/sun/star/lang/XMultiServiceFactory.hpp> 31cdf0e10cSrcweir 32cdf0e10cSrcweir namespace cssu = com::sun::star::uno; 33cdf0e10cSrcweir namespace cssl = com::sun::star::lang; 34cdf0e10cSrcweir namespace cssxc = com::sun::star::xml::crypto; 35cdf0e10cSrcweir namespace cssxw = com::sun::star::xml::wrapper; 36cdf0e10cSrcweir 37cdf0e10cSrcweir #define SERVICE_NAME "com.sun.star.xml.crypto.sax.Encryptor" 38cdf0e10cSrcweir #define IMPLEMENTATION_NAME "com.sun.star.xml.security.framework.EncryptorImpl" 39cdf0e10cSrcweir 40cdf0e10cSrcweir #define DECLARE_ASCII( SASCIIVALUE ) \ 41cdf0e10cSrcweir rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SASCIIVALUE ) ) 42cdf0e10cSrcweir 43cdf0e10cSrcweir EncryptorImpl::EncryptorImpl( const cssu::Reference< cssl::XMultiServiceFactory >& rxMSF) 44cdf0e10cSrcweir { 45cdf0e10cSrcweir m_nReferenceId = -1; 46cdf0e10cSrcweir mxMSF = rxMSF; 47cdf0e10cSrcweir } 48cdf0e10cSrcweir 49cdf0e10cSrcweir EncryptorImpl::~EncryptorImpl() 50cdf0e10cSrcweir { 51cdf0e10cSrcweir } 52cdf0e10cSrcweir 53cdf0e10cSrcweir bool EncryptorImpl::checkReady() const 54cdf0e10cSrcweir /****** EncryptorImpl/checkReady ********************************************* 55cdf0e10cSrcweir * 56cdf0e10cSrcweir * NAME 57cdf0e10cSrcweir * checkReady -- checks the conditions for the encryption. 58cdf0e10cSrcweir * 59cdf0e10cSrcweir * SYNOPSIS 60cdf0e10cSrcweir * bReady = checkReady( ); 61cdf0e10cSrcweir * 62cdf0e10cSrcweir * FUNCTION 63cdf0e10cSrcweir * checks whether all following conditions are satisfied: 64cdf0e10cSrcweir * 1. the result listener is ready; 65cdf0e10cSrcweir * 2. the EncryptionEngine is ready. 66cdf0e10cSrcweir * 67cdf0e10cSrcweir * INPUTS 68cdf0e10cSrcweir * empty 69cdf0e10cSrcweir * 70cdf0e10cSrcweir * RESULT 71cdf0e10cSrcweir * bReady - true if all conditions are satisfied, false otherwise 72cdf0e10cSrcweir * 73cdf0e10cSrcweir * HISTORY 74cdf0e10cSrcweir * 05.01.2004 - implemented 75cdf0e10cSrcweir * 76cdf0e10cSrcweir * AUTHOR 77cdf0e10cSrcweir * Michael Mi 78cdf0e10cSrcweir * Email: michael.mi@sun.com 79cdf0e10cSrcweir ******************************************************************************/ 80cdf0e10cSrcweir { 81cdf0e10cSrcweir sal_Int32 nKeyInc = 0; 82cdf0e10cSrcweir if (m_nIdOfKeyEC != 0) 83cdf0e10cSrcweir { 84cdf0e10cSrcweir nKeyInc = 1; 85cdf0e10cSrcweir } 86cdf0e10cSrcweir 87cdf0e10cSrcweir return (m_xResultListener.is() && 88cdf0e10cSrcweir (m_nReferenceId != -1) && 89cdf0e10cSrcweir (2+nKeyInc == m_nNumOfResolvedReferences) && 90cdf0e10cSrcweir EncryptionEngine::checkReady()); 91cdf0e10cSrcweir } 92cdf0e10cSrcweir 93cdf0e10cSrcweir void EncryptorImpl::notifyResultListener() const 94cdf0e10cSrcweir throw (cssu::Exception, cssu::RuntimeException) 95cdf0e10cSrcweir /****** DecryptorImpl/notifyResultListener *********************************** 96cdf0e10cSrcweir * 97cdf0e10cSrcweir * NAME 98cdf0e10cSrcweir * notifyResultListener -- notifies the listener about the encryption 99cdf0e10cSrcweir * result. 100cdf0e10cSrcweir * 101cdf0e10cSrcweir * SYNOPSIS 102cdf0e10cSrcweir * notifyResultListener( ); 103cdf0e10cSrcweir * 104cdf0e10cSrcweir * FUNCTION 105cdf0e10cSrcweir * see NAME. 106cdf0e10cSrcweir * 107cdf0e10cSrcweir * INPUTS 108cdf0e10cSrcweir * empty 109cdf0e10cSrcweir * 110cdf0e10cSrcweir * RESULT 111cdf0e10cSrcweir * empty 112cdf0e10cSrcweir * 113cdf0e10cSrcweir * HISTORY 114cdf0e10cSrcweir * 05.01.2004 - implemented 115cdf0e10cSrcweir * 116cdf0e10cSrcweir * AUTHOR 117cdf0e10cSrcweir * Michael Mi 118cdf0e10cSrcweir * Email: michael.mi@sun.com 119cdf0e10cSrcweir ******************************************************************************/ 120cdf0e10cSrcweir { 121cdf0e10cSrcweir cssu::Reference< cssxc::sax::XEncryptionResultListener > 122cdf0e10cSrcweir xEncryptionResultListener ( m_xResultListener , cssu::UNO_QUERY ) ; 123cdf0e10cSrcweir 124cdf0e10cSrcweir xEncryptionResultListener->encrypted( m_nSecurityId, m_nStatus ); 125cdf0e10cSrcweir } 126cdf0e10cSrcweir 127cdf0e10cSrcweir void EncryptorImpl::startEngine( const cssu::Reference< 128cdf0e10cSrcweir cssxc::XXMLEncryptionTemplate >& 129cdf0e10cSrcweir xEncryptionTemplate) 130cdf0e10cSrcweir throw (cssu::Exception, cssu::RuntimeException) 131cdf0e10cSrcweir /****** EncryptorImpl/startEngine ******************************************** 132cdf0e10cSrcweir * 133cdf0e10cSrcweir * NAME 134cdf0e10cSrcweir * startEngine -- generates the encryption. 135cdf0e10cSrcweir * 136cdf0e10cSrcweir * SYNOPSIS 137cdf0e10cSrcweir * startEngine( xEncryptionTemplate ); 138cdf0e10cSrcweir * 139cdf0e10cSrcweir * FUNCTION 140cdf0e10cSrcweir * generates the encryption element, then if succeeds, updates the link 141cdf0e10cSrcweir * of old template element to the new encryption element in 142cdf0e10cSrcweir * SAXEventKeeper. 143cdf0e10cSrcweir * 144cdf0e10cSrcweir * INPUTS 145cdf0e10cSrcweir * xEncryptionTemplate - the encryption template to be encrypted. 146cdf0e10cSrcweir * 147cdf0e10cSrcweir * RESULT 148cdf0e10cSrcweir * empty 149cdf0e10cSrcweir * 150cdf0e10cSrcweir * HISTORY 151cdf0e10cSrcweir * 05.01.2004 - implemented 152cdf0e10cSrcweir * 153cdf0e10cSrcweir * AUTHOR 154cdf0e10cSrcweir * Michael Mi 155cdf0e10cSrcweir * Email: michael.mi@sun.com 156cdf0e10cSrcweir ******************************************************************************/ 157cdf0e10cSrcweir { 158cdf0e10cSrcweir cssu::Reference < cssxc::XXMLEncryptionTemplate > xResultTemplate; 159cdf0e10cSrcweir 160cdf0e10cSrcweir cssu::Reference< cssxw::XXMLElementWrapper > 161cdf0e10cSrcweir xXMLElement = m_xSAXEventKeeper->getElement( m_nReferenceId ); 162cdf0e10cSrcweir xEncryptionTemplate->setTarget(xXMLElement); 163cdf0e10cSrcweir 164cdf0e10cSrcweir try 165cdf0e10cSrcweir { 166cdf0e10cSrcweir xResultTemplate = m_xXMLEncryption->encrypt( 167cdf0e10cSrcweir xEncryptionTemplate, m_xSecurityEnvironment); 168cdf0e10cSrcweir m_nStatus = xResultTemplate->getStatus(); 169cdf0e10cSrcweir } 170cdf0e10cSrcweir catch( cssu::Exception& ) 171cdf0e10cSrcweir { 172cdf0e10cSrcweir m_nStatus = cssxc::SecurityOperationStatus_RUNTIMEERROR_FAILED; 173cdf0e10cSrcweir } 174cdf0e10cSrcweir 175cdf0e10cSrcweir if (m_nStatus == cssxc::SecurityOperationStatus_OPERATION_SUCCEEDED) 176cdf0e10cSrcweir { 177cdf0e10cSrcweir cssu::Reference < cssxw::XXMLElementWrapper > xResultEncryption 178cdf0e10cSrcweir = xResultTemplate->getTemplate(); 179cdf0e10cSrcweir m_xSAXEventKeeper->setElement(m_nIdOfTemplateEC, xResultEncryption); 180cdf0e10cSrcweir m_xSAXEventKeeper->setElement(m_nReferenceId, NULL); 181cdf0e10cSrcweir } 182cdf0e10cSrcweir } 183cdf0e10cSrcweir 184cdf0e10cSrcweir /* XReferenceCollector */ 185cdf0e10cSrcweir void SAL_CALL EncryptorImpl::setReferenceCount(sal_Int32) 186cdf0e10cSrcweir throw (cssu::Exception, cssu::RuntimeException) 187cdf0e10cSrcweir { 188cdf0e10cSrcweir /* 189cdf0e10cSrcweir * dummp method, because there is only one reference in 190cdf0e10cSrcweir * encryption, different from signature. 191cdf0e10cSrcweir * so the referenceNumber is always 1 192cdf0e10cSrcweir */ 193cdf0e10cSrcweir } 194cdf0e10cSrcweir 195cdf0e10cSrcweir void SAL_CALL EncryptorImpl::setReferenceId( sal_Int32 id ) 196cdf0e10cSrcweir throw (cssu::Exception, cssu::RuntimeException) 197cdf0e10cSrcweir { 198cdf0e10cSrcweir m_nReferenceId = id; 199cdf0e10cSrcweir } 200cdf0e10cSrcweir 201cdf0e10cSrcweir /* XEncryptionResultBroadcaster */ 202cdf0e10cSrcweir void SAL_CALL EncryptorImpl::addEncryptionResultListener( const cssu::Reference< cssxc::sax::XEncryptionResultListener >& listener ) 203cdf0e10cSrcweir throw (cssu::Exception, cssu::RuntimeException) 204cdf0e10cSrcweir { 205cdf0e10cSrcweir m_xResultListener = listener; 206cdf0e10cSrcweir tryToPerform(); 207cdf0e10cSrcweir } 208cdf0e10cSrcweir 209cdf0e10cSrcweir void SAL_CALL EncryptorImpl::removeEncryptionResultListener( const cssu::Reference< cssxc::sax::XEncryptionResultListener >&) 210cdf0e10cSrcweir throw (cssu::RuntimeException) 211cdf0e10cSrcweir { 212cdf0e10cSrcweir } 213cdf0e10cSrcweir 214cdf0e10cSrcweir /* XInitialization */ 215cdf0e10cSrcweir void SAL_CALL EncryptorImpl::initialize( const cssu::Sequence< cssu::Any >& aArguments ) 216cdf0e10cSrcweir throw (cssu::Exception, cssu::RuntimeException) 217cdf0e10cSrcweir { 218cdf0e10cSrcweir OSL_ASSERT(aArguments.getLength() == 5); 219cdf0e10cSrcweir 220cdf0e10cSrcweir rtl::OUString ouTempString; 221cdf0e10cSrcweir 222cdf0e10cSrcweir aArguments[0] >>= ouTempString; 223cdf0e10cSrcweir m_nSecurityId = ouTempString.toInt32(); 224cdf0e10cSrcweir aArguments[1] >>= m_xSAXEventKeeper; 225cdf0e10cSrcweir aArguments[2] >>= ouTempString; 226cdf0e10cSrcweir m_nIdOfTemplateEC = ouTempString.toInt32(); 227cdf0e10cSrcweir aArguments[3] >>= m_xSecurityEnvironment; 228cdf0e10cSrcweir aArguments[4] >>= m_xXMLEncryption; 229cdf0e10cSrcweir } 230cdf0e10cSrcweir 231cdf0e10cSrcweir 232cdf0e10cSrcweir rtl::OUString EncryptorImpl_getImplementationName () 233cdf0e10cSrcweir throw (cssu::RuntimeException) 234cdf0e10cSrcweir { 235cdf0e10cSrcweir return rtl::OUString ( RTL_CONSTASCII_USTRINGPARAM ( IMPLEMENTATION_NAME ) ); 236cdf0e10cSrcweir } 237cdf0e10cSrcweir 238cdf0e10cSrcweir sal_Bool SAL_CALL EncryptorImpl_supportsService( const rtl::OUString& ServiceName ) 239cdf0e10cSrcweir throw (cssu::RuntimeException) 240cdf0e10cSrcweir { 241cdf0e10cSrcweir return ServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( SERVICE_NAME )); 242cdf0e10cSrcweir } 243cdf0e10cSrcweir 244cdf0e10cSrcweir cssu::Sequence< rtl::OUString > SAL_CALL EncryptorImpl_getSupportedServiceNames( ) 245cdf0e10cSrcweir throw (cssu::RuntimeException) 246cdf0e10cSrcweir { 247cdf0e10cSrcweir cssu::Sequence < rtl::OUString > aRet(1); 248cdf0e10cSrcweir rtl::OUString* pArray = aRet.getArray(); 249cdf0e10cSrcweir pArray[0] = rtl::OUString ( RTL_CONSTASCII_USTRINGPARAM ( SERVICE_NAME ) ); 250cdf0e10cSrcweir return aRet; 251cdf0e10cSrcweir } 252cdf0e10cSrcweir #undef SERVICE_NAME 253cdf0e10cSrcweir 254cdf0e10cSrcweir cssu::Reference< cssu::XInterface > SAL_CALL EncryptorImpl_createInstance( 255cdf0e10cSrcweir const cssu::Reference< cssl::XMultiServiceFactory >& rSMgr) 256cdf0e10cSrcweir throw( cssu::Exception ) 257cdf0e10cSrcweir { 258cdf0e10cSrcweir return (cppu::OWeakObject*) new EncryptorImpl(rSMgr); 259cdf0e10cSrcweir } 260cdf0e10cSrcweir 261cdf0e10cSrcweir /* XServiceInfo */ 262cdf0e10cSrcweir rtl::OUString SAL_CALL EncryptorImpl::getImplementationName( ) 263cdf0e10cSrcweir throw (cssu::RuntimeException) 264cdf0e10cSrcweir { 265cdf0e10cSrcweir return EncryptorImpl_getImplementationName(); 266cdf0e10cSrcweir } 267cdf0e10cSrcweir sal_Bool SAL_CALL EncryptorImpl::supportsService( const rtl::OUString& rServiceName ) 268cdf0e10cSrcweir throw (cssu::RuntimeException) 269cdf0e10cSrcweir { 270cdf0e10cSrcweir return EncryptorImpl_supportsService( rServiceName ); 271cdf0e10cSrcweir } 272cdf0e10cSrcweir cssu::Sequence< rtl::OUString > SAL_CALL EncryptorImpl::getSupportedServiceNames( ) 273cdf0e10cSrcweir throw (cssu::RuntimeException) 274cdf0e10cSrcweir { 275cdf0e10cSrcweir return EncryptorImpl_getSupportedServiceNames(); 276cdf0e10cSrcweir } 277cdf0e10cSrcweir 278