chromium/chromeos/ash/components/scalable_iph/iph_session.h

// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROMEOS_ASH_COMPONENTS_SCALABLE_IPH_IPH_SESSION_H_
#define CHROMEOS_ASH_COMPONENTS_SCALABLE_IPH_IPH_SESSION_H_

#include "base/feature_list.h"
#include "base/memory/raw_ref.h"
#include "chromeos/ash/components/scalable_iph/scalable_iph_constants.h"
#include "components/feature_engagement/public/tracker.h"

namespace scalable_iph {

// `IphSession` manages a single IPH session. An IPH UI is responsible to
// destroy this object once it stops showing the IPH. UI code should interact
// with ScalableIph framework via `IphSession` object which is passed from the
// service. UI code should not query/interact directly with `ScalableIph` keyed
// service.
class IphSession {
 public:
  class Delegate {
   public:
    virtual void PerformActionForIphSession(ActionType action_type) = 0;
  };

  IphSession(const base::Feature& feature,
             feature_engagement::Tracker* tracker,
             Delegate* delegate);
  ~IphSession();

  IphSession(const IphSession& iph_session) = delete;
  IphSession& operator=(const IphSession& iph_session) = delete;

  // Perform `action_type` as a result of a user action. This records a
  // corresponding IPH `event_name` to the feature engagement framework.
  void PerformAction(ActionType action_type, const std::string& event_name);

 private:
  // This is an IPH feature which is tied to this IPH session. See
  // //components/feature_engagement/README.md for details about an IPH feature.
  const raw_ref<const base::Feature> feature_;
  const raw_ptr<feature_engagement::Tracker> tracker_;
  const raw_ptr<Delegate> delegate_;
};

}  // namespace scalable_iph

#endif  // CHROMEOS_ASH_COMPONENTS_SCALABLE_IPH_IPH_SESSION_H_