ef3d5f7fa2
2008/03/31 16:31:10 rt 1.9.102.1: #i87441# Change license header to LPGL v3.
554 lines
20 KiB
C++
554 lines
20 KiB
C++
/*************************************************************************
|
|
*
|
|
* 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: signaturetest.cxx,v $
|
|
* $Revision: 1.10 $
|
|
*
|
|
* 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
|
|
* <http://www.openoffice.org/license.html>
|
|
* for a copy of the LGPLv3 License.
|
|
*
|
|
************************************************************************/
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
#include "precompiled_xmlsecurity.hxx"
|
|
|
|
#include <sal/main.h>
|
|
#include <vcl/event.hxx>
|
|
#include <vcl/svapp.hxx>
|
|
#include <vcl/wrkwin.hxx>
|
|
#include <vcl/msgbox.hxx>
|
|
#include <vcl/fixed.hxx>
|
|
#include <vcl/edit.hxx>
|
|
#include <vcl/button.hxx>
|
|
#include <vcl/lstbox.hxx>
|
|
#include <svtools/filectrl.hxx>
|
|
#include <tools/urlobj.hxx>
|
|
#include <osl/file.hxx>
|
|
|
|
#include <svtools/docpasswdrequest.hxx>
|
|
|
|
#include <comphelper/processfactory.hxx>
|
|
#include <cppuhelper/servicefactory.hxx>
|
|
#include <cppuhelper/bootstrap.hxx>
|
|
#include <unotools/streamhelper.hxx>
|
|
|
|
#include <ucbhelper/contentbroker.hxx>
|
|
#include <ucbhelper/configurationkeys.hxx>
|
|
|
|
// Will be in comphelper if CWS MAV09 is integrated
|
|
#include <comphelper/storagehelper.hxx>
|
|
|
|
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
|
|
|
|
#include <xmlsecurity/xmlsignaturehelper.hxx>
|
|
#include <xmlsecurity/digitalsignaturesdialog.hxx>
|
|
#include <xmlsecurity/certificatechooser.hxx>
|
|
#include <xmlsecurity/biginteger.hxx>
|
|
|
|
#include <com/sun/star/security/XDocumentDigitalSignatures.hpp>
|
|
|
|
using namespace ::com::sun::star;
|
|
using namespace ::com::sun::star;
|
|
|
|
void Main();
|
|
|
|
#define TEXTFIELDWIDTH 80
|
|
#define TEXTFIELDSTARTX 10
|
|
|
|
#define EDITWIDTH 200
|
|
#define EDITHEIGHT 20
|
|
|
|
#define FIXEDLINEHEIGHT 15
|
|
|
|
#define BUTTONWIDTH 50
|
|
#define BUTTONHEIGHT 22
|
|
#define BUTTONSPACE 20
|
|
|
|
#define LISTBOXHEIGHT 120
|
|
|
|
// #define TEST_IMPLEMENTATION_DIRECTLY
|
|
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
SAL_IMPLEMENT_MAIN()
|
|
{
|
|
uno::Reference< lang::XMultiServiceFactory > xMSF;
|
|
try
|
|
{
|
|
uno::Reference< uno::XComponentContext > xCtx( cppu::defaultBootstrap_InitialComponentContext() );
|
|
if ( !xCtx.is() )
|
|
{
|
|
DBG_ERROR( "Error creating initial component context!" );
|
|
return -1;
|
|
}
|
|
|
|
xMSF = uno::Reference< lang::XMultiServiceFactory >(xCtx->getServiceManager(), uno::UNO_QUERY );
|
|
|
|
if ( !xMSF.is() )
|
|
{
|
|
DBG_ERROR( "No service manager!" );
|
|
return -1;
|
|
}
|
|
|
|
// Init USB
|
|
uno::Sequence< uno::Any > aArgs( 2 );
|
|
aArgs[ 0 ] <<= rtl::OUString::createFromAscii( UCB_CONFIGURATION_KEY1_LOCAL );
|
|
aArgs[ 1 ] <<= rtl::OUString::createFromAscii( UCB_CONFIGURATION_KEY2_OFFICE );
|
|
sal_Bool bSuccess = ::ucb::ContentBroker::initialize( xMSF, aArgs );
|
|
if ( !bSuccess )
|
|
{
|
|
DBG_ERROR( "Error creating UCB!" );
|
|
return -1;
|
|
}
|
|
|
|
}
|
|
catch ( uno::Exception const & )
|
|
{
|
|
DBG_ERROR( "Exception during creation of initial component context!" );
|
|
return -1;
|
|
}
|
|
comphelper::setProcessServiceFactory( xMSF );
|
|
|
|
InitVCL( xMSF );
|
|
::Main();
|
|
DeInitVCL();
|
|
|
|
return 0;
|
|
}
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
class MyWin : public WorkWindow
|
|
{
|
|
private:
|
|
FixedLine maTokenLine;
|
|
CheckBox maCryptoCheckBox;
|
|
FixedText maFixedTextTokenName;
|
|
FileControl maEditTokenName;
|
|
FixedLine maTest1Line;
|
|
FixedText maFixedTextXMLFileName;
|
|
FileControl maEditXMLFileName;
|
|
FixedText maFixedTextBINFileName;
|
|
FileControl maEditBINFileName;
|
|
FixedText maFixedTextSIGFileName;
|
|
FileControl maEditSIGFileName;
|
|
PushButton maSignButton;
|
|
PushButton maVerifyButton;
|
|
FixedLine maTest2Line;
|
|
FixedText maFixedTextDOCFileName;
|
|
FileControl maEditDOCFileName;
|
|
PushButton maDigitalSignaturesButton;
|
|
PushButton maVerifyDigitalSignaturesButton;
|
|
FixedLine maHintLine;
|
|
FixedText maHintText;
|
|
|
|
DECL_LINK( CryptoCheckBoxHdl, CheckBox* );
|
|
DECL_LINK( SignButtonHdl, Button* );
|
|
DECL_LINK( VerifyButtonHdl, Button* );
|
|
DECL_LINK( DigitalSignaturesWithServiceHdl, Button* );
|
|
DECL_LINK( VerifyDigitalSignaturesHdl, Button* );
|
|
DECL_LINK( DigitalSignaturesWithTokenHdl, Button* );
|
|
DECL_LINK( StartVerifySignatureHdl, void* );
|
|
|
|
public:
|
|
MyWin( Window* pParent, WinBits nWinStyle );
|
|
|
|
};
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
void Main()
|
|
{
|
|
MyWin aMainWin( NULL, WB_APP | WB_STDWORK | WB_3DLOOK);
|
|
aMainWin.Show();
|
|
|
|
Application::Execute();
|
|
}
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
MyWin::MyWin( Window* pParent, WinBits nWinStyle ) :
|
|
WorkWindow( pParent, nWinStyle ),
|
|
maTokenLine( this ),
|
|
maTest1Line( this ),
|
|
maTest2Line( this ),
|
|
maHintLine( this ),
|
|
maFixedTextXMLFileName( this ),
|
|
maEditXMLFileName( this, WB_BORDER ),
|
|
maFixedTextBINFileName( this ),
|
|
maEditBINFileName( this, WB_BORDER ),
|
|
maFixedTextSIGFileName( this ),
|
|
maEditSIGFileName( this, WB_BORDER ),
|
|
maFixedTextTokenName( this ),
|
|
maEditTokenName( this, WB_BORDER ),
|
|
maFixedTextDOCFileName( this ),
|
|
maEditDOCFileName( this, WB_BORDER ),
|
|
maSignButton( this ),
|
|
maVerifyButton( this ),
|
|
maDigitalSignaturesButton( this ),
|
|
maVerifyDigitalSignaturesButton( this ),
|
|
maHintText( this, WB_WORDBREAK ),
|
|
maCryptoCheckBox( this )
|
|
|
|
{
|
|
#ifdef TEST_IMPLEMENTATION_DIRECTLY
|
|
Size aOutputSize( 400, 600 );
|
|
#else
|
|
Size aOutputSize( 400, 400 );
|
|
#endif
|
|
SetOutputSizePixel( aOutputSize );
|
|
SetText( String( RTL_CONSTASCII_USTRINGPARAM( "XML Signature Test" ) ) );
|
|
|
|
long nY = 15;
|
|
|
|
maTokenLine.SetPosSizePixel( TEXTFIELDSTARTX, nY, aOutputSize.Width()-2*TEXTFIELDSTARTX, FIXEDLINEHEIGHT );
|
|
maTokenLine.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Crypto Settings" ) ) );
|
|
maTokenLine.Show();
|
|
|
|
nY += EDITHEIGHT*3/2;
|
|
|
|
maCryptoCheckBox.SetPosSizePixel( TEXTFIELDSTARTX, nY, aOutputSize.Width()-2*TEXTFIELDSTARTX, FIXEDLINEHEIGHT );
|
|
maCryptoCheckBox.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Use Default Token (NSS option only)" ) ) );
|
|
maCryptoCheckBox.Check( TRUE );
|
|
maEditTokenName.Disable();
|
|
maFixedTextTokenName.Disable();
|
|
maCryptoCheckBox.SetClickHdl( LINK( this, MyWin, CryptoCheckBoxHdl ) );
|
|
maCryptoCheckBox.Show();
|
|
|
|
nY += EDITHEIGHT;
|
|
|
|
maFixedTextTokenName.SetPosSizePixel( TEXTFIELDSTARTX, nY, TEXTFIELDWIDTH, EDITHEIGHT );
|
|
maFixedTextTokenName.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Crypto Token:" ) ) );
|
|
maFixedTextTokenName.Show();
|
|
|
|
maEditTokenName.SetPosSizePixel( TEXTFIELDSTARTX+TEXTFIELDWIDTH, nY, EDITWIDTH, EDITHEIGHT );
|
|
maEditTokenName.Show();
|
|
|
|
nY += EDITHEIGHT*3;
|
|
|
|
#ifdef TEST_IMPLEMENTATION_DIRECTLY
|
|
|
|
maTest1Line.SetPosSizePixel( TEXTFIELDSTARTX, nY, aOutputSize.Width()-2*TEXTFIELDSTARTX, FIXEDLINEHEIGHT );
|
|
maTest1Line.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Test simple files" ) ) );
|
|
maTest1Line.Show();
|
|
|
|
nY += EDITHEIGHT*3/2;
|
|
|
|
maFixedTextXMLFileName.SetPosSizePixel( TEXTFIELDSTARTX, nY, TEXTFIELDWIDTH, EDITHEIGHT );
|
|
maFixedTextXMLFileName.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "XML File:" ) ) );
|
|
maFixedTextXMLFileName.Show();
|
|
|
|
maEditXMLFileName.SetPosSizePixel( TEXTFIELDSTARTX+TEXTFIELDWIDTH, nY, EDITWIDTH, EDITHEIGHT );
|
|
maEditXMLFileName.Show();
|
|
|
|
nY += EDITHEIGHT*3/2;
|
|
|
|
maFixedTextBINFileName.SetPosSizePixel( TEXTFIELDSTARTX, nY, TEXTFIELDWIDTH, EDITHEIGHT );
|
|
maFixedTextBINFileName.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Binary File:" ) ) );
|
|
maFixedTextBINFileName.Show();
|
|
|
|
maEditBINFileName.SetPosSizePixel( TEXTFIELDSTARTX+TEXTFIELDWIDTH, nY, EDITWIDTH, EDITHEIGHT );
|
|
maEditBINFileName.Show();
|
|
|
|
nY += EDITHEIGHT*3/2;
|
|
|
|
maFixedTextSIGFileName.SetPosSizePixel( TEXTFIELDSTARTX, nY, TEXTFIELDWIDTH, EDITHEIGHT );
|
|
maFixedTextSIGFileName.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Signature File:" ) ) );
|
|
maFixedTextSIGFileName.Show();
|
|
|
|
maEditSIGFileName.SetPosSizePixel( TEXTFIELDSTARTX+TEXTFIELDWIDTH, nY, EDITWIDTH, EDITHEIGHT );
|
|
maEditSIGFileName.Show();
|
|
|
|
nY += EDITHEIGHT*2;
|
|
|
|
maSignButton.SetPosSizePixel( TEXTFIELDSTARTX, nY, BUTTONWIDTH, BUTTONHEIGHT );
|
|
maSignButton.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Sign" ) ) );
|
|
maSignButton.SetClickHdl( LINK( this, MyWin, SignButtonHdl ) );
|
|
maSignButton.Show();
|
|
|
|
maVerifyButton.SetPosSizePixel( TEXTFIELDSTARTX+BUTTONWIDTH+BUTTONSPACE, nY, BUTTONWIDTH, BUTTONHEIGHT );
|
|
maVerifyButton.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Verify" ) ) );
|
|
maVerifyButton.SetClickHdl( LINK( this, MyWin, VerifyButtonHdl ) );
|
|
maVerifyButton.Show();
|
|
|
|
nY += EDITHEIGHT*3;
|
|
|
|
#endif // TEST_IMPLEMENTATION_DIRECTLY
|
|
|
|
maTest2Line.SetPosSizePixel( TEXTFIELDSTARTX, nY, aOutputSize.Width()-2*TEXTFIELDSTARTX, FIXEDLINEHEIGHT );
|
|
maTest2Line.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Test Office Document" ) ) );
|
|
maTest2Line.Show();
|
|
|
|
nY += EDITHEIGHT*3/2;
|
|
|
|
|
|
maFixedTextDOCFileName.SetPosSizePixel( TEXTFIELDSTARTX, nY, TEXTFIELDWIDTH, EDITHEIGHT );
|
|
maFixedTextDOCFileName.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Office File:" ) ) );
|
|
maFixedTextDOCFileName.Show();
|
|
|
|
maEditDOCFileName.SetPosSizePixel( TEXTFIELDSTARTX+TEXTFIELDWIDTH, nY, EDITWIDTH, EDITHEIGHT );
|
|
maEditDOCFileName.Show();
|
|
|
|
nY += EDITHEIGHT*2;
|
|
|
|
maDigitalSignaturesButton.SetPosSizePixel( TEXTFIELDSTARTX, nY, BUTTONWIDTH*2, BUTTONHEIGHT );
|
|
maDigitalSignaturesButton.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Digital Signatures..." ) ) );
|
|
maDigitalSignaturesButton.SetClickHdl( LINK( this, MyWin, DigitalSignaturesWithServiceHdl ) );
|
|
maDigitalSignaturesButton.Show();
|
|
|
|
maVerifyDigitalSignaturesButton.SetPosSizePixel( TEXTFIELDSTARTX+BUTTONWIDTH*2+BUTTONSPACE, nY, BUTTONWIDTH*2, BUTTONHEIGHT );
|
|
maVerifyDigitalSignaturesButton.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Verify Signatures" ) ) );
|
|
maVerifyDigitalSignaturesButton.SetClickHdl( LINK( this, MyWin, VerifyDigitalSignaturesHdl ) );
|
|
maVerifyDigitalSignaturesButton.Show();
|
|
|
|
nY += EDITHEIGHT*2;
|
|
|
|
maHintLine.SetPosSizePixel( TEXTFIELDSTARTX, nY, aOutputSize.Width()-2*TEXTFIELDSTARTX, FIXEDLINEHEIGHT );
|
|
maHintLine.Show();
|
|
|
|
nY += EDITHEIGHT*2;
|
|
|
|
maHintText.SetPosSizePixel( TEXTFIELDSTARTX, nY, aOutputSize.Width()-2*TEXTFIELDSTARTX, aOutputSize.Height()-nY );
|
|
maHintText.SetText( String( RTL_CONSTASCII_USTRINGPARAM( "Hint: Copy crypto files from xmlsecurity/tools/cryptoken/nss and sample files from xmlsecurity/tools/examples to <temp>/nss.\nThis location will be used from the demo as the default location." ) ) );
|
|
maHintText.Show();
|
|
|
|
// Help the user with some default values
|
|
::rtl::OUString aTempDirURL;
|
|
::osl::File::getTempDirURL( aTempDirURL );
|
|
INetURLObject aURLObj( aTempDirURL );
|
|
aURLObj.insertName( String( RTL_CONSTASCII_USTRINGPARAM( "nss" ) ), true );
|
|
::rtl::OUString aNSSFolder = aURLObj.getFSysPath( INetURLObject::FSYS_DETECT );
|
|
String aDefaultXMLFileName( aNSSFolder );
|
|
maEditXMLFileName.SetText( aNSSFolder + String( RTL_CONSTASCII_USTRINGPARAM( "demo-sample.xml" ) ) );
|
|
maEditBINFileName.SetText( aNSSFolder + String( RTL_CONSTASCII_USTRINGPARAM( "demo-sample.gif" ) ) );
|
|
maEditDOCFileName.SetText( aNSSFolder + String( RTL_CONSTASCII_USTRINGPARAM( "demo-sample.sxw" ) ) );
|
|
maEditSIGFileName.SetText( aNSSFolder + String( RTL_CONSTASCII_USTRINGPARAM( "demo-result.xml" ) ) );
|
|
maEditTokenName.SetText( aNSSFolder );
|
|
|
|
#ifdef WNT
|
|
maEditTokenName.SetText( String() );
|
|
maEditTokenName.Disable();
|
|
maCryptoCheckBox.Disable();
|
|
#endif
|
|
|
|
}
|
|
|
|
IMPL_LINK( MyWin, CryptoCheckBoxHdl, CheckBox*, EMPTYARG )
|
|
{
|
|
if ( maCryptoCheckBox.IsChecked() )
|
|
{
|
|
maEditTokenName.Disable();
|
|
maFixedTextTokenName.Disable();
|
|
}
|
|
else
|
|
{
|
|
maEditTokenName.Enable();
|
|
maFixedTextTokenName.Enable();
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
IMPL_LINK( MyWin, DigitalSignaturesWithServiceHdl, Button*, EMPTYARG )
|
|
{
|
|
rtl::OUString aDocFileName = maEditDOCFileName.GetText();
|
|
uno::Reference < embed::XStorage > xStore = ::comphelper::OStorageHelper::GetStorageFromURL(
|
|
aDocFileName, embed::ElementModes::READWRITE, comphelper::getProcessServiceFactory() );
|
|
|
|
uno::Reference< security::XDocumentDigitalSignatures > xD(
|
|
comphelper::getProcessServiceFactory()->createInstance( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.security.DocumentDigitalSignatures" ) ) ), uno::UNO_QUERY );
|
|
if ( xD.is() )
|
|
xD->signDocumentContent( xStore, NULL );
|
|
|
|
|
|
return 0;
|
|
}
|
|
|
|
IMPL_LINK( MyWin, VerifyDigitalSignaturesHdl, Button*, EMPTYARG )
|
|
{
|
|
rtl::OUString aDocFileName = maEditDOCFileName.GetText();
|
|
uno::Reference < embed::XStorage > xStore = ::comphelper::OStorageHelper::GetStorageFromURL(
|
|
aDocFileName, embed::ElementModes::READWRITE, comphelper::getProcessServiceFactory() );
|
|
|
|
uno::Reference< security::XDocumentDigitalSignatures > xD(
|
|
comphelper::getProcessServiceFactory()->createInstance( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.security.DocumentDigitalSignatures" ) ) ), uno::UNO_QUERY );
|
|
if ( xD.is() )
|
|
{
|
|
uno::Sequence< security::DocumentSignatureInformation > aInfos = xD->verifyDocumentContentSignatures( xStore, NULL );
|
|
int nInfos = aInfos.getLength();
|
|
for ( int n = 0; n < nInfos; n++ )
|
|
{
|
|
security::DocumentSignatureInformation& rInf = aInfos[n];
|
|
String aText( RTL_CONSTASCII_USTRINGPARAM( "The document is signed by\n\n " ) );
|
|
aText += String( rInf.Signer->getSubjectName() );
|
|
aText += String( RTL_CONSTASCII_USTRINGPARAM( "\n\n The signature is " ) );
|
|
if ( !rInf.SignatureIsValid )
|
|
aText += String( RTL_CONSTASCII_USTRINGPARAM( "NOT " ) );
|
|
aText += String( RTL_CONSTASCII_USTRINGPARAM( "valid" ) );
|
|
InfoBox( this, aText ).Execute();
|
|
}
|
|
|
|
}
|
|
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
#ifdef TEST_IMPLEMENTATION_DIRECTLY
|
|
|
|
IMPL_LINK( MyWin, DigitalSignaturesWithTokenHdl, Button*, EMPTYARG )
|
|
{
|
|
String aDocFileName = maEditDOCFileName.GetText();
|
|
String aTokenFileName = maEditTokenName.GetText();
|
|
|
|
DigitalSignaturesDialog aSignaturesDialog( this, comphelper::getProcessServiceFactory(), SignatureModeDocumentContent, false );
|
|
|
|
bool bInit = aSignaturesDialog.Init( aTokenFileName );
|
|
if ( !bInit )
|
|
{
|
|
ErrorBox( this, WB_OK, String( RTL_CONSTASCII_USTRINGPARAM( "Error initializing security context!" ) ) ).Execute();
|
|
return 0;
|
|
}
|
|
|
|
uno::Reference < embed::XStorage > xStore = ::comphelper::OStorageHelper::GetStorageFromURL(
|
|
aDocFileName, embed::ElementModes::READWRITE, comphelper::getProcessServiceFactory() );
|
|
|
|
aSignaturesDialog.SetStorage( xStore );
|
|
|
|
aSignaturesDialog.Execute();
|
|
|
|
return 0;
|
|
}
|
|
|
|
IMPL_LINK( MyWin, SignButtonHdl, Button*, EMPTYARG )
|
|
{
|
|
String aXMLFileName = maEditXMLFileName.GetText();
|
|
String aBINFileName = maEditBINFileName.GetText();
|
|
String aSIGFileName = maEditSIGFileName.GetText();
|
|
|
|
String aTokenFileName;
|
|
if ( !maCryptoCheckBox.IsChecked() )
|
|
aTokenFileName = maEditTokenName.GetText();
|
|
|
|
XMLSignatureHelper aSignatureHelper( comphelper::getProcessServiceFactory() );
|
|
bool bInit = aSignatureHelper.Init( aTokenFileName );
|
|
|
|
if ( !bInit )
|
|
{
|
|
ErrorBox( this, WB_OK, String( RTL_CONSTASCII_USTRINGPARAM( "Error initializing security context!" ) ) ).Execute();
|
|
return 0;
|
|
}
|
|
|
|
uno::Reference< ::com::sun::star::security::XCertificate > xCertToUse;
|
|
CertificateChooser aChooser( this, aSignatureHelper.GetSecurityEnvironment(), SignatureInformations() );
|
|
if ( aChooser.Execute() )
|
|
xCertToUse = aChooser.GetSelectedCertificate();
|
|
|
|
if ( !xCertToUse.is() )
|
|
return 0;
|
|
|
|
|
|
aSignatureHelper.StartMission();
|
|
|
|
sal_Int32 nSecurityId = aSignatureHelper.GetNewSecurityId();
|
|
|
|
aSignatureHelper.SetX509Certificate( nSecurityId, xCertToUse->getIssuerName(), bigIntegerToNumericString( xCertToUse->getSerialNumber() ) );
|
|
|
|
aSignatureHelper.AddForSigning( nSecurityId, aXMLFileName, aXMLFileName, sal_False );
|
|
aSignatureHelper.AddForSigning( nSecurityId, aBINFileName, aBINFileName, sal_True );
|
|
|
|
SvFileStream* pStream = new SvFileStream( aSIGFileName, STREAM_WRITE );
|
|
SvLockBytesRef xLockBytes = new SvLockBytes( pStream, TRUE );
|
|
uno::Reference< io::XOutputStream > xOutputStream = new utl::OOutputStreamHelper( xLockBytes );
|
|
bool bDone = aSignatureHelper.CreateAndWriteSignature( xOutputStream );
|
|
|
|
aSignatureHelper.EndMission();
|
|
|
|
if ( !bDone )
|
|
{
|
|
ErrorBox( this, WB_OK, String( RTL_CONSTASCII_USTRINGPARAM( "Error creating Signature!" ) ) ).Execute();
|
|
}
|
|
else
|
|
{
|
|
rtl::OUString aInfo( String( RTL_CONSTASCII_USTRINGPARAM( "Signature successfully created!\n\n" ) ) );
|
|
// aInfo += getSignatureInformationmations( aSignatureHelper.getAllSignatureInformation(), aSignatureHelper.GetSecurityEnvironment() );
|
|
|
|
|
|
InfoBox( this, aInfo ).Execute();
|
|
}
|
|
|
|
// Check for more detailed results...
|
|
|
|
return 0;
|
|
}
|
|
|
|
IMPL_LINK( MyWin, VerifyButtonHdl, Button*, EMPTYARG )
|
|
{
|
|
String aXMLFileName = maEditXMLFileName.GetText();
|
|
String aBINFileName = maEditBINFileName.GetText();
|
|
String aSIGFileName = maEditSIGFileName.GetText();
|
|
|
|
String aTokenFileName;
|
|
if ( !maCryptoCheckBox.IsChecked() )
|
|
aTokenFileName = maEditTokenName.GetText();
|
|
|
|
XMLSignatureHelper aSignatureHelper( comphelper::getProcessServiceFactory() );
|
|
bool bInit = aSignatureHelper.Init( aTokenFileName );
|
|
|
|
if ( !bInit )
|
|
{
|
|
ErrorBox( this, WB_OK, String( RTL_CONSTASCII_USTRINGPARAM( "Error initializing security context!" ) ) ).Execute();
|
|
return 0;
|
|
}
|
|
|
|
aSignatureHelper.SetStartVerifySignatureHdl( LINK( this, MyWin, StartVerifySignatureHdl ) );
|
|
|
|
aSignatureHelper.StartMission();
|
|
|
|
SvFileStream* pStream = new SvFileStream( aSIGFileName, STREAM_READ );
|
|
pStream->Seek( STREAM_SEEK_TO_END );
|
|
ULONG nBytes = pStream->Tell();
|
|
pStream->Seek( STREAM_SEEK_TO_BEGIN );
|
|
SvLockBytesRef xLockBytes = new SvLockBytes( pStream, TRUE );
|
|
uno::Reference< io::XInputStream > xInputStream = new utl::OInputStreamHelper( xLockBytes, nBytes );
|
|
bool bDone = aSignatureHelper.ReadAndVerifySignature( xInputStream );
|
|
xInputStream->closeInput();
|
|
|
|
aSignatureHelper.EndMission();
|
|
|
|
if ( !bDone )
|
|
ErrorBox( this, WB_OK, String( RTL_CONSTASCII_USTRINGPARAM( "Error in Signature!" ) ) ).Execute();
|
|
else
|
|
InfoBox( this, String( RTL_CONSTASCII_USTRINGPARAM( "Signatures verified without any problems!" ) ) ).Execute();
|
|
|
|
return 0;
|
|
}
|
|
|
|
IMPL_LINK( MyWin, StartVerifySignatureHdl, void*, EMPTYARG )
|
|
{
|
|
QueryBox aQueryBox( this, WB_YES_NO|WB_DEF_YES, String( RTL_CONSTASCII_USTRINGPARAM( "Found Signature - Verify?" ) ) );
|
|
return ( aQueryBox.Execute() == RET_YES ) ? 1 : 0;
|
|
}
|
|
|
|
|
|
#endif // #ifdef TEST_IMPLEMENTATION_DIRECTLY
|