chromium/components/gcm_driver/gcm_stats_recorder_android.h

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

#ifndef COMPONENTS_GCM_DRIVER_GCM_STATS_RECORDER_ANDROID_H_
#define COMPONENTS_GCM_DRIVER_GCM_STATS_RECORDER_ANDROID_H_

#include <string>

#include "base/containers/circular_deque.h"
#include "base/memory/raw_ptr.h"
#include "components/gcm_driver/gcm_activity.h"

namespace gcm {

enum class GCMDecryptionResult;

// Stats recorder for Android, used for recording stats and activities on the
// GCM Driver level for debugging purposes. Based on the GCMStatsRecorder, as
// defined in the GCM Engine, which does not exist on Android.
//
// Note that this class, different from the GCMStatsRecorder(Impl), is expected
// to be used on the UI thread.
class GCMStatsRecorderAndroid {
 public:
  // A delegate interface that allows the GCMStatsRecorderAndroid instance to
  // interact with its container.
  class Delegate {
   public:
    // Called when the GCMStatsRecorderAndroid is recording activities and a new
    // activity has just been recorded.
    virtual void OnActivityRecorded() = 0;
  };

  // A weak reference to |delegate| is stored, so it must outlive the recorder.
  explicit GCMStatsRecorderAndroid(Delegate* delegate);

  GCMStatsRecorderAndroid(const GCMStatsRecorderAndroid&) = delete;
  GCMStatsRecorderAndroid& operator=(const GCMStatsRecorderAndroid&) = delete;

  ~GCMStatsRecorderAndroid();

  // Clears the recorded activities.
  void Clear();

  // Collects all recorded activities into |*recorded_activities|.
  void CollectActivities(RecordedActivities* recorded_activities) const;

  // Records that a registration for |app_id| has been sent.
  void RecordRegistrationSent(const std::string& app_id);

  // Records that the registration sent for |app_id| has received a response.
  // |success| indicates whether the registration was successful.
  void RecordRegistrationResponse(const std::string& app_id, bool success);

  // Records that an unregistration for |app_id| has been sent.
  void RecordUnregistrationSent(const std::string& app_id);

  // Records that the unregistration sent for |app_id| has received a response.
  // |success| indicates whether the unregistration was successful.
  void RecordUnregistrationResponse(const std::string& app_id, bool success);

  // Records that a data message has been received for |app_id|.
  void RecordDataMessageReceived(const std::string& app_id,
                                 const std::string& from,
                                 int message_byte_size);

  // Records a message decryption failure caused by |result| for |app_id|.
  void RecordDecryptionFailure(const std::string& app_id,
                               GCMDecryptionResult result);

  bool is_recording() const { return is_recording_; }
  void set_is_recording(bool recording) { is_recording_ = recording; }

 private:
  void RecordRegistration(const std::string& app_id,
                          const std::string& event,
                          const std::string& details);

  // Delegate made available by the container. May be a nullptr.
  raw_ptr<Delegate> delegate_;

  // Toggle determining whether the recorder is recording.
  bool is_recording_ = false;

  // Recorded registration activities (which includes unregistrations).
  base::circular_deque<RegistrationActivity> registration_activities_;

  // Recorded received message activities.
  base::circular_deque<ReceivingActivity> receiving_activities_;

  // Recorded message decryption failure activities.
  base::circular_deque<DecryptionFailureActivity>
      decryption_failure_activities_;
};

}  // namespace gcm

#endif  // COMPONENTS_GCM_DRIVER_GCM_STATS_RECORDER_ANDROID_H_