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

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: Remove translated strings 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
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 57%
rename from chrome/browser/chromeos/network_settings/onc_certificate_importer.h
rename to chromeos/network/onc/onc_certificate_importer.h
index 10cc185bdb99db7fa93e7e1b5b3fe511a0677038..d0aa843a1855efa5678118c2f5fefe36f5e6df1b 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;
@@ -26,29 +27,44 @@ typedef std::vector<scoped_refptr<X509Certificate> > CertificateList;
namespace chromeos {
namespace onc {
+CHROMEOS_EXPORT extern const char kErrorCertDataMalformed[];
pneubeck (no reviews) 2012/12/04 10:43:56 If we want to use the strings as replacements for
Greg Spencer (Chromium) 2012/12/07 18:12:27 We're not returning these anymore.
+CHROMEOS_EXPORT extern const char kErrorCertDataMissing[];
+CHROMEOS_EXPORT extern const char kErrorCertDelete[];
+CHROMEOS_EXPORT extern const char kErrorCertGuidCollision[];
+CHROMEOS_EXPORT extern const char kErrorCertGuidMissing[];
+CHROMEOS_EXPORT extern const char kErrorCertImport[];
+CHROMEOS_EXPORT extern const char kErrorCertTrustInvalid[];
+CHROMEOS_EXPORT extern const char kErrorCertTrustUnknown[];
+CHROMEOS_EXPORT extern const char kErrorCertTypeMissing[];
+CHROMEOS_EXPORT extern const char kErrorUnknown[];
+
// 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:
+
// 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 an error, some of the
+ // certificates may already be stored/removed. Otherwise, if no error
+ // occurred, returns PARSE_OK.
+ bool ParseAndStoreCertificates(
pneubeck (no reviews) 2012/12/04 10:43:56 You don't document the return value anymore. I wo
Greg Spencer (Chromium) 2012/12/07 18:12:27 Fixed this: it now returns an error code, and docu
+ const base::ListValue& onc_certificates,
+ std::string* result);
// Parses and stores/removes |certificate| in/from the certificate
- // store. Returns false if an error occured. Returns true otherwise.
- bool ParseAndStoreCertificate(const base::DictionaryValue& certificate);
+ // store. Returns false if an error occurred. Returns true otherwise.
+ bool ParseAndStoreCertificate(
+ const base::DictionaryValue& certificate,
+ std::string* result);
// Lists the certificates that have the string |label| as their certificate
// nickname (exact match).
@@ -64,24 +80,24 @@ class CertificateImporter {
bool ParseServerOrCaCertificate(
const std::string& cert_type,
const std::string& guid,
- const base::DictionaryValue& certificate);
+ const base::DictionaryValue& certificate,
+ std::string* result);
bool ParseClientCertificate(
pneubeck (no reviews) 2012/12/04 10:43:56 nit: add an empty line
Greg Spencer (Chromium) 2012/12/07 18:12:27 Done.
const std::string& guid,
- const base::DictionaryValue& certificate);
+ const base::DictionaryValue& certificate,
+ std::string* result);
// 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_

Powered by Google App Engine
This is Rietveld 408576698