naiveproxy/net/cert/x509_util_ios_and_mac.cc

59 lines
2.0 KiB
C++
Raw Normal View History

2018-01-28 21:32:06 +03:00
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "net/cert/x509_util_ios_and_mac.h"
#include "net/cert/x509_certificate.h"
#if defined(OS_IOS)
#include "net/cert/x509_util_ios.h"
#else
#include "net/cert/x509_util_mac.h"
#endif
#include "third_party/boringssl/src/include/openssl/pool.h"
namespace net {
namespace x509_util {
base::ScopedCFTypeRef<CFMutableArrayRef>
CreateSecCertificateArrayForX509Certificate(X509Certificate* cert) {
return CreateSecCertificateArrayForX509Certificate(
cert, InvalidIntermediateBehavior::kFail);
}
base::ScopedCFTypeRef<CFMutableArrayRef>
CreateSecCertificateArrayForX509Certificate(
X509Certificate* cert,
InvalidIntermediateBehavior invalid_intermediate_behavior) {
base::ScopedCFTypeRef<CFMutableArrayRef> cert_list(
CFArrayCreateMutable(kCFAllocatorDefault, 0, &kCFTypeArrayCallBacks));
if (!cert_list)
return base::ScopedCFTypeRef<CFMutableArrayRef>();
std::string bytes;
base::ScopedCFTypeRef<SecCertificateRef> sec_cert(
CreateSecCertificateFromBytes(CRYPTO_BUFFER_data(cert->os_cert_handle()),
CRYPTO_BUFFER_len(cert->os_cert_handle())));
if (!sec_cert)
return base::ScopedCFTypeRef<CFMutableArrayRef>();
CFArrayAppendValue(cert_list, sec_cert);
for (X509Certificate::OSCertHandle intermediate :
cert->GetIntermediateCertificates()) {
base::ScopedCFTypeRef<SecCertificateRef> sec_cert(
CreateSecCertificateFromBytes(CRYPTO_BUFFER_data(intermediate),
CRYPTO_BUFFER_len(intermediate)));
if (!sec_cert) {
if (invalid_intermediate_behavior == InvalidIntermediateBehavior::kFail)
return base::ScopedCFTypeRef<CFMutableArrayRef>();
LOG(WARNING) << "error parsing intermediate";
continue;
}
CFArrayAppendValue(cert_list, sec_cert);
}
return cert_list;
}
} // namespace x509_util
} // namespace net