blob: a3fcd69623866e532cf6a36ef9ac03788215f406 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
// Copyright (c) 2010 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 "base/message_loop.h"
#include "base/path_service.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/json_pref_store.h"
#include "chrome/common/main_function_params.h"
#include "chrome/service/cloud_print/cloud_print_proxy.h"
#include "chrome/service/service_process.h"
#if defined(ENABLE_REMOTING)
#include "remoting/host/json_host_config.h"
#include "remoting/host/chromoting_host.h"
#include "remoting/host/chromoting_host_context.h"
// This method is called as a signal that the Chromoting Host Process is
// shutting down because of failure or a request made by the user.
// We'll then post a task to |message_loop| to stop the chromoting host
// context to finish the final cleanup.
static void OnChromotingHostShutdown(
MessageLoop* message_loop, remoting::ChromotingHostContext* context) {
message_loop->PostTask(FROM_HERE,
NewRunnableMethod(context, &remoting::ChromotingHostContext::Stop));
}
#endif
// Mainline routine for running as the service process.
int ServiceProcessMain(const MainFunctionParams& parameters) {
MessageLoopForUI main_message_loop;
PlatformThread::SetName("CrServiceMain");
ServiceProcess service_process;
service_process.Initialize();
// TODO(sanjeevr): The interface to start individual services such as the
// cloud print proxy needs to change from a command-line interface to an
// IPC interface. There will be eventually only one service process to handle
// requests from multiple Chrome browser profiles. The path of the user data
// directory will be passed in to the command and there will be one instance
// of services such as the cloud print proxy per requesting profile.
FilePath user_data_dir;
PathService::Get(chrome::DIR_USER_DATA, &user_data_dir);
FilePath pref_path = user_data_dir.Append(chrome::kServiceStateFileName);
scoped_ptr<JsonPrefStore> service_prefs(
new JsonPrefStore(
pref_path,
service_process.file_thread()->message_loop_proxy()));
service_prefs->ReadPrefs();
// Enable Cloud Print if needed.
if (parameters.command_line_.HasSwitch(switches::kEnableCloudPrintProxy)) {
std::string lsid =
parameters.command_line_.GetSwitchValueASCII(
switches::kServiceAccountLsid);
CloudPrintProxy* cloud_print_proxy =
service_process.CreateCloudPrintProxy(service_prefs.get());
cloud_print_proxy->EnableForUser(lsid);
}
#if defined(ENABLE_REMOTING)
// Enable Chromoting Host if needed.
// TODO(hclam): Merge this config file with Cloud Printing.
// TODO(hclam): There is only start but not stop of the chromoting host
// process.
FilePath chromoting_config_path =
user_data_dir.Append(FILE_PATH_LITERAL(".ChromotingConfig.json"));
scoped_refptr<remoting::JsonHostConfig> chromoting_config;
scoped_ptr<remoting::ChromotingHostContext> chromoting_context;
scoped_refptr<remoting::ChromotingHost> chromoting_host;
if (parameters.command_line_.HasSwitch(switches::kEnableChromoting)) {
chromoting_config = new remoting::JsonHostConfig(
chromoting_config_path,
service_process.file_thread()->message_loop_proxy());
if (!chromoting_config->Read()) {
LOG(ERROR) << "Failed to read chromoting config file.";
} else {
chromoting_context.reset(new remoting::ChromotingHostContext());
// Create the Chromoting Host Process with the context and config.
chromoting_host = service_process.CreateChromotingHost(
chromoting_context.get(), chromoting_config);
// And start the context and the host process.
chromoting_context->Start();
// When ChromotingHost is shutdown because of failure or a request that
// we made. ShutdownChromotingTask() is calls.
// ShutdownChromotingTask() will then post a task to
// |main_message_loop| to shutdown the chromoting context.
chromoting_host->Start(
NewRunnableFunction(&OnChromotingHostShutdown,
&main_message_loop, chromoting_context.get()));
}
}
#endif
MessageLoop::current()->Run();
service_prefs->WritePrefs();
service_process.Teardown();
return 0;
}
|