// Copyright (c) 2012 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 CHROME_BROWSER_UI_TAB_CONTENTS_TAB_CONTENTS_H_ #define CHROME_BROWSER_UI_TAB_CONTENTS_TAB_CONTENTS_H_ #include "base/basictypes.h" #include "base/compiler_specific.h" #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "base/property_bag.h" #include "content/public/browser/web_contents_observer.h" class AlternateErrorPageTabObserver; class AutocompleteHistoryManager; class AutofillManager; class AutofillExternalDelegate; class AutomationTabHelper; class BlockedContentTabHelper; class BookmarkTabHelper; class ConstrainedWindowTabHelper; class CoreTabHelper; class ExternalProtocolObserver; class FaviconTabHelper; class FindTabHelper; class HistoryTabHelper; class HungPluginTabHelper; class InfoBarTabHelper; class MetroPinTabHelper; class OmniboxSearchHint; class PasswordManager; class PasswordManagerDelegate; class PDFTabObserver; class PluginObserver; class PrefsTabHelper; class Profile; class RestoreTabHelper; class SadTabHelper; class SearchEngineTabHelper; class SnapshotTabHelper; class TabContentsSSLHelper; class TabSpecificContentSettings; class ThumbnailGenerator; class TranslateTabHelper; class WebIntentPickerController; class ZoomController; #if defined(ENABLE_ONE_CLICK_SIGNIN) class OneClickSigninHelper; #endif namespace browser_sync { class SyncedTabDelegate; } namespace captive_portal { class CaptivePortalTabHelper; } namespace chrome { namespace search { class SearchTabHelper; } } namespace extensions { class TabHelper; class WebNavigationTabObserver; } namespace prerender { class PrerenderTabHelper; } namespace printing { class PrintViewManager; class PrintPreviewMessageHandler; } namespace safe_browsing { class SafeBrowsingTabObserver; } // Wraps WebContents and all of its supporting objects in order to control // their ownership and lifetime. // // WARNING: Not every place where HTML can run has a TabContents. This class is // *only* used in a visible, actual, tab inside a browser. Examples of things // that do not have a TabContents include: // - Extension background pages and popup bubbles // - HTML notification bubbles // - Screensavers on Chrome OS // - Other random places we decide to display HTML over time // // Consider carefully whether your feature is something that makes sense only // when a tab is displayed, or could make sense in other cases we use HTML. It // may makes sense to push down into WebContents and make configurable, or at // least to make easy for other WebContents hosts to include and support. class TabContents : public content::WebContentsObserver { public: // Takes ownership of |contents|, which must be heap-allocated (as it lives // in a scoped_ptr) and can not be NULL. explicit TabContents(content::WebContents* contents); virtual ~TabContents(); // Create a TabContents with the same state as this one. The returned // heap-allocated pointer is owned by the caller. TabContents* Clone(); // Helper to retrieve the existing instance that owns a given WebContents. // Returns NULL if there is no such existing instance. // NOTE: This is not intended for general use. It is intended for situations // like callbacks from content/ where only a WebContents is available. In the // general case, please do NOT use this; plumb TabContents through the chrome/ // code instead of WebContents. static TabContents* FromWebContents(content::WebContents* contents); static const TabContents* FromWebContents( const content::WebContents* contents); // Returns the WebContents that this owns. content::WebContents* web_contents() const; // Returns the Profile that is associated with this TabContents. Profile* profile() const; // True if this TabContents is being torn down. bool in_destructor() const { return in_destructor_; } // Tab Helpers --------------------------------------------------------------- AutocompleteHistoryManager* autocomplete_history_manager() { return autocomplete_history_manager_.get(); } AutofillManager* autofill_manager() { return autofill_manager_.get(); } // Used only for testing/automation. AutomationTabHelper* automation_tab_helper() { return automation_tab_helper_.get(); } BlockedContentTabHelper* blocked_content_tab_helper() { return blocked_content_tab_helper_.get(); } BookmarkTabHelper* bookmark_tab_helper() { return bookmark_tab_helper_.get(); } #if defined(ENABLE_CAPTIVE_PORTAL_DETECTION) captive_portal::CaptivePortalTabHelper* captive_portal_tab_helper() { return captive_portal_tab_helper_.get(); } #endif ConstrainedWindowTabHelper* constrained_window_tab_helper() { return constrained_window_tab_helper_.get(); } CoreTabHelper* core_tab_helper() { return core_tab_helper_.get(); } extensions::TabHelper* extension_tab_helper() { return extension_tab_helper_.get(); } const extensions::TabHelper* extension_tab_helper() const { return extension_tab_helper_.get(); } FaviconTabHelper* favicon_tab_helper() { return favicon_tab_helper_.get(); } FindTabHelper* find_tab_helper() { return find_tab_helper_.get(); } HistoryTabHelper* history_tab_helper() { return history_tab_helper_.get(); } HungPluginTabHelper* hung_plugin_tab_helper() { return hung_plugin_tab_helper_.get(); } InfoBarTabHelper* infobar_tab_helper() { return infobar_tab_helper_.get(); } MetroPinTabHelper* metro_pin_tab_helper() { return metro_pin_tab_helper_.get(); } #if defined(ENABLE_ONE_CLICK_SIGNIN) OneClickSigninHelper* one_click_signin_helper() { return one_click_signin_helper_.get(); } #endif PasswordManager* password_manager() { return password_manager_.get(); } PrefsTabHelper* prefs_tab_helper() { return prefs_tab_helper_.get(); } prerender::PrerenderTabHelper* prerender_tab_helper() { return prerender_tab_helper_.get(); } printing::PrintViewManager* print_view_manager() { return print_view_manager_.get(); } RestoreTabHelper* restore_tab_helper() { return restore_tab_helper_.get(); } const RestoreTabHelper* restore_tab_helper() const { return restore_tab_helper_.get(); } SadTabHelper* sad_tab_helper() { return sad_tab_helper_.get(); } SearchEngineTabHelper* search_engine_tab_helper() { return search_engine_tab_helper_.get(); } chrome::search::SearchTabHelper* search_tab_helper() { return search_tab_helper_.get(); } SnapshotTabHelper* snapshot_tab_helper() { return snapshot_tab_helper_.get(); } TabContentsSSLHelper* ssl_helper() { return ssl_helper_.get(); } browser_sync::SyncedTabDelegate* synced_tab_delegate() { return synced_tab_delegate_.get(); } TabSpecificContentSettings* content_settings() { return content_settings_.get(); } // NOTE: This returns NULL unless in-browser thumbnail generation is enabled. ThumbnailGenerator* thumbnail_generator() { return thumbnail_generator_.get(); } TranslateTabHelper* translate_tab_helper() { return translate_tab_helper_.get(); } WebIntentPickerController* web_intent_picker_controller() { return web_intent_picker_controller_.get(); } ZoomController* zoom_controller() { return zoom_controller_.get(); } // Overrides ----------------------------------------------------------------- // content::WebContentsObserver overrides: virtual void WebContentsDestroyed(content::WebContents* tab) OVERRIDE; private: // Used to retrieve this object from |web_contents_|, which is placed in // its property bag to avoid adding additional interfaces. static base::PropertyAccessor* property_accessor(); // Tab Helpers --------------------------------------------------------------- // (These provide API for callers and have a getter function listed in the // "Tab Helpers" section in the member functions area, above.) scoped_ptr autocomplete_history_manager_; scoped_refptr autofill_manager_; scoped_ptr autofill_external_delegate_; scoped_ptr automation_tab_helper_; scoped_ptr blocked_content_tab_helper_; scoped_ptr bookmark_tab_helper_; #if defined(ENABLE_CAPTIVE_PORTAL_DETECTION) scoped_ptr captive_portal_tab_helper_; #endif scoped_ptr constrained_window_tab_helper_; scoped_ptr core_tab_helper_; scoped_ptr extension_tab_helper_; scoped_ptr favicon_tab_helper_; scoped_ptr find_tab_helper_; scoped_ptr history_tab_helper_; scoped_ptr hung_plugin_tab_helper_; scoped_ptr infobar_tab_helper_; scoped_ptr metro_pin_tab_helper_; // PasswordManager and its delegate. The delegate must outlive the manager, // per documentation in password_manager.h. scoped_ptr password_manager_delegate_; scoped_ptr password_manager_; scoped_ptr prefs_tab_helper_; scoped_ptr prerender_tab_helper_; // Handles print job for this contents. scoped_ptr print_view_manager_; scoped_ptr restore_tab_helper_; scoped_ptr sad_tab_helper_; scoped_ptr search_engine_tab_helper_; scoped_ptr search_tab_helper_; scoped_ptr snapshot_tab_helper_; scoped_ptr ssl_helper_; scoped_ptr synced_tab_delegate_; // The TabSpecificContentSettings object is used to query the blocked content // state by various UI elements. scoped_ptr content_settings_; scoped_ptr thumbnail_generator_; scoped_ptr translate_tab_helper_; // Handles displaying a web intents picker to the user. scoped_ptr web_intent_picker_controller_; scoped_ptr zoom_controller_; // Per-tab observers --------------------------------------------------------- // (These provide no API for callers; objects that need to exist 1:1 with tabs // and silently do their thing live here.) scoped_ptr alternate_error_page_tab_observer_; scoped_ptr webnavigation_observer_; scoped_ptr external_protocol_observer_; scoped_ptr omnibox_search_hint_; #if defined(ENABLE_ONE_CLICK_SIGNIN) scoped_ptr one_click_signin_helper_; #endif scoped_ptr pdf_tab_observer_; scoped_ptr plugin_observer_; scoped_ptr print_preview_; scoped_ptr safe_browsing_tab_observer_; // WebContents (MUST BE LAST) ------------------------------------------------ // If true, we're running the destructor. bool in_destructor_; // The supporting objects need to outlive the WebContents dtor (as they may // be called upon during its execution). As a result, this must come last // in the list. scoped_ptr web_contents_; DISALLOW_COPY_AND_ASSIGN(TabContents); }; #endif // CHROME_BROWSER_UI_TAB_CONTENTS_TAB_CONTENTS_H_