blob: e6d2d349beb89422174052ab254aecdb517016af [file] [log] [blame]
// Copyright (c) 2014 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_USER_MANAGER_H_
#define CHROME_BROWSER_UI_USER_MANAGER_H_
#include "base/callback_forward.h"
#include "base/macros.h"
#include "chrome/browser/profiles/profile_window.h"
#include "components/signin/core/browser/signin_metrics.h"
#include "content/public/browser/web_contents_delegate.h"
namespace base {
class FilePath;
}
// Cross-platform methods for displaying the user manager.
class UserManager {
public:
// Shows the User Manager or re-activates an existing one, focusing the
// profile given by |profile_path_to_focus|; passing an empty base::FilePath
// focuses no user pod. Based on the value of |tutorial_mode|, a tutorial
// could be shown, in which case |profile_path_to_focus| is ignored. After a
// profile is opened, executes the |profile_open_action|.
static void Show(const base::FilePath& profile_path_to_focus,
profiles::UserManagerTutorialMode tutorial_mode,
profiles::UserManagerProfileSelected profile_open_action);
// Hides the User Manager.
static void Hide();
// Returns whether the User Manager is showing.
static bool IsShowing();
// To be called once the User Manager's contents are showing.
static void OnUserManagerShown();
// Add a callback that will be called when OnUserManagerShown is called.
static void AddOnUserManagerShownCallbackForTesting(
const base::Closure& callback);
// Shows a dialog where the user can re-authenticate the profile with the
// given |email|. This is called in the following scenarios:
// -From the user manager when a profile is locked and the user's password is
// detected to have been changed.
// -From the user manager when a custodian account needs to be
// reauthenticated.
// |reason| can be REASON_UNLOCK or REASON_REAUTHENTICATION to indicate
// whether this is a reauth or unlock scenario.
static void ShowReauthDialog(content::BrowserContext* browser_context,
const std::string& email,
signin_metrics::Reason reason);
// Hides the reauth dialog if it is showing.
static void HideReauthDialog();
// TODO(noms): Figure out if this size can be computed dynamically or adjusted
// for smaller screens.
static const int kWindowWidth = 800;
static const int kWindowHeight = 600;
// Dimensions of the reauth dialog displaying the old-style signin flow with
// the username and password challenge on the same form.
static const int kPasswordCombinedReauthDialogHeight = 440;
static const int kPasswordCombinedReauthDialogWidth = 360;
// Dimensions of the reauth dialog displaying the password-separated signin
// flow.
static const int kReauthDialogHeight = 512;
static const int kReauthDialogWidth = 448;
// Abstract base class for performing online reauthentication of profiles in
// the User Manager. It is concretely implemented in UserManagerMac and
// UserManagerView to specialize the closing of the UI's dialog widgets.
class BaseReauthDialogDelegate : public content::WebContentsDelegate {
public:
BaseReauthDialogDelegate();
// content::WebContentsDelegate:
bool HandleContextMenu(const content::ContextMenuParams& params) override;
// content::WebContentsDelegate:
void LoadingStateChanged(content::WebContents* source,
bool to_different_document) override;
private:
virtual void CloseReauthDialog() = 0;
// WebContents of the embedded WebView.
content::WebContents* guest_web_contents_;
DISALLOW_COPY_AND_ASSIGN(BaseReauthDialogDelegate);
};
private:
DISALLOW_COPY_AND_ASSIGN(UserManager);
};
#endif // CHROME_BROWSER_UI_USER_MANAGER_H_