| Index: chrome/browser/extensions/api/messaging/native_message_host_chromeos.cc
|
| diff --git a/chrome/browser/extensions/api/messaging/native_message_host_chromeos.cc b/chrome/browser/extensions/api/messaging/native_message_host_chromeos.cc
|
| index 799a5b64350360bc7df621158ad453e7a8e5ffa8..fdb43188b74b9725df0b4db1062b5395111900e9 100644
|
| --- a/chrome/browser/extensions/api/messaging/native_message_host_chromeos.cc
|
| +++ b/chrome/browser/extensions/api/messaging/native_message_host_chromeos.cc
|
| @@ -16,9 +16,17 @@
|
| #include "base/memory/scoped_ptr.h"
|
| #include "base/message_loop/message_loop_proxy.h"
|
| #include "base/values.h"
|
| +#include "chrome/browser/browser_process.h"
|
| #include "chrome/browser/extensions/api/messaging/native_messaging_test_util.h"
|
| +#include "components/policy/core/common/policy_service.h"
|
| #include "extensions/common/constants.h"
|
| +#include "extensions/common/switches.h"
|
| #include "extensions/common/url_pattern.h"
|
| +#include "net/url_request/url_request_context_getter.h"
|
| +#if defined(USE_X11)
|
| +#include "remoting/host/chromoting_host_context.h"
|
| +#include "remoting/host/it2me/it2me_native_messaging_host.h"
|
| +# endif // defined(USE_X11)
|
| #include "ui/gfx/native_widget_types.h"
|
| #include "url/gurl.h"
|
|
|
| @@ -26,10 +34,9 @@ namespace extensions {
|
|
|
| namespace {
|
|
|
| -// A simple NativeMesageHost that echoes the received message. It is currently
|
| -// used for testing.
|
| -// TODO(kelvinp): Replace this class once Remote Assistance in process host
|
| -// is implemented.
|
| +// A simple NativeMessageHost that mimics the implementation of
|
| +// chrome/test/data/native_messaging/native_hosts/echo.py. It is currently
|
| +// used for testing by ExtensionApiTest::NativeMessagingBasic.
|
|
|
| const char* const kEchoHostOrigins[] = {
|
| // ScopedTestNativeMessagingHost::kExtensionId
|
| @@ -90,25 +97,52 @@ struct BuiltInHost {
|
| scoped_ptr<NativeMessageHost>(*create_function)();
|
| };
|
|
|
| +// Remote assistance currently only supports X11.
|
| +// TODO(kelvinp): Migrate to ozone once it is ready (crbug.com/426716).
|
| +#if defined(USE_X11)
|
| +scoped_ptr<NativeMessageHost> CreateIt2MeHost() {
|
| + if (CommandLine::ForCurrentProcess()->HasSwitch(
|
| + switches::kEnableRemoteAssistance)) {
|
| + scoped_ptr<remoting::It2MeHostFactory> host_factory(
|
| + new remoting::It2MeHostFactory());
|
| + host_factory->set_policy_service(g_browser_process->policy_service());
|
| + scoped_ptr<remoting::ChromotingHostContext> context =
|
| + remoting::ChromotingHostContext::CreateForChromeOS(
|
| + make_scoped_refptr(g_browser_process->system_request_context()));
|
| + scoped_ptr<NativeMessageHost> host(new remoting::It2MeNativeMessagingHost(
|
| + context.Pass(), host_factory.Pass()));
|
| + return host.Pass();
|
| + }
|
| + return nullptr;
|
| +}
|
| +
|
| // If you modify the list of allowed_origins, don't forget to update
|
| // remoting/host/it2me/com.google.chrome.remote_assistance.json.jinja2
|
| // to keep the two lists in sync.
|
| // TODO(kelvinp): Load the native messaging manifest as a resource file into
|
| -// chrome and fetch the list of allowed_origins from the manifest.
|
| -/*const char* const kRemotingIt2MeOrigins[] = {
|
| +// chrome and fetch the list of allowed_origins from the manifest (see
|
| +// crbug/424743).
|
| +const char* const kRemotingIt2MeOrigins[] = {
|
| "chrome-extension://ljacajndfccfgnfohlgkdphmbnpkjflk/",
|
| "chrome-extension://gbchcmhmhahfdphkhkmpfmihenigjmpp/",
|
| "chrome-extension://kgngmbheleoaphbjbaiobfdepmghbfah/",
|
| "chrome-extension://odkaodonbgfohohmklejpjiejmcipmib/",
|
| "chrome-extension://dokpleeekgeeiehdhmdkeimnkmoifgdd/",
|
| "chrome-extension://ajoainacpilcemgiakehflpbkbfipojk/",
|
| - "chrome-extension://hmboipgjngjoiaeicfdifdoeacilalgc/"};*/
|
| + "chrome-extension://hmboipgjngjoiaeicfdifdoeacilalgc/"};
|
| +#endif // defined(USE_X11)
|
|
|
| static const BuiltInHost kBuiltInHost[] = {
|
| {"com.google.chrome.test.echo", // ScopedTestNativeMessagingHost::kHostName
|
| kEchoHostOrigins,
|
| arraysize(kEchoHostOrigins),
|
| &EchoHost::Create},
|
| +#if defined(USE_X11)
|
| + {"com.google.chrome.remote_assistance",
|
| + kRemotingIt2MeOrigins,
|
| + arraysize(kRemotingIt2MeOrigins),
|
| + &CreateIt2MeHost},
|
| +#endif // defined(USE_X11)
|
| };
|
|
|
| bool MatchesSecurityOrigin(const BuiltInHost& host,
|
|
|