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

Side by Side Diff: chrome/browser/chromeos/policy/login_profile_policy_provider.cc

Issue 16658015: Add device policies to control accessibility settings on the login screen (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix copy&paste mistake found by clang. Created 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/chromeos/policy/login_profile_policy_provider.h"
6
7 #include <string>
8
9 #include "base/bind.h"
10 #include "base/memory/scoped_ptr.h"
11 #include "base/values.h"
12 #include "chrome/browser/policy/policy_bundle.h"
13 #include "chrome/browser/policy/policy_map.h"
14 #include "chrome/browser/policy/policy_types.h"
15 #include "policy/policy_constants.h"
16
17 namespace policy {
18
19 namespace {
20
21 // Applies the value of |device_policy| in |device_policy_map| as the
22 // recommended value of |user_policy| in |user_policy_map|. If the value of
23 // |device_policy| is unset, does nothing.
24 void ApplyDevicePolicy(const std::string& device_policy,
25 const std::string& user_policy,
26 const PolicyMap& device_policy_map,
27 PolicyMap* user_policy_map) {
28 const base::Value* value = device_policy_map.GetValue(device_policy);
29 if (value) {
30 user_policy_map->Set(user_policy,
31 POLICY_LEVEL_RECOMMENDED,
32 POLICY_SCOPE_USER,
33 value->DeepCopy());
34 }
35 }
36
37 } // namespace
38
39 LoginProfilePolicyProvider::LoginProfilePolicyProvider(
40 PolicyService* device_policy_service)
41 : device_policy_service_(device_policy_service),
42 weak_factory_(this) {
43 }
44
45 LoginProfilePolicyProvider::~LoginProfilePolicyProvider() {
46 }
47
48 void LoginProfilePolicyProvider::Init() {
49 ConfigurationPolicyProvider::Init();
50 device_policy_service_->AddObserver(POLICY_DOMAIN_CHROME, this);
51 if (device_policy_service_->IsInitializationComplete(POLICY_DOMAIN_CHROME))
52 UpdateFromDevicePolicy();
53 }
54
55 void LoginProfilePolicyProvider::Shutdown() {
56 device_policy_service_->RemoveObserver(POLICY_DOMAIN_CHROME, this);
57 weak_factory_.InvalidateWeakPtrs();
58 ConfigurationPolicyProvider::Shutdown();
59 }
60
61 bool LoginProfilePolicyProvider::IsInitializationComplete(
62 PolicyDomain domain) const {
63 if (domain == POLICY_DOMAIN_CHROME)
64 return device_policy_service_->IsInitializationComplete(domain);
Mattias Nissler (ping if slow) 2013/06/12 13:55:16 This might hold startup, have you checked?
bartfab (slow) 2013/06/12 18:57:49 Removed so that ConfigurationPolicyProvider::IsIni
65 return true;
66 }
67
68 void LoginProfilePolicyProvider::RefreshPolicies() {
69 device_policy_service_->RefreshPolicies(base::Bind(
70 &LoginProfilePolicyProvider::UpdateFromDevicePolicy,
71 weak_factory_.GetWeakPtr()));
Mattias Nissler (ping if slow) 2013/06/12 13:55:16 The contract is that if you receive a RefreshPolic
bartfab (slow) 2013/06/12 18:57:49 Done. The correct implementation is slightly diffe
72 }
73
74 void LoginProfilePolicyProvider::OnPolicyUpdated(const PolicyNamespace& ns,
75 const PolicyMap& previous,
76 const PolicyMap& current) {
77 if (ns == PolicyNamespace(POLICY_DOMAIN_CHROME, std::string()))
78 UpdateFromDevicePolicy();
79 }
80
81 void LoginProfilePolicyProvider::OnPolicyServiceInitialized(
82 PolicyDomain domain) {
83 if (domain == POLICY_DOMAIN_CHROME)
84 UpdateFromDevicePolicy();
85 }
86
87 void LoginProfilePolicyProvider::UpdateFromDevicePolicy() {
88 const PolicyNamespace chrome_namespaces(POLICY_DOMAIN_CHROME, std::string());
89 const PolicyMap& device_policy_map =
90 device_policy_service_->GetPolicies(chrome_namespaces);
91 scoped_ptr<PolicyBundle> bundle(new PolicyBundle);
92 PolicyMap& user_policy_map = bundle->Get(chrome_namespaces);
93
94 ApplyDevicePolicy(key::kLoginScreenDefaultLargeCursorEnabled,
95 key::kLargeCursorEnabled,
96 device_policy_map, &user_policy_map);
97 ApplyDevicePolicy(key::kLoginScreenDefaultSpokenFeedbackEnabled,
98 key::kSpokenFeedbackEnabled,
99 device_policy_map, &user_policy_map);
100 ApplyDevicePolicy(key::kLoginScreenDefaultHighContrastEnabled,
101 key::kHighContrastEnabled,
102 device_policy_map, &user_policy_map);
103 ApplyDevicePolicy(key::kLoginScreenDefaultScreenMagnifierType,
104 key::kScreenMagnifierType,
105 device_policy_map, &user_policy_map);
106 UpdatePolicy(bundle.Pass());
107 }
108
109 } // namespace policy
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698