blob: 2f5b8765c36a1a8c70125674f22dea139c894dfc [file] [log] [blame]
hbos74e1a4f2016-09-15 23:33:01 -07001/*
2 * Copyright 2016 The WebRTC Project Authors. All rights reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Steve Anton10542f22019-01-11 09:11:00 -080011#ifndef API_STATS_RTC_STATS_REPORT_H_
12#define API_STATS_RTC_STATS_REPORT_H_
hbos74e1a4f2016-09-15 23:33:01 -070013
Yves Gerey3e707812018-11-28 16:47:49 +010014#include <stddef.h>
15#include <stdint.h>
hbos74e1a4f2016-09-15 23:33:01 -070016#include <map>
17#include <memory>
18#include <string>
19#include <vector>
20
Mirko Bonadeid9708072019-01-25 20:26:48 +010021#include "api/scoped_refptr.h"
Steve Anton10542f22019-01-11 09:11:00 -080022#include "api/stats/rtc_stats.h"
23#include "rtc_base/ref_count.h"
24#include "rtc_base/ref_counted_object.h"
Mirko Bonadei3b56ee72018-10-15 17:15:12 +020025#include "rtc_base/system/rtc_export.h"
hbos74e1a4f2016-09-15 23:33:01 -070026
27namespace webrtc {
28
29// A collection of stats.
30// This is accessible as a map from |RTCStats::id| to |RTCStats|.
Mirko Bonadei3b56ee72018-10-15 17:15:12 +020031class RTC_EXPORT RTCStatsReport : public rtc::RefCountInterface {
hbos74e1a4f2016-09-15 23:33:01 -070032 public:
33 typedef std::map<std::string, std::unique_ptr<const RTCStats>> StatsMap;
34
35 class ConstIterator {
36 public:
37 ConstIterator(const ConstIterator&& other);
38 ~ConstIterator();
39
40 ConstIterator& operator++();
41 ConstIterator& operator++(int);
42 const RTCStats& operator*() const;
hbos6ded1902016-11-01 01:50:46 -070043 const RTCStats* operator->() const;
hbos74e1a4f2016-09-15 23:33:01 -070044 bool operator==(const ConstIterator& other) const;
45 bool operator!=(const ConstIterator& other) const;
46
47 private:
48 friend class RTCStatsReport;
49 ConstIterator(const rtc::scoped_refptr<const RTCStatsReport>& report,
50 StatsMap::const_iterator it);
51
52 // Reference report to make sure it is kept alive.
53 rtc::scoped_refptr<const RTCStatsReport> report_;
54 StatsMap::const_iterator it_;
55 };
56
hbos6ded1902016-11-01 01:50:46 -070057 // TODO(hbos): Remove "= 0" once Chromium unittest has been updated to call
58 // with a parameter. crbug.com/627816
nissedeb95f32016-11-28 01:54:54 -080059 static rtc::scoped_refptr<RTCStatsReport> Create(int64_t timestamp_us = 0);
hbos74e1a4f2016-09-15 23:33:01 -070060
nissedeb95f32016-11-28 01:54:54 -080061 explicit RTCStatsReport(int64_t timestamp_us);
hbos74e1a4f2016-09-15 23:33:01 -070062 RTCStatsReport(const RTCStatsReport& other) = delete;
Henrik Boström5b3541f2018-03-19 13:52:56 +010063 rtc::scoped_refptr<RTCStatsReport> Copy() const;
hbos74e1a4f2016-09-15 23:33:01 -070064
nissedeb95f32016-11-28 01:54:54 -080065 int64_t timestamp_us() const { return timestamp_us_; }
hbos02d2a922016-12-21 01:29:05 -080066 void AddStats(std::unique_ptr<const RTCStats> stats);
hbos74e1a4f2016-09-15 23:33:01 -070067 const RTCStats* Get(const std::string& id) const;
68 size_t size() const { return stats_.size(); }
69
Steve Antonffa6ce42018-11-30 09:26:08 -080070 // Gets the stat object of type |T| by ID, where |T| is any class descending
71 // from |RTCStats|.
72 // Returns null if there is no stats object for the given ID or it is the
73 // wrong type.
74 template <typename T>
75 const T* GetAs(const std::string& id) const {
76 const RTCStats* stats = Get(id);
77 if (!stats || stats->type() != T::kType) {
78 return nullptr;
79 }
80 return &stats->cast_to<const T>();
81 }
82
Henrik Boströmb6199362018-03-12 10:27:55 +010083 // Removes the stats object from the report, returning ownership of it or null
84 // if there is no object with |id|.
85 std::unique_ptr<const RTCStats> Take(const std::string& id);
hbos74e1a4f2016-09-15 23:33:01 -070086 // Takes ownership of all the stats in |victim|, leaving it empty.
87 void TakeMembersFrom(rtc::scoped_refptr<RTCStatsReport> victim);
88
89 // Stats iterators. Stats are ordered lexicographically on |RTCStats::id|.
90 ConstIterator begin() const;
91 ConstIterator end() const;
92
93 // Gets the subset of stats that are of type |T|, where |T| is any class
94 // descending from |RTCStats|.
Yves Gerey665174f2018-06-19 15:03:05 +020095 template <typename T>
hbos74e1a4f2016-09-15 23:33:01 -070096 std::vector<const T*> GetStatsOfType() const {
97 std::vector<const T*> stats_of_type;
98 for (const RTCStats& stats : *this) {
99 if (stats.type() == T::kType)
100 stats_of_type.push_back(&stats.cast_to<const T>());
101 }
102 return stats_of_type;
103 }
104
ehmaldonado35a872c2017-07-28 07:29:12 -0700105 // Creates a JSON readable string representation of the report,
106 // listing all of its stats objects.
107 std::string ToJson() const;
hbos6ded1902016-11-01 01:50:46 -0700108
hbos74e1a4f2016-09-15 23:33:01 -0700109 friend class rtc::RefCountedObject<RTCStatsReport>;
110
111 private:
112 ~RTCStatsReport() override;
113
nissedeb95f32016-11-28 01:54:54 -0800114 int64_t timestamp_us_;
hbos74e1a4f2016-09-15 23:33:01 -0700115 StatsMap stats_;
116};
117
118} // namespace webrtc
119
Steve Anton10542f22019-01-11 09:11:00 -0800120#endif // API_STATS_RTC_STATS_REPORT_H_