blob: 45c181c81906ed79e43273230152b1138b074691 [file] [log] [blame]
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_EXTENSIONS_WINDOW_CONTROLLER_H_
#define CHROME_BROWSER_EXTENSIONS_WINDOW_CONTROLLER_H_
#include <stdint.h>
#include <memory>
#include <string>
#include <vector>
#include "base/memory/raw_ptr.h"
#include "base/values.h"
#include "chrome/common/extensions/api/tabs.h"
#include "chrome/common/extensions/api/windows.h"
#include "extensions/common/mojom/context_type.mojom-forward.h"
class Browser; // TODO(stevenjb) eliminate this dependency.
class GURL;
class Profile;
namespace content {
class WebContents;
}
namespace ui {
class BaseWindow;
}
namespace extensions {
class Extension;
// This API provides a way for the extension system to talk "up" to the
// enclosing window (the `Browser` object on desktop builds) without depending
// on the implementation details of the exact object.
//
// Subclasses must add/remove themselves from the WindowControllerList upon
// construction/destruction.
class WindowController {
public:
enum PopulateTabBehavior {
kPopulateTabs,
kDontPopulateTabs,
};
enum Reason {
REASON_NONE,
REASON_NOT_EDITABLE,
};
// A bitmask used as filter on window types.
using TypeFilter = uint32_t;
// Represents the lack of any window filter, implying
// IsVisibleToExtension will be used as non-filtered behavior.
static const TypeFilter kNoWindowFilter = 0;
// Returns a filter allowing all window types to be manipulated
// through the chrome.windows APIs.
static TypeFilter GetAllWindowFilter();
// Builds a filter out of a vector of window types.
static TypeFilter GetFilterFromWindowTypes(
const std::vector<api::windows::WindowType>& types);
static TypeFilter GetFilterFromWindowTypesValues(
const base::Value::List* types);
WindowController(ui::BaseWindow* window, Profile* profile);
WindowController(const WindowController&) = delete;
WindowController& operator=(const WindowController&) = delete;
virtual ~WindowController();
ui::BaseWindow* window() const { return window_; }
Profile* profile() const { return profile_; }
// Return an id uniquely identifying the window.
virtual int GetWindowId() const = 0;
// Return the type name for the window.
// TODO(devlin): Remove this in favor of the method on ExtensionTabUtil.
virtual std::string GetWindowTypeText() const = 0;
// Sets the window's fullscreen state. `extension_url` provides the url
// associated with the extension (used by FullscreenController).
virtual void SetFullscreenMode(bool is_fullscreen,
const GURL& extension_url) const = 0;
// Returns false if the window is in a state where closing the window is not
// permitted and sets `reason` if not NULL.
virtual bool CanClose(Reason* reason) const = 0;
// Returns a Browser if available. Defaults to returning NULL.
// TODO(stevenjb): Temporary workaround. Eliminate this.
virtual Browser* GetBrowser() const;
// Returns true if the window is in the process of being torn down. See
// Browser::is_delete_scheduled().
virtual bool IsDeleteScheduled() const = 0;
// Returns the WebContents associated with the active tab, if any. Returns
// null if there is no active tab.
virtual content::WebContents* GetActiveTab() const = 0;
// Returns true if this window has a tab strip that's currently editable or
// if there's no visible tab strip.
//
// During some animations and drags the tab strip won't be editable and
// extensions should not update it. Many callers should use
// ExtensionTabUtil::IsTabStripEditable() which will check *all* tab strips
// because some move operations span tab strips. This checking of all windows
// is why windows that don't have visible tab strips should still return true
// here: otherwise they will prevent some operations from happening that use
// the ExtensionTabUtil.
virtual bool HasEditableTabStrip() const = 0;
// Returns the number of tabs in this window.
virtual int GetTabCount() const = 0;
// Returns the web contents at the given tab index, or null if it's off the
// end of the tab strip.
virtual content::WebContents* GetWebContentsAt(int i) const = 0;
// Returns true if the window is visible to the tabs API, when used by the
// given `extension`.
// `allow_dev_tools_windows` indicates whether dev tools windows should be
// treated as visible.
// TODO(devlin): Remove include_dev_tools_windows.
virtual bool IsVisibleToTabsAPIForExtension(
const Extension* extension,
bool include_dev_tools_windows) const = 0;
// Returns true if the window type of the controller matches the `filter`.
bool MatchesFilter(TypeFilter filter) const;
// Notifies that a window's bounds are changed.
void NotifyWindowBoundsChanged();
// Creates a base::Value::Dict representing the window for the browser and
// scrubs any privacy-sensitive data that `extension` does not have access to.
// `populate_tab_behavior` determines whether tabs will be populated in the
// result. `context` is used to determine the ScrubTabBehavior for the
// populated tabs data.
// TODO(devlin): Convert this to a api::Windows::Window object.
virtual base::Value::Dict CreateWindowValueForExtension(
const Extension* extension,
PopulateTabBehavior populate_tab_behavior,
mojom::ContextType context) const = 0;
// Returns the JSON tab information for all tabs in this window. See the
// chrome.tabs.getAllInWindow() extensions API.
virtual base::Value::List CreateTabList(const Extension* extension,
mojom::ContextType context) const = 0;
// Open the extension's options page as instructed. Returns true if an options
// page was successfully opened (though it may not necessarily *load*, e.g. if
// the URL does not exist).
virtual bool OpenOptionsPage(const Extension* extension,
const GURL& url,
bool open_in_tab) = 0;
// Returns true if the Browser can report tabs to extensions. Example of
// Browsers which don't support tabs include apps and devtools.
virtual bool SupportsTabs() = 0;
private:
raw_ptr<ui::BaseWindow, DanglingUntriaged> window_;
raw_ptr<Profile, DanglingUntriaged> profile_;
};
} // namespace extensions
#endif // CHROME_BROWSER_EXTENSIONS_WINDOW_CONTROLLER_H_