Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(53)

Side by Side Diff: remoting/host/host_extension_session_manager.cc

Issue 2091553002: Expose ClientSession details to Host Extensions (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@desktop_environment
Patch Set: Adressing feedback Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "remoting/host/host_extension_session_manager.h" 5 #include "remoting/host/host_extension_session_manager.h"
6 6
7 #include "remoting/base/capabilities.h" 7 #include "remoting/base/capabilities.h"
8 #include "remoting/codec/video_encoder.h" 8 #include "remoting/host/client_session_details.h"
9 #include "remoting/host/client_session_control.h"
10 #include "remoting/host/host_extension.h" 9 #include "remoting/host/host_extension.h"
11 #include "remoting/host/host_extension_session.h" 10 #include "remoting/host/host_extension_session.h"
12 #include "third_party/webrtc/modules/desktop_capture/desktop_capturer.h"
13 11
14 namespace remoting { 12 namespace remoting {
15 13
16 HostExtensionSessionManager::HostExtensionSessionManager( 14 HostExtensionSessionManager::HostExtensionSessionManager(
17 const std::vector<HostExtension*>& extensions, 15 const std::vector<HostExtension*>& extensions,
18 ClientSessionControl* client_session_control) 16 ClientSessionDetails* client_session_details)
19 : client_session_control_(client_session_control), 17 : client_session_details_(client_session_details),
20 client_stub_(nullptr), 18 client_stub_(nullptr),
21 extensions_(extensions) {} 19 extensions_(extensions) {}
22 20
23 HostExtensionSessionManager::~HostExtensionSessionManager() {} 21 HostExtensionSessionManager::~HostExtensionSessionManager() {}
24 22
25 std::string HostExtensionSessionManager::GetCapabilities() const { 23 std::string HostExtensionSessionManager::GetCapabilities() const {
26 std::string capabilities; 24 std::string capabilities;
27 for (HostExtensions::const_iterator extension = extensions_.begin(); 25 for (HostExtensions::const_iterator extension = extensions_.begin();
28 extension != extensions_.end(); ++extension) { 26 extension != extensions_.end(); ++extension) {
29 const std::string& capability = (*extension)->capability(); 27 const std::string& capability = (*extension)->capability();
(...skipping 20 matching lines...) Expand all
50 extension != extensions_.end(); ++extension) { 48 extension != extensions_.end(); ++extension) {
51 // If the extension requires a capability that was not negotiated then do 49 // If the extension requires a capability that was not negotiated then do
52 // not instantiate it. 50 // not instantiate it.
53 if (!(*extension)->capability().empty() && 51 if (!(*extension)->capability().empty() &&
54 !HasCapability(capabilities, (*extension)->capability())) { 52 !HasCapability(capabilities, (*extension)->capability())) {
55 continue; 53 continue;
56 } 54 }
57 55
58 std::unique_ptr<HostExtensionSession> extension_session = 56 std::unique_ptr<HostExtensionSession> extension_session =
59 (*extension) 57 (*extension)
60 ->CreateExtensionSession(client_session_control_, client_stub_); 58 ->CreateExtensionSession(client_session_details_, client_stub_);
61 DCHECK(extension_session); 59 DCHECK(extension_session);
62 60
63 extension_sessions_.push_back(extension_session.release()); 61 extension_sessions_.push_back(extension_session.release());
64 } 62 }
65 } 63 }
66 64
67 bool HostExtensionSessionManager::OnExtensionMessage( 65 bool HostExtensionSessionManager::OnExtensionMessage(
68 const protocol::ExtensionMessage& message) { 66 const protocol::ExtensionMessage& message) {
69 for(HostExtensionSessions::const_iterator it = extension_sessions_.begin(); 67 for(HostExtensionSessions::const_iterator it = extension_sessions_.begin();
70 it != extension_sessions_.end(); ++it) { 68 it != extension_sessions_.end(); ++it) {
71 if ((*it)->OnExtensionMessage(client_session_control_, client_stub_, 69 if ((*it)->OnExtensionMessage(client_session_details_, client_stub_,
72 message)) { 70 message)) {
73 return true; 71 return true;
74 } 72 }
75 } 73 }
76 return false; 74 return false;
77 } 75 }
78 76
79 } // namespace remoting 77 } // namespace remoting
OLDNEW
« no previous file with comments | « remoting/host/host_extension_session_manager.h ('k') | remoting/host/host_extension_session_manager_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698