// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROMEOS_NETWORK_CERTIFICATE_PATTERN_H_ #define CHROMEOS_NETWORK_CERTIFICATE_PATTERN_H_ #include #include #include "chromeos/chromeos_export.h" namespace base { class DictionaryValue; } namespace chromeos { // Class to represent the DER fields of an issuer or a subject in a // certificate and compare them. class CHROMEOS_EXPORT IssuerSubjectPattern { public: IssuerSubjectPattern(); IssuerSubjectPattern(const std::string& common_name, const std::string& locality, const std::string& organization, const std::string& organizational_unit); ~IssuerSubjectPattern(); // Returns true if all fields in the pattern are empty. bool Empty() const; // Clears out all values in this pattern (so Empty returns true). void Clear(); void set_common_name(const std::string& name) { common_name_ = name; } void set_locality(const std::string& locality) { locality_ = locality; } void set_organization(const std::string& organization) { organization_ = organization; } void set_organizational_unit(const std::string& unit) { organizational_unit_ = unit; } const std::string& common_name() const { return common_name_; } const std::string& locality() const { return locality_; } const std::string& organization() const { return organization_; } const std::string& organizational_unit() const { return organizational_unit_; } // Creates a new dictionary with the issuer subject pattern as its contents. // Caller assumes ownership. base::DictionaryValue* CreateAsDictionary() const; bool CopyFromDictionary(const base::DictionaryValue& dictionary); private: std::string common_name_; std::string locality_; std::string organization_; std::string organizational_unit_; }; // A class to contain a certificate pattern and find existing matches to the // pattern in the certificate database. class CHROMEOS_EXPORT CertificatePattern { public: CertificatePattern(); ~CertificatePattern(); // Returns true if this pattern has nothing set (and so would match // all certs). Ignores enrollment_uri_; bool Empty() const; // Clears out all the values in this pattern (so Empty returns true). void Clear(); void set_issuer_ca_ref_list(const std::vector& ref_list) { issuer_ca_ref_list_ = ref_list; } void set_issuer(const IssuerSubjectPattern& issuer) { issuer_ = issuer; } void set_subject(const IssuerSubjectPattern& subject) { subject_ = subject; } void set_enrollment_uri_list(const std::vector& uri_list) { enrollment_uri_list_ = uri_list; } const IssuerSubjectPattern& issuer() const { return issuer_; } const IssuerSubjectPattern& subject() const { return subject_; } const std::vector& issuer_ca_ref_list() const { return issuer_ca_ref_list_; } const std::vector& enrollment_uri_list() const { return enrollment_uri_list_; } // Creates a new dictionary containing the data in the certificate pattern. base::DictionaryValue* CreateAsDictionary() const; // Replaces the contents of this CertificatePattern object with // the values in the dictionary. Returns false if the dictionary is // malformed. bool CopyFromDictionary(const base::DictionaryValue& dictionary); private: std::vector issuer_ca_ref_list_; IssuerSubjectPattern issuer_; IssuerSubjectPattern subject_; std::vector enrollment_uri_list_; }; } // namespace chromeos #endif // CHROMEOS_NETWORK_CERTIFICATE_PATTERN_H_