2010-10-12 08:57:08 -05:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2004-07-12 07:15:31 -05:00
|
|
|
#include "helper.hxx"
|
|
|
|
#include "osl/diagnose.h"
|
|
|
|
#include "rtl/ustring.h"
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Helper : create a input stream from a file
|
|
|
|
*/
|
|
|
|
Reference< XInputStream > createStreamFromFile( const OUString sFile )
|
|
|
|
{
|
|
|
|
const sal_Char* pcFile ;
|
|
|
|
OString aString ;
|
|
|
|
|
|
|
|
aString = OUStringToOString( sFile , RTL_TEXTENCODING_ASCII_US ) ;
|
|
|
|
pcFile = aString.getStr() ;
|
|
|
|
if( pcFile != NULL ) {
|
|
|
|
FILE *f = fopen( pcFile , "rb" );
|
|
|
|
Reference< XInputStream > r;
|
|
|
|
|
|
|
|
if( f ) {
|
|
|
|
fseek( f , 0 , SEEK_END );
|
|
|
|
int nLength = ftell( f );
|
|
|
|
fseek( f , 0 , SEEK_SET );
|
|
|
|
|
|
|
|
Sequence<sal_Int8> seqIn(nLength);
|
|
|
|
fread( seqIn.getArray() , nLength , 1 , f );
|
|
|
|
|
|
|
|
r = Reference< XInputStream > ( new OInputStream( seqIn ) );
|
|
|
|
fclose( f );
|
|
|
|
}
|
|
|
|
return r;
|
|
|
|
} else {
|
|
|
|
return NULL ;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL ;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Helper : set a output stream to a file
|
|
|
|
*/
|
|
|
|
Reference< XOutputStream > createStreamToFile( const OUString sFile )
|
|
|
|
{
|
|
|
|
const sal_Char* pcFile ;
|
|
|
|
OString aString ;
|
|
|
|
|
|
|
|
aString = OUStringToOString( sFile , RTL_TEXTENCODING_ASCII_US ) ;
|
|
|
|
pcFile = aString.getStr() ;
|
|
|
|
if( pcFile != NULL )
|
|
|
|
return Reference< XOutputStream >( new OOutputStream( pcFile ) ) ;
|
|
|
|
else
|
|
|
|
return NULL ;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Helper : get service manager and context
|
|
|
|
*/
|
|
|
|
Reference< XMultiComponentFactory > serviceManager( Reference< XComponentContext >& xContext , OUString sUnoUrl , OUString sRdbUrl ) throw( RuntimeException , Exception )
|
|
|
|
{
|
|
|
|
Reference< XMultiComponentFactory > xLocalServiceManager = NULL ;
|
|
|
|
Reference< XComponentContext > xLocalComponentContext = NULL ;
|
|
|
|
Reference< XMultiComponentFactory > xUsedServiceManager = NULL ;
|
|
|
|
Reference< XComponentContext > xUsedComponentContext = NULL ;
|
|
|
|
|
2011-01-28 08:19:18 -06:00
|
|
|
OSL_ENSURE( sUnoUrl.getLength() ,
|
2004-07-12 07:15:31 -05:00
|
|
|
"serviceManager - "
|
|
|
|
"No uno URI specified" ) ;
|
|
|
|
|
2011-01-28 08:19:18 -06:00
|
|
|
OSL_ENSURE( sRdbUrl.getLength() ,
|
2004-07-12 07:15:31 -05:00
|
|
|
"serviceManager - "
|
|
|
|
"No rdb URI specified" ) ;
|
|
|
|
|
2011-01-20 03:30:44 -06:00
|
|
|
if( sUnoUrl.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "local" ) ) ) {
|
2004-07-12 07:15:31 -05:00
|
|
|
Reference< XSimpleRegistry > xSimpleRegistry = createSimpleRegistry();
|
|
|
|
OSL_ENSURE( xSimpleRegistry.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create simple registry" ) ;
|
|
|
|
|
2010-11-28 11:33:53 -06:00
|
|
|
//xSimpleRegistry->open(OUString(RTL_CONSTASCII_USTRINGPARAM("xmlsecurity.rdb")), sal_False, sal_False);
|
2004-07-12 07:15:31 -05:00
|
|
|
xSimpleRegistry->open(sRdbUrl, sal_True, sal_False);
|
|
|
|
OSL_ENSURE( xSimpleRegistry->isValid() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot open xml security registry rdb" ) ;
|
|
|
|
|
|
|
|
xLocalComponentContext = bootstrap_InitialComponentContext( xSimpleRegistry ) ;
|
|
|
|
OSL_ENSURE( xLocalComponentContext.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create intial component context" ) ;
|
|
|
|
|
|
|
|
xLocalServiceManager = xLocalComponentContext->getServiceManager() ;
|
|
|
|
OSL_ENSURE( xLocalServiceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create intial service manager" ) ;
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Because of the exception rasied from
|
|
|
|
* ucbhelper/source/provider/provconf.cxx, lin 323
|
|
|
|
* I do not use the content broker at present
|
|
|
|
********************************************************************
|
|
|
|
//init ucb
|
|
|
|
if( ::ucb::ContentBroker::get() == NULL ) {
|
|
|
|
Reference< lang::XMultiServiceFactory > xSvmg( xLocalServiceManager , UNO_QUERY ) ;
|
|
|
|
OSL_ENSURE( xLocalServiceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get multi-service factory" ) ;
|
|
|
|
|
|
|
|
Sequence< Any > args( 2 ) ;
|
2010-11-29 16:01:56 -06:00
|
|
|
args[ 0 ] <<= OUString(RTL_CONSTASCII_USTRINGPARAM( UCB_CONFIGURATION_KEY1_LOCAL )) ;
|
|
|
|
args[ 1 ] <<= OUString(RTL_CONSTASCII_USTRINGPARAM( UCB_CONFIGURATION_KEY2_OFFICE )) ;
|
2004-07-12 07:15:31 -05:00
|
|
|
if( ! ::ucb::ContentBroker::initialize( xSvmg , args ) ) {
|
2010-11-28 11:33:53 -06:00
|
|
|
throw RuntimeException( OUString(RTL_CONSTASCII_USTRINGPARAM("Cannot inlitialize ContentBroker")) , Reference< XInterface >() , Any() ) ;
|
2004-07-12 07:15:31 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
********************************************************************/
|
|
|
|
|
2006-09-16 08:51:15 -05:00
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_xmlsecurity.hxx"
|
|
|
|
|
2004-07-12 07:15:31 -05:00
|
|
|
xUsedComponentContext = xLocalComponentContext ;
|
|
|
|
xUsedServiceManager = xLocalServiceManager ;
|
|
|
|
} else {
|
|
|
|
Reference< XComponentContext > xLocalComponentContext = defaultBootstrap_InitialComponentContext() ;
|
|
|
|
OSL_ENSURE( xLocalComponentContext.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create intial component context" ) ;
|
|
|
|
|
|
|
|
Reference< XMultiComponentFactory > xLocalServiceManager = xLocalComponentContext->getServiceManager();
|
|
|
|
OSL_ENSURE( xLocalServiceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create intial service manager" ) ;
|
|
|
|
|
|
|
|
Reference< XInterface > urlResolver =
|
2010-11-28 11:33:53 -06:00
|
|
|
xLocalServiceManager->createInstanceWithContext( OUString(RTL_CONSTASCII_USTRINGPARAM("com.sun.star.bridge.UnoUrlResolver")) , xLocalComponentContext ) ;
|
2004-07-12 07:15:31 -05:00
|
|
|
OSL_ENSURE( urlResolver.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get service instance of \"bridge.UnoUrlResolver\"" ) ;
|
|
|
|
|
|
|
|
Reference< XUnoUrlResolver > xUnoUrlResolver( urlResolver , UNO_QUERY ) ;
|
|
|
|
OSL_ENSURE( xUnoUrlResolver.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get interface of \"XUnoUrlResolver\" from service \"bridge.UnoUrlResolver\"" ) ;
|
|
|
|
|
|
|
|
Reference< XInterface > initialObject = xUnoUrlResolver->resolve( sUnoUrl ) ;
|
|
|
|
OSL_ENSURE( initialObject.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot resolve uno url" ) ;
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Method 1: with Naming Service
|
|
|
|
********************************************************************
|
|
|
|
Reference< XNamingService > xNamingService( initialObject , UNO_QUERY ) ;
|
|
|
|
OSL_ENSURE( xNamingService.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get interface of \"XNamingService\" from URL resolver" ) ;
|
|
|
|
|
|
|
|
Reference< XInterface > serviceManager =
|
2010-11-28 11:33:53 -06:00
|
|
|
xNamingService->getRegisteredObject( OUString(RTL_CONSTASCII_USTRINGPARAM("StarOffice.ServiceManager")) ) ;
|
2004-07-12 07:15:31 -05:00
|
|
|
OSL_ENSURE( serviceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get service instance of \"StarOffice.ServiceManager\"" ) ;
|
|
|
|
|
|
|
|
xUsedServiceManager = Reference< XMultiComponentFactory >( serviceManager , UNO_QUERY );
|
|
|
|
OSL_ENSURE( xUsedServiceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get interface of \"XMultiComponentFactory\" from service \"StarOffice.ServiceManager\"" ) ;
|
|
|
|
|
|
|
|
Reference< XPropertySet > xPropSet( xUsedServiceManager , UNO_QUERY ) ;
|
|
|
|
OSL_ENSURE( xPropSet.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get interface of \"XPropertySet\" from service \"StarOffice.ServiceManager\"" ) ;
|
|
|
|
|
2010-11-28 11:33:53 -06:00
|
|
|
xPropSet->getPropertyValue( OUString(RTL_CONSTASCII_USTRINGPARAM("DefaultContext")) ) >>= xUsedComponentContext ;
|
2004-07-12 07:15:31 -05:00
|
|
|
OSL_ENSURE( xUsedComponentContext.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create remote component context" ) ;
|
|
|
|
|
|
|
|
********************************************************************/
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Method 2: with Componnent context
|
|
|
|
********************************************************************
|
|
|
|
Reference< XPropertySet > xPropSet( initialObject , UNO_QUERY ) ;
|
|
|
|
OSL_ENSURE( xPropSet.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get interface of \"XPropertySet\" from URL resolver" ) ;
|
|
|
|
|
2010-11-28 11:33:53 -06:00
|
|
|
xPropSet->getPropertyValue( OUString(RTL_CONSTASCII_USTRINGPARAM("DefaultContext")) ) >>= xUsedComponentContext ;
|
2004-07-12 07:15:31 -05:00
|
|
|
OSL_ENSURE( xUsedComponentContext.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create remote component context" ) ;
|
|
|
|
|
|
|
|
xUsedServiceManager = xUsedComponentContext->getServiceManager();
|
|
|
|
OSL_ENSURE( xUsedServiceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create remote service manager" ) ;
|
|
|
|
********************************************************************/
|
|
|
|
|
|
|
|
/*-
|
|
|
|
* Method 3: with Service Manager
|
|
|
|
********************************************************************/
|
|
|
|
xUsedServiceManager = Reference< XMultiComponentFactory >( initialObject , UNO_QUERY );
|
|
|
|
OSL_ENSURE( xUsedServiceManager.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create remote service manager" ) ;
|
|
|
|
|
|
|
|
Reference< XPropertySet > xPropSet( xUsedServiceManager , UNO_QUERY ) ;
|
|
|
|
OSL_ENSURE( xPropSet.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot get interface of \"XPropertySet\" from service \"StarOffice.ServiceManager\"" ) ;
|
|
|
|
|
2010-11-28 11:33:53 -06:00
|
|
|
xPropSet->getPropertyValue( OUString(RTL_CONSTASCII_USTRINGPARAM("DefaultContext")) ) >>= xUsedComponentContext ;
|
2004-07-12 07:15:31 -05:00
|
|
|
OSL_ENSURE( xUsedComponentContext.is() ,
|
|
|
|
"serviceManager - "
|
|
|
|
"Cannot create remote component context" ) ;
|
|
|
|
/********************************************************************/
|
|
|
|
}
|
|
|
|
|
|
|
|
xContext = xUsedComponentContext ;
|
|
|
|
return xUsedServiceManager ;
|
|
|
|
}
|
|
|
|
|
2010-10-12 08:57:08 -05:00
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|