diff options
Diffstat (limited to 'content/browser/renderer_host/media/media_stream_ui_proxy.h')
-rw-r--r-- | content/browser/renderer_host/media/media_stream_ui_proxy.h | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/content/browser/renderer_host/media/media_stream_ui_proxy.h b/content/browser/renderer_host/media/media_stream_ui_proxy.h new file mode 100644 index 0000000..b0e30c5 --- /dev/null +++ b/content/browser/renderer_host/media/media_stream_ui_proxy.h @@ -0,0 +1,73 @@ +// Copyright 2013 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_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_UI_PROXY_H_ +#define CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_UI_PROXY_H_ + +#include "base/basictypes.h" +#include "base/callback.h" +#include "base/memory/scoped_ptr.h" +#include "base/memory/weak_ptr.h" +#include "content/public/common/media_stream_request.h" + +namespace content { + +// MediaStreamUIProxy proxies calls to media stream UI between IO thread and UI +// thread. One instance of this class is create per MediaStream object. It must +// be create, used and destroyed on IO thread. +class CONTENT_EXPORT MediaStreamUIProxy { + public: + typedef base::Callback< + void (const MediaStreamDevices& devices)> ResponseCallback; + + MediaStreamUIProxy(); + virtual ~MediaStreamUIProxy(); + + // Requests access for the MediaStream by calling + // WebContentsDelegate::RequestMediaAccessPermission(). The specified + // |response_callback| is called when the WebContentsDelegate approves or + // denies request. + virtual void RequestAccess(const MediaStreamRequest& request, + const ResponseCallback& response_callback); + + // Notifies the UI that the MediaStream has been started. Must be called after + // access has been approved using RequestAccess(). |stop_callback| is be + // called on the IO thread after the user has requests the stream to be + // stopped. + virtual void OnStarted(const base::Closure& stop_callback); + + private: + class Core; + friend class Core; + friend class FakeMediaStreamUIProxy; + + void ProcessAccessRequestResponse(const MediaStreamDevices& devices); + void ProcessStopRequestFromUI(); + + scoped_ptr<Core> core_; + ResponseCallback response_callback_; + base::Closure stop_callback_; + + base::WeakPtrFactory<MediaStreamUIProxy> weak_factory_; + + DISALLOW_COPY_AND_ASSIGN(MediaStreamUIProxy); +}; + +class CONTENT_EXPORT FakeMediaStreamUIProxy : public MediaStreamUIProxy { + public: + explicit FakeMediaStreamUIProxy(); + virtual ~FakeMediaStreamUIProxy(); + + virtual void RequestAccess( + const MediaStreamRequest& request, + const ResponseCallback& response_callback) OVERRIDE; + virtual void OnStarted(const base::Closure& stop_callback) OVERRIDE; + + private: + DISALLOW_COPY_AND_ASSIGN(FakeMediaStreamUIProxy); +}; + +} // namespace content + +#endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_UI_PROXY_H_ |