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 |