1*06b3ce53SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*06b3ce53SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*06b3ce53SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*06b3ce53SAndrew Rist * distributed with this work for additional information 6*06b3ce53SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*06b3ce53SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*06b3ce53SAndrew Rist * "License"); you may not use this file except in compliance 9*06b3ce53SAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 11*06b3ce53SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 13*06b3ce53SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*06b3ce53SAndrew Rist * software distributed under the License is distributed on an 15*06b3ce53SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*06b3ce53SAndrew Rist * KIND, either express or implied. See the License for the 17*06b3ce53SAndrew Rist * specific language governing permissions and limitations 18*06b3ce53SAndrew Rist * under the License. 19cdf0e10cSrcweir * 20*06b3ce53SAndrew Rist *************************************************************/ 21*06b3ce53SAndrew Rist 22*06b3ce53SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 25cdf0e10cSrcweir #include "precompiled_xmlsecurity.hxx" 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "util.hxx" 28cdf0e10cSrcweir 29cdf0e10cSrcweir #include <stdio.h> 30cdf0e10cSrcweir #include <cppuhelper/servicefactory.hxx> 31cdf0e10cSrcweir 32cdf0e10cSrcweir #include <xmlsecurity/xmlsignaturehelper.hxx> 33cdf0e10cSrcweir 34cdf0e10cSrcweir using namespace ::com::sun::star; 35cdf0e10cSrcweir 36cdf0e10cSrcweir long startVerifyHandler( void *, void * ) 37cdf0e10cSrcweir { 38cdf0e10cSrcweir return QueryVerifySignature(); 39cdf0e10cSrcweir } 40cdf0e10cSrcweir 41cdf0e10cSrcweir int SAL_CALL main( int argc, char **argv ) 42cdf0e10cSrcweir { 43cdf0e10cSrcweir if( argc < 2 ) 44cdf0e10cSrcweir { 45cdf0e10cSrcweir fprintf( stderr, "Usage: %s <signature file> [<cryptoken>]\n" , argv[0] ) ; 46cdf0e10cSrcweir return -1 ; 47cdf0e10cSrcweir } 48cdf0e10cSrcweir 49cdf0e10cSrcweir rtl::OUString aSIGFileName = rtl::OUString::createFromAscii(argv[1]); 50cdf0e10cSrcweir rtl::OUString aCryptoToken; 51cdf0e10cSrcweir if ( argc >= 3 ) 52cdf0e10cSrcweir aCryptoToken = rtl::OUString::createFromAscii(argv[2]); 53cdf0e10cSrcweir 54cdf0e10cSrcweir uno::Reference< lang::XMultiServiceFactory > xMSF = CreateDemoServiceFactory(); 55cdf0e10cSrcweir 56cdf0e10cSrcweir 57cdf0e10cSrcweir /* 58cdf0e10cSrcweir * creates a signature helper 59cdf0e10cSrcweir */ 60cdf0e10cSrcweir XMLSignatureHelper aSignatureHelper( xMSF ); 61cdf0e10cSrcweir 62cdf0e10cSrcweir /* 63cdf0e10cSrcweir * creates a security context. 64cdf0e10cSrcweir */ 65cdf0e10cSrcweir bool bInit = aSignatureHelper.Init( aCryptoToken ); 66cdf0e10cSrcweir if ( !bInit ) 67cdf0e10cSrcweir { 68cdf0e10cSrcweir fprintf( stderr, "Error initializing security context!" ); 69cdf0e10cSrcweir return -1; 70cdf0e10cSrcweir } 71cdf0e10cSrcweir 72cdf0e10cSrcweir /* 73cdf0e10cSrcweir * configures the start-verify handler 74cdf0e10cSrcweir */ 75cdf0e10cSrcweir aSignatureHelper.SetStartVerifySignatureHdl( Link( NULL, startVerifyHandler ) ); 76cdf0e10cSrcweir 77cdf0e10cSrcweir aSignatureHelper.StartMission(); 78cdf0e10cSrcweir 79cdf0e10cSrcweir /* 80cdf0e10cSrcweir * verifies the signature 81cdf0e10cSrcweir */ 82cdf0e10cSrcweir uno::Reference< io::XInputStream > xInputStream = OpenInputStream( aSIGFileName ); 83cdf0e10cSrcweir bool bDone = aSignatureHelper.ReadAndVerifySignature( xInputStream ); 84cdf0e10cSrcweir 85cdf0e10cSrcweir /* 86cdf0e10cSrcweir * closes the signature stream 87cdf0e10cSrcweir */ 88cdf0e10cSrcweir xInputStream->closeInput(); 89cdf0e10cSrcweir 90cdf0e10cSrcweir if ( !bDone ) 91cdf0e10cSrcweir { 92cdf0e10cSrcweir fprintf( stderr, "\nSTATUS: Error verifying Signature!\n" ); 93cdf0e10cSrcweir } 94cdf0e10cSrcweir else 95cdf0e10cSrcweir { 96cdf0e10cSrcweir fprintf( stdout, "\nSTATUS: All choosen Signatures veryfied successfully!\n" ); 97cdf0e10cSrcweir } 98cdf0e10cSrcweir 99cdf0e10cSrcweir aSignatureHelper.EndMission(); 100cdf0e10cSrcweir 101cdf0e10cSrcweir QueryPrintSignatureDetails( aSignatureHelper.GetSignatureInformations(), aSignatureHelper.GetSecurityEnvironment() ); 102cdf0e10cSrcweir 103cdf0e10cSrcweir return 0; 104cdf0e10cSrcweir } 105cdf0e10cSrcweir 106