Chromium Code Reviews| 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 |