| Index: chrome/browser/policy/policy_path_parser_win.cc
|
| diff --git a/chrome/browser/policy/policy_path_parser_win.cc b/chrome/browser/policy/policy_path_parser_win.cc
|
| index 9de7ed9da96a9f77ac5b1848d2bce64c45010ced..573e9b45a30d2f7b14c8fa3b6baae2b50c3b25e1 100644
|
| --- a/chrome/browser/policy/policy_path_parser_win.cc
|
| +++ b/chrome/browser/policy/policy_path_parser_win.cc
|
| @@ -14,6 +14,7 @@
|
| #include "base/strings/utf_string_conversions.h"
|
| #include "base/win/registry.h"
|
| #include "chrome/common/chrome_switches.h"
|
| +#include "chrome/install_static/policy_path_parser.h"
|
| #include "components/policy/policy_constants.h"
|
|
|
| namespace {
|
| @@ -32,34 +33,6 @@ bool LoadUserDataDirPolicyFromRegistry(HKEY hive,
|
| return false;
|
| }
|
|
|
| -const WCHAR* kMachineNamePolicyVarName = L"${machine_name}";
|
| -const WCHAR* kUserNamePolicyVarName = L"${user_name}";
|
| -const WCHAR* kWinDocumentsFolderVarName = L"${documents}";
|
| -const WCHAR* kWinLocalAppDataFolderVarName = L"${local_app_data}";
|
| -const WCHAR* kWinRoamingAppDataFolderVarName = L"${roaming_app_data}";
|
| -const WCHAR* kWinProfileFolderVarName = L"${profile}";
|
| -const WCHAR* kWinProgramDataFolderVarName = L"${global_app_data}";
|
| -const WCHAR* kWinProgramFilesFolderVarName = L"${program_files}";
|
| -const WCHAR* kWinWindowsFolderVarName = L"${windows}";
|
| -const WCHAR* kWinClientName = L"${client_name}";
|
| -const WCHAR* kWinSessionName = L"${session_name}";
|
| -
|
| -struct WinFolderNamesToCSIDLMapping {
|
| - const WCHAR* name;
|
| - int id;
|
| -};
|
| -
|
| -// Mapping from variable names to Windows CSIDL ids.
|
| -const WinFolderNamesToCSIDLMapping win_folder_mapping[] = {
|
| - { kWinWindowsFolderVarName, CSIDL_WINDOWS},
|
| - { kWinProgramFilesFolderVarName, CSIDL_PROGRAM_FILES},
|
| - { kWinProgramDataFolderVarName, CSIDL_COMMON_APPDATA},
|
| - { kWinProfileFolderVarName, CSIDL_PROFILE},
|
| - { kWinLocalAppDataFolderVarName, CSIDL_LOCAL_APPDATA},
|
| - { kWinRoamingAppDataFolderVarName, CSIDL_APPDATA},
|
| - { kWinDocumentsFolderVarName, CSIDL_PERSONAL}
|
| -};
|
| -
|
| } // namespace
|
|
|
| namespace policy {
|
| @@ -70,80 +43,10 @@ namespace path_parser {
|
| // system settings values.
|
| base::FilePath::StringType ExpandPathVariables(
|
| const base::FilePath::StringType& untranslated_string) {
|
| - base::FilePath::StringType result(untranslated_string);
|
| - if (result.length() == 0)
|
| - return result;
|
| - // Sanitize quotes in case of any around the whole string.
|
| - if (result.length() > 1 &&
|
| - ((result.front() == L'"' && result.back() == L'"') ||
|
| - (result.front() == L'\'' && result.back() == L'\''))) {
|
| - // Strip first and last char which should be matching quotes now.
|
| - result = result.substr(1, result.length() - 2);
|
| - }
|
| - // First translate all path variables we recognize.
|
| - for (size_t i = 0; i < arraysize(win_folder_mapping); ++i) {
|
| - size_t position = result.find(win_folder_mapping[i].name);
|
| - if (position != std::wstring::npos) {
|
| - WCHAR path[MAX_PATH];
|
| - ::SHGetSpecialFolderPath(0, path, win_folder_mapping[i].id, false);
|
| - std::wstring path_string(path);
|
| - result.replace(position, wcslen(win_folder_mapping[i].name), path_string);
|
| - }
|
| - }
|
| - // Next translate other windows specific variables.
|
| - size_t position = result.find(kUserNamePolicyVarName);
|
| - if (position != std::wstring::npos) {
|
| - DWORD return_length = 0;
|
| - ::GetUserName(NULL, &return_length);
|
| - if (return_length != 0) {
|
| - std::unique_ptr<WCHAR[]> username(new WCHAR[return_length]);
|
| - ::GetUserName(username.get(), &return_length);
|
| - std::wstring username_string(username.get());
|
| - result.replace(position, wcslen(kUserNamePolicyVarName), username_string);
|
| - }
|
| - }
|
| - position = result.find(kMachineNamePolicyVarName);
|
| - if (position != std::wstring::npos) {
|
| - DWORD return_length = 0;
|
| - ::GetComputerNameEx(ComputerNamePhysicalDnsHostname, NULL, &return_length);
|
| - if (return_length != 0) {
|
| - std::unique_ptr<WCHAR[]> machinename(new WCHAR[return_length]);
|
| - ::GetComputerNameEx(ComputerNamePhysicalDnsHostname,
|
| - machinename.get(), &return_length);
|
| - std::wstring machinename_string(machinename.get());
|
| - result.replace(
|
| - position, wcslen(kMachineNamePolicyVarName), machinename_string);
|
| - }
|
| - }
|
| - position = result.find(kWinClientName);
|
| - if (position != std::wstring::npos) {
|
| - LPWSTR buffer = NULL;
|
| - DWORD buffer_length = 0;
|
| - if (::WTSQuerySessionInformation(WTS_CURRENT_SERVER, WTS_CURRENT_SESSION,
|
| - WTSClientName,
|
| - &buffer, &buffer_length)) {
|
| - std::wstring clientname_string(buffer);
|
| - result.replace(position, wcslen(kWinClientName), clientname_string);
|
| - ::WTSFreeMemory(buffer);
|
| - }
|
| - }
|
| - position = result.find(kWinSessionName);
|
| - if (position != std::wstring::npos) {
|
| - LPWSTR buffer = NULL;
|
| - DWORD buffer_length = 0;
|
| - if (::WTSQuerySessionInformation(WTS_CURRENT_SERVER, WTS_CURRENT_SESSION,
|
| - WTSWinStationName,
|
| - &buffer, &buffer_length)) {
|
| - std::wstring sessionname_string(buffer);
|
| - result.replace(position, wcslen(kWinSessionName), sessionname_string);
|
| - ::WTSFreeMemory(buffer);
|
| - }
|
| - }
|
| - // TODO(pastarmovj): Consider reorganizing this code once there are even more
|
| - // variables to be supported. The search for the var and its replacement can
|
| - // be extracted as common functionality.
|
| -
|
| - return result;
|
| + // This is implemented in the install_static library so that it can also be
|
| + // used by Crashpad initialization code in chrome_elf, which has very
|
| + // constrained set of dependencies.
|
| + return install_static::ExpandPathVariables(untranslated_string);
|
| }
|
|
|
| void CheckUserDataDirPolicy(base::FilePath* user_data_dir) {
|
|
|