| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #ifndef NET_CERT_X509_UTIL_NSS_H_ | 5 #ifndef NET_CERT_X509_UTIL_NSS_H_ |
| 6 #define NET_CERT_X509_UTIL_NSS_H_ | 6 #define NET_CERT_X509_UTIL_NSS_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/time.h" | 11 #include "base/time.h" |
| 12 #include "net/base/net_export.h" | 12 #include "net/base/net_export.h" |
| 13 #include "net/cert/x509_certificate.h" | 13 #include "net/cert/x509_certificate.h" |
| 14 | 14 |
| 15 class PickleIterator; | 15 class PickleIterator; |
| 16 | 16 |
| 17 typedef struct CERTCertificateStr CERTCertificate; | 17 typedef struct CERTCertificateStr CERTCertificate; |
| 18 typedef struct CERTNameStr CERTName; | 18 typedef struct CERTNameStr CERTName; |
| 19 typedef struct PK11SlotInfoStr PK11SlotInfo; | 19 typedef struct PK11SlotInfoStr PK11SlotInfo; |
| 20 typedef struct PLArenaPool PLArenaPool; | 20 typedef struct PLArenaPool PLArenaPool; |
| 21 typedef struct SECItemStr SECItem; | 21 typedef struct SECItemStr SECItem; |
| 22 typedef struct SECKEYPrivateKeyStr SECKEYPrivateKey; | |
| 23 typedef struct SECKEYPublicKeyStr SECKEYPublicKey; | |
| 24 | 22 |
| 25 namespace net { | 23 namespace net { |
| 26 | 24 |
| 27 namespace x509_util { | 25 namespace x509_util { |
| 28 | 26 |
| 29 // Creates a self-signed certificate containing |public_key|. Subject, serial | |
| 30 // number and validity period are given as parameters. The certificate is | |
| 31 // signed by |private_key|. The hashing algorithm for the signature is SHA-1. | |
| 32 // |subject| is a distinguished name defined in RFC4514. | |
| 33 NET_EXPORT_PRIVATE CERTCertificate* CreateSelfSignedCert( | |
| 34 SECKEYPublicKey* public_key, | |
| 35 SECKEYPrivateKey* private_key, | |
| 36 const std::string& subject, | |
| 37 uint32 serial_number, | |
| 38 base::Time not_valid_before, | |
| 39 base::Time not_valid_after); | |
| 40 | |
| 41 #if defined(USE_NSS) || defined(OS_IOS) | 27 #if defined(USE_NSS) || defined(OS_IOS) |
| 42 // Parses the Principal attribute from |name| and outputs the result in | 28 // Parses the Principal attribute from |name| and outputs the result in |
| 43 // |principal|. | 29 // |principal|. |
| 44 void ParsePrincipal(CERTName* name, | 30 void ParsePrincipal(CERTName* name, |
| 45 CertPrincipal* principal); | 31 CertPrincipal* principal); |
| 46 | 32 |
| 47 // Parses the date from |der_date| and outputs the result in |result|. | 33 // Parses the date from |der_date| and outputs the result in |result|. |
| 48 void ParseDate(const SECItem* der_date, base::Time* result); | 34 void ParseDate(const SECItem* der_date, base::Time* result); |
| 49 | 35 |
| 50 // Parses the serial number from |certificate|. | 36 // Parses the serial number from |certificate|. |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 104 std::string GetUniqueNicknameForSlot(const std::string& nickname, | 90 std::string GetUniqueNicknameForSlot(const std::string& nickname, |
| 105 const SECItem* subject, | 91 const SECItem* subject, |
| 106 PK11SlotInfo* slot); | 92 PK11SlotInfo* slot); |
| 107 #endif // defined(USE_NSS) || defined(OS_IOS) | 93 #endif // defined(USE_NSS) || defined(OS_IOS) |
| 108 | 94 |
| 109 } // namespace x509_util | 95 } // namespace x509_util |
| 110 | 96 |
| 111 } // namespace net | 97 } // namespace net |
| 112 | 98 |
| 113 #endif // NET_CERT_X509_UTIL_NSS_H_ | 99 #endif // NET_CERT_X509_UTIL_NSS_H_ |
| OLD | NEW |