blob: a48d58cc2d89056c9eecb4a1dcf3f80bbb0c3b26 [file] [log] [blame]
// Copyright 2021 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_USER_EDUCATION_USER_EDUCATION_SERVICE_H_
#define CHROME_BROWSER_USER_EDUCATION_USER_EDUCATION_SERVICE_H_
#include <memory>
#include "base/feature_list.h"
#include "base/memory/raw_ref.h"
#include "base/types/pass_key.h"
#include "chrome/browser/user_education/browser_tutorial_service.h"
#include "chrome/browser/user_education/browser_user_education_storage_service.h"
#include "chrome/browser/user_education/recent_session_observer.h"
#include "chrome/browser/user_education/recent_session_tracker.h"
#include "components/keyed_service/core/keyed_service.h"
#include "components/user_education/common/feature_promo/feature_promo_controller.h"
#include "components/user_education/common/feature_promo/feature_promo_registry.h"
#include "components/user_education/common/feature_promo/feature_promo_session_policy.h"
#include "components/user_education/common/help_bubble/help_bubble_factory_registry.h"
#include "components/user_education/common/new_badge/new_badge_controller.h"
#include "components/user_education/common/ntp_promo/ntp_promo_controller.h"
#include "components/user_education/common/ntp_promo/ntp_promo_registry.h"
#include "components/user_education/common/product_messaging_controller.h"
#include "components/user_education/common/session/user_education_session_manager.h"
#include "components/user_education/common/tutorial/tutorial.h"
#include "components/user_education/common/tutorial/tutorial_registry.h"
#include "components/user_education/common/user_education_storage_service.h"
#include "content/public/browser/browser_context.h"
// Kill switch for recent session tracking. Enabled by default.
BASE_DECLARE_FEATURE(kAllowRecentSessionTracking);
class BrowserHelpBubble;
class BrowserUserEducationInterfaceImpl;
class ToolbarButtonMenuHighlighter;
class UserEducationInternalsPageHandlerImpl;
namespace web_app {
class WebAppUiManagerImpl;
}
class UserEducationService : public KeyedService {
public:
explicit UserEducationService(Profile* profile, bool allows_promos);
~UserEducationService() override;
user_education::TutorialRegistry& tutorial_registry() {
return tutorial_registry_;
}
user_education::TutorialService& tutorial_service() {
return tutorial_service_;
}
user_education::HelpBubbleFactoryRegistry& help_bubble_factory_registry() {
return help_bubble_factory_registry_;
}
user_education::FeaturePromoRegistry& feature_promo_registry() {
return feature_promo_registry_;
}
user_education::ProductMessagingController& product_messaging_controller() {
return product_messaging_controller_;
}
user_education::UserEducationStorageService&
user_education_storage_service() {
return *user_education_storage_service_;
}
user_education::UserEducationSessionManager&
user_education_session_manager() {
return user_education_session_manager_;
}
user_education::FeaturePromoSessionPolicy& feature_promo_session_policy() {
return *feature_promo_session_policy_;
}
user_education::NewBadgeRegistry* new_badge_registry() {
return new_badge_registry_.get();
}
user_education::NewBadgeController* new_badge_controller() {
return new_badge_controller_.get();
}
RecentSessionTracker* recent_session_tracker() {
return recent_session_tracker_.get();
}
RecentSessionObserver* recent_session_observer() {
return recent_session_observer_.get();
}
user_education::NtpPromoRegistry* ntp_promo_registry() {
return ntp_promo_registry_.get();
}
user_education::NtpPromoController* ntp_promo_controller() {
return ntp_promo_controller_.get();
}
Profile& profile() { return *profile_; }
// Only a limited number of non-test classes are allowed direct access to the
// feature promo controller.
template <typename T>
requires std::same_as<T, BrowserHelpBubble> ||
std::same_as<T, BrowserUserEducationInterfaceImpl> ||
std::same_as<T, ToolbarButtonMenuHighlighter> ||
std::same_as<T, UserEducationInternalsPageHandlerImpl> ||
std::same_as<T, web_app::WebAppUiManagerImpl>
const user_education::FeaturePromoController* GetFeaturePromoController(
base::PassKey<T>) const {
return feature_promo_controller_.get();
}
template <typename T>
user_education::FeaturePromoController* GetFeaturePromoController(
base::PassKey<T> key) {
return const_cast<user_education::FeaturePromoController*>(
const_cast<const UserEducationService*>(this)
->GetFeaturePromoController(std::move(key)));
}
user_education::FeaturePromoController*
GetFeaturePromoControllerForTesting() {
return feature_promo_controller_.get();
}
// Sets the promo controller (typically for setting a mock).
// Note: in the vast majority of cases you probably want to mock
// BrowserUserEducationInterface, since that's the API most production code
// actually uses.
void SetFeaturePromoControllerForTesting(
std::unique_ptr<user_education::FeaturePromoController>
feature_promo_controller) {
feature_promo_controller_ = std::move(feature_promo_controller);
}
// KeyedService:
void Shutdown() override;
// Utility methods for when a browser [window] isn't available; for example,
// when only a WebContents is available:
// Checks if a "New" Badge should be shown for the given `context` (or
// profile), for `feature`.
static user_education::DisplayNewBadge MaybeShowNewBadge(
content::BrowserContext* context,
const base::Feature& feature);
// Notifies that a feature associated with a "New" Badge was used in `context`
// (or profile), if the context supports User Education.
static void MaybeNotifyNewBadgeFeatureUsed(content::BrowserContext* context,
const base::Feature& feature);
private:
friend class UserEducationServiceFactory;
const raw_ref<Profile> profile_;
user_education::TutorialRegistry tutorial_registry_;
user_education::HelpBubbleFactoryRegistry help_bubble_factory_registry_;
user_education::FeaturePromoRegistry feature_promo_registry_;
BrowserTutorialService tutorial_service_;
std::unique_ptr<BrowserUserEducationStorageService>
user_education_storage_service_;
user_education::UserEducationSessionManager user_education_session_manager_;
std::unique_ptr<user_education::FeaturePromoSessionPolicy>
feature_promo_session_policy_;
user_education::ProductMessagingController product_messaging_controller_;
std::unique_ptr<user_education::NewBadgeRegistry> new_badge_registry_;
std::unique_ptr<user_education::NewBadgeController> new_badge_controller_;
std::unique_ptr<RecentSessionTracker> recent_session_tracker_;
std::unique_ptr<RecentSessionObserver> recent_session_observer_;
std::unique_ptr<user_education::NtpPromoRegistry> ntp_promo_registry_;
std::unique_ptr<user_education::NtpPromoController> ntp_promo_controller_;
std::unique_ptr<user_education::FeaturePromoController>
feature_promo_controller_;
};
#endif // CHROME_BROWSER_USER_EDUCATION_USER_EDUCATION_SERVICE_H_