// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef WEBKIT_GLUE_WEBPLUGIN_H__ #define WEBKIT_GLUE_WEBPLUGIN_H__ #include #include #include "base/basictypes.h" #include "base/file_path.h" #include "base/gfx/rect.h" typedef struct HWND__* HWND; typedef void* HANDLE; class GURL; class WebFrame; class WebPluginResourceClient; struct NPObject; // Describes a mime type entry for a plugin. struct WebPluginMimeType { // The actual mime type. std::string mime_type; // A list of all the file extensions for this mime type. std::vector file_extensions; // Description of the mime type. std::wstring description; }; // Describes an available NPAPI plugin. struct WebPluginInfo { // The name of the plugin (i.e. Flash). std::wstring name; // The path to the plugin file (DLL/bundle/library). FilePath path; // The version number of the plugin file (may be OS-specific) std::wstring version; // A description of the plugin that we get from its version info. std::wstring desc; // A list of all the mime types that this plugin supports. std::vector mime_types; }; // Describes the new location for a plugin window. struct WebPluginGeometry { HWND window; gfx::Rect window_rect; // Clip rect (include) and cutouts (excludes), relative to // window_rect origin. gfx::Rect clip_rect; std::vector cutout_rects; bool visible; }; enum RoutingStatus { ROUTED, NOT_ROUTED, INVALID_URL, GENERAL_FAILURE }; // The WebKit side of a plugin implementation. It provides wrappers around // operations that need to interact with the frame and other WebCore objects. class WebPlugin { public: WebPlugin() { } virtual ~WebPlugin() { } // Called by the plugin delegate to let the WebPlugin know if the plugin is // windowed (i.e. handle is not NULL) or windowless (handle is NULL). This // tells the WebPlugin to send mouse/keyboard events to the plugin delegate, // as well as the information about the HDC for paint operations. // The pump_messages_event is a event handle which is valid only for // windowless plugins and is used in NPP_HandleEvent calls to pump messages // if the plugin enters a modal loop. virtual void SetWindow(HWND window, HANDLE pump_messages_event) = 0; // Cancels a pending request. virtual void CancelResource(int id) = 0; virtual void Invalidate() = 0; virtual void InvalidateRect(const gfx::Rect& rect) = 0; // Returns the NPObject for the browser's window object. virtual NPObject* GetWindowScriptNPObject() = 0; // Returns the DOM element that loaded the plugin. virtual NPObject* GetPluginElement() = 0; // Returns the WebFrame that contains this plugin. virtual WebFrame* GetWebFrame() = 0; // Cookies virtual void SetCookie(const GURL& url, const GURL& policy_url, const std::string& cookie) = 0; virtual std::string GetCookies(const GURL& url, const GURL& policy_url) = 0; // Shows a modal HTML dialog containing the given URL. json_arguments are // passed to the dialog via the DOM 'window.chrome.dialogArguments', and the // retval is the string returned by 'window.chrome.send("DialogClose", // retval)'. virtual void ShowModalHTMLDialog(const GURL& url, int width, int height, const std::string& json_arguments, std::string* json_retval) = 0; // When a default plugin has downloaded the plugin list and finds it is // available, it calls this method to notify the renderer. Also it will update // the status when user clicks on the plugin to install. virtual void OnMissingPluginStatus(int status) = 0; // Handles GetURL/GetURLNotify/PostURL/PostURLNotify requests initiated // by plugins. virtual void HandleURLRequest(const char *method, bool is_javascript_url, const char* target, unsigned int len, const char* buf, bool is_file_data, bool notify, const char* url, void* notify_data, bool popups_allowed) = 0; // Cancels document load. virtual void CancelDocumentLoad() = 0; // Initiates a HTTP range request. virtual void InitiateHTTPRangeRequest(const char* url, const char* range_info, void* existing_stream, bool notify_needed, HANDLE notify_data) = 0; private: DISALLOW_EVIL_CONSTRUCTORS(WebPlugin); }; // Simpler version of ResourceHandleClient that lends itself to proxying. class WebPluginResourceClient { public: virtual ~WebPluginResourceClient() {} virtual void WillSendRequest(const GURL& url) = 0; // The request_is_seekable parameter indicates whether byte range requests // can be issued for the underlying stream. virtual void DidReceiveResponse(const std::string& mime_type, const std::string& headers, uint32 expected_length, uint32 last_modified, bool request_is_seekable, bool* cancel) = 0; virtual void DidReceiveData(const char* buffer, int length, int data_offset) = 0; virtual void DidFinishLoading() = 0; virtual void DidFail() = 0; virtual bool IsMultiByteResponseExpected() = 0; }; #endif // #ifndef WEBKIT_GLUE_WEBPLUGIN_H__