/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: encryptionengine.cxx,v $ * * $Revision: 1.2 $ * * last change: $Author: rt $ $Date: 2005-09-09 17:16:39 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ #include "encryptionengine.hxx" #ifndef _COM_SUN_STAR_XML_CRYPTO_XXMLENCRYPTIONTEMPLATE_HPP_ #include #endif #ifndef _COM_SUN_STAR_XML_WRAPPER_XXMLELEMENTWRAPPER_HPP_ #include #endif #ifndef _COM_SUN_STAR_LANG_XMULTISERVICEFACTORY_HPP_ #include #endif namespace cssu = com::sun::star::uno; namespace cssl = com::sun::star::lang; namespace cssxc = com::sun::star::xml::crypto; namespace cssxw = com::sun::star::xml::wrapper; #define ENCRYPTION_TEMPLATE "com.sun.star.xml.crypto.XMLEncryptionTemplate" #define DECLARE_ASCII( SASCIIVALUE ) \ rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SASCIIVALUE ) ) EncryptionEngine::EncryptionEngine( ) :m_nIdOfBlocker(-1) { } bool EncryptionEngine::checkReady() const /****** EncryptionEngine/checkReady ****************************************** * * NAME * checkReady -- checks the conditions for the main operation. * * SYNOPSIS * bReady = checkReady( ); * * FUNCTION * checks whether all following conditions are satisfied: * 1. the main operation has't begun yet; * 2. the key material is known; * 3. the id of the template blocker is known; * 4. both the key element and the encryption template * are bufferred. * * INPUTS * empty * * RESULT * bReady - true if all conditions are satisfied, false otherwise * * HISTORY * 05.01.2004 - implemented * * AUTHOR * Michael Mi * Email: michael.mi@sun.com ******************************************************************************/ { bool rc = true; sal_Int32 nKeyInc = 0; if (m_nIdOfKeyEC != 0) { nKeyInc = 1; } if (m_bMissionDone || m_nIdOfKeyEC == -1 || m_nIdOfBlocker == -1 || 1+nKeyInc > m_nNumOfResolvedReferences ) { rc = false; } return rc; } void EncryptionEngine::tryToPerform( ) throw (cssu::Exception, cssu::RuntimeException) /****** EncryptionEngine/tryToPerform **************************************** * * NAME * tryToPerform -- tries to perform the encryption/decryption operation. * * SYNOPSIS * tryToPerform( ); * * FUNCTION * if the situation is ready, perform following operations. * 1. prepares a encryption template; * 2. calls the encryption bridge component; * 3. clears up all used resources; * 4. notifies the result listener; * 5. sets the "accomplishment" flag. * * INPUTS * empty * * RESULT * empty * * HISTORY * 05.01.2004 - implemented * * AUTHOR * Michael Mi * Email: michael.mi@sun.com ******************************************************************************/ { if (checkReady()) { const rtl::OUString sEncryptionTemplate ( RTL_CONSTASCII_USTRINGPARAM( ENCRYPTION_TEMPLATE ) ); cssu::Reference < cssxc::XXMLEncryptionTemplate > xEncryptionTemplate( mxMSF->createInstance( sEncryptionTemplate ), cssu::UNO_QUERY ); OSL_ASSERT( xEncryptionTemplate.is() ); cssu::Reference< cssxw::XXMLElementWrapper > xXMLElement = m_xSAXEventKeeper->getElement( m_nIdOfTemplateEC ); xEncryptionTemplate->setTemplate(xXMLElement); startEngine( xEncryptionTemplate ); /* * done */ clearUp( ); notifyResultListener(); m_bMissionDone = true; } } void EncryptionEngine::clearUp( ) const /****** EncryptionEngine/clearup ********************************************* * * NAME * clearUp -- clear up all resources used by this operation. * * SYNOPSIS * clearUp( ); * * FUNCTION * cleaning resources up includes: * 1. releases the ElementCollector for the encryption template element; * 2. releases the Blocker for the encryption template element; * 3. releases the ElementCollector for the key element, if there is one. * * INPUTS * empty * * RESULT * empty * * HISTORY * 05.01.2004 - implemented * * AUTHOR * Michael Mi * Email: michael.mi@sun.com ******************************************************************************/ { cssu::Reference < cssxc::sax::XReferenceResolvedBroadcaster > xReferenceResolvedBroadcaster( m_xSAXEventKeeper, cssu::UNO_QUERY ); xReferenceResolvedBroadcaster->removeReferenceResolvedListener( m_nIdOfTemplateEC, (const cssu::Reference < cssxc::sax::XReferenceResolvedListener >)((SecurityEngine *)this)); m_xSAXEventKeeper->removeElementCollector(m_nIdOfTemplateEC); if (m_nIdOfBlocker != -1) { m_xSAXEventKeeper->removeBlocker(m_nIdOfBlocker); } if (m_nIdOfKeyEC != 0 && m_nIdOfKeyEC != -1) { m_xSAXEventKeeper->removeElementCollector(m_nIdOfKeyEC); } } /* XBlockerMonitor */ void SAL_CALL EncryptionEngine::setBlockerId( sal_Int32 id ) throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException) { m_nIdOfBlocker = id; tryToPerform(); }