Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(727)

Unified Diff: rlz/win/lib/machine_deal.cc

Issue 10642009: Add a regenerate button to regenerate the password in Windows. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Sync and Merge. Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « rlz/win/lib/machine_deal.h ('k') | rlz/win/lib/machine_deal_test.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: rlz/win/lib/machine_deal.cc
diff --git a/rlz/win/lib/machine_deal.cc b/rlz/win/lib/machine_deal.cc
deleted file mode 100644
index 32162606e650a8196a000f0c975ab42e830eee8d..0000000000000000000000000000000000000000
--- a/rlz/win/lib/machine_deal.cc
+++ /dev/null
@@ -1,300 +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.
-//
-// Library functions related to the OEM Deal Confirmation Code.
-
-#include "rlz/win/lib/machine_deal.h"
-
-#include <windows.h>
-#include <vector>
-
-#include "base/basictypes.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/string_split.h"
-#include "base/string_util.h"
-#include "base/stringprintf.h"
-#include "base/win/registry.h"
-#include "rlz/lib/assert.h"
-#include "rlz/lib/lib_values.h"
-#include "rlz/win/lib/lib_mutex.h"
-#include "rlz/win/lib/registry_util.h"
-#include "rlz/win/lib/rlz_value_store_registry.h"
-
-const wchar_t kDccValueName[] = L"DCC";
-
-namespace {
-
-// Current DCC can only uses [a-zA-Z0-9_-!@$*();.<>,:]
-// We will be more liberal and allow some additional chars, but not url meta
-// chars.
-bool IsGoodDccChar(char ch) {
- if (IsAsciiAlpha(ch) || IsAsciiDigit(ch))
- return true;
-
- switch (ch) {
- case '_':
- case '-':
- case '!':
- case '@':
- case '$':
- case '*':
- case '(':
- case ')':
- case ';':
- case '.':
- case '<':
- case '>':
- case ',':
- case ':':
- return true;
- }
-
- return false;
-}
-
-// This function will remove bad rlz chars and also limit the max rlz to some
-// reasonable size. It also assumes that normalized_dcc is at least
-// kMaxDccLength+1 long.
-void NormalizeDcc(const char* raw_dcc, char* normalized_dcc) {
- int index = 0;
- for (; raw_dcc[index] != 0 && index < rlz_lib::kMaxDccLength; ++index) {
- char current = raw_dcc[index];
- if (IsGoodDccChar(current)) {
- normalized_dcc[index] = current;
- } else {
- normalized_dcc[index] = '.';
- }
- }
-
- normalized_dcc[index] = 0;
-}
-
-bool GetResponseLine(const char* response_text, int response_length,
- int* search_index, std::string* response_line) {
- if (!response_line || !search_index || *search_index > response_length)
- return false;
-
- response_line->clear();
-
- if (*search_index < 0)
- return false;
-
- int line_begin = *search_index;
- const char* line_end = strchr(response_text + line_begin, '\n');
-
- if (line_end == NULL || line_end - response_text > response_length) {
- line_end = response_text + response_length;
- *search_index = -1;
- } else {
- *search_index = line_end - response_text + 1;
- }
-
- response_line->assign(response_text + line_begin,
- line_end - response_text - line_begin);
- return true;
-}
-
-bool GetResponseValue(const std::string& response_line,
- const std::string& response_key,
- std::string* value) {
- if (!value)
- return false;
-
- value->clear();
-
- if (!StartsWithASCII(response_line, response_key, true))
- return false;
-
- std::vector<std::string> tokens;
- base::SplitString(response_line, ':', &tokens);
- if (tokens.size() != 2)
- return false;
-
- // The first token is the key, the second is the value. The value is already
- // trimmed for whitespace.
- *value = tokens[1];
- return true;
-}
-
-} // namespace anonymous
-
-namespace rlz_lib {
-
-bool MachineDealCode::Set(const char* dcc) {
- LibMutex lock;
- if (lock.failed())
- return false;
-
- // TODO: if (!ProcessInfo::CanWriteMachineKey()) return false;
-
- // Validate the new dcc value.
- size_t length = strlen(dcc);
- if (length > kMaxDccLength) {
- ASSERT_STRING("MachineDealCode::Set: DCC length is exceeds max allowed.");
- return false;
- }
-
- base::win::RegKey hklm_key(HKEY_LOCAL_MACHINE,
- RlzValueStoreRegistry::GetWideLibKeyName().c_str(),
- KEY_READ | KEY_WRITE | KEY_WOW64_32KEY);
- if (!hklm_key.Valid()) {
- ASSERT_STRING("MachineDealCode::Set: Unable to create / open machine key."
- " Did you call rlz_lib::CreateMachineState()?");
- return false;
- }
-
- char normalized_dcc[kMaxDccLength + 1];
- NormalizeDcc(dcc, normalized_dcc);
- VERIFY(length == strlen(normalized_dcc));
-
- // Write the DCC to HKLM. Note that we need to include the null character
- // when writing the string.
- if (!RegKeyWriteValue(hklm_key, kDccValueName, normalized_dcc)) {
- ASSERT_STRING("MachineDealCode::Set: Could not write the DCC value");
- return false;
- }
-
- return true;
-}
-
-bool MachineDealCode::GetNewCodeFromPingResponse(const char* response,
- bool* has_new_dcc, char* new_dcc, int new_dcc_size) {
- if (!has_new_dcc || !new_dcc || !new_dcc_size)
- return false;
-
- *has_new_dcc = false;
- new_dcc[0] = 0;
-
- int response_length = -1;
- if (!IsPingResponseValid(response, &response_length))
- return false;
-
- // Get the current DCC value to compare to later)
- char stored_dcc[kMaxDccLength + 1];
- if (!Get(stored_dcc, arraysize(stored_dcc)))
- stored_dcc[0] = 0;
-
- int search_index = 0;
- std::string response_line;
- std::string new_dcc_value;
- bool old_dcc_confirmed = false;
- const std::string dcc_cgi(kDccCgiVariable);
- const std::string dcc_cgi_response(kSetDccResponseVariable);
- while (GetResponseLine(response, response_length, &search_index,
- &response_line)) {
- std::string value;
-
- if (!old_dcc_confirmed &&
- GetResponseValue(response_line, dcc_cgi, &value)) {
- // This is the old DCC confirmation - should match value in registry.
- if (value != stored_dcc)
- return false; // Corrupted DCC - ignore this response.
- else
- old_dcc_confirmed = true;
- continue;
- }
-
- if (!(*has_new_dcc) &&
- GetResponseValue(response_line, dcc_cgi_response, &value)) {
- // This is the new DCC.
- if (value.size() > kMaxDccLength) continue; // Too long
- *has_new_dcc = true;
- new_dcc_value = value;
- }
- }
-
- old_dcc_confirmed |= (NULL == stored_dcc[0]);
-
- base::strlcpy(new_dcc, new_dcc_value.c_str(), new_dcc_size);
- return old_dcc_confirmed;
-}
-
-bool MachineDealCode::SetFromPingResponse(const char* response) {
- bool has_new_dcc = false;
- char new_dcc[kMaxDccLength + 1];
-
- bool response_valid = GetNewCodeFromPingResponse(
- response, &has_new_dcc, new_dcc, arraysize(new_dcc));
-
- if (response_valid && has_new_dcc)
- return Set(new_dcc);
-
- return response_valid;
-}
-
-bool MachineDealCode::GetAsCgi(char* cgi, int cgi_size) {
- if (!cgi || cgi_size <= 0) {
- ASSERT_STRING("MachineDealCode::GetAsCgi: Invalid buffer");
- return false;
- }
-
- cgi[0] = 0;
-
- std::string cgi_arg;
- base::StringAppendF(&cgi_arg, "%s=", kDccCgiVariable);
- int cgi_arg_length = cgi_arg.size();
-
- if (cgi_arg_length >= cgi_size) {
- ASSERT_STRING("MachineDealCode::GetAsCgi: Insufficient buffer size");
- return false;
- }
-
- base::strlcpy(cgi, cgi_arg.c_str(), cgi_size);
-
- if (!Get(cgi + cgi_arg_length, cgi_size - cgi_arg_length)) {
- cgi[0] = 0;
- return false;
- }
- return true;
-}
-
-bool MachineDealCode::Get(char* dcc, int dcc_size) {
- LibMutex lock;
- if (lock.failed())
- return false;
-
- if (!dcc || dcc_size <= 0) {
- ASSERT_STRING("MachineDealCode::Get: Invalid buffer");
- return false;
- }
-
- dcc[0] = 0;
-
- base::win::RegKey dcc_key(HKEY_LOCAL_MACHINE,
- RlzValueStoreRegistry::GetWideLibKeyName().c_str(),
- KEY_READ | KEY_WOW64_32KEY);
- if (!dcc_key.Valid())
- return false; // no DCC key.
-
- size_t size = dcc_size;
- if (!RegKeyReadValue(dcc_key, kDccValueName, dcc, &size)) {
- ASSERT_STRING("MachineDealCode::Get: Insufficient buffer size");
- dcc[0] = 0;
- return false;
- }
-
- return true;
-}
-
-bool MachineDealCode::Clear() {
- base::win::RegKey dcc_key(HKEY_LOCAL_MACHINE,
- RlzValueStoreRegistry::GetWideLibKeyName().c_str(),
- KEY_READ | KEY_WRITE | KEY_WOW64_32KEY);
- if (!dcc_key.Valid())
- return false; // no DCC key.
-
- dcc_key.DeleteValue(kDccValueName);
-
- // Verify deletion.
- wchar_t dcc[kMaxDccLength + 1];
- DWORD dcc_size = arraysize(dcc);
- if (dcc_key.ReadValue(kDccValueName, dcc, &dcc_size, NULL) == ERROR_SUCCESS) {
- ASSERT_STRING("MachineDealCode::Clear: Could not delete the DCC value.");
- return false;
- }
-
- return true;
-}
-
-} // namespace rlz_lib
« no previous file with comments | « rlz/win/lib/machine_deal.h ('k') | rlz/win/lib/machine_deal_test.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698