1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_REQUESTER_H_
6 #define CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_REQUESTER_H_
10 #include "content/common/content_export.h"
11 #include "content/common/media/media_stream_options.h"
15 // MediaStreamRequester must be implemented by the class requesting a new media
16 // stream to be opened. MediaStreamManager will use this interface to signal
17 // success and error for a request.
18 class CONTENT_EXPORT MediaStreamRequester
{
20 // Called as a reply of a successful call to GenerateStream.
21 virtual void StreamGenerated(const std::string
& label
,
22 const StreamDeviceInfoArray
& audio_devices
,
23 const StreamDeviceInfoArray
& video_devices
) = 0;
24 // Called if GenerateStream failed.
25 virtual void StreamGenerationFailed(const std::string
& label
) = 0;
27 // Called if a device has been stopped by a user from UI or the device
28 // has become unavailable. |render_view_id| is the render view that requested
29 // the device and |label| is the label of the request|.
30 virtual void DeviceStopped(int render_view_id
,
31 const std::string
& label
,
32 const StreamDeviceInfo
& device
) = 0;
34 // Called as a reply of a successful call to EnumerateDevices.
35 virtual void DevicesEnumerated(const std::string
& label
,
36 const StreamDeviceInfoArray
& devices
) = 0;
37 // Called as a reply of a successful call to OpenDevice.
38 virtual void DeviceOpened(const std::string
& label
,
39 const StreamDeviceInfo
& device_info
) = 0;
42 virtual ~MediaStreamRequester() {
46 } // namespace content
48 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_REQUESTER_H_