summaryrefslogtreecommitdiffstats
path: root/chrome/browser/blocked_popup_container.h
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/blocked_popup_container.h')
-rw-r--r--chrome/browser/blocked_popup_container.h258
1 files changed, 258 insertions, 0 deletions
diff --git a/chrome/browser/blocked_popup_container.h b/chrome/browser/blocked_popup_container.h
new file mode 100644
index 0000000..f9b5d14
--- /dev/null
+++ b/chrome/browser/blocked_popup_container.h
@@ -0,0 +1,258 @@
+// Copyright (c) 2009 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.
+
+// Defines the public interface for the blocked popup notifications. This
+// interface should only be used by TabContents. Users and subclasses of
+// TabContents should use the appropriate methods on TabContents to access
+// information about blocked popups.
+
+#ifndef CHROME_BROWSER_BLOCKED_POPUP_CONTAINER_H_
+#define CHROME_BROWSER_BLOCKED_POPUP_CONTAINER_H_
+
+#include <map>
+#include <set>
+
+#include "base/gfx/native_widget_types.h"
+#include "base/gfx/rect.h"
+#include "chrome/browser/tab_contents/constrained_window.h"
+#include "chrome/browser/tab_contents/tab_contents_delegate.h"
+#include "chrome/common/notification_registrar.h"
+
+class BlockedPopupContainerImpl;
+class PrefService;
+class Profile;
+class TabContents;
+
+// Takes ownership of TabContents that are unrequested popup windows and
+// presents an interface to the user for launching them. (Or never showing them
+// again). This class contains all the cross-platform bits that can be used in
+// all ports.
+//
+// Currently, BlockedPopupContainer only exists as a cross platform model
+// extracted from browser/views/blocked_popup_container.cc. This is what it
+// used to look like before:
+//
+// +- BlockedPopupContainer -------------------------------+
+// | <views::WidgetWin> |
+// | All model logic. |
+// | All views code. |
+// +-------------------------------------------------------+
+//
+// As of now, it looks like this:
+//
+// +- BlockedPopupContainer -------------------------------+
+// | All model logic |
+// +-------------------------------------------------------+
+// ^
+// |
+// +- BlockedPopupContainerImpl ---------------------------+
+// | views::WidgetWin |
+// | All views code. |
+// | |
+// +-------------------------------------------------------+
+//
+// TODO(erg): While it is not in this state yet, I want it to look like this:
+//
+// +- BlockedPopupContainer ---+ +- BlockedPopupContainerView -----+
+// | All model logic | +--->| Abstract cross platform |
+// | | | | interface |
+// | | | | |
+// | Owns a platform view_ +----+ | |
+// +---------------------------+ +---------------------------------+
+// ^
+// |
+// +-------------------------------+-----------+
+// | |
+// +- BPCViewGtk -----------+ +- BPCViewWin ----------------------+
+// | Gtk UI | | Views UI |
+// | | | |
+// +------------------------+ +-----------------------------------+
+//
+// Getting here will take multiple patches.
+class BlockedPopupContainer : public TabContentsDelegate,
+ public NotificationObserver {
+ public:
+ // Creates a BlockedPopupContainer, anchoring the container to the lower
+ // right corner.
+ static BlockedPopupContainer* Create(
+ TabContents* owner, Profile* profile, const gfx::Point& initial_anchor);
+
+ static void RegisterUserPrefs(PrefService* prefs);
+
+ // Adds a popup to this container. |bounds| are the window bounds requested by
+ // the popup window.
+ void AddTabContents(TabContents* tab_contents,
+ const gfx::Rect& bounds,
+ const std::string& host);
+
+ // Shows the blocked popup at index |index|.
+ void LaunchPopupAtIndex(size_t index);
+
+ // Returns the number of blocked popups
+ size_t GetBlockedPopupCount() const;
+
+ // Returns true if host |index| is whitelisted. Returns false if |index| is
+ // invalid.
+ bool IsHostWhitelisted(size_t index) const;
+
+ // If host |index| is currently whitelisted, un-whitelists it. Otherwise,
+ // whitelists it and opens all blocked popups from it.
+ void ToggleWhitelistingForHost(size_t index);
+
+ // Deletes all popups and hides the interface parts.
+ void CloseAll();
+
+ // Sets this object up to delete itself.
+ virtual void Destroy() = 0;
+
+ // Message called when a BlockedPopupContainer should move itself to the
+ // bottom right corner of |view|.
+ virtual void RepositionBlockedPopupContainer(gfx::NativeView view) = 0;
+
+ // Called to force this container to never show itself again.
+ void set_dismissed() { has_been_dismissed_ = true; }
+
+ // Overridden from TabContentsDelegate:
+
+ // Forwards OpenURLFromTab to our |owner_|.
+ virtual void OpenURLFromTab(TabContents* source,
+ const GURL& url, const GURL& referrer,
+ WindowOpenDisposition disposition,
+ PageTransition::Type transition);
+
+ // Ignored; BlockedPopupContainer doesn't display a throbber.
+ virtual void NavigationStateChanged(const TabContents* source,
+ unsigned changed_flags) { }
+
+ // Forwards AddNewContents to our |owner_|.
+ virtual void AddNewContents(TabContents* source,
+ TabContents* new_contents,
+ WindowOpenDisposition disposition,
+ const gfx::Rect& initial_position,
+ bool user_gesture);
+
+ // Ignore activation requests from the TabContents we're blocking.
+ virtual void ActivateContents(TabContents* contents) { }
+
+ // Ignored; BlockedPopupContainer doesn't display a throbber.
+ virtual void LoadingStateChanged(TabContents* source) { }
+
+ // Removes |source| from our internal list of blocked popups.
+ virtual void CloseContents(TabContents* source);
+
+ // Changes the opening rectangle associated with |source|.
+ virtual void MoveContents(TabContents* source, const gfx::Rect& new_bounds);
+
+ // Always returns true.
+ virtual bool IsPopup(TabContents* source);
+
+ // Returns our |owner_|.
+ virtual TabContents* GetConstrainingContents(TabContents* source);
+
+ // Ignored; BlockedPopupContainer doesn't display a toolbar.
+ virtual void ToolbarSizeChanged(TabContents* source, bool is_animating) { }
+
+ // Ignored; BlockedPopupContainer doesn't display a bookmarking star.
+ virtual void URLStarredChanged(TabContents* source, bool starred) { }
+
+ // Ignored; BlockedPopupContainer doesn't display a URL bar.
+ virtual void UpdateTargetURL(TabContents* source, const GURL& url) { }
+
+ // Creates an ExtensionFunctionDispatcher that has no browser
+ virtual ExtensionFunctionDispatcher* CreateExtensionFunctionDispatcher(
+ RenderViewHost* render_view_host,
+ const std::string& extension_id);
+
+ // A number larger than the internal popup count on the Renderer; meant for
+ // preventing a compromised renderer from exhausting GDI memory by spawning
+ // infinite windows.
+ static const size_t kImpossibleNumberOfPopups = 30;
+
+ protected:
+ struct BlockedPopup {
+ BlockedPopup(TabContents* tab_contents,
+ const gfx::Rect& bounds,
+ const std::string& host)
+ : tab_contents(tab_contents), bounds(bounds), host(host) {
+ }
+
+ TabContents* tab_contents;
+ gfx::Rect bounds;
+ std::string host;
+ };
+ typedef std::vector<BlockedPopup> BlockedPopups;
+
+ // TabContents is the popup contents. string is opener hostname.
+ typedef std::map<TabContents*, std::string> UnblockedPopups;
+
+ // string is hostname. bool is whitelisted status.
+ typedef std::map<std::string, bool> PopupHosts;
+
+ // Shows the UI.
+ virtual void ShowSelf() = 0;
+
+ // Hides the UI portion of the container.
+ virtual void HideSelf();
+
+ // Updates the text on the label on the notification.
+ virtual void UpdateLabel() = 0;
+
+ // Deletes all local state.
+ virtual void ClearData();
+
+ // Helper function to convert a host index (which the view uses) into an
+ // iterator into |popup_hosts_|. Returns popup_hosts_.end() if |index| is
+ // invalid.
+ PopupHosts::const_iterator ConvertHostIndexToIterator(size_t index) const;
+
+ // Removes the popup at |i| from the blocked popup list. If this popup's host
+ // is not otherwised referenced on either popup list, removes the host from
+ // the host list. Updates the view's label to match the new state.
+ void EraseDataForPopupAndUpdateUI(BlockedPopups::iterator i);
+
+ // Same as above, but works on the unblocked popup list.
+ void EraseDataForPopupAndUpdateUI(UnblockedPopups::iterator i);
+
+ private:
+ friend class BlockedPopupContainerImpl;
+
+ // string is hostname.
+ typedef std::set<std::string> Whitelist;
+
+ // Creates a container for a certain TabContents:
+ BlockedPopupContainer(TabContents* owner, PrefService* prefs);
+
+ // Overridden from notificationObserver:
+ virtual void Observe(NotificationType type,
+ const NotificationSource& source,
+ const NotificationDetails& details);
+
+ // The TabContents that owns and constrains this BlockedPopupContainer.
+ TabContents* owner_;
+
+ // The PrefService we can query to find out what's on the whitelist.
+ PrefService* prefs_;
+
+ // Once the container is hidden, this is set to prevent it from reappearing.
+ bool has_been_dismissed_;
+
+ // Registrar to handle notifications we care about.
+ NotificationRegistrar registrar_;
+
+ // The whitelisted hosts, which we allow to open popups directly.
+ Whitelist whitelist_;
+
+ // Information about all blocked popups.
+ BlockedPopups blocked_popups_;
+
+ // Information about all unblocked popups.
+ UnblockedPopups unblocked_popups_;
+
+ // Information about all popup hosts.
+ PopupHosts popup_hosts_;
+
+ DISALLOW_IMPLICIT_CONSTRUCTORS(BlockedPopupContainer);
+};
+
+#endif // CHROME_BROWSER_BLOCKED_POPUP_CONTAINER_H_