blob: 31ed5905f791947dfcb457f17892df0b25bf6cfc [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.
#include "remoting/host/host_extension_session_manager.h"
#include "remoting/base/capabilities.h"
#include "remoting/codec/video_encoder.h"
#include "remoting/host/client_session_control.h"
#include "remoting/host/host_extension.h"
#include "remoting/host/host_extension_session.h"
#include "third_party/webrtc/modules/desktop_capture/desktop_capturer.h"
namespace remoting {
HostExtensionSessionManager::HostExtensionSessionManager(
const std::vector<HostExtension*>& extensions,
ClientSessionControl* client_session_control)
: client_session_control_(client_session_control),
client_stub_(NULL),
extensions_(extensions) {
}
HostExtensionSessionManager::~HostExtensionSessionManager() {
}
std::string HostExtensionSessionManager::GetCapabilities() {
std::string capabilities;
for (HostExtensionList::const_iterator extension = extensions_.begin();
extension != extensions_.end(); ++extension) {
std::string capability = (*extension)->capability();
if (capability.empty()) {
continue;
}
if (!capabilities.empty()) {
capabilities.append(" ");
}
capabilities.append(capability);
}
return capabilities;
}
scoped_ptr<webrtc::DesktopCapturer>
HostExtensionSessionManager::OnCreateVideoCapturer(
scoped_ptr<webrtc::DesktopCapturer> capturer) {
for(HostExtensionSessionList::const_iterator it = extension_sessions_.begin();
it != extension_sessions_.end(); ++it) {
if ((*it)->ModifiesVideoPipeline()) {
capturer = (*it)->OnCreateVideoCapturer(capturer.Pass());
}
}
return capturer.Pass();
}
scoped_ptr<VideoEncoder> HostExtensionSessionManager::OnCreateVideoEncoder(
scoped_ptr<VideoEncoder> encoder) {
for(HostExtensionSessionList::const_iterator it = extension_sessions_.begin();
it != extension_sessions_.end(); ++it) {
if ((*it)->ModifiesVideoPipeline()) {
encoder = (*it)->OnCreateVideoEncoder(encoder.Pass());
}
}
return encoder.Pass();
}
void HostExtensionSessionManager::OnNegotiatedCapabilities(
protocol::ClientStub* client_stub,
const std::string& capabilities) {
DCHECK(client_stub);
DCHECK(!client_stub_);
client_stub_ = client_stub;
bool reset_video_pipeline = false;
for (HostExtensionList::const_iterator extension = extensions_.begin();
extension != extensions_.end(); ++extension) {
// If the extension requires a capability that was not negotiated then do
// not instantiate it.
if (!(*extension)->capability().empty() &&
!HasCapability(capabilities, (*extension)->capability())) {
continue;
}
scoped_ptr<HostExtensionSession> extension_session =
(*extension)->CreateExtensionSession(
client_session_control_, client_stub_);
DCHECK(extension_session);
if (extension_session->ModifiesVideoPipeline()) {
reset_video_pipeline = true;
}
extension_sessions_.push_back(extension_session.release());
}
// Re-create the video pipeline if one or more extensions need to modify it.
if (reset_video_pipeline) {
client_session_control_->ResetVideoPipeline();
}
}
bool HostExtensionSessionManager::OnExtensionMessage(
const protocol::ExtensionMessage& message) {
for(HostExtensionSessionList::const_iterator it = extension_sessions_.begin();
it != extension_sessions_.end(); ++it) {
if ((*it)->OnExtensionMessage(
client_session_control_, client_stub_, message)) {
return true;
}
}
return false;
}
} // namespace remoting