/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: encryptorimpl.hxx,v $ * $Revision: 1.4 $ * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org 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 version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef _ENCRYPTORIMPL_HXX #define _ENCRYPTORIMPL_HXX #include #include #ifndef _COM_SUN_STAR_XML_CRYPTO_SAX_XSIGNATURECOLLECTOR_HPP_ #include #endif #include #include #include #include #include "encryptionengine.hxx" class EncryptorImpl : public cppu::ImplInheritanceHelper4 < EncryptionEngine, com::sun::star::xml::crypto::sax::XEncryptionResultBroadcaster, com::sun::star::xml::crypto::sax::XReferenceCollector, com::sun::star::lang::XInitialization, com::sun::star::lang::XServiceInfo > /****** EncryptorImpl.hxx/CLASS EncryptorImpl ********************************* * * NAME * EncryptorImpl -- generates an encryption * * FUNCTION * Collects all resources for an encryption generation, then generates the * encryption by invoking a xmlsec-based encryption bridge component. * * HISTORY * 05.01.2004 - Interface supported: XInitialization, XServiceInfo * * AUTHOR * Michael Mi * Email: michael.mi@sun.com ******************************************************************************/ { private: /* * the Id of the encryption, which is used for the result listener to * identify the encryption. */ sal_Int32 m_nEncryptionId; /* * the Id of the element to be encrypted. */ sal_Int32 m_nReferenceId; /* * the decryption result, * remembers whether the encryption succeeds. */ bool m_bEncryptionSucceed; com::sun::star::uno::Reference< com::sun::star::xml::crypto::XSecurityEnvironment > m_xSecurityEnvironment; virtual void notifyResultListener() const throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException); virtual bool checkReady() const; virtual void startEngine( const com::sun::star::uno::Reference< com::sun::star::xml::crypto::XXMLEncryptionTemplate >& xEncryptionTemplate) throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException); public: explicit EncryptorImpl( const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxMSF); virtual ~EncryptorImpl(); /* XEncryptionResultBroadcaster */ virtual void SAL_CALL addEncryptionResultListener( const com::sun::star::uno::Reference< com::sun::star::xml::crypto::sax::XEncryptionResultListener >& listener ) throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException); virtual void SAL_CALL removeEncryptionResultListener( const com::sun::star::uno::Reference< com::sun::star::xml::crypto::sax::XEncryptionResultListener >& listener ) throw (com::sun::star::uno::RuntimeException); /* XReferenceCollector */ virtual void SAL_CALL setReferenceCount( sal_Int32 count ) throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException); virtual void SAL_CALL setReferenceId( sal_Int32 id ) throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException); /* XInitialization */ virtual void SAL_CALL initialize( const com::sun::star::uno::Sequence< com::sun::star::uno::Any >& aArguments ) throw (com::sun::star::uno::Exception, com::sun::star::uno::RuntimeException); /* XServiceInfo */ virtual rtl::OUString SAL_CALL getImplementationName( ) throw (com::sun::star::uno::RuntimeException); virtual sal_Bool SAL_CALL supportsService( const rtl::OUString& ServiceName ) throw (com::sun::star::uno::RuntimeException); virtual com::sun::star::uno::Sequence< rtl::OUString > SAL_CALL getSupportedServiceNames( ) throw (com::sun::star::uno::RuntimeException); }; rtl::OUString EncryptorImpl_getImplementationName() throw ( com::sun::star::uno::RuntimeException ); sal_Bool SAL_CALL EncryptorImpl_supportsService( const rtl::OUString& ServiceName ) throw ( com::sun::star::uno::RuntimeException ); com::sun::star::uno::Sequence< rtl::OUString > SAL_CALL EncryptorImpl_getSupportedServiceNames( ) throw ( com::sun::star::uno::RuntimeException ); com::sun::star::uno::Reference< com::sun::star::uno::XInterface > SAL_CALL EncryptorImpl_createInstance( const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rSMgr) throw ( com::sun::star::uno::Exception ); #endif