blob: aeed2325b5a4fe1853b9d91fd23d1181866d5141 [file] [log] [blame]
// Copyright 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.
#include <stdint.h>
#include <map>
#include <string>
#include "base/time/time.h"
#include "content/common/media/media_stream.mojom.h"
#include "mojo/public/cpp/bindings/binding_set.h"
namespace content {
// Responsible for logging metrics about audio and video track
// lifetimes. These are based on messages from the renderer that are
// sent when tracks are created and destroyed. Unfortunately we can't
// reliably log the lifetime metric in the renderer because that
// process may be destroyed at any time by the fast shutdown path (see
// RenderProcessHost::FastShutdownIfPossible).
// There is one instance of this class per render process.
// If the renderer process goes away without sending messages that
// tracks were removed, this class instead infers that the tracks were
// removed.
class MediaStreamTrackMetricsHost : public mojom::MediaStreamTrackMetricsHost {
explicit MediaStreamTrackMetricsHost();
~MediaStreamTrackMetricsHost() override;
void BindRequest(mojom::MediaStreamTrackMetricsHostRequest request);
void AddTrack(uint64_t id, bool is_audio, bool is_remote) override;
void RemoveTrack(uint64_t id) override;
// Information for a track we're keeping in |tracks_|. |is_audio|
// specifies whether it's an audio or video track, |is_remote|
// specifies whether it's remote (received over a PeerConnection) or
// local (sent over a PeerConnection). |timestamp| specifies when
// the track was connected.
struct TrackInfo {
bool is_audio;
bool is_remote;
base::TimeTicks timestamp;
void ReportDuration(const TrackInfo& info);
// Values are unique (per renderer) track IDs.
typedef std::map<uint64_t, TrackInfo> TrackMap;
TrackMap tracks_;
mojo::BindingSet<mojom::MediaStreamTrackMetricsHost> bindings_;
} // namespace content