blob: 1ba2639002083a0d2785f4cb10433e340e10c6da [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_xmlsecurity.hxx"
#include <xmlsecurity/warnings.hxx>
#include <xmlsecurity/certificateviewer.hxx>
#include <com/sun/star/xml/crypto/XSecurityEnvironment.hpp>
#include <comphelper/sequence.hxx>
// 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;
}*/