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

Side by Side Diff: chrome/browser/ui/webui/policy_ui.cc

Issue 1304843004: Add source column to chrome://policy showing the origins of policies. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 3 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
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/webui/policy_ui.h" 5 #include "chrome/browser/ui/webui/policy_ui.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/callback.h" 9 #include "base/callback.h"
10 #include "base/compiler_specific.h" 10 #include "base/compiler_specific.h"
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
70 #include "extensions/browser/extension_registry_observer.h" 70 #include "extensions/browser/extension_registry_observer.h"
71 #include "extensions/common/extension.h" 71 #include "extensions/common/extension.h"
72 #include "extensions/common/manifest.h" 72 #include "extensions/common/manifest.h"
73 #include "extensions/common/manifest_constants.h" 73 #include "extensions/common/manifest_constants.h"
74 #endif 74 #endif
75 75
76 namespace em = enterprise_management; 76 namespace em = enterprise_management;
77 77
78 namespace { 78 namespace {
79 79
80 struct PolicySourceMap {
81 const char* key;
82 int string_id;
83 };
84
85 // Strings that map from PolicySource enum to i18n string keys and their IDs.
86 const PolicySourceMap kPolicySources[policy::POLICY_SOURCE_COUNT] = {
87 {"", -1}, // policy::POLICY_SOURCE_UNKNOWN
bartfab (slow) 2015/09/14 14:42:26 Will the UI handle ID -1 gracefully? Should there
fhorschig 2015/09/16 13:52:04 The value won't be used as it is mapped to an actu
88 {"sourceEnterprise", IDS_POLICY_SOURCE_ENTERPRISE},
89 {"sourceProgrammatic", IDS_POLICY_SOURCE_PROGRAMMATIC},
90 {"sourcePlatform", IDS_POLICY_SOURCE_PLATFORM},
91 {"sourceCloud", IDS_POLICY_SOURCE_CLOUD}
92 };
93
94 void AddLocalizedPoilcySourceStrings(content::WebUIDataSource* source) {
95 for (int i = 1; i < policy::POLICY_SOURCE_COUNT; ++i) {
96 source->AddLocalizedString(kPolicySources[i].key,
97 kPolicySources[i].string_id);
98 }
99 }
100
80 content::WebUIDataSource* CreatePolicyUIHTMLSource() { 101 content::WebUIDataSource* CreatePolicyUIHTMLSource() {
81 content::WebUIDataSource* source = 102 content::WebUIDataSource* source =
82 content::WebUIDataSource::Create(chrome::kChromeUIPolicyHost); 103 content::WebUIDataSource::Create(chrome::kChromeUIPolicyHost);
83 104
84 // Localized strings. 105 // Localized strings.
85 source->AddLocalizedString("title", IDS_POLICY_TITLE); 106 source->AddLocalizedString("title", IDS_POLICY_TITLE);
86 source->AddLocalizedString("filterPlaceholder", 107 source->AddLocalizedString("filterPlaceholder",
87 IDS_POLICY_FILTER_PLACEHOLDER); 108 IDS_POLICY_FILTER_PLACEHOLDER);
88 source->AddLocalizedString("reloadPolicies", IDS_POLICY_RELOAD_POLICIES); 109 source->AddLocalizedString("reloadPolicies", IDS_POLICY_RELOAD_POLICIES);
89 source->AddLocalizedString("status", IDS_POLICY_STATUS); 110 source->AddLocalizedString("status", IDS_POLICY_STATUS);
(...skipping 11 matching lines...) Expand all
101 source->AddLocalizedString("labelRefreshInterval", 122 source->AddLocalizedString("labelRefreshInterval",
102 IDS_POLICY_LABEL_REFRESH_INTERVAL); 123 IDS_POLICY_LABEL_REFRESH_INTERVAL);
103 source->AddLocalizedString("labelStatus", IDS_POLICY_LABEL_STATUS); 124 source->AddLocalizedString("labelStatus", IDS_POLICY_LABEL_STATUS);
104 source->AddLocalizedString("showUnset", IDS_POLICY_SHOW_UNSET); 125 source->AddLocalizedString("showUnset", IDS_POLICY_SHOW_UNSET);
105 source->AddLocalizedString("noPoliciesSet", IDS_POLICY_NO_POLICIES_SET); 126 source->AddLocalizedString("noPoliciesSet", IDS_POLICY_NO_POLICIES_SET);
106 source->AddLocalizedString("headerScope", IDS_POLICY_HEADER_SCOPE); 127 source->AddLocalizedString("headerScope", IDS_POLICY_HEADER_SCOPE);
107 source->AddLocalizedString("headerLevel", IDS_POLICY_HEADER_LEVEL); 128 source->AddLocalizedString("headerLevel", IDS_POLICY_HEADER_LEVEL);
108 source->AddLocalizedString("headerName", IDS_POLICY_HEADER_NAME); 129 source->AddLocalizedString("headerName", IDS_POLICY_HEADER_NAME);
109 source->AddLocalizedString("headerValue", IDS_POLICY_HEADER_VALUE); 130 source->AddLocalizedString("headerValue", IDS_POLICY_HEADER_VALUE);
110 source->AddLocalizedString("headerStatus", IDS_POLICY_HEADER_STATUS); 131 source->AddLocalizedString("headerStatus", IDS_POLICY_HEADER_STATUS);
132 source->AddLocalizedString("headerSource", IDS_POLICY_HEADER_SOURCE);
111 source->AddLocalizedString("showExpandedValue", 133 source->AddLocalizedString("showExpandedValue",
112 IDS_POLICY_SHOW_EXPANDED_VALUE); 134 IDS_POLICY_SHOW_EXPANDED_VALUE);
113 source->AddLocalizedString("hideExpandedValue", 135 source->AddLocalizedString("hideExpandedValue",
114 IDS_POLICY_HIDE_EXPANDED_VALUE); 136 IDS_POLICY_HIDE_EXPANDED_VALUE);
115 source->AddLocalizedString("scopeUser", IDS_POLICY_SCOPE_USER); 137 source->AddLocalizedString("scopeUser", IDS_POLICY_SCOPE_USER);
116 source->AddLocalizedString("scopeDevice", IDS_POLICY_SCOPE_DEVICE); 138 source->AddLocalizedString("scopeDevice", IDS_POLICY_SCOPE_DEVICE);
117 source->AddLocalizedString("levelRecommended", IDS_POLICY_LEVEL_RECOMMENDED); 139 source->AddLocalizedString("levelRecommended", IDS_POLICY_LEVEL_RECOMMENDED);
118 source->AddLocalizedString("levelMandatory", IDS_POLICY_LEVEL_MANDATORY); 140 source->AddLocalizedString("levelMandatory", IDS_POLICY_LEVEL_MANDATORY);
119 source->AddLocalizedString("ok", IDS_POLICY_OK); 141 source->AddLocalizedString("ok", IDS_POLICY_OK);
120 source->AddLocalizedString("unset", IDS_POLICY_UNSET); 142 source->AddLocalizedString("unset", IDS_POLICY_UNSET);
121 source->AddLocalizedString("unknown", IDS_POLICY_UNKNOWN); 143 source->AddLocalizedString("unknown", IDS_POLICY_UNKNOWN);
122 source->AddLocalizedString("notSpecified", IDS_POLICY_NOT_SPECIFIED); 144 source->AddLocalizedString("notSpecified", IDS_POLICY_NOT_SPECIFIED);
145 AddLocalizedPoilcySourceStrings(source);
123 146
124 source->SetJsonPath("strings.js"); 147 source->SetJsonPath("strings.js");
125 148
126 // Add required resources. 149 // Add required resources.
127 source->AddResourcePath("policy.css", IDR_POLICY_CSS); 150 source->AddResourcePath("policy.css", IDR_POLICY_CSS);
128 source->AddResourcePath("policy.js", IDR_POLICY_JS); 151 source->AddResourcePath("policy.js", IDR_POLICY_JS);
129 source->AddResourcePath("uber_utils.js", IDR_UBER_UTILS_JS); 152 source->AddResourcePath("uber_utils.js", IDR_UBER_UTILS_JS);
130 source->SetDefaultResource(IDR_POLICY_HTML); 153 source->SetDefaultResource(IDR_POLICY_HTML);
131 154
132 return source; 155 return source;
(...skipping 612 matching lines...) Expand 10 before | Expand all | Expand 10 after
745 base::DictionaryValue* value = new base::DictionaryValue; 768 base::DictionaryValue* value = new base::DictionaryValue;
746 value->Set("value", CopyAndConvert(entry->second.value).release()); 769 value->Set("value", CopyAndConvert(entry->second.value).release());
747 if (entry->second.scope == policy::POLICY_SCOPE_USER) 770 if (entry->second.scope == policy::POLICY_SCOPE_USER)
748 value->SetString("scope", "user"); 771 value->SetString("scope", "user");
749 else 772 else
750 value->SetString("scope", "machine"); 773 value->SetString("scope", "machine");
751 if (entry->second.level == policy::POLICY_LEVEL_RECOMMENDED) 774 if (entry->second.level == policy::POLICY_LEVEL_RECOMMENDED)
752 value->SetString("level", "recommended"); 775 value->SetString("level", "recommended");
753 else 776 else
754 value->SetString("level", "mandatory"); 777 value->SetString("level", "mandatory");
778 value->SetString("source", kPolicySources[entry->second.source].key);
755 base::string16 error = errors->GetErrors(entry->first); 779 base::string16 error = errors->GetErrors(entry->first);
756 if (!error.empty()) 780 if (!error.empty())
757 value->SetString("error", error); 781 value->SetString("error", error);
758 values->Set(entry->first, value); 782 values->Set(entry->first, value);
759 } 783 }
760 } 784 }
761 785
762 void PolicyUIHandler::GetChromePolicyValues( 786 void PolicyUIHandler::GetChromePolicyValues(
763 base::DictionaryValue* values) const { 787 base::DictionaryValue* values) const {
764 policy::PolicyService* policy_service = GetPolicyService(); 788 policy::PolicyService* policy_service = GetPolicyService();
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after
837 } 861 }
838 862
839 PolicyUI::PolicyUI(content::WebUI* web_ui) : WebUIController(web_ui) { 863 PolicyUI::PolicyUI(content::WebUI* web_ui) : WebUIController(web_ui) {
840 web_ui->AddMessageHandler(new PolicyUIHandler); 864 web_ui->AddMessageHandler(new PolicyUIHandler);
841 content::WebUIDataSource::Add(Profile::FromWebUI(web_ui), 865 content::WebUIDataSource::Add(Profile::FromWebUI(web_ui),
842 CreatePolicyUIHTMLSource()); 866 CreatePolicyUIHTMLSource());
843 } 867 }
844 868
845 PolicyUI::~PolicyUI() { 869 PolicyUI::~PolicyUI() {
846 } 870 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698