2010-10-12 15:57:08 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2012-07-16 17:32:30 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the LibreOffice project.
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*
|
|
|
|
* This file incorporates work covered by the following license notice:
|
|
|
|
*
|
|
|
|
* 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 .
|
|
|
|
*/
|
2004-07-12 12:15:31 +00:00
|
|
|
|
2006-09-16 13:40:25 +00:00
|
|
|
|
2004-07-12 12:15:31 +00:00
|
|
|
#include <xmlsecurity/xmlsignaturehelper.hxx>
|
2008-05-14 09:22:07 +00:00
|
|
|
#include <xmlsecurity/documentsignaturehelper.hxx>
|
2004-07-12 12:15:31 +00:00
|
|
|
#include <xsecctl.hxx>
|
|
|
|
|
|
|
|
#include <xmlsignaturehelper2.hxx>
|
|
|
|
|
|
|
|
#include <tools/stream.hxx>
|
|
|
|
#include <tools/debug.hxx>
|
|
|
|
|
|
|
|
#include <xmloff/attrlist.hxx>
|
|
|
|
|
|
|
|
#include <com/sun/star/io/XOutputStream.hpp>
|
|
|
|
#include <com/sun/star/io/XInputStream.hpp>
|
|
|
|
#include <com/sun/star/io/XActiveDataSource.hpp>
|
2004-07-22 09:34:22 +00:00
|
|
|
#include <com/sun/star/lang/XComponent.hpp>
|
2008-08-18 12:13:39 +00:00
|
|
|
#include <com/sun/star/beans/XPropertySet.hpp>
|
2012-10-03 13:30:43 +02:00
|
|
|
#include <com/sun/star/xml/sax/Parser.hpp>
|
2012-10-10 10:13:18 +02:00
|
|
|
#include <com/sun/star/xml/sax/Writer.hpp>
|
2012-10-31 14:58:31 +02:00
|
|
|
#include <com/sun/star/xml/crypto/SEInitializer.hpp>
|
2004-07-22 09:34:22 +00:00
|
|
|
|
2004-07-15 06:16:12 +00:00
|
|
|
#include <tools/date.hxx>
|
|
|
|
#include <tools/time.hxx>
|
|
|
|
|
2004-08-12 01:29:21 +00:00
|
|
|
#define TAG_DOCUMENTSIGNATURES "document-signatures"
|
|
|
|
#define NS_DOCUMENTSIGNATURES "http://openoffice.org/2004/documentsignatures"
|
2008-05-14 09:22:07 +00:00
|
|
|
#define NS_DOCUMENTSIGNATURES_ODF_1_2 "urn:oasis:names:tc:opendocument:xmlns:digitalsignature:1.0"
|
2004-07-12 12:15:31 +00:00
|
|
|
|
|
|
|
using namespace ::com::sun::star;
|
2009-09-17 13:53:54 +00:00
|
|
|
using namespace ::com::sun::star::uno;
|
2004-07-12 12:15:31 +00:00
|
|
|
|
2008-08-18 12:13:39 +00:00
|
|
|
XMLSignatureHelper::XMLSignatureHelper( const uno::Reference< uno::XComponentContext >& rxCtx)
|
|
|
|
: mxCtx(rxCtx), mbODFPre1_2(false)
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
2008-08-18 12:13:39 +00:00
|
|
|
mpXSecController = new XSecController(rxCtx);
|
2004-07-12 12:15:31 +00:00
|
|
|
mxSecurityController = mpXSecController;
|
|
|
|
mbError = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
XMLSignatureHelper::~XMLSignatureHelper()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2011-03-09 17:29:09 +01:00
|
|
|
bool XMLSignatureHelper::Init()
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
DBG_ASSERT( !mxSEInitializer.is(), "XMLSignatureHelper::Init - mxSEInitializer already set!" );
|
|
|
|
DBG_ASSERT( !mxSecurityContext.is(), "XMLSignatureHelper::Init - mxSecurityContext already set!" );
|
|
|
|
|
2012-10-31 14:58:31 +02:00
|
|
|
mxSEInitializer = com::sun::star::xml::crypto::SEInitializer::create( mxCtx );
|
2004-07-16 01:22:26 +00:00
|
|
|
|
2005-03-10 17:08:17 +00:00
|
|
|
if ( mxSEInitializer.is() )
|
2013-04-07 12:06:47 +02:00
|
|
|
mxSecurityContext = mxSEInitializer->createSecurityContext( OUString() );
|
2004-07-16 01:22:26 +00:00
|
|
|
|
2004-07-12 12:15:31 +00:00
|
|
|
return mxSecurityContext.is();
|
|
|
|
}
|
|
|
|
|
2009-09-17 13:53:54 +00:00
|
|
|
void XMLSignatureHelper::SetStorage(
|
|
|
|
const Reference < css::embed::XStorage >& rxStorage,
|
2014-03-17 09:18:44 +02:00
|
|
|
const OUString& sODFVersion)
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
DBG_ASSERT( !mxUriBinding.is(), "SetStorage - UriBinding already set!" );
|
|
|
|
mxUriBinding = new UriBindingHelper( rxStorage );
|
2008-05-14 09:22:07 +00:00
|
|
|
DBG_ASSERT(rxStorage.is(), "SetStorage - empty storage!");
|
2009-09-17 13:53:54 +00:00
|
|
|
mbODFPre1_2 = DocumentSignatureHelper::isODFPre_1_2(sODFVersion);
|
2004-07-12 12:15:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void XMLSignatureHelper::SetStartVerifySignatureHdl( const Link& rLink )
|
|
|
|
{
|
|
|
|
maStartVerifySignatureHdl = rLink;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void XMLSignatureHelper::StartMission()
|
|
|
|
{
|
|
|
|
if ( !mxUriBinding.is() )
|
|
|
|
mxUriBinding = new UriBindingHelper();
|
|
|
|
|
|
|
|
mpXSecController->startMission( mxUriBinding, mxSecurityContext );
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLSignatureHelper::EndMission()
|
|
|
|
{
|
|
|
|
mpXSecController->endMission();
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Int32 XMLSignatureHelper::GetNewSecurityId()
|
|
|
|
{
|
|
|
|
return mpXSecController->getNewSecurityId();
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLSignatureHelper::SetX509Certificate(
|
|
|
|
sal_Int32 nSecurityId,
|
2013-04-07 12:06:47 +02:00
|
|
|
const OUString& ouX509IssuerName,
|
|
|
|
const OUString& ouX509SerialNumber,
|
|
|
|
const OUString& ouX509Cert)
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
mpXSecController->setX509Certificate(
|
|
|
|
nSecurityId,
|
|
|
|
ouX509IssuerName,
|
2006-04-07 10:56:44 +00:00
|
|
|
ouX509SerialNumber,
|
|
|
|
ouX509Cert);
|
2004-07-12 12:15:31 +00:00
|
|
|
}
|
|
|
|
|
2004-07-15 06:16:12 +00:00
|
|
|
void XMLSignatureHelper::SetDateTime( sal_Int32 nSecurityId, const Date& rDate, const Time& rTime )
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
2004-08-12 01:29:21 +00:00
|
|
|
::com::sun::star::util::DateTime stDateTime;
|
2013-03-17 08:36:26 +01:00
|
|
|
stDateTime.NanoSeconds = rTime.GetNanoSec();
|
2004-08-12 01:29:21 +00:00
|
|
|
stDateTime.Seconds = (::sal_uInt16)rTime.GetSec();
|
|
|
|
stDateTime.Minutes = (::sal_uInt16)rTime.GetMin();
|
|
|
|
stDateTime.Hours = (::sal_uInt16)rTime.GetHour();
|
|
|
|
stDateTime.Day = (::sal_uInt16)rDate.GetDay();
|
|
|
|
stDateTime.Month = (::sal_uInt16)rDate.GetMonth();
|
|
|
|
stDateTime.Year = (::sal_uInt16)rDate.GetYear();
|
|
|
|
mpXSecController->setDate( nSecurityId, stDateTime );
|
2004-07-12 12:15:31 +00:00
|
|
|
}
|
|
|
|
|
2014-04-23 13:44:07 +02:00
|
|
|
void XMLSignatureHelper::AddForSigning( sal_Int32 nSecurityId, const OUString& uri, const OUString& objectURL, bool bBinary )
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
mpXSecController->signAStream( nSecurityId, uri, objectURL, bBinary );
|
|
|
|
}
|
|
|
|
|
2009-09-17 13:53:54 +00:00
|
|
|
|
2012-10-10 10:13:18 +02:00
|
|
|
uno::Reference<xml::sax::XWriter> XMLSignatureHelper::CreateDocumentHandlerWithHeader(
|
2004-07-12 12:15:31 +00:00
|
|
|
const com::sun::star::uno::Reference< com::sun::star::io::XOutputStream >& xOutputStream )
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* get SAX writer component
|
|
|
|
*/
|
2008-08-18 12:13:39 +00:00
|
|
|
uno::Reference< lang::XMultiComponentFactory > xMCF( mxCtx->getServiceManager() );
|
2012-10-10 10:13:18 +02:00
|
|
|
uno::Reference< xml::sax::XWriter > xSaxWriter = xml::sax::Writer::create(mxCtx);
|
2004-07-12 12:15:31 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* connect XML writer to output stream
|
|
|
|
*/
|
|
|
|
xSaxWriter->setOutputStream( xOutputStream );
|
|
|
|
|
|
|
|
/*
|
|
|
|
* write the xml context for signatures
|
|
|
|
*/
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString tag_AllSignatures(TAG_DOCUMENTSIGNATURES);
|
2004-08-12 01:29:21 +00:00
|
|
|
|
|
|
|
SvXMLAttributeList *pAttributeList = new SvXMLAttributeList();
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString sNamespace;
|
2008-05-14 09:22:07 +00:00
|
|
|
if (mbODFPre1_2)
|
2013-04-07 12:06:47 +02:00
|
|
|
sNamespace = OUString(NS_DOCUMENTSIGNATURES);
|
2008-05-14 09:22:07 +00:00
|
|
|
else
|
2013-04-07 12:06:47 +02:00
|
|
|
sNamespace = OUString(NS_DOCUMENTSIGNATURES_ODF_1_2);
|
2008-05-14 09:22:07 +00:00
|
|
|
|
2004-08-12 01:29:21 +00:00
|
|
|
pAttributeList->AddAttribute(
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString(ATTR_XMLNS),
|
2008-05-14 09:22:07 +00:00
|
|
|
sNamespace);
|
2004-07-12 12:15:31 +00:00
|
|
|
|
2012-10-10 10:13:18 +02:00
|
|
|
xSaxWriter->startDocument();
|
|
|
|
xSaxWriter->startElement(
|
2004-07-12 12:15:31 +00:00
|
|
|
tag_AllSignatures,
|
2004-08-12 01:29:21 +00:00
|
|
|
uno::Reference< com::sun::star::xml::sax::XAttributeList > (pAttributeList));
|
2004-07-12 12:15:31 +00:00
|
|
|
|
2012-10-10 10:13:18 +02:00
|
|
|
return xSaxWriter;
|
2004-07-12 12:15:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void XMLSignatureHelper::CloseDocumentHandler( const uno::Reference<xml::sax::XDocumentHandler>& xDocumentHandler )
|
|
|
|
{
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString tag_AllSignatures(TAG_DOCUMENTSIGNATURES);
|
2004-07-12 12:15:31 +00:00
|
|
|
xDocumentHandler->endElement( tag_AllSignatures );
|
|
|
|
xDocumentHandler->endDocument();
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLSignatureHelper::ExportSignature(
|
|
|
|
const uno::Reference< xml::sax::XDocumentHandler >& xDocumentHandler,
|
|
|
|
const SignatureInformation& signatureInfo )
|
|
|
|
{
|
|
|
|
mpXSecController->exportSignature(xDocumentHandler, signatureInfo);
|
|
|
|
}
|
|
|
|
|
2004-07-14 10:06:31 +00:00
|
|
|
bool XMLSignatureHelper::CreateAndWriteSignature( const uno::Reference< xml::sax::XDocumentHandler >& xDocumentHandler )
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
mbError = false;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* create a signature listener
|
|
|
|
*/
|
2010-11-16 20:26:46 +01:00
|
|
|
|
2004-07-12 12:15:31 +00:00
|
|
|
/*
|
|
|
|
* configure the signature creation listener
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* write signatures
|
|
|
|
*/
|
2004-07-14 10:06:31 +00:00
|
|
|
if ( !mpXSecController->WriteSignature( xDocumentHandler ) )
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
mbError = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* clear up the signature creation listener
|
|
|
|
*/
|
|
|
|
|
|
|
|
return !mbError;
|
|
|
|
}
|
|
|
|
|
2004-07-14 10:06:31 +00:00
|
|
|
bool XMLSignatureHelper::ReadAndVerifySignature( const com::sun::star::uno::Reference< com::sun::star::io::XInputStream >& xInputStream )
|
2004-07-12 12:15:31 +00:00
|
|
|
{
|
|
|
|
mbError = false;
|
|
|
|
|
|
|
|
DBG_ASSERT(xInputStream.is(), "input stream missing");
|
|
|
|
|
|
|
|
/*
|
|
|
|
* prepare ParserInputSrouce
|
|
|
|
*/
|
|
|
|
xml::sax::InputSource aParserInput;
|
|
|
|
aParserInput.aInputStream = xInputStream;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* get SAX parser component
|
|
|
|
*/
|
2012-10-03 13:30:43 +02:00
|
|
|
uno::Reference< xml::sax::XParser > xParser = xml::sax::Parser::create(mxCtx);
|
2004-07-12 12:15:31 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* create a signature reader
|
|
|
|
*/
|
|
|
|
uno::Reference< xml::sax::XDocumentHandler > xHandler
|
|
|
|
= mpXSecController->createSignatureReader( );
|
|
|
|
|
|
|
|
/*
|
|
|
|
* create a signature listener
|
|
|
|
*/
|
|
|
|
ImplXMLSignatureListener* pSignatureListener = new ImplXMLSignatureListener(
|
|
|
|
LINK( this, XMLSignatureHelper, SignatureCreationResultListener ),
|
|
|
|
LINK( this, XMLSignatureHelper, SignatureVerifyResultListener ),
|
|
|
|
LINK( this, XMLSignatureHelper, StartVerifySignatureElement ) );
|
|
|
|
|
|
|
|
/*
|
|
|
|
* configure the signature verify listener
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* setup the connection:
|
|
|
|
* Parser -> SignatureListener -> SignatureReader
|
|
|
|
*/
|
|
|
|
pSignatureListener->setNextHandler(xHandler);
|
|
|
|
xParser->setDocumentHandler( pSignatureListener );
|
|
|
|
|
|
|
|
/*
|
|
|
|
* parser the stream
|
|
|
|
*/
|
|
|
|
try
|
|
|
|
{
|
|
|
|
xParser->parseStream( aParserInput );
|
|
|
|
}
|
|
|
|
catch( xml::sax::SAXParseException& )
|
|
|
|
{
|
|
|
|
mbError = true;
|
|
|
|
}
|
|
|
|
catch( xml::sax::SAXException& )
|
|
|
|
{
|
|
|
|
mbError = true;
|
|
|
|
}
|
|
|
|
catch( com::sun::star::io::IOException& )
|
|
|
|
{
|
|
|
|
mbError = true;
|
|
|
|
}
|
|
|
|
catch( uno::Exception& )
|
|
|
|
{
|
|
|
|
mbError = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* clear up the connection
|
|
|
|
*/
|
|
|
|
pSignatureListener->setNextHandler( NULL );
|
|
|
|
|
|
|
|
/*
|
|
|
|
* clear up the signature verify listener
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* release the signature reader
|
|
|
|
*/
|
|
|
|
mpXSecController->releaseSignatureReader( );
|
|
|
|
|
|
|
|
return !mbError;
|
|
|
|
}
|
|
|
|
|
2004-08-18 08:14:42 +00:00
|
|
|
SignatureInformation XMLSignatureHelper::GetSignatureInformation( sal_Int32 nSecurityId ) const
|
|
|
|
{
|
|
|
|
return mpXSecController->getSignatureInformation( nSecurityId );
|
|
|
|
}
|
|
|
|
|
2004-07-12 12:15:31 +00:00
|
|
|
SignatureInformations XMLSignatureHelper::GetSignatureInformations() const
|
|
|
|
{
|
|
|
|
return mpXSecController->getSignatureInformations();
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Reference< ::com::sun::star::xml::crypto::XSecurityEnvironment > XMLSignatureHelper::GetSecurityEnvironment()
|
|
|
|
{
|
2004-11-27 11:59:35 +00:00
|
|
|
return (mxSecurityContext.is()?(mxSecurityContext->getSecurityEnvironment()): uno::Reference< ::com::sun::star::xml::crypto::XSecurityEnvironment >());
|
2004-07-12 12:15:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
IMPL_LINK( XMLSignatureHelper, SignatureCreationResultListener, XMLSignatureCreationResult*, pResult )
|
|
|
|
{
|
|
|
|
maCreationResults.insert( maCreationResults.begin() + maCreationResults.size(), *pResult );
|
2004-11-26 13:56:01 +00:00
|
|
|
if ( pResult->nSignatureCreationResult != com::sun::star::xml::crypto::SecurityOperationStatus_OPERATION_SUCCEEDED )
|
2004-07-12 12:15:31 +00:00
|
|
|
mbError = true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
IMPL_LINK( XMLSignatureHelper, SignatureVerifyResultListener, XMLSignatureVerifyResult*, pResult )
|
|
|
|
{
|
|
|
|
maVerifyResults.insert( maVerifyResults.begin() + maVerifyResults.size(), *pResult );
|
2004-11-26 13:56:01 +00:00
|
|
|
if ( pResult->nSignatureVerifyResult != com::sun::star::xml::crypto::SecurityOperationStatus_OPERATION_SUCCEEDED )
|
2004-07-12 12:15:31 +00:00
|
|
|
mbError = true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
IMPL_LINK( XMLSignatureHelper, StartVerifySignatureElement, const uno::Reference< com::sun::star::xml::sax::XAttributeList >*, pAttrs )
|
|
|
|
{
|
|
|
|
if ( !maStartVerifySignatureHdl.IsSet() || maStartVerifySignatureHdl.Call( (void*)pAttrs ) )
|
|
|
|
{
|
|
|
|
sal_Int32 nSignatureId = mpXSecController->getNewSecurityId();
|
|
|
|
mpXSecController->addSignature( nSignatureId );
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2010-10-12 15:57:08 +02:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|