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

Side by Side Diff: chrome/common/net/x509_certificate_model.h

Issue 3565006: Decouples certificates viewers from NSS to prepare support for OpenSSL. (Closed)
Patch Set: Comments / ProcessIDN Created 10 years, 2 months 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 unified diff | Download patch
« no previous file with comments | « chrome/common/net/DEPS ('k') | chrome/common/net/x509_certificate_model.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef NET_BASE_X509_CERTIFICATE_MODEL_H_
6 #define NET_BASE_X509_CERTIFICATE_MODEL_H_
7 #pragma once
8
9 #include "net/base/cert_database.h"
10 #include "net/base/cert_type.h"
11 #include "net/base/x509_certificate.h"
12
13 // This namespace defines a set of functions to be used in UI-related bits of
14 // X509 certificates. It decouples the UI from the underlying crypto library
15 // (currently NSS or OpenSSL - in development).
16 // This is currently only used by linux, as mac / windows use their own native
17 // certificate viewers and crypto libraries.
18 namespace x509_certificate_model {
19
20 std::string GetCertNameOrNickname(
21 net::X509Certificate::OSCertHandle cert_handle);
22
23 std::string GetTokenName(net::X509Certificate::OSCertHandle cert_handle);
24
25 std::string GetVersion(net::X509Certificate::OSCertHandle cert_handle);
26
27 net::CertType GetType(net::X509Certificate::OSCertHandle cert_handle);
28
29 std::string GetEmailAddress(net::X509Certificate::OSCertHandle cert_handle);
30
31 void GetUsageStrings(
32 net::X509Certificate::OSCertHandle cert_handle,
33 std::vector<std::string>* usages);
34
35 std::string GetKeyUsageString(net::X509Certificate::OSCertHandle cert_handle);
36
37 std::string GetSerialNumberHexified(
38 net::X509Certificate::OSCertHandle cert_handle,
39 const std::string& alternative_text);
40
41 std::string GetIssuerCommonName(
42 net::X509Certificate::OSCertHandle cert_handle,
43 const std::string& alternative_text);
44
45 std::string GetIssuerOrgName(
46 net::X509Certificate::OSCertHandle cert_handle,
47 const std::string& alternative_text);
48
49 std::string GetIssuerOrgUnitName(
50 net::X509Certificate::OSCertHandle cert_handle,
51 const std::string& alternative_text);
52
53 std::string GetSubjectOrgName(
54 net::X509Certificate::OSCertHandle cert_handle,
55 const std::string& alternative_text);
56
57 std::string GetSubjectOrgUnitName(
58 net::X509Certificate::OSCertHandle cert_handle,
59 const std::string& alternative_text);
60
61 std::string GetSubjectCommonName(
62 net::X509Certificate::OSCertHandle cert_handle,
63 const std::string& alternative_text);
64
65 bool GetTimes(net::X509Certificate::OSCertHandle cert_handle,
66 base::Time* issued, base::Time* expires);
67
68 std::string GetTitle(net::X509Certificate::OSCertHandle cert_handle);
69 std::string GetIssuerName(net::X509Certificate::OSCertHandle cert_handle);
70 std::string GetSubjectName(net::X509Certificate::OSCertHandle cert_handle);
71
72 void GetEmailAddresses(net::X509Certificate::OSCertHandle cert_handle,
73 std::vector<std::string>* email_addresses);
74
75 void GetNicknameStringsFromCertList(const net::CertificateList& certs,
76 const std::string& cert_expired,
77 const std::string& cert_not_yet_valid,
78 std::vector<std::string>* nick_names);
79
80 struct Extension {
81 std::string name;
82 std::string value;
83 };
84
85 typedef std::vector<Extension> Extensions;
86
87 void GetExtensions(
88 const std::string& critical_label,
89 const std::string& non_critical_label,
90 net::X509Certificate::OSCertHandle cert_handle,
91 Extensions* extensions);
92
93 // Hash a certificate using the given algorithm, return the result as a
94 // colon-seperated hex string.
95 std::string HashCertSHA256(net::X509Certificate::OSCertHandle cert_handle);
96 std::string HashCertSHA1(net::X509Certificate::OSCertHandle cert_handle);
97
98 // For host values, if they contain IDN Punycode-encoded A-labels, this will
99 // return a string suitable for display that contains both the original and the
100 // decoded U-label form. Otherwise, the string will be returned as is.
101 std::string ProcessIDN(const std::string& input);
102
103 void GetCertChainFromCert(net::X509Certificate::OSCertHandle cert_handle,
104 net::X509Certificate::OSCertHandles* cert_handles);
105 void DestroyCertChain(net::X509Certificate::OSCertHandles* cert_handles);
106
107 std::string GetDerString(net::X509Certificate::OSCertHandle cert_handle);
108 std::string GetCMSString(const net::X509Certificate::OSCertHandles& cert_chain,
109 size_t start, size_t end);
110
111 std::string ProcessSecAlgorithmSignature(
112 net::X509Certificate::OSCertHandle cert_handle);
113 std::string ProcessSecAlgorithmSubjectPublicKey(
114 net::X509Certificate::OSCertHandle cert_handle);
115 std::string ProcessSecAlgorithmSignatureWrap(
116 net::X509Certificate::OSCertHandle cert_handle);
117
118 std::string ProcessSubjectPublicKeyInfo(
119 net::X509Certificate::OSCertHandle cert_handle);
120
121 std::string ProcessRawBitsSignatureWrap(
122 net::X509Certificate::OSCertHandle cert_handle);
123
124 void RegisterDynamicOids();
125
126 } // namespace x509_certificate_model
127
128 #endif // NET_BASE_X509_CERTIFICATE_MODEL_H_
OLDNEW
« no previous file with comments | « chrome/common/net/DEPS ('k') | chrome/common/net/x509_certificate_model.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698