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

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

Issue 11299236: This moves the ONC parsing code into chromeos/network/onc (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix unit tests Created 8 years 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) 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 Normalizer::~Normalizer() {
22 }
23
24 scoped_ptr<base::DictionaryValue> Normalizer::NormalizeObject(
25 const OncValueSignature* object_signature,
26 const base::DictionaryValue& onc_object) {
27 CHECK(object_signature != NULL);
28 return MapObject(*object_signature, onc_object);
29 }
30
31 scoped_ptr<base::DictionaryValue> Normalizer::MapObject(
32 const OncValueSignature& signature,
33 const base::DictionaryValue& onc_object) {
34 scoped_ptr<base::DictionaryValue> normalized =
35 Mapper::MapObject(signature, onc_object);
36
37 if (normalized.get() == NULL)
38 return scoped_ptr<base::DictionaryValue>();
39
40 if (remove_recommended_fields_)
41 normalized->RemoveWithoutPathExpansion(kRecommended, NULL);
42
43 if (&signature == &kNetworkConfigurationSignature)
44 NormalizeNetworkConfiguration(normalized.get());
45 else if (&signature == &kVPNSignature)
46 NormalizeVPN(normalized.get());
47 else if (&signature == &kIPsecSignature)
48 NormalizeIPsec(normalized.get());
49
50 return normalized.Pass();
51 }
52
53 namespace {
54 void RemoveEntryUnless(base::DictionaryValue* dict,
55 const std::string path,
56 bool condition) {
57 if (!condition)
58 dict->RemoveWithoutPathExpansion(path, NULL);
59 }
60 } // namespace
61
62 void Normalizer::NormalizeIPsec(base::DictionaryValue* ipsec) {
63 using namespace vpn;
64
65 std::string auth_type;
66 ipsec->GetStringWithoutPathExpansion(kAuthenticationType, &auth_type);
67 RemoveEntryUnless(ipsec, kClientCertType, auth_type == kCert);
68 RemoveEntryUnless(ipsec, kServerCARef, auth_type == kCert);
69 RemoveEntryUnless(ipsec, kPSK, auth_type == kPSK);
70 RemoveEntryUnless(ipsec, kSaveCredentials, auth_type == kPSK);
71
72 std::string clientcert_type;
73 ipsec->GetStringWithoutPathExpansion(kClientCertType, &clientcert_type);
74 RemoveEntryUnless(ipsec, kClientCertPattern,
75 clientcert_type == certificate::kPattern);
76 RemoveEntryUnless(ipsec, kClientCertRef,
77 clientcert_type == certificate::kRef);
78
79 int ike_version = -1;
80 ipsec->GetIntegerWithoutPathExpansion(kIKEVersion, &ike_version);
81 RemoveEntryUnless(ipsec, kEAP, ike_version == 2);
82 RemoveEntryUnless(ipsec, kGroup, ike_version == 1);
83 RemoveEntryUnless(ipsec, kXAUTH, ike_version == 1);
84 }
85
86 void Normalizer::NormalizeVPN(base::DictionaryValue* vpn) {
87 using namespace vpn;
88 std::string type;
89 vpn->GetStringWithoutPathExpansion(vpn::kType, &type);
90 RemoveEntryUnless(vpn, kOpenVPN, type == kOpenVPN);
91 RemoveEntryUnless(vpn, kIPsec, type == kIPsec || type == kTypeL2TP_IPsec);
92 RemoveEntryUnless(vpn, kL2TP, type == kTypeL2TP_IPsec);
93 }
94
95 void Normalizer::NormalizeNetworkConfiguration(base::DictionaryValue* network) {
96 std::string type;
97 network->GetStringWithoutPathExpansion(kType, &type);
98 RemoveEntryUnless(network, kEthernet, type == kEthernet);
99 RemoveEntryUnless(network, kVPN, type == kVPN);
100 RemoveEntryUnless(network, kWiFi, type == kWiFi);
101 }
102
103 } // namespace onc
104 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698