1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef REMOTING_HOST_DESKTOP_ENVIRONMENT_H_
6 #define REMOTING_HOST_DESKTOP_ENVIRONMENT_H_
10 #include "base/basictypes.h"
11 #include "base/callback_forward.h"
12 #include "base/memory/ref_counted.h"
13 #include "base/memory/scoped_ptr.h"
14 #include "base/memory/weak_ptr.h"
17 class SingleThreadTaskRunner
;
28 } // namespace protocol
31 class ClientSessionControl
;
32 class GnubbyAuthHandler
;
36 // Provides factory methods for creation of audio/video capturers and event
37 // executor for a given desktop environment.
38 class DesktopEnvironment
{
40 virtual ~DesktopEnvironment() {}
42 // Factory methods used to create audio/video capturers, event executor, and
43 // screen controls object for a particular desktop environment.
44 virtual scoped_ptr
<AudioCapturer
> CreateAudioCapturer() = 0;
45 virtual scoped_ptr
<InputInjector
> CreateInputInjector() = 0;
46 virtual scoped_ptr
<ScreenControls
> CreateScreenControls() = 0;
47 virtual scoped_ptr
<webrtc::ScreenCapturer
> CreateVideoCapturer() = 0;
49 // Returns the set of all capabilities supported by |this|.
50 virtual std::string
GetCapabilities() const = 0;
52 // Passes the final set of capabilities negotiated between the client and host
54 virtual void SetCapabilities(const std::string
& capabilities
) = 0;
56 // Factory method to create a gnubby auth handler suitable for the particular
57 // desktop environment.
58 virtual scoped_ptr
<GnubbyAuthHandler
> CreateGnubbyAuthHandler(
59 protocol::ClientStub
* client_stub
) = 0;
62 // Used to create |DesktopEnvironment| instances.
63 class DesktopEnvironmentFactory
{
65 virtual ~DesktopEnvironmentFactory() {}
67 // Creates an instance of |DesktopEnvironment|. Returns a NULL pointer if
68 // the desktop environment could not be created for any reason (if the curtain
69 // failed to active for instance). |client_session_control| must outlive
70 // the created desktop environment.
71 virtual scoped_ptr
<DesktopEnvironment
> Create(
72 base::WeakPtr
<ClientSessionControl
> client_session_control
) = 0;
74 // Enables or disables the curtain mode.
75 virtual void SetEnableCurtaining(bool enable
) {}
77 // Returns |true| if created |DesktopEnvironment| instances support audio
79 virtual bool SupportsAudioCapture() const = 0;
81 // Enables or disables gnubby authentication.
82 virtual void SetEnableGnubbyAuth(bool enable
) {}
85 } // namespace remoting
87 #endif // REMOTING_HOST_DESKTOP_ENVIRONMENT_H_