|  | // Copyright 2012 The Chromium Authors | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef REMOTING_HOST_DESKTOP_SESSION_WIN_H_ | 
|  | #define REMOTING_HOST_DESKTOP_SESSION_WIN_H_ | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include <memory> | 
|  |  | 
|  | #include "base/memory/raw_ptr.h" | 
|  | #include "base/memory/scoped_refptr.h" | 
|  | #include "base/time/time.h" | 
|  | #include "base/timer/timer.h" | 
|  | #include "base/win/scoped_handle.h" | 
|  | #include "mojo/public/cpp/bindings/associated_receiver.h" | 
|  | #include "mojo/public/cpp/bindings/scoped_interface_endpoint_handle.h" | 
|  | #include "mojo/public/cpp/system/message_pipe.h" | 
|  | #include "remoting/host/desktop_session.h" | 
|  | #include "remoting/host/mojom/desktop_session.mojom.h" | 
|  | #include "remoting/host/win/wts_terminal_observer.h" | 
|  | #include "remoting/host/worker_process_ipc_delegate.h" | 
|  |  | 
|  | namespace base { | 
|  | class Location; | 
|  | }  // namespace base | 
|  |  | 
|  | namespace remoting { | 
|  |  | 
|  | class AutoThreadTaskRunner; | 
|  | class DaemonProcess; | 
|  | class DesktopSession; | 
|  | class ScreenResolution; | 
|  | class WorkerProcessLauncher; | 
|  | class WtsTerminalMonitor; | 
|  |  | 
|  | // DesktopSession implementation which attaches to either physical or virtual | 
|  | // (RDP) console. Receives IPC messages from the desktop process, running in | 
|  | // the target session, via |WorkerProcessIpcDelegate|, and monitors session | 
|  | // attach/detach events via |WtsTerminalObserer|. | 
|  | class DesktopSessionWin : public DesktopSession, | 
|  | public WorkerProcessIpcDelegate, | 
|  | public WtsTerminalObserver, | 
|  | public mojom::DesktopSessionRequestHandler { | 
|  | public: | 
|  | // Creates a desktop session instance that attaches to the physical console. | 
|  | static std::unique_ptr<DesktopSession> CreateForConsole( | 
|  | scoped_refptr<AutoThreadTaskRunner> caller_task_runner, | 
|  | scoped_refptr<AutoThreadTaskRunner> io_task_runner, | 
|  | DaemonProcess* daemon_process, | 
|  | int id, | 
|  | const ScreenResolution& resolution); | 
|  |  | 
|  | // Creates a desktop session instance that attaches to a virtual console. | 
|  | static std::unique_ptr<DesktopSession> CreateForVirtualTerminal( | 
|  | scoped_refptr<AutoThreadTaskRunner> caller_task_runner, | 
|  | scoped_refptr<AutoThreadTaskRunner> io_task_runner, | 
|  | DaemonProcess* daemon_process, | 
|  | int id, | 
|  | const ScreenResolution& resolution); | 
|  |  | 
|  | DesktopSessionWin(const DesktopSessionWin&) = delete; | 
|  | DesktopSessionWin& operator=(const DesktopSessionWin&) = delete; | 
|  |  | 
|  | protected: | 
|  | // Passes the owning |daemon_process|, a unique identifier of the desktop | 
|  | // session |id| and the interface for monitoring session attach/detach events. | 
|  | // Both |daemon_process| and |monitor| must outlive |this|. | 
|  | DesktopSessionWin(scoped_refptr<AutoThreadTaskRunner> caller_task_runner, | 
|  | scoped_refptr<AutoThreadTaskRunner> io_task_runner, | 
|  | DaemonProcess* daemon_process, | 
|  | int id, | 
|  | WtsTerminalMonitor* monitor); | 
|  | ~DesktopSessionWin() override; | 
|  |  | 
|  | const scoped_refptr<AutoThreadTaskRunner>& caller_task_runner() const { | 
|  | return caller_task_runner_; | 
|  | } | 
|  |  | 
|  | // Called when |session_attach_timer_| expires. | 
|  | void OnSessionAttachTimeout(); | 
|  |  | 
|  | // Starts monitoring for session attach/detach events for |terminal_id|. | 
|  | void StartMonitoring(const std::string& terminal_id); | 
|  |  | 
|  | // Stops monitoring for session attach/detach events. | 
|  | void StopMonitoring(); | 
|  |  | 
|  | // Asks DaemonProcess to terminate this session. | 
|  | void TerminateSession(); | 
|  |  | 
|  | // Injects a secure attention sequence into the session. | 
|  | virtual void InjectSas() = 0; | 
|  |  | 
|  | // WorkerProcessIpcDelegate implementation. | 
|  | void OnChannelConnected(int32_t peer_pid) override; | 
|  | void OnPermanentError(int exit_code) override; | 
|  | void OnWorkerProcessStopped() override; | 
|  | void OnAssociatedInterfaceRequest( | 
|  | const std::string& interface_name, | 
|  | mojo::ScopedInterfaceEndpointHandle handle) override; | 
|  |  | 
|  | // WtsTerminalObserver implementation. | 
|  | void OnSessionAttached(uint32_t session_id) override; | 
|  | void OnSessionDetached() override; | 
|  |  | 
|  | private: | 
|  | // mojom::DesktopSessionRequestHandler implementation. | 
|  | void ConnectDesktopChannel( | 
|  | mojo::ScopedMessagePipeHandle desktop_pipe) override; | 
|  | void InjectSecureAttentionSequence() override; | 
|  | void CrashNetworkProcess() override; | 
|  |  | 
|  | // Requests the desktop process to crash. | 
|  | void CrashDesktopProcess(const base::Location& location); | 
|  |  | 
|  | // Reports time elapsed since previous event to the debug log. | 
|  | void ReportElapsedTime(const std::string& event); | 
|  |  | 
|  | // Task runner on which public methods of this class should be called. | 
|  | scoped_refptr<AutoThreadTaskRunner> caller_task_runner_; | 
|  |  | 
|  | // Message loop used by the IPC channel. | 
|  | scoped_refptr<AutoThreadTaskRunner> io_task_runner_; | 
|  |  | 
|  | // Handle of the desktop process (running an instance of DesktopSessionAgent). | 
|  | base::win::ScopedHandle desktop_process_; | 
|  |  | 
|  | // Launches and monitors the desktop process. | 
|  | std::unique_ptr<WorkerProcessLauncher> launcher_; | 
|  |  | 
|  | // Used to unsubscribe from session attach and detach events. | 
|  | raw_ptr<WtsTerminalMonitor> monitor_; | 
|  |  | 
|  | // Indicates whether session attach/detach notifications are subscribed to. | 
|  | bool monitoring_notifications_; | 
|  |  | 
|  | // Reports an error if the session attach notification does not arrive. | 
|  | base::OneShotTimer session_attach_timer_; | 
|  |  | 
|  | base::Time last_timestamp_; | 
|  |  | 
|  | mojo::AssociatedReceiver<mojom::DesktopSessionRequestHandler> | 
|  | desktop_session_request_handler_{this}; | 
|  |  | 
|  | // The id of the current desktop session being remoted or UINT32_MAX if no | 
|  | // session exists. | 
|  | int session_id_ = UINT32_MAX; | 
|  | }; | 
|  |  | 
|  | }  // namespace remoting | 
|  |  | 
|  | #endif  // REMOTING_HOST_DESKTOP_SESSION_WIN_H_ |