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

Unified Diff: chrome/browser/chromeos/login/signed_settings_cache.cc

Issue 10824112: Move Chrome OS device settings stuff to chrome/browser/chromeos/settings. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase. Created 8 years, 5 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
Index: chrome/browser/chromeos/login/signed_settings_cache.cc
diff --git a/chrome/browser/chromeos/login/signed_settings_cache.cc b/chrome/browser/chromeos/login/signed_settings_cache.cc
deleted file mode 100644
index 5e0dec19bc32be1be5f0fb4768ea8496bebfbcdc..0000000000000000000000000000000000000000
--- a/chrome/browser/chromeos/login/signed_settings_cache.cc
+++ /dev/null
@@ -1,133 +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.
-
-#include "chrome/browser/chromeos/login/signed_settings_cache.h"
-
-#include <string>
-
-#include "base/base64.h"
-#include "base/bind.h"
-#include "chrome/browser/chromeos/cros_settings.h"
-#include "chrome/browser/chromeos/login/ownership_service.h"
-#include "chrome/browser/chromeos/login/signed_settings_helper.h"
-#include "chrome/browser/policy/proto/device_management_backend.pb.h"
-#include "chrome/browser/prefs/pref_service.h"
-#include "chrome/common/pref_names.h"
-
-using content::BrowserThread;
-
-namespace em = enterprise_management;
-
-namespace chromeos {
-
-namespace {
-
-void OnStorePolicyCompleted(SignedSettings::ReturnCode code) {
- if (code != SignedSettings::SUCCESS)
- LOG(ERROR) << "Couldn't save temp store to the policy blob. code: " << code;
- else
- CrosSettings::Get()->ReloadProviders();
-}
-
-void FinishFinalize(PrefService* local_state,
- SignedSettings::ReturnCode code,
- const em::PolicyFetchResponse& policy) {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
-
- if (code != SignedSettings::SUCCESS) {
- LOG(ERROR) << "Can't finalize temp store error code:" << code;
- return;
- }
-
- if (local_state) {
- std::string encoded =
- local_state->GetString(prefs::kSignedSettingsCache);
- std::string policy_string;
- if (!base::Base64Decode(encoded, &policy_string)) {
- LOG(ERROR) << "Can't decode policy from base64 on finalizing.";
- return;
- }
-
- em::PolicyData merging_policy_data;
- if (!merging_policy_data.ParseFromString(policy_string)) {
- LOG(ERROR) << "Can't decode policy from string on finalizing.";
- return;
- }
-
- em::PolicyFetchResponse policy_envelope = policy;
- DCHECK(policy_envelope.has_policy_data());
- em::PolicyData base_policy_data;
- base_policy_data.ParseFromString(policy_envelope.policy_data());
- // Merge only the policy value as we should never ever rewrite the other
- // fields of the PolicyData protobuf.
- base_policy_data.set_policy_value(merging_policy_data.policy_value());
- policy_envelope.set_policy_data(base_policy_data.SerializeAsString());
- DCHECK(base_policy_data.has_username());
- policy_envelope.clear_policy_data_signature();
- SignedSettingsHelper::Get()->StartStorePolicyOp(
- policy_envelope, base::Bind(&OnStorePolicyCompleted));
- }
-}
-
-// Reload the initial policy blob, and if successful apply the settings from
-// temp storage, and write them back the blob in FinishFinalize.
-void ReloadSignedSettingsAndFinalize(
- PrefService* local_state,
- OwnershipService::Status status,
- bool current_user_is_owner) {
- if (current_user_is_owner) {
- SignedSettingsHelper::Get()->StartRetrievePolicyOp(
- base::Bind(FinishFinalize, local_state));
- }
-}
-
-} // namespace
-
-namespace signed_settings_cache {
-
-void RegisterPrefs(PrefService* local_state) {
- local_state->RegisterStringPref(prefs::kSignedSettingsCache,
- "invalid",
- PrefService::UNSYNCABLE_PREF);
-}
-
-bool Store(const em::PolicyData& policy, PrefService* local_state) {
- if (local_state) {
- std::string policy_string = policy.SerializeAsString();
- std::string encoded;
- if (!base::Base64Encode(policy_string, &encoded)) {
- LOG(ERROR) << "Can't encode policy in base64.";
- return false;
- }
- local_state->SetString(prefs::kSignedSettingsCache, encoded);
- return true;
- }
- return false;
-}
-
-bool Retrieve(em::PolicyData *policy, PrefService* local_state) {
- if (local_state) {
- std::string encoded =
- local_state->GetString(prefs::kSignedSettingsCache);
- std::string policy_string;
- if (!base::Base64Decode(encoded, &policy_string)) {
- // This is normal and happens on first boot.
- VLOG(1) << "Can't decode policy from base64.";
- return false;
- }
- return policy->ParseFromString(policy_string);
- }
- return false;
-}
-
-void Finalize(PrefService* local_state) {
- // First we have to make sure the owner is really logged in because the key
- // notification is generated on every cloud policy key rotation too.
- OwnershipService::GetSharedInstance()->GetStatusAsync(
- base::Bind(&ReloadSignedSettingsAndFinalize, local_state));
-}
-
-} // namespace signed_settings_cache
-
-} // namespace chromeos
« no previous file with comments | « chrome/browser/chromeos/login/signed_settings_cache.h ('k') | chrome/browser/chromeos/login/signed_settings_cache_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698