1d1766043SAndrew Rist/**************************************************************
2cdf0e10cSrcweir *
3d1766043SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
4d1766043SAndrew Rist * or more contributor license agreements.  See the NOTICE file
5d1766043SAndrew Rist * distributed with this work for additional information
6d1766043SAndrew Rist * regarding copyright ownership.  The ASF licenses this file
7d1766043SAndrew Rist * to you under the Apache License, Version 2.0 (the
8d1766043SAndrew Rist * "License"); you may not use this file except in compliance
9d1766043SAndrew Rist * with the License.  You may obtain a copy of the License at
10d1766043SAndrew Rist *
11d1766043SAndrew Rist *   http://www.apache.org/licenses/LICENSE-2.0
12d1766043SAndrew Rist *
13d1766043SAndrew Rist * Unless required by applicable law or agreed to in writing,
14d1766043SAndrew Rist * software distributed under the License is distributed on an
15d1766043SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16d1766043SAndrew Rist * KIND, either express or implied.  See the License for the
17d1766043SAndrew Rist * specific language governing permissions and limitations
18d1766043SAndrew Rist * under the License.
19d1766043SAndrew Rist *
20d1766043SAndrew Rist *************************************************************/
21d1766043SAndrew Rist
22d1766043SAndrew Rist
23cdf0e10cSrcweir#ifndef __com_sun_star_mozilla_XPluginInstance_idl__
24cdf0e10cSrcweir#define __com_sun_star_mozilla_XPluginInstance_idl__
25cdf0e10cSrcweir
26cdf0e10cSrcweir#ifndef __com_sun_star_uno_XInterface_idl__
27cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl>
28cdf0e10cSrcweir#endif
29cdf0e10cSrcweir
30cdf0e10cSrcweir#ifndef __com_sun_star_io_XInputStream_idl__
31cdf0e10cSrcweir#include <com/sun/star/io/XInputStream.idl>
32cdf0e10cSrcweir#endif
33cdf0e10cSrcweir
34cdf0e10cSrcweir//=============================================================================
35cdf0e10cSrcweir
36cdf0e10cSrcweir module com {  module sun {  module star {  module mozilla {
37cdf0e10cSrcweir
38cdf0e10cSrcweir//=============================================================================
39cdf0e10cSrcweir
40cdf0e10cSrcweir
41cdf0e10cSrcweir// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::start
42*a893be29SPedro Giffuni/** Allows to control an office side plugin instance and to communicate with it.
43cdf0e10cSrcweir	This interface is oriented for communication with browsers plugins.
44cdf0e10cSrcweir */
45cdf0e10cSrcweirpublished interface XPluginInstance: com::sun::star::uno::XInterface
46cdf0e10cSrcweir{
47cdf0e10cSrcweir	//-------------------------------------------------------------------------
48cdf0e10cSrcweir
49cdf0e10cSrcweir
50cdf0e10cSrcweir	// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::start
51cdf0e10cSrcweir	/** Starts plugin operation. This is called after a plugin instance is
52cdf0e10cSrcweir		created.
53cdf0e10cSrcweir	 */
54cdf0e10cSrcweir	[oneway] void start();
55cdf0e10cSrcweir
56cdf0e10cSrcweir	//-------------------------------------------------------------------------
57cdf0e10cSrcweir
58cdf0e10cSrcweir
59cdf0e10cSrcweir	// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::stop
60cdf0e10cSrcweir	/** Stops plugin operation. This is called when the user goes to another web
61cdf0e10cSrcweir		page. The <member>XPluginInstance::destroy</member> method is directly called
62cdf0e10cSrcweir		afterwards.
63cdf0e10cSrcweir	 */
64cdf0e10cSrcweir	[oneway] void stop();
65cdf0e10cSrcweir
66cdf0e10cSrcweir	//-------------------------------------------------------------------------
67cdf0e10cSrcweir
68cdf0e10cSrcweir
69cdf0e10cSrcweir	// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::destroy
70cdf0e10cSrcweir	/** Destroy the plugin instance. This method is called when it is no
71cdf0e10cSrcweir		longer possible to return to the plugin instance, because it was
72cdf0e10cSrcweir		destroyed by the browser (e.g., window close).
73cdf0e10cSrcweir	 */
74cdf0e10cSrcweir	[oneway] void destroy();
75cdf0e10cSrcweir
76cdf0e10cSrcweir	//-------------------------------------------------------------------------
77cdf0e10cSrcweir
78cdf0e10cSrcweir
79cdf0e10cSrcweir	// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::createWindow
80cdf0e10cSrcweir	/** Creates a new window for plugin operation.
81cdf0e10cSrcweir
82cdf0e10cSrcweir		@param PlatformParentData	[in]:	platform dependent window data
83cdf0e10cSrcweir		@param embedded				[in]:	selects embedded or full page plugin mode
84cdf0e10cSrcweir
85cdf0e10cSrcweir	 */
86cdf0e10cSrcweir	[oneway] void createWindow( [in] any PlatformParentData, [in] boolean embedded );
87cdf0e10cSrcweir
88cdf0e10cSrcweir	//-------------------------------------------------------------------------
89cdf0e10cSrcweir
90cdf0e10cSrcweir
91cdf0e10cSrcweir	// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::newStream
92cdf0e10cSrcweir	/** Notifies the plugin of a new stream to display.
93cdf0e10cSrcweir
94cdf0e10cSrcweir		@param MIMEDesc		[in]:	the MIMEtype of the data stream
95cdf0e10cSrcweir		@param theURL		[in]:	the URL that denotes the stream
96cdf0e10cSrcweir		@param filter		[in]:	a filter string to suggest a component that should handle the document
97cdf0e10cSrcweir		@param stream		[in]:	the data stream
98cdf0e10cSrcweir		@param sessiondata	[in]:	the data specifying the current session
99cdf0e10cSrcweir
100cdf0e10cSrcweir	 */
101cdf0e10cSrcweir	[oneway] void newStream(
102cdf0e10cSrcweir		[in] string MIMEDesc,
103cdf0e10cSrcweir		[in] string theURL,
104cdf0e10cSrcweir		[in] string filter,
105cdf0e10cSrcweir		[in] ::com::sun::star::io::XInputStream stream ,
106cdf0e10cSrcweir		[in] any sessionData
107cdf0e10cSrcweir	);
108cdf0e10cSrcweir
109cdf0e10cSrcweir	//-------------------------------------------------------------------------
110cdf0e10cSrcweir
111cdf0e10cSrcweir
112cdf0e10cSrcweir	// DocMerge from xml: method com::sun::star::mozilla::XPluginInstance::newURL
113cdf0e10cSrcweir	/** Notifies the plugin of a new url to open as document.
114cdf0e10cSrcweir
115cdf0e10cSrcweir		@param MIMEDesc		[in]:	the MIMEtype of the data stream
116cdf0e10cSrcweir		@param theURL		[in]:	the URL to be openend
117cdf0e10cSrcweir		@param filter		[in]:	a filter string to suggest a component that should handle the document
118cdf0e10cSrcweir		@param sessiondata	[in]:	the data specifying the current session
119cdf0e10cSrcweir
120cdf0e10cSrcweir	 */
121cdf0e10cSrcweir	[oneway] void newURL( [in] string MIMEDesc, [in] string theURL, [in] string filter, [in] any sessionData );
122cdf0e10cSrcweir
123cdf0e10cSrcweir	//-------------------------------------------------------------------------
124cdf0e10cSrcweir
125cdf0e10cSrcweir
126cdf0e10cSrcweir	// DocMerge from idl: method com::sun::star::mozilla::XPluginInstance::getHttpServerURL
127cdf0e10cSrcweir	/** Retrieves the URL of the HTTP Loadbalancing Slave.
128cdf0e10cSrcweir
129cdf0e10cSrcweir		@param aURL		[out]:	the full qualified host name of the LBS
130cdf0e10cSrcweir		@param aPort	[out]:	the port number
131cdf0e10cSrcweir		@param aPrefix	[out]:	the url prefix to the portal
132cdf0e10cSrcweir
133cdf0e10cSrcweir	 */
134cdf0e10cSrcweir	void getHttpServerURL( [out] string aHost, [out] unsigned short aPort,
135cdf0e10cSrcweir						   [out] string aPrefix);
136cdf0e10cSrcweir};
137cdf0e10cSrcweir
138cdf0e10cSrcweir//=============================================================================
139cdf0e10cSrcweir
140cdf0e10cSrcweir}; }; }; };
141cdf0e10cSrcweir
142cdf0e10cSrcweir#endif
143