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

Unified Diff: chromeos/network/onc/onc_certificate_importer.h

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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chromeos/network/network_event_log_unittest.cc ('k') | chromeos/network/onc/onc_certificate_importer.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chromeos/network/onc/onc_certificate_importer.h
diff --git a/chrome/browser/chromeos/network_settings/onc_certificate_importer.h b/chromeos/network/onc/onc_certificate_importer.h
similarity index 63%
rename from chrome/browser/chromeos/network_settings/onc_certificate_importer.h
rename to chromeos/network/onc/onc_certificate_importer.h
index 10cc185bdb99db7fa93e7e1b5b3fe511a0677038..bb64f81abe0732a068e6b1d69f288d97ff42fc83 100644
--- a/chrome/browser/chromeos/network_settings/onc_certificate_importer.h
+++ b/chromeos/network/onc/onc_certificate_importer.h
@@ -2,8 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_BROWSER_CHROMEOS_NETWORK_SETTINGS_ONC_CERTIFICATE_IMPORTER_H_
-#define CHROME_BROWSER_CHROMEOS_NETWORK_SETTINGS_ONC_CERTIFICATE_IMPORTER_H_
+#ifndef CHROMEOS_NETWORK_ONC_ONC_CERTIFICATE_IMPORTER_H_
+#define CHROMEOS_NETWORK_ONC_ONC_CERTIFICATE_IMPORTER_H_
#include <string>
#include <vector>
@@ -11,7 +11,8 @@
#include "base/basictypes.h"
#include "base/memory/ref_counted.h"
#include "base/memory/scoped_ptr.h"
-#include "chrome/browser/chromeos/cros/network_ui_data.h"
+#include "chromeos/chromeos_export.h"
+#include "chromeos/network/onc/onc_constants.h"
namespace base {
class DictionaryValue;
@@ -29,25 +30,31 @@ namespace onc {
// This class handles certificate imports from ONC (both policy and user
// imports) into the certificate store. In particular, the GUID of certificates
// is stored together with the certificate as Nickname.
-class CertificateImporter {
+class CHROMEOS_EXPORT CertificateImporter {
public:
+ enum ParseResult {
+ IMPORT_OK,
+ IMPORT_INCOMPLETE,
+ IMPORT_FAILED,
+ };
+
// Certificates pushed from a policy source with Web trust are only imported
// with ParseCertificate() if the |allow_web_trust_from_policy| permission is
// granted.
- CertificateImporter(NetworkUIData::ONCSource onc_source,
+ CertificateImporter(ONCSource onc_source,
bool allow_web_trust_from_policy);
// Parses and stores the certificates in |onc_certificates| into the
// certificate store. If the "Remove" field of a certificate is enabled, then
- // removes the certificate from the store instead of importing. Returns false
- // and sets |error| to a user readable message if an error occured. In that
- // case, some of the certificates may already be stored/removed. Otherwise, if
- // no error occured, returns true and doesn't modify |error|.
- bool ParseAndStoreCertificates(const base::ListValue& onc_certificates,
- std::string* error);
+ // removes the certificate from the store instead of importing. Returns the
+ // result of the parse operation. In case of IMPORT_INCOMPLETE, some of the
+ // certificates may be stored/removed successfully while others had errors.
+ // If no error occurred, returns IMPORT_OK.
+ ParseResult ParseAndStoreCertificates(
+ const base::ListValue& onc_certificates);
// Parses and stores/removes |certificate| in/from the certificate
- // store. Returns false if an error occured. Returns true otherwise.
+ // store. Returns true if the operation succeeded.
bool ParseAndStoreCertificate(const base::DictionaryValue& certificate);
// Lists the certificates that have the string |label| as their certificate
@@ -61,27 +68,24 @@ class CertificateImporter {
static bool DeleteCertAndKeyByNickname(const std::string& label);
private:
- bool ParseServerOrCaCertificate(
- const std::string& cert_type,
- const std::string& guid,
- const base::DictionaryValue& certificate);
- bool ParseClientCertificate(
- const std::string& guid,
- const base::DictionaryValue& certificate);
+ bool ParseServerOrCaCertificate(const std::string& cert_type,
+ const std::string& guid,
+ const base::DictionaryValue& certificate);
+
+ bool ParseClientCertificate(const std::string& guid,
+ const base::DictionaryValue& certificate);
// Where the ONC blob comes from.
- NetworkUIData::ONCSource onc_source_;
+ ONCSource onc_source_;
// Whether certificates with Web trust should be stored when pushed from a
// policy source.
bool allow_web_trust_from_policy_;
- std::string error_;
-
DISALLOW_COPY_AND_ASSIGN(CertificateImporter);
};
} // chromeos
} // onc
-#endif // CHROME_BROWSER_CHROMEOS_NETWORK_SETTINGS_ONC_CERTIFICATE_IMPORTER_H_
+#endif // CHROMEOS_NETWORK_ONC_ONC_CERTIFICATE_IMPORTER_H_
« no previous file with comments | « chromeos/network/network_event_log_unittest.cc ('k') | chromeos/network/onc/onc_certificate_importer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698