OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "net/cert/x509_certificate.h" | 5 #include "net/cert/x509_certificate.h" |
6 | 6 |
7 #include <cert.h> | 7 #include <cert.h> |
8 #include <cryptohi.h> | 8 #include <cryptohi.h> |
9 #include <keyhi.h> | 9 #include <keyhi.h> |
10 #include <nss.h> | 10 #include <nss.h> |
(...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
274 cert_handle->derCert.len); | 274 cert_handle->derCert.len); |
275 } | 275 } |
276 | 276 |
277 // static | 277 // static |
278 void X509Certificate::GetPublicKeyInfo(OSCertHandle cert_handle, | 278 void X509Certificate::GetPublicKeyInfo(OSCertHandle cert_handle, |
279 size_t* size_bits, | 279 size_t* size_bits, |
280 PublicKeyType* type) { | 280 PublicKeyType* type) { |
281 x509_util::GetPublicKeyInfo(cert_handle, size_bits, type); | 281 x509_util::GetPublicKeyInfo(cert_handle, size_bits, type); |
282 } | 282 } |
283 | 283 |
284 // static | |
285 bool X509Certificate::IsSelfSigned(OSCertHandle cert_handle) { | |
286 SECKEYPublicKey* public_key = CERT_ExtractPublicKey(cert_handle); | |
Ryan Sleevi
2014/10/27 23:33:13
BUG: You're leaking this
palmer
2014/10/28 23:13:41
Done.
| |
287 if (!public_key) | |
288 return false; | |
289 return SECSuccess == CERT_VerifySignedDataWithPublicKey( | |
290 &cert_handle->signatureWrap, public_key, NULL); | |
291 } | |
292 | |
284 } // namespace net | 293 } // namespace net |
OLD | NEW |