1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
// 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_MEDIA_ROUTER_BROWSER_MEDIA_SINKS_OBSERVER_H_
#define COMPONENTS_MEDIA_ROUTER_BROWSER_MEDIA_SINKS_OBSERVER_H_
#include <optional>
#include <vector>
#include "base/memory/raw_ptr.h"
#include "components/media_router/common/media_sink.h"
#include "components/media_router/common/media_source.h"
#include "url/origin.h"
namespace media_router {
class MediaRouter;
// Base class for observing when the collection of sinks compatible with
// a MediaSource has been updated.
// A MediaSinksObserver implementation can be registered to MediaRouter to
// receive results. It can then interpret / process the results accordingly.
// More documentation can be found at
// docs.google.com/document/d/1RDXdzi2y7lRuL08HAe-qlSJG2DMz2iH3gBzMs0IRR78
class MediaSinksObserver {
public:
// Constructs an observer from |origin| that will observe for sinks compatible
// with |source|.
MediaSinksObserver(MediaRouter* router,
const MediaSource& source,
const url::Origin& origin);
// Constructs an observer for all sinks known to |router|.
// NOTE: Not all Media Route Providers support sink queries with an empty
// source, so the returned sink list may be incomplete.
// TODO(crbug.com/40613044): Fix this.
explicit MediaSinksObserver(MediaRouter* router);
MediaSinksObserver(const MediaSinksObserver&) = delete;
MediaSinksObserver& operator=(const MediaSinksObserver&) = delete;
virtual ~MediaSinksObserver();
// Registers with MediaRouter to start observing. Must be called before the
// observer will start receiving updates. Returns |true| if the observer is
// initialized. This method is no-op if the observer is already initialized.
bool Init();
// This function is invoked when the list of sinks compatible with |source_|
// has been updated, unless |source_| is nullopt, in which case it is invoked
// with all sinks. The result also contains the list of valid origins.
// If |origins| is empty or contains |origin_|, then |OnSinksReceived(sinks)|
// will be invoked with |sinks|. Otherwise, it will be invoked with an empty
// list.
// Marked virtual for tests.
virtual void OnSinksUpdated(const std::vector<MediaSink>& sinks,
const std::vector<url::Origin>& origins);
const std::optional<const MediaSource>& source() const { return source_; }
protected:
// This function is invoked from |OnSinksUpdated(sinks, origins)|.
// Implementations may not perform operations that modify the Media Router's
// observer list. In particular, invoking this observer's destructor within
// OnSinksReceived will result in undefined behavior.
virtual void OnSinksReceived(const std::vector<MediaSink>& sinks) = 0;
private:
const std::optional<const MediaSource> source_;
const url::Origin origin_;
const raw_ptr<MediaRouter> router_;
bool initialized_;
#if DCHECK_IS_ON()
bool in_on_sinks_updated_ = false;
#endif
};
} // namespace media_router
#endif // COMPONENTS_MEDIA_ROUTER_BROWSER_MEDIA_SINKS_OBSERVER_H_
|