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

Side by Side Diff: chrome/browser/chromeos/network_settings/onc_normalizer.cc

Issue 10944009: Implementation of ONC signature, validator and normalizer. (Closed) Base URL: http://git.chromium.org/chromium/src.git@gperffix
Patch Set: Addressed comments (formatting, sorting). Minor change in policy.onc. Created 8 years, 2 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "chrome/browser/chromeos/network_settings/onc_normalizer.h"
6
7 #include <string>
8
9 #include "base/logging.h"
10 #include "base/values.h"
11 #include "chrome/browser/chromeos/cros/onc_constants.h"
12 #include "chrome/browser/chromeos/network_settings/onc_signature.h"
13
14 namespace chromeos {
15 namespace onc {
16
17 Normalizer::Normalizer(bool remove_recommended_fields)
18 : remove_recommended_fields_(remove_recommended_fields) {
19 }
20
21 scoped_ptr<base::DictionaryValue> Normalizer::NormalizeObject(
22 const OncValueSignature* object_signature,
23 const base::DictionaryValue& onc_object) {
24 CHECK(object_signature != NULL);
25 scoped_ptr<base::Value> result_value =
26 MapValue(*object_signature, onc_object);
27 base::DictionaryValue* result_dict = NULL;
28 if (result_value.get()) {
29 result_value.release()->GetAsDictionary(&result_dict);
30 CHECK(result_dict != NULL);
31 }
32 return make_scoped_ptr(result_dict);
33 }
34
35 scoped_ptr<base::DictionaryValue> Normalizer::MapObject(
36 const OncValueSignature& signature,
37 const base::DictionaryValue& onc_object) {
38 scoped_ptr<base::DictionaryValue> normalized =
39 Mapper::MapObject(signature, onc_object);
40
41 if (!normalized.get())
42 return scoped_ptr<base::DictionaryValue>();
43
44 if (remove_recommended_fields_)
45 normalized->RemoveWithoutPathExpansion(kRecommended, NULL);
46
47 if (&signature == &network_configuration_signature)
48 NormalizeNetworkConfiguration(normalized.get());
49 else if (&signature == &vpn_signature)
50 NormalizeVPN(normalized.get());
51 else if (&signature == &ipsec_signature)
52 NormalizeIPsec(normalized.get());
53
54 return normalized.Pass();
55 }
56
57 namespace {
58 void RemoveEntryUnless(base::DictionaryValue* dict,
59 const std::string path,
60 bool condition) {
61 if (!condition)
62 dict->RemoveWithoutPathExpansion(path, NULL);
63 }
64 } // namespace
65
66 void NormalizeIPsec(base::DictionaryValue* ipsec) {
67 using namespace vpn;
68
69 std::string auth_type = "";
stevenjb 2012/10/11 19:54:00 nit: = "" is unnecessary here and elsewhere
pneubeck (no reviews) 2012/10/15 13:57:44 Done.
70 ipsec->GetStringWithoutPathExpansion(kAuthenticationType, &auth_type);
71 RemoveEntryUnless(ipsec, kClientCertType, auth_type == "Cert");
stevenjb 2012/10/11 19:54:00 "Cert" and other strings should be consts declared
pneubeck (no reviews) 2012/10/15 13:57:44 I added constants for the possible field values to
72 RemoveEntryUnless(ipsec, kServerCARef, auth_type == "Cert");
73 RemoveEntryUnless(ipsec, kPSK, auth_type == "PSK");
74 RemoveEntryUnless(ipsec, kSaveCredentials, auth_type == "PSK");
75
76 std::string clientcert_type = "";
77 ipsec->GetStringWithoutPathExpansion(kClientCertType, &clientcert_type);
78 RemoveEntryUnless(ipsec, kClientCertPattern, clientcert_type == "Pattern");
79 RemoveEntryUnless(ipsec, kClientCertRef, clientcert_type == "Ref");
80
81 int ike_version = -1;
82 ipsec->GetIntegerWithoutPathExpansion(kIKEVersion, &ike_version);
83 RemoveEntryUnless(ipsec, kEAP, ike_version == 2);
84 RemoveEntryUnless(ipsec, kGroup, ike_version == 1);
85 RemoveEntryUnless(ipsec, kXAUTH, ike_version == 1);
86 }
87
88 void NormalizeVPN(base::DictionaryValue* vpn) {
89 using namespace vpn;
90 std::string type = "";
91 vpn->GetStringWithoutPathExpansion(vpn::kType, &type);
92 RemoveEntryUnless(vpn, kOpenVPN, type == kOpenVPN);
93 RemoveEntryUnless(vpn, kIPsec, type == kIPsec || type == "L2TP-IPsec");
94 RemoveEntryUnless(vpn, kL2TP, type == "L2TP-IPSec");
95 }
96
97 void NormalizeNetworkConfiguration(base::DictionaryValue* network) {
98 std::string type = "";
99 network->GetStringWithoutPathExpansion(kType, &type);
100 RemoveEntryUnless(network, kEthernet, type == kEthernet);
101 RemoveEntryUnless(network, kVPN, type == kVPN);
102 RemoveEntryUnless(network, kWiFi, type == kWiFi);
103 }
104
105 } // namespace onc
106 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698