| /* | 
 |  *  Copyright 2018 The WebRTC Project Authors. All rights reserved. | 
 |  * | 
 |  *  Use of this source code is governed by a BSD-style license | 
 |  *  that can be found in the LICENSE file in the root of the source | 
 |  *  tree. An additional intellectual property rights grant can be found | 
 |  *  in the file PATENTS.  All contributing project authors may | 
 |  *  be found in the AUTHORS file in the root of the source tree. | 
 |  */ | 
 |  | 
 | #ifndef RTC_BASE_OPENSSLUTILITY_H_ | 
 | #define RTC_BASE_OPENSSLUTILITY_H_ | 
 |  | 
 | #include <openssl/ossl_typ.h> | 
 | #include <string> | 
 | #include "rtc_base/sslcertificate.h" | 
 |  | 
 | namespace rtc { | 
 | // The openssl namespace holds static helper methods. All methods related | 
 | // to OpenSSL that are commonly used and don't require global state should be | 
 | // placed here. | 
 | namespace openssl { | 
 | // Verifies that the hostname provided matches that in the peer certificate | 
 | // attached to this SSL state. | 
 | bool VerifyPeerCertMatchesHost(SSL* ssl, const std::string& host); | 
 |  | 
 | // Logs all the errors in the OpenSSL errror queue from the current thread. A | 
 | // prefix can be provided for context. | 
 | void LogSSLErrors(const std::string& prefix); | 
 |  | 
 | #ifndef WEBRTC_DISABLE_BUILT_IN_SSL_ROOT_CERTIFICATES | 
 | // Attempt to add the certificates from the loader into the SSL_CTX. False is | 
 | // returned only if there are no certificates returned from the loader or none | 
 | // of them can be added to the TrustStore for the provided context. | 
 | bool LoadBuiltinSSLRootCertificates(SSL_CTX* ssl_ctx); | 
 | #endif  // WEBRTC_DISABLE_BUILT_IN_SSL_ROOT_CERTIFICATES | 
 |  | 
 | }  // namespace openssl | 
 | }  // namespace rtc | 
 |  | 
 | #endif  // RTC_BASE_OPENSSLUTILITY_H_ |