blob: a9963affe335654e38df140c71d496dfbebd4af2 (
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
|
// Copyright (c) 2013 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 "chromeos/chromeos_paths.h"
#include "base/file_util.h"
#include "base/files/file_path.h"
#include "base/path_service.h"
#include "base/sys_info.h"
namespace chromeos {
namespace {
const base::FilePath::CharType kDefaultAppOrderFileName[] =
#if defined(GOOGLE_CHROME_BUILD)
FILE_PATH_LITERAL("/usr/share/google-chrome/default_app_order.json");
#else
FILE_PATH_LITERAL("/usr/share/chromium/default_app_order.json");
#endif // defined(GOOGLE_CHROME_BUILD)
const base::FilePath::CharType kDefaultUserPolicyKeysDir[] =
FILE_PATH_LITERAL("/var/run/user_policy");
const base::FilePath::CharType kOwnerKeyFileName[] =
FILE_PATH_LITERAL("/var/lib/whitelist/owner.key");
const base::FilePath::CharType kInstallAttributesFileName[] =
FILE_PATH_LITERAL("/var/run/lockbox/install_attributes.pb");
const base::FilePath::CharType kUptimeFileName[] =
FILE_PATH_LITERAL("/proc/uptime");
const base::FilePath::CharType kUpdateRebootNeededUptimeFile[] =
FILE_PATH_LITERAL("/var/run/chrome/update_reboot_needed_uptime");
const base::FilePath::CharType kDeviceLocalAccountExtensionDir[] =
FILE_PATH_LITERAL("/var/cache/device_local_account_extensions");
const base::FilePath::CharType kDeviceLocalAccountExternalDataDir[] =
FILE_PATH_LITERAL("/var/cache/device_local_account_external_policy_data");
bool PathProvider(int key, base::FilePath* result) {
switch (key) {
case FILE_DEFAULT_APP_ORDER:
*result = base::FilePath(kDefaultAppOrderFileName);
break;
case DIR_USER_POLICY_KEYS:
*result = base::FilePath(kDefaultUserPolicyKeysDir);
break;
case FILE_OWNER_KEY:
*result = base::FilePath(kOwnerKeyFileName);
break;
case FILE_INSTALL_ATTRIBUTES:
*result = base::FilePath(kInstallAttributesFileName);
break;
case FILE_UPTIME:
*result = base::FilePath(kUptimeFileName);
break;
case FILE_UPDATE_REBOOT_NEEDED_UPTIME:
*result = base::FilePath(kUpdateRebootNeededUptimeFile);
break;
case DIR_DEVICE_LOCAL_ACCOUNT_EXTENSIONS:
*result = base::FilePath(kDeviceLocalAccountExtensionDir);
break;
case DIR_DEVICE_LOCAL_ACCOUNT_EXTERNAL_DATA:
*result = base::FilePath(kDeviceLocalAccountExternalDataDir);
break;
default:
return false;
}
return true;
}
} // namespace
void RegisterPathProvider() {
PathService::RegisterProvider(PathProvider, PATH_START, PATH_END);
}
void RegisterStubPathOverrides(const base::FilePath& stubs_dir) {
CHECK(!base::SysInfo::IsRunningOnChromeOS());
// Override these paths on the desktop, so that enrollment and cloud
// policy work and can be tested.
base::FilePath parent = base::MakeAbsoluteFilePath(stubs_dir);
PathService::Override(
DIR_USER_POLICY_KEYS,
parent.AppendASCII("stub_user_policy"));
const bool is_absolute = true;
const bool create = false;
PathService::OverrideAndCreateIfNeeded(
FILE_OWNER_KEY,
parent.AppendASCII("stub_owner.key"),
is_absolute,
create);
PathService::OverrideAndCreateIfNeeded(
FILE_INSTALL_ATTRIBUTES,
parent.AppendASCII("stub_install_attributes.pb"),
is_absolute,
create);
}
} // namespace chromeos
|