1*cdf0e10cSrcweir/************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir//i20156 - new file for xmlsecurity module 29*cdf0e10cSrcweir 30*cdf0e10cSrcweir/** -- idl definition -- **/ 31*cdf0e10cSrcweir 32*cdf0e10cSrcweir#ifndef __com_sun_star_security_XDocumentDigitalSignatures_idl_ 33*cdf0e10cSrcweir#define __com_sun_star_security_XDocumentDigitalSignatures_idl_ 34*cdf0e10cSrcweir 35*cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl> 36*cdf0e10cSrcweir#include <com/sun/star/io/XInputStream.idl> 37*cdf0e10cSrcweir#include <com/sun/star/io/XStream.idl> 38*cdf0e10cSrcweir#include <com/sun/star/embed/XStorage.idl> 39*cdf0e10cSrcweir#include <com/sun/star/security/DocumentSignatureInformation.idl> 40*cdf0e10cSrcweir#include <com/sun/star/security/XCertificate.idl> 41*cdf0e10cSrcweir 42*cdf0e10cSrcweirmodule com { module sun { module star { module security { 43*cdf0e10cSrcweir 44*cdf0e10cSrcweir/** interface for signing and verifying digital signatures in office documents 45*cdf0e10cSrcweir 46*cdf0e10cSrcweir <p> 47*cdf0e10cSrcweir This interface can be used to digitaly sign different content in a office document. 48*cdf0e10cSrcweir It can also be used to verify digital signatures. 49*cdf0e10cSrcweir </p> 50*cdf0e10cSrcweir */ 51*cdf0e10cSrcweir 52*cdf0e10cSrcweirinterface XDocumentDigitalSignatures : com::sun::star::uno::XInterface 53*cdf0e10cSrcweir{ 54*cdf0e10cSrcweir /** signs the content of the document including text and pictures. 55*cdf0e10cSrcweir 56*cdf0e10cSrcweir <p>Macros will not be signed.</p> 57*cdf0e10cSrcweir */ 58*cdf0e10cSrcweir boolean signDocumentContent( [in] ::com::sun::star::embed::XStorage xStorage, 59*cdf0e10cSrcweir [in] ::com::sun::star::io::XStream xSignStream); 60*cdf0e10cSrcweir 61*cdf0e10cSrcweir /** checks for digital signatures and their status. 62*cdf0e10cSrcweir 63*cdf0e10cSrcweir <p>Only document content will be checked.</p> 64*cdf0e10cSrcweir */ 65*cdf0e10cSrcweir sequence< com::sun::star::security::DocumentSignatureInformation > verifyDocumentContentSignatures( 66*cdf0e10cSrcweir [in] ::com::sun::star::embed::XStorage xStorage, 67*cdf0e10cSrcweir [in] ::com::sun::star::io::XInputStream xSignInStream ); 68*cdf0e10cSrcweir 69*cdf0e10cSrcweir /** shows the digital signatures of the document content 70*cdf0e10cSrcweir */ 71*cdf0e10cSrcweir void showDocumentContentSignatures( 72*cdf0e10cSrcweir [in] ::com::sun::star::embed::XStorage xStorage, 73*cdf0e10cSrcweir [in] ::com::sun::star::io::XInputStream xSignInStream ); 74*cdf0e10cSrcweir 75*cdf0e10cSrcweir /** allows to get the default stream name for storing of the signature of 76*cdf0e10cSrcweir the document content. 77*cdf0e10cSrcweir */ 78*cdf0e10cSrcweir string getDocumentContentSignatureDefaultStreamName(); 79*cdf0e10cSrcweir 80*cdf0e10cSrcweir /** signs the content of the Scripting including macros and basic dialogs 81*cdf0e10cSrcweir 82*cdf0e10cSrcweir <p>The rest of document content will not be signed.</p> 83*cdf0e10cSrcweir */ 84*cdf0e10cSrcweir boolean signScriptingContent( [in] ::com::sun::star::embed::XStorage xStorage, 85*cdf0e10cSrcweir [in] ::com::sun::star::io::XStream xSignStream); 86*cdf0e10cSrcweir 87*cdf0e10cSrcweir /** checks for digital signatures and their status. 88*cdf0e10cSrcweir 89*cdf0e10cSrcweir <p>Only Scripting content will be checked.</p> 90*cdf0e10cSrcweir */ 91*cdf0e10cSrcweir sequence< com::sun::star::security::DocumentSignatureInformation > verifyScriptingContentSignatures( 92*cdf0e10cSrcweir [in] ::com::sun::star::embed::XStorage xStorage, 93*cdf0e10cSrcweir [in] ::com::sun::star::io::XInputStream xSignInStream ); 94*cdf0e10cSrcweir 95*cdf0e10cSrcweir /** shows the digital signatures of the scripting content 96*cdf0e10cSrcweir */ 97*cdf0e10cSrcweir void showScriptingContentSignatures( 98*cdf0e10cSrcweir [in] ::com::sun::star::embed::XStorage xStorage, 99*cdf0e10cSrcweir [in] ::com::sun::star::io::XInputStream xSignInStream ); 100*cdf0e10cSrcweir 101*cdf0e10cSrcweir /** allows to get the default stream name for storing of the signature of 102*cdf0e10cSrcweir the scripting content. 103*cdf0e10cSrcweir */ 104*cdf0e10cSrcweir string getScriptingContentSignatureDefaultStreamName(); 105*cdf0e10cSrcweir 106*cdf0e10cSrcweir /** signs the full Package, which means everything in the storage excecpt the content of META-INF 107*cdf0e10cSrcweir */ 108*cdf0e10cSrcweir boolean signPackage( [in] ::com::sun::star::embed::XStorage Storage, 109*cdf0e10cSrcweir [in] ::com::sun::star::io::XStream xSignStream); 110*cdf0e10cSrcweir 111*cdf0e10cSrcweir /** checks for digital signatures and their status. 112*cdf0e10cSrcweir 113*cdf0e10cSrcweir <p>Only Package content will be checked.</p> 114*cdf0e10cSrcweir */ 115*cdf0e10cSrcweir sequence< com::sun::star::security::DocumentSignatureInformation > verifyPackageSignatures( 116*cdf0e10cSrcweir [in] ::com::sun::star::embed::XStorage Storage, 117*cdf0e10cSrcweir [in] ::com::sun::star::io::XInputStream xSignInStream ); 118*cdf0e10cSrcweir 119*cdf0e10cSrcweir /** shows the digital signatures of the package 120*cdf0e10cSrcweir */ 121*cdf0e10cSrcweir void showPackageSignatures( 122*cdf0e10cSrcweir [in] ::com::sun::star::embed::XStorage xStorage, 123*cdf0e10cSrcweir [in] ::com::sun::star::io::XInputStream xSignInStream ); 124*cdf0e10cSrcweir 125*cdf0e10cSrcweir /** allows to get the default stream name for storing of the signature of 126*cdf0e10cSrcweir the package. 127*cdf0e10cSrcweir */ 128*cdf0e10cSrcweir string getPackageSignatureDefaultStreamName(); 129*cdf0e10cSrcweir 130*cdf0e10cSrcweir 131*cdf0e10cSrcweir void showCertificate( [in] com::sun::star::security::XCertificate Certificate ); 132*cdf0e10cSrcweir 133*cdf0e10cSrcweir 134*cdf0e10cSrcweir /** manages trusted sources (Authors and pathes ) 135*cdf0e10cSrcweir */ 136*cdf0e10cSrcweir 137*cdf0e10cSrcweir void manageTrustedSources(); 138*cdf0e10cSrcweir boolean isAuthorTrusted( [in] com::sun::star::security::XCertificate Author ); 139*cdf0e10cSrcweir boolean isLocationTrusted( [in] string Location ); 140*cdf0e10cSrcweir 141*cdf0e10cSrcweir // These method should raise confirmation dialog, so it can not used from bad macros... 142*cdf0e10cSrcweir void addAuthorToTrustedSources( [in] com::sun::star::security::XCertificate Author ); 143*cdf0e10cSrcweir void addLocationToTrustedSources( [in] string Location ); 144*cdf0e10cSrcweir 145*cdf0e10cSrcweir 146*cdf0e10cSrcweir 147*cdf0e10cSrcweir} ; 148*cdf0e10cSrcweir 149*cdf0e10cSrcweir} ; } ; } ; } ; 150*cdf0e10cSrcweir 151*cdf0e10cSrcweir#endif 152*cdf0e10cSrcweir 153*cdf0e10cSrcweir 154