Chromium Code Reviews| Index: chrome/browser/devtools/device/webrtc/webrtc_device_provider.cc |
| diff --git a/chrome/browser/devtools/device/webrtc/webrtc_device_provider.cc b/chrome/browser/devtools/device/webrtc/webrtc_device_provider.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..91faeba3995b5a9ab996d1bc05507672e796bb76 |
| --- /dev/null |
| +++ b/chrome/browser/devtools/device/webrtc/webrtc_device_provider.cc |
| @@ -0,0 +1,139 @@ |
| +// 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 "chrome/browser/devtools/device/webrtc/webrtc_device_provider.h" |
| + |
| +#include "chrome/browser/ui/browser.h" |
| +#include "chrome/common/url_constants.h" |
| +#include "content/public/browser/web_contents.h" |
| +#include "content/public/browser/web_ui_data_source.h" |
| +#include "content/public/browser/web_ui_message_handler.h" |
| +#include "grit/webrtc_device_provider_resources_map.h" |
| +#include "ui/base/page_transition_types.h" |
| + |
| +const char kBackgroundWorkerURL[] = |
| + "chrome://webrtc-device-provider/background_worker.html"; |
| + |
| +class WebRTCDeviceProvider::MessageHandler |
| + : public content::WebUIMessageHandler { |
| + public: |
| + |
| + void RegisterMessages() override; |
| + |
| + protected: |
| + virtual void OnLoaded() {} |
| + |
| + private: |
| + void HandleLoaded(const base::ListValue* args); |
| +}; |
| + |
| +class WebRTCDeviceProvider::MessageHandlerImpl : public MessageHandler { |
| + public: |
| + explicit MessageHandlerImpl(WebRTCDeviceProvider* owner); |
| + ~MessageHandlerImpl() override; |
| + |
| + void Release(); |
| + |
| + protected: |
| + void OnLoaded() override {} |
| + |
| + private: |
| + WebRTCDeviceProvider* owner_; |
| +}; |
| + |
| +// WebRTCDeviceProvider::WebUI |
| +WebRTCDeviceProvider::WebUI::WebUI(content::WebUI* web_ui) |
| + : content::WebUIController(web_ui) { |
| + Profile* profile = Profile::FromWebUI(web_ui); |
| + |
| + content::WebUIDataSource* source = content::WebUIDataSource::Create( |
| + chrome::kChromeUIWebRTCDeviceProviderHost); |
| + |
| + for (size_t i = 0; i < kWebrtcDeviceProviderResourcesSize; i++) { |
| + source->AddResourcePath(kWebrtcDeviceProviderResources[i].name, |
| + kWebrtcDeviceProviderResources[i].value); |
| + } |
| + |
| + // Sets a stub message handler. If web contents load from WebRTCDeviceProvider |
| + // message callbacks will be overridden by a real implementation. |
| + web_ui->AddMessageHandler(new MessageHandler); |
| + |
| + content::WebUIDataSource::Add(profile, source); |
| +} |
| + |
| +WebRTCDeviceProvider::WebUI::~WebUI() {} |
| + |
| +// WebRTCDeviceProvider::MessageHandler |
| + |
| +void WebRTCDeviceProvider::MessageHandler::RegisterMessages() { |
| + web_ui()->RegisterMessageCallback( |
| + "loaded", |
| + base::Bind(&MessageHandler::HandleLoaded, base::Unretained(this))); |
| +} |
| + |
| +void WebRTCDeviceProvider::MessageHandler::HandleLoaded( |
| + const base::ListValue* args) { |
| + OnLoaded(); |
| +} |
| + |
| +// WebRTCDeviceProvider::MessageHandlerImpl |
| +WebRTCDeviceProvider::MessageHandlerImpl::MessageHandlerImpl( |
| + WebRTCDeviceProvider* owner) : owner_(owner) { |
| + DCHECK(owner_->handler_ == NULL); |
| + owner_->handler_ = this; |
| +} |
| + |
| +WebRTCDeviceProvider::MessageHandlerImpl::~MessageHandlerImpl() { |
| + if (owner_ != NULL) { |
| + DCHECK(owner_->handler_ == this); |
| + owner_->handler_ = NULL; |
| + } |
| +} |
| + |
| +void WebRTCDeviceProvider::MessageHandlerImpl::Release() { |
| + DCHECK(owner_ != NULL); |
| + owner_ = NULL; |
| +} |
| + |
| +// WebRTCDeviceProvider |
| + |
| +WebRTCDeviceProvider::WebRTCDeviceProvider(content::BrowserContext* context) |
| + : handler_(NULL) { |
| + background_worker_.reset(content::WebContents::Create( |
| + content::WebContents::CreateParams(context))); |
| + |
| + // TODO(serya): Make sure background_worker_ destructed before profile. |
| + GURL url(kBackgroundWorkerURL); |
| + |
| + DCHECK_EQ(chrome::kChromeUIWebRTCDeviceProviderHost, url.host()); |
| + |
| + background_worker_->GetController().LoadURL( |
| + url, |
| + content::Referrer(), |
| + ui::PAGE_TRANSITION_AUTO_TOPLEVEL, |
| + std::string()); |
| + |
| + background_worker_->GetWebUI()->AddMessageHandler( |
| + new MessageHandlerImpl(this)); |
| +} |
| + |
| +WebRTCDeviceProvider::~WebRTCDeviceProvider() { |
| + if (handler_ != NULL) |
|
dgozman
2014/11/28 12:17:24
I think |handler_| must be destroyed as a part of
SeRya
2014/11/28 12:31:18
Done.
|
| + handler_->Release(); |
| +} |
| + |
| +void WebRTCDeviceProvider::QueryDevices(const SerialsCallback& callback) { |
| + // TODO(serya): Implement |
| +} |
| + |
| +void WebRTCDeviceProvider::QueryDeviceInfo(const std::string& serial, |
| + const DeviceInfoCallback& callback) { |
| + // TODO(serya): Implement |
| +} |
| + |
| +void WebRTCDeviceProvider::OpenSocket(const std::string& serial, |
| + const std::string& socket_name, |
| + const SocketCallback& callback) { |
| + // TODO(serya): Implement |
| +} |