Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "chromeos/network/onc/onc_translator.h" | 5 #include "chromeos/network/onc/onc_translator.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
| 10 #include "base/json/json_reader.h" | 10 #include "base/json/json_reader.h" |
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 82 // associated to |onc_field_name| and adds it to |onc_object_| at | 82 // associated to |onc_field_name| and adds it to |onc_object_| at |
| 83 // |onc_field_name|. | 83 // |onc_field_name|. |
| 84 void TranslateAndAddNestedObject(const std::string& onc_field_name, | 84 void TranslateAndAddNestedObject(const std::string& onc_field_name, |
| 85 const base::DictionaryValue& dictionary); | 85 const base::DictionaryValue& dictionary); |
| 86 | 86 |
| 87 // Creates an ONC object from |shill_dictionary_| according to the signature | 87 // Creates an ONC object from |shill_dictionary_| according to the signature |
| 88 // associated to |onc_field_name| and adds it to |onc_object_| at | 88 // associated to |onc_field_name| and adds it to |onc_object_| at |
| 89 // |onc_field_name|. | 89 // |onc_field_name|. |
| 90 void TranslateAndAddNestedObject(const std::string& onc_field_name); | 90 void TranslateAndAddNestedObject(const std::string& onc_field_name); |
| 91 | 91 |
| 92 // Sets |onc_field_name| in dictionary |onc_dictionary_name| in |onc_object_| | |
| 93 // to |value| if the dictionary exists. | |
| 94 void SetNestedOncValue(const std::string& onc_dictionary_name, | |
| 95 const std::string& onc_field_name, | |
| 96 const base::Value& value); | |
| 97 | |
| 92 // Translates a list of nested objects and adds the list to |onc_object_| at | 98 // Translates a list of nested objects and adds the list to |onc_object_| at |
| 93 // |onc_field_name|. If there are errors while parsing individual objects or | 99 // |onc_field_name|. If there are errors while parsing individual objects or |
| 94 // if the resulting list contains no entries, the result will not be added to | 100 // if the resulting list contains no entries, the result will not be added to |
| 95 // |onc_object_|. | 101 // |onc_object_|. |
| 96 void TranslateAndAddListOfObjects(const std::string& onc_field_name, | 102 void TranslateAndAddListOfObjects(const std::string& onc_field_name, |
| 97 const base::ListValue& list); | 103 const base::ListValue& list); |
| 98 | 104 |
| 99 // Applies function CopyProperty to each field of |value_signature| and its | 105 // Applies function CopyProperty to each field of |value_signature| and its |
| 100 // base signatures. | 106 // base signatures. |
| 101 void CopyPropertiesAccordingToSignature( | 107 void CopyPropertiesAccordingToSignature( |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 175 shill::kOpenVPNRemoteCertKUProperty, &certKU)) { | 181 shill::kOpenVPNRemoteCertKUProperty, &certKU)) { |
| 176 scoped_ptr<base::ListValue> certKUs(new base::ListValue); | 182 scoped_ptr<base::ListValue> certKUs(new base::ListValue); |
| 177 certKUs->AppendString(certKU); | 183 certKUs->AppendString(certKU); |
| 178 onc_object_->SetWithoutPathExpansion(::onc::openvpn::kRemoteCertKU, | 184 onc_object_->SetWithoutPathExpansion(::onc::openvpn::kRemoteCertKU, |
| 179 certKUs.release()); | 185 certKUs.release()); |
| 180 } | 186 } |
| 181 | 187 |
| 182 for (const OncFieldSignature* field_signature = onc_signature_->fields; | 188 for (const OncFieldSignature* field_signature = onc_signature_->fields; |
| 183 field_signature->onc_field_name != NULL; ++field_signature) { | 189 field_signature->onc_field_name != NULL; ++field_signature) { |
| 184 const std::string& onc_field_name = field_signature->onc_field_name; | 190 const std::string& onc_field_name = field_signature->onc_field_name; |
| 185 if (onc_field_name == ::onc::vpn::kSaveCredentials || | 191 if (onc_field_name == ::onc::openvpn::kRemoteCertKU || |
| 186 onc_field_name == ::onc::openvpn::kRemoteCertKU || | |
| 187 onc_field_name == ::onc::openvpn::kServerCAPEMs) { | 192 onc_field_name == ::onc::openvpn::kServerCAPEMs) { |
| 188 CopyProperty(field_signature); | 193 CopyProperty(field_signature); |
| 189 continue; | 194 continue; |
| 190 } | 195 } |
| 191 | 196 |
| 192 std::string shill_property_name; | 197 std::string shill_property_name; |
| 193 const base::Value* shill_value = NULL; | 198 const base::Value* shill_value = NULL; |
| 194 if (!field_translation_table_ || | 199 if (!field_translation_table_ || |
| 195 !GetShillPropertyName(field_signature->onc_field_name, | 200 !GetShillPropertyName(field_signature->onc_field_name, |
| 196 field_translation_table_, | 201 field_translation_table_, |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 226 } | 231 } |
| 227 } | 232 } |
| 228 | 233 |
| 229 void ShillToONCTranslator::TranslateIPsec() { | 234 void ShillToONCTranslator::TranslateIPsec() { |
| 230 CopyPropertiesAccordingToSignature(); | 235 CopyPropertiesAccordingToSignature(); |
| 231 if (shill_dictionary_->HasKey(shill::kL2tpIpsecXauthUserProperty)) | 236 if (shill_dictionary_->HasKey(shill::kL2tpIpsecXauthUserProperty)) |
| 232 TranslateAndAddNestedObject(::onc::ipsec::kXAUTH); | 237 TranslateAndAddNestedObject(::onc::ipsec::kXAUTH); |
| 233 } | 238 } |
| 234 | 239 |
| 235 void ShillToONCTranslator::TranslateVPN() { | 240 void ShillToONCTranslator::TranslateVPN() { |
| 236 TranslateWithTableAndSet( | |
| 237 shill::kProviderTypeProperty, kVPNTypeTable, ::onc::vpn::kType); | |
| 238 CopyPropertiesAccordingToSignature(); | 241 CopyPropertiesAccordingToSignature(); |
| 239 | 242 |
| 240 std::string vpn_type; | 243 // Parse Shill Provider dictionary. |
| 241 if (onc_object_->GetStringWithoutPathExpansion(::onc::vpn::kType, | 244 const base::DictionaryValue* provider = NULL; |
| 242 &vpn_type)) { | 245 if (!shill_dictionary_->GetDictionaryWithoutPathExpansion( |
| 243 if (vpn_type == ::onc::vpn::kTypeL2TP_IPsec) { | 246 shill::kProviderProperty, &provider)) { |
| 244 TranslateAndAddNestedObject(::onc::vpn::kIPsec); | 247 LOG(ERROR) << "Shill VPN object with no Provider dictionary"; |
| 245 TranslateAndAddNestedObject(::onc::vpn::kL2TP); | 248 return; |
| 246 } else { | 249 } |
| 247 TranslateAndAddNestedObject(vpn_type); | 250 std::string shill_provider_type, onc_provider_type; |
| 251 if (!provider->GetStringWithoutPathExpansion(shill::kTypeProperty, | |
| 252 &shill_provider_type)) { | |
| 253 LOG(ERROR) << "Shill VPN object with no Provider.Type"; | |
|
pneubeck (no reviews)
2014/08/20 08:16:16
alternatively, instead of catching a missing input
stevenjb
2014/08/20 17:18:37
Done.
| |
| 254 return; | |
| 255 } | |
| 256 TranslateStringToONC(kVPNTypeTable, shill_provider_type, &onc_provider_type); | |
| 257 onc_object_->SetStringWithoutPathExpansion(::onc::vpn::kType, | |
| 258 onc_provider_type); | |
| 259 std::string provider_host; | |
| 260 if (provider->GetStringWithoutPathExpansion(shill::kHostProperty, | |
|
pneubeck (no reviews)
2014/08/20 08:16:16
The translation tables were meant for the cases wh
stevenjb
2014/08/20 17:18:37
Ugh. Yeah, I understand your point, but this is te
pneubeck (no reviews)
2014/08/20 19:49:36
Yes, it's tedious. To get rid of it, I would prefe
| |
| 261 &provider_host)) { | |
| 262 onc_object_->SetStringWithoutPathExpansion(::onc::vpn::kHost, | |
| 263 provider_host); | |
| 264 } | |
| 265 | |
| 266 const base::Value* save_credentials = NULL; | |
| 267 shill_dictionary_->GetWithoutPathExpansion(shill::kSaveCredentialsProperty, | |
|
pneubeck (no reviews)
2014/08/20 08:16:16
like the Host property above,
please comment out i
stevenjb
2014/08/20 17:18:37
Done.
| |
| 268 &save_credentials); | |
| 269 if (save_credentials && !save_credentials->IsType(base::Value::TYPE_BOOLEAN)) | |
| 270 save_credentials = NULL; | |
| 271 | |
| 272 // Translate the nested dictionary. | |
| 273 if (onc_provider_type == ::onc::vpn::kTypeL2TP_IPsec) { | |
| 274 TranslateAndAddNestedObject(::onc::vpn::kIPsec, *provider); | |
| 275 TranslateAndAddNestedObject(::onc::vpn::kL2TP, *provider); | |
| 276 if (save_credentials) { | |
| 277 SetNestedOncValue( | |
| 278 ::onc::vpn::kIPsec, ::onc::vpn::kSaveCredentials, *save_credentials); | |
| 279 SetNestedOncValue( | |
|
pneubeck (no reviews)
2014/08/20 08:16:16
nit: wasn't set before and could be removed.
stevenjb
2014/08/20 17:18:37
Done.
| |
| 280 ::onc::vpn::kL2TP, ::onc::vpn::kSaveCredentials, *save_credentials); | |
| 281 } | |
| 282 } else { | |
| 283 TranslateAndAddNestedObject(onc_provider_type, *provider); | |
| 284 if (save_credentials) { | |
| 285 SetNestedOncValue( | |
| 286 onc_provider_type, ::onc::vpn::kSaveCredentials, *save_credentials); | |
| 248 } | 287 } |
| 249 } | 288 } |
| 250 } | 289 } |
| 251 | 290 |
| 252 void ShillToONCTranslator::TranslateWiFiWithState() { | 291 void ShillToONCTranslator::TranslateWiFiWithState() { |
| 253 TranslateWithTableAndSet( | 292 TranslateWithTableAndSet( |
| 254 shill::kSecurityProperty, kWiFiSecurityTable, ::onc::wifi::kSecurity); | 293 shill::kSecurityProperty, kWiFiSecurityTable, ::onc::wifi::kSecurity); |
| 255 std::string ssid = shill_property_util::GetSSIDFromProperties( | 294 std::string ssid = shill_property_util::GetSSIDFromProperties( |
| 256 *shill_dictionary_, NULL /* ignore unknown encoding */); | 295 *shill_dictionary_, NULL /* ignore unknown encoding */); |
| 257 if (!ssid.empty()) | 296 if (!ssid.empty()) |
| (...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 397 const std::string& onc_field_name, | 436 const std::string& onc_field_name, |
| 398 const base::DictionaryValue& dictionary) { | 437 const base::DictionaryValue& dictionary) { |
| 399 const OncFieldSignature* field_signature = | 438 const OncFieldSignature* field_signature = |
| 400 GetFieldSignature(*onc_signature_, onc_field_name); | 439 GetFieldSignature(*onc_signature_, onc_field_name); |
| 401 DCHECK(field_signature) << "Unable to find signature for field " | 440 DCHECK(field_signature) << "Unable to find signature for field " |
| 402 << onc_field_name << "."; | 441 << onc_field_name << "."; |
| 403 ShillToONCTranslator nested_translator(dictionary, | 442 ShillToONCTranslator nested_translator(dictionary, |
| 404 *field_signature->value_signature); | 443 *field_signature->value_signature); |
| 405 scoped_ptr<base::DictionaryValue> nested_object = | 444 scoped_ptr<base::DictionaryValue> nested_object = |
| 406 nested_translator.CreateTranslatedONCObject(); | 445 nested_translator.CreateTranslatedONCObject(); |
| 407 if (nested_object->empty()) | 446 // Note: this may create an empty nested object which is necessary in case |
|
pneubeck (no reviews)
2014/08/20 08:16:16
Instead of potentially creating empty nested objec
stevenjb
2014/08/20 17:18:38
I was trying to avoid code duplication since an em
| |
| 408 return; | 447 // properties are added later with SetNestedOncValue. |
| 409 onc_object_->SetWithoutPathExpansion(onc_field_name, nested_object.release()); | 448 onc_object_->SetWithoutPathExpansion(onc_field_name, nested_object.release()); |
| 410 } | 449 } |
| 411 | 450 |
| 451 void ShillToONCTranslator::SetNestedOncValue( | |
| 452 const std::string& onc_dictionary_name, | |
| 453 const std::string& onc_field_name, | |
| 454 const base::Value& value) { | |
| 455 base::DictionaryValue* nested; | |
| 456 if (!onc_object_->GetDictionaryWithoutPathExpansion( | |
| 457 onc_dictionary_name, &nested)) { | |
| 458 NOTREACHED(); | |
| 459 } | |
| 460 nested->SetWithoutPathExpansion(onc_field_name, value.DeepCopy()); | |
| 461 } | |
| 462 | |
| 412 void ShillToONCTranslator::TranslateAndAddListOfObjects( | 463 void ShillToONCTranslator::TranslateAndAddListOfObjects( |
| 413 const std::string& onc_field_name, | 464 const std::string& onc_field_name, |
| 414 const base::ListValue& list) { | 465 const base::ListValue& list) { |
| 415 const OncFieldSignature* field_signature = | 466 const OncFieldSignature* field_signature = |
| 416 GetFieldSignature(*onc_signature_, onc_field_name); | 467 GetFieldSignature(*onc_signature_, onc_field_name); |
| 417 if (field_signature->value_signature->onc_type != base::Value::TYPE_LIST) { | 468 if (field_signature->value_signature->onc_type != base::Value::TYPE_LIST) { |
| 418 LOG(ERROR) << "ONC Field name: '" << onc_field_name << "' has type '" | 469 LOG(ERROR) << "ONC Field name: '" << onc_field_name << "' has type '" |
| 419 << field_signature->value_signature->onc_type | 470 << field_signature->value_signature->onc_type |
| 420 << "', expected: base::Value::TYPE_LIST."; | 471 << "', expected: base::Value::TYPE_LIST."; |
| 421 return; | 472 return; |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 508 const base::DictionaryValue& shill_dictionary, | 559 const base::DictionaryValue& shill_dictionary, |
| 509 const OncValueSignature* onc_signature) { | 560 const OncValueSignature* onc_signature) { |
| 510 CHECK(onc_signature != NULL); | 561 CHECK(onc_signature != NULL); |
| 511 | 562 |
| 512 ShillToONCTranslator translator(shill_dictionary, *onc_signature); | 563 ShillToONCTranslator translator(shill_dictionary, *onc_signature); |
| 513 return translator.CreateTranslatedONCObject(); | 564 return translator.CreateTranslatedONCObject(); |
| 514 } | 565 } |
| 515 | 566 |
| 516 } // namespace onc | 567 } // namespace onc |
| 517 } // namespace chromeos | 568 } // namespace chromeos |
| OLD | NEW |