1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: XRemoteContentProviderAcceptor.idl,v $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
30 #ifndef __com_sun_star_ucb_XRemoteContentProviderAcceptor_idl__
31 #define __com_sun_star_ucb_XRemoteContentProviderAcceptor_idl__
33 #ifndef __com_sun_star_lang_XMultiServiceFactory_idl__
34 #include
<com
/sun
/star
/lang
/XMultiServiceFactory.idl
>
37 #ifndef __com_sun_star_uno_XInterface_idl__
38 #include
<com
/sun
/star
/uno
/XInterface.idl
>
42 //=============================================================================
44 module com
{ module sun
{ module star
{ module ucb
{
46 published
interface XRemoteContentProviderDoneListener
;
48 //=============================================================================
49 /** Accept remote content providers that want to make themselves known to the
53 @author Stephan Bergmann
55 published
interface XRemoteContentProviderAcceptor
: com
::sun
::star
::uno
::XInterface
57 //-------------------------------------------------------------------------
58 /** Add a remote content provider.
60 @param Identifier An arbitrary identifier uniquely identifying the
61 remote content provider.
63 @param Factory A factory through which the remote content provider's
64 <type>UniversalContentBroker</type> service can be instantiated.
66 @param Templates A sequence of URL templates the remote content
67 provider is willing to handle.
69 @param DoneListener If not null, the implementation of this interface
70 can---through this callback---tell the calling side that the
71 implementation no longer needs the remote content provider. (And the
72 calling side should call
73 <member>XRemoteContentProviderAcceptor::removeRemoteContentProvider</member>
76 To enable connection control, it is recommended that this argument
77 also implements the interface
78 <type>XRemoteContentProviderConnectionControl</type>.
80 @return true if the remote content provider has successfully been
84 addRemoteContentProvider
([in] string Identifier
,
85 [in] com
::sun
::star
::lang
::XMultiServiceFactory
87 [in] sequence
< string > Templates
,
88 [in] XRemoteContentProviderDoneListener
91 //-------------------------------------------------------------------------
92 /** Remove a remote content provider.
94 @param Identifier An arbitrary identifier uniquely identifying the
95 remote content provider.
97 @return true if the remote content provider has successfully been
101 removeRemoteContentProvider
([in] string Identifier
);
104 //=============================================================================