Files
libreoffice/xmlsecurity/source/dialogs/warnings.cxx
Oliver Bolte dfac1442b9 INTEGRATION: CWS pchfix02 (1.5.86); FILE MERGED
2006/09/01 18:00:49 kaib 1.5.86.1: #i68856# Added header markers and pch files
2006-09-16 13:36:29 +00:00

160 lines
5.2 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: warnings.cxx,v $
*
* $Revision: 1.6 $
*
* last change: $Author: obo $ $Date: 2006-09-16 14:36:29 $
*
* 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
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_xmlsecurity.hxx"
#include <xmlsecurity/warnings.hxx>
#include <xmlsecurity/certificateviewer.hxx>
#ifndef _COM_SUN_STAR_XML_CRYPTO_XSECURITYENVIRONMENT_HPP_
#include <com/sun/star/xml/crypto/XSecurityEnvironment.hpp>
#endif
#ifndef _COMPHELPER_SEQUENCE_HXX_
#include <comphelper/sequence.hxx>
#endif
// MM : added for password exception
#include <vcl/msgbox.hxx>
#include <com/sun/star/security/NoPasswordException.hpp>
using namespace ::com::sun::star::security;
#include "dialogs.hrc"
#include "resourcemanager.hxx"
/* HACK: disable some warnings for MS-C */
#ifdef _MSC_VER
#pragma warning (disable : 4355) // 4355: this used in initializer-list
#endif
using namespace ::com::sun::star;
using namespace ::com::sun::star;
MacroWarning::MacroWarning( Window* _pParent, uno::Reference< dcss::xml::crypto::XSecurityEnvironment >& _rxSecurityEnvironment, cssu::Reference< dcss::security::XCertificate >& _rxCert )
:ModalDialog ( _pParent, XMLSEC_RES( RID_XMLSECTP_MACROWARN ) )
,maDocNameFI ( this, ResId( FI_DOCNAME ) )
,maDescr1aFI ( this, ResId( FI_DESCR1A ) )
,maDescr1bFI ( this, ResId( FI_DESCR1B ) )
,maSignsFI ( this, ResId( FI_SIGNS ) )
,maViewSignsBtn ( this, ResId( PB_VIEWSIGNS ) )
,maDescr2FI ( this, ResId( FI_DESCR2 ) )
,maAlwaysTrustCB ( this, ResId( CB_ALWAYSTRUST ) )
,maBottomSepFL ( this, ResId( FL_BOTTOM_SEP ) )
,maEnableBtn ( this, ResId( PB_DISABLE ) )
,maDisableBtn ( this, ResId( PB_DISABLE ) )
,maHelpBtn ( this, ResId( BTN_HELP ) )
,mbSignedMode ( true )
{
FreeResource();
mxSecurityEnvironment = _rxSecurityEnvironment;
mxCert = _rxCert;
// hide unused parts
maDescr1bFI.Hide();
maViewSignsBtn.SetClickHdl( LINK( this, MacroWarning, ViewSignsBtnHdl ) );
maEnableBtn.SetClickHdl( LINK( this, MacroWarning, EnableBtnHdl ) );
// maDisableBtn.SetClickHdl( LINK( this, MacroWarning, DisableBtnHdl ) );
if( mxCert.is() )
maSignsFI.SetText( XmlSec::GetContentPart( mxCert->getSubjectName() ) );
else
// nothing to view!
maViewSignsBtn.Disable();
}
MacroWarning::MacroWarning( Window* _pParent )
:ModalDialog ( _pParent, XMLSEC_RES( RID_XMLSECTP_MACROWARN ) )
,maDocNameFI ( this, ResId( FI_DOCNAME ) )
,maDescr1aFI ( this, ResId( FI_DESCR1A ) )
,maDescr1bFI ( this, ResId( FI_DESCR1B ) )
,maSignsFI ( this, ResId( FI_SIGNS ) )
,maViewSignsBtn ( this, ResId( PB_VIEWSIGNS ) )
,maDescr2FI ( this, ResId( FI_DESCR2 ) )
,maAlwaysTrustCB ( this, ResId( CB_ALWAYSTRUST ) )
,maBottomSepFL ( this, ResId( FL_BOTTOM_SEP ) )
,maEnableBtn ( this, ResId( PB_DISABLE ) )
,maDisableBtn ( this, ResId( PB_DISABLE ) )
,maHelpBtn ( this, ResId( BTN_HELP ) )
,mbSignedMode ( false )
{
FreeResource();
// hide unused parts
maDescr1aFI.Hide();
maSignsFI.Hide();
maViewSignsBtn.Hide();
maAlwaysTrustCB.Hide();
maDescr2FI.Hide();
// move hint up to position of signer list
maDescr1bFI.SetPosPixel( maSignsFI.GetPosPixel() );
}
MacroWarning::~MacroWarning()
{
}
IMPL_LINK( MacroWarning, ViewSignsBtnHdl, void*, EMPTYARG )
{
DBG_ASSERT( mxCert.is(), "*MacroWarning::ViewSignsBtnHdl(): no certificate set!" );
CertificateViewer aViewer( this, mxSecurityEnvironment, mxCert );
aViewer.Execute();
return 0;
}
IMPL_LINK( MacroWarning, EnableBtnHdl, void*, EMPTYARG )
{
if( mbSignedMode && maAlwaysTrustCB.IsChecked() )
{ // insert path into trusted path list
}
EndDialog( RET_OK );
return 0;
}
/*IMPL_LINK( MacroWarning, DisableBtnHdl, void*, EMPTYARG )
{
return 0;
}*/