blob: c476ad7c56721a2e3a3ddd0efa5e9187e023202b [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.
#ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_SOURCE_H_
#define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_SOURCE_H_
#include "base/callback.h"
#include "base/compiler_specific.h"
#include "base/logging.h"
#include "base/macros.h"
#include "base/threading/thread_checker.h"
#include "content/common/content_export.h"
#include "content/common/media/media_stream_options.h"
#include "third_party/WebKit/public/platform/WebMediaStreamSource.h"
namespace content {
class CONTENT_EXPORT MediaStreamSource
: NON_EXPORTED_BASE(public blink::WebMediaStreamSource::ExtraData) {
public:
typedef base::Callback<void(const blink::WebMediaStreamSource& source)>
SourceStoppedCallback;
typedef base::Callback<void(MediaStreamSource* source,
MediaStreamRequestResult result,
const blink::WebString& result_name)>
ConstraintsCallback;
// Source constraints key for
// http://dev.w3.org/2011/webrtc/editor/getusermedia.html.
static const char kSourceId[];
MediaStreamSource();
~MediaStreamSource() override;
// Returns device information about a source that has been created by a
// JavaScript call to GetUserMedia, e.g., a camera or microphone.
const StreamDeviceInfo& device_info() const {
return device_info_;
}
// Stops the source (by calling DoStopSource()). This runs the
// |stop_callback_| (if set), and then sets the
// WebMediaStreamSource::readyState to ended.
void StopSource();
// Sets the source's state to muted or to live.
void SetSourceMuted(bool is_muted);
// Sets device information about a source that has been created by a
// JavaScript call to GetUserMedia. F.E a camera or microphone.
void SetDeviceInfo(const StreamDeviceInfo& device_info);
// Sets a callback that will be triggered when StopSource is called.
void SetStopCallback(const SourceStoppedCallback& stop_callback);
// Clears the previously-set SourceStoppedCallback so that it will not be run
// in the future.
void ResetSourceStoppedCallback();
protected:
// Called when StopSource is called. It allows derived classes to implement
// its own Stop method.
virtual void DoStopSource() = 0;
private:
StreamDeviceInfo device_info_;
SourceStoppedCallback stop_callback_;
// In debug builds, check that all methods are being called on the main
// thread.
base::ThreadChecker thread_checker_;
DISALLOW_COPY_AND_ASSIGN(MediaStreamSource);
};
} // namespace content
#endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_SOURCE_H_