/* * Copyright (C) 2011 Google Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * Neither the name of Google Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef WebFrameClient_h #define WebFrameClient_h #include "WebCommon.h" #include "WebFileSystem.h" #include "WebNavigationPolicy.h" #include "WebNavigationType.h" #include "WebStorageQuotaType.h" #include "WebTextDirection.h" #include "WebURLError.h" namespace WebKit { class WebApplicationCacheHost; class WebApplicationCacheHostClient; class WebCookieJar; class WebDataSource; class WebFormElement; class WebFrame; class WebMediaPlayer; class WebMediaPlayerClient; class WebNode; class WebPlugin; class WebSecurityOrigin; class WebSharedWorker; class WebStorageQuotaCallbacks; class WebString; class WebURL; class WebURLRequest; class WebURLResponse; class WebWorker; class WebWorkerClient; struct WebPluginParams; struct WebRect; struct WebSize; struct WebURLError; class WebFrameClient { public: // Factory methods ----------------------------------------------------- // May return null. virtual WebPlugin* createPlugin(WebFrame*, const WebPluginParams&) { return 0; } // May return null. virtual WebWorker* createWorker(WebFrame*, WebWorkerClient*) { return 0; } // May return null. virtual WebSharedWorker* createSharedWorker(WebFrame*, const WebURL&, const WebString&, unsigned long long) { return 0; } // May return null. virtual WebMediaPlayer* createMediaPlayer(WebFrame*, WebMediaPlayerClient*) { return 0; } // May return null. virtual WebApplicationCacheHost* createApplicationCacheHost(WebFrame*, WebApplicationCacheHostClient*) { return 0; } // Services ------------------------------------------------------------ // A frame specific cookie jar. May return null, in which case // WebKitClient::cookieJar() will be called to access cookies. virtual WebCookieJar* cookieJar(WebFrame*) { return 0; } // General notifications ----------------------------------------------- // This frame has been detached from the view. // // FIXME: Do not use this in new code. Currently this is used by code in // Chromium that errantly caches WebKit objects. virtual void frameDetached(WebFrame*) { } // This frame is about to be closed. virtual void willClose(WebFrame*) { } // Controls whether plugins are allowed for this frame. virtual bool allowPlugins(WebFrame*, bool enabledPerSettings) { return enabledPerSettings; } // Notifies the client that the frame would have instantiated a plug-in if plug-ins were enabled. virtual void didNotAllowPlugins(WebFrame*) { } // Controls whether images are allowed for this frame. virtual bool allowImages(WebFrame*, bool enabledPerSettings) { return enabledPerSettings; } // Notifies the client that continuous spell checking has been enabled or // disabled. virtual void didToggleContinuousSpellChecking(WebFrame*) { } // Load commands ------------------------------------------------------- // The client should handle the navigation externally. virtual void loadURLExternally( WebFrame*, const WebURLRequest&, WebNavigationPolicy) { } // Navigational queries ------------------------------------------------ // The client may choose to alter the navigation policy. Otherwise, // defaultPolicy should just be returned. virtual WebNavigationPolicy decidePolicyForNavigation( WebFrame*, const WebURLRequest&, WebNavigationType, const WebNode& originatingNode, WebNavigationPolicy defaultPolicy, bool isRedirect) { return defaultPolicy; } // Query if the specified request can be handled. virtual bool canHandleRequest( WebFrame*, const WebURLRequest& request) { return true; } // Returns an error corresponding to canHandledRequest() returning false. virtual WebURLError cannotHandleRequestError( WebFrame*, const WebURLRequest& request) { return WebURLError(); } // Returns an error corresponding to a user cancellation event. virtual WebURLError cancelledError( WebFrame*, const WebURLRequest& request) { return WebURLError(); } // Notify that a URL cannot be handled. virtual void unableToImplementPolicyWithError( WebFrame*, const WebURLError&) { } // Navigational notifications ------------------------------------------ // A form submission has been requested, but the page's submit event handler // hasn't yet had a chance to run (and possibly alter/interrupt the submit.) virtual void willSendSubmitEvent(WebFrame*, const WebFormElement&) { } // A form submission is about to occur. virtual void willSubmitForm(WebFrame*, const WebFormElement&) { } // A client-side redirect will occur. This may correspond to a <META // refresh> or some script activity. virtual void willPerformClientRedirect( WebFrame*, const WebURL& from, const WebURL& to, double interval, double fireTime) { } // A client-side redirect was cancelled. virtual void didCancelClientRedirect(WebFrame*) { } // A client-side redirect completed. virtual void didCompleteClientRedirect(WebFrame*, const WebURL& fromURL) { } // A datasource has been created for a new navigation. The given // datasource will become the provisional datasource for the frame. virtual void didCreateDataSource(WebFrame*, WebDataSource*) { } // A new provisional load has been started. virtual void didStartProvisionalLoad(WebFrame*) { } // The provisional load was redirected via a HTTP 3xx response. virtual void didReceiveServerRedirectForProvisionalLoad(WebFrame*) { } // The provisional load failed. virtual void didFailProvisionalLoad(WebFrame*, const WebURLError&) { } // Notifies the client to commit data for the given frame. The client // may optionally prevent default processing by setting preventDefault // to true before returning. If default processing is prevented, then // it is up to the client to manually call commitDocumentData on the // WebFrame. It is only valid to call commitDocumentData within a call // to didReceiveDocumentData. If commitDocumentData is not called, // then an empty document will be loaded. virtual void didReceiveDocumentData( WebFrame*, const char* data, size_t length, bool& preventDefault) { } // The provisional datasource is now committed. The first part of the // response body has been received, and the encoding of the response // body is known. virtual void didCommitProvisionalLoad(WebFrame*, bool isNewNavigation) { } // The window object for the frame has been cleared of any extra // properties that may have been set by script from the previously // loaded document. virtual void didClearWindowObject(WebFrame*) { } // The document element has been created. virtual void didCreateDocumentElement(WebFrame*) { } // The page title is available. // FIXME: remove override once Chrome is updated to new API. virtual void didReceiveTitle(WebFrame*, const WebString& title) { } virtual void didReceiveTitle(WebFrame* frame, const WebString& title, WebTextDirection direction) { didReceiveTitle(frame, title); } // The icons for the page have changed. virtual void didChangeIcons(WebFrame*) { } // The frame's document finished loading. virtual void didFinishDocumentLoad(WebFrame*) { } // The 'load' event was dispatched. virtual void didHandleOnloadEvents(WebFrame*) { } // The frame's document or one of its subresources failed to load. virtual void didFailLoad(WebFrame*, const WebURLError&) { } // The frame's document and all of its subresources succeeded to load. virtual void didFinishLoad(WebFrame*) { } // The navigation resulted in no change to the documents within the page. // For example, the navigation may have just resulted in scrolling to a // named anchor or a PopState event may have been dispatched. virtual void didNavigateWithinPage(WebFrame*, bool isNewNavigation) { } // The navigation resulted in scrolling the page to a named anchor instead // of downloading a new document. virtual void didChangeLocationWithinPage(WebFrame*) { } // Called upon update to scroll position, document state, and other // non-navigational events related to the data held by WebHistoryItem. // WARNING: This method may be called very frequently. virtual void didUpdateCurrentHistoryItem(WebFrame*) { } // Low-level resource notifications ------------------------------------ // An identifier was assigned to the specified request. The client // should remember this association if interested in subsequent events. virtual void assignIdentifierToRequest( WebFrame*, unsigned identifier, const WebURLRequest&) { } // Remove the association between an identifier assigned to a request if // the client keeps such an association. virtual void removeIdentifierForRequest(unsigned identifier) { } // A request is about to be sent out, and the client may modify it. Request // is writable, and changes to the URL, for example, will change the request // made. If this request is the result of a redirect, then redirectResponse // will be non-null and contain the response that triggered the redirect. virtual void willSendRequest( WebFrame*, unsigned identifier, WebURLRequest&, const WebURLResponse& redirectResponse) { } // Response headers have been received for the resource request given // by identifier. virtual void didReceiveResponse( WebFrame*, unsigned identifier, const WebURLResponse&) { } // The resource request given by identifier succeeded. virtual void didFinishResourceLoad( WebFrame*, unsigned identifier) { } // The resource request given by identifier failed. virtual void didFailResourceLoad( WebFrame*, unsigned identifier, const WebURLError&) { } // The specified request was satified from WebCore's memory cache. virtual void didLoadResourceFromMemoryCache( WebFrame*, const WebURLRequest&, const WebURLResponse&) { } // This frame has displayed inactive content (such as an image) from an // insecure source. Inactive content cannot spread to other frames. virtual void didDisplayInsecureContent(WebFrame*) { } // The indicated security origin has run active content (such as a // script) from an insecure source. Note that the insecure content can // spread to other frames in the same origin. virtual void didRunInsecureContent(WebFrame*, const WebSecurityOrigin&, const WebURL& insecureURL) { } // Script notifications ------------------------------------------------ // Controls whether scripts are allowed to execute for this frame. virtual bool allowScript(WebFrame*, bool enabledPerSettings) { return enabledPerSettings; } // Controls whether access to Web Databases is allowed for this frame. virtual bool allowDatabase(WebFrame*, const WebString& name, const WebString& displayName, unsigned long estimatedSize) { return true; } // Notifies the client that the frame would have executed script if script were enabled. virtual void didNotAllowScript(WebFrame*) { } // Script in the page tried to allocate too much memory. virtual void didExhaustMemoryAvailableForScript(WebFrame*) { } // Notifies that a new script context has been created for this frame. // This is similar to didClearWindowObject but only called once per // frame context. virtual void didCreateScriptContext(WebFrame*) { } // Notifies that this frame's script context has been destroyed. virtual void didDestroyScriptContext(WebFrame*) { } // Notifies that a garbage-collected context was created - content // scripts. virtual void didCreateIsolatedScriptContext(WebFrame*) { } // Controls whether the given script extension should run in a new script // context in this frame. If extensionGroup is 0, the script context is the // frame's main context. Otherwise, it is a context created by // WebFrame::executeScriptInIsolatedWorld with that same extensionGroup // value. virtual bool allowScriptExtension(WebFrame*, const WebString& extensionName, int extensionGroup) { return true; } // Geometry notifications ---------------------------------------------- // The frame's document finished the initial layout of a page. virtual void didFirstLayout(WebFrame*) { } // The frame's document finished the initial non-empty layout of a page. virtual void didFirstVisuallyNonEmptyLayout(WebFrame*) { } // The size of the content area changed. virtual void didChangeContentsSize(WebFrame*, const WebSize&) { } // The main frame scrolled. virtual void didChangeScrollOffset(WebFrame*) { } // Find-in-page notifications ------------------------------------------ // Notifies how many matches have been found so far, for a given // identifier. |finalUpdate| specifies whether this is the last update // (all frames have completed scoping). virtual void reportFindInPageMatchCount( int identifier, int count, bool finalUpdate) { } // Notifies what tick-mark rect is currently selected. The given // identifier lets the client know which request this message belongs // to, so that it can choose to ignore the message if it has moved on // to other things. The selection rect is expected to have coordinates // relative to the top left corner of the web page area and represent // where on the screen the selection rect is currently located. virtual void reportFindInPageSelection( int identifier, int activeMatchOrdinal, const WebRect& selection) { } // FileSystem ---------------------------------------------------- // Requests to open a FileSystem. // |size| indicates how much storage space (in bytes) the caller expects // to need. // WebFileSystemCallbacks::didOpenFileSystem() must be called with // a name and root path for the requested FileSystem when the operation // is completed successfully. WebFileSystemCallbacks::didFail() must be // called otherwise. The create bool is for indicating whether or not to // create root path for file systems if it do not exist. virtual void openFileSystem( WebFrame*, WebFileSystem::Type, long long size, bool create, WebFileSystemCallbacks*) { } // Quota --------------------------------------------------------- // Queries the origin's storage usage and quota information. // WebStorageQuotaCallbacks::didQueryStorageUsageAndQuota will be called // with the current usage and quota information for the origin. When // an error occurs WebStorageQuotaCallbacks::didFail is called with an // error code. // The callbacks object is deleted when the callback method is called // and does not need to be (and should not be) deleted manually. virtual void queryStorageUsageAndQuota( WebFrame*, WebStorageQuotaType, WebStorageQuotaCallbacks*) { } // Requests a new quota size for the origin's storage. // |newQuotaInBytes| indicates how much storage space (in bytes) the // caller expects to need. // WebStorageQuotaCallbacks::didGrantStorageQuota will be called when // a new quota is granted. WebStorageQuotaCallbacks::didFail // is called with an error code otherwise. // Note that the requesting quota size may not always be granted and // a smaller amount of quota than requested might be returned. // The callbacks object is deleted when the callback method is called // and does not need to be (and should not be) deleted manually. virtual void requestStorageQuota( WebFrame*, WebStorageQuotaType, unsigned long long newQuotaInBytes, WebStorageQuotaCallbacks*) { } protected: ~WebFrameClient() { } }; } // namespace WebKit #endif