Index: rlz/win/lib/registry_util.cc |
diff --git a/rlz/win/lib/registry_util.cc b/rlz/win/lib/registry_util.cc |
deleted file mode 100644 |
index 6a324d5325ce0ecb0a188a3b8e55de04e0d16080..0000000000000000000000000000000000000000 |
--- a/rlz/win/lib/registry_util.cc |
+++ /dev/null |
@@ -1,77 +0,0 @@ |
-// Copyright (c) 2012 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. |
-// |
-// A helper library to keep track of a user's key by SID. |
-// Used by RLZ libary. Also to be used by SearchWithGoogle library. |
- |
-#include "rlz/win/lib/registry_util.h" |
- |
-#include "base/process_util.h" |
-#include "base/utf_string_conversions.h" |
-#include "base/win/registry.h" |
-#include "base/win/windows_version.h" |
-#include "rlz/lib/assert.h" |
-#include "rlz/win/lib/process_info.h" |
- |
-namespace rlz_lib { |
- |
-bool RegKeyReadValue(base::win::RegKey& key, const wchar_t* name, |
- char* value, size_t* value_size) { |
- value[0] = 0; |
- |
- std::wstring value_string; |
- if (key.ReadValue(name, &value_string) != ERROR_SUCCESS) { |
- return false; |
- } |
- |
- if (value_string.length() > *value_size) { |
- *value_size = value_string.length(); |
- return false; |
- } |
- |
- // Note that RLZ string are always ASCII by design. |
- strncpy(value, WideToUTF8(value_string).c_str(), *value_size); |
- value[*value_size - 1] = 0; |
- return true; |
-} |
- |
-bool RegKeyWriteValue(base::win::RegKey& key, const wchar_t* name, |
- const char* value) { |
- std::wstring value_string(ASCIIToWide(value)); |
- return key.WriteValue(name, value_string.c_str()) == ERROR_SUCCESS; |
-} |
- |
-bool HasUserKeyAccess(bool write_access) { |
- // The caller is trying to access HKEY_CURRENT_USER. Test to see if we can |
- // read from there. Don't try HKEY_CURRENT_USER because this will cause |
- // problems in the unit tests: if we open HKEY_CURRENT_USER directly here, |
- // the overriding done for unit tests will no longer work. So we try subkey |
- // "Software" which is known to always exist. |
- base::win::RegKey key; |
- if (key.Open(HKEY_CURRENT_USER, L"Software", KEY_READ) != ERROR_SUCCESS) |
- ASSERT_STRING("Could not open HKEY_CURRENT_USER"); |
- |
- if (ProcessInfo::IsRunningAsSystem()) { |
- ASSERT_STRING("UserKey::HasAccess: No access as SYSTEM without SID set."); |
- return false; |
- } |
- |
- if (write_access) { |
- if (base::win::GetVersion() < base::win::VERSION_VISTA) return true; |
- base::ProcessHandle process_handle = base::GetCurrentProcessHandle(); |
- base::IntegrityLevel level = base::INTEGRITY_UNKNOWN; |
- |
- if (!base::GetProcessIntegrityLevel(process_handle, &level)) { |
- ASSERT_STRING("UserKey::HasAccess: Cannot determine Integrity Level."); |
- return false; |
- } |
- if (level <= base::LOW_INTEGRITY) { |
- ASSERT_STRING("UserKey::HasAccess: Cannot write from Low Integrity."); |
- return false; |
- } |
- } |
- return true; |
-} |
- |
-} // namespace rlz_lib |