/* * Copyright 2004 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_SSL_ADAPTER_H_ #define RTC_BASE_SSL_ADAPTER_H_ #include <string> #include <vector> #include "absl/strings/string_view.h" #include "rtc_base/async_socket.h" #include "rtc_base/ssl_certificate.h" #include "rtc_base/ssl_identity.h" #include "rtc_base/ssl_stream_adapter.h" #include "rtc_base/system/rtc_export.h" namespace rtc { class SSLAdapter; // Class for creating SSL adapters with shared state, e.g., a session cache, // which allows clients to resume SSL sessions to previously-contacted hosts. // Clients should create the factory using Create(), set up the factory as // needed using SetMode, and then call CreateAdapter to create adapters when // needed. class SSLAdapterFactory { … }; // Class that abstracts a client-to-server SSL session. It can be created // standalone, via SSLAdapter::Create, or through a factory as described above, // in which case it will share state with other SSLAdapters created from the // same factory. // After creation, call StartSSL to initiate the SSL handshake to the server. class SSLAdapter : public AsyncSocketAdapter { … }; /////////////////////////////////////////////////////////////////////////////// // Call this on the main thread, before using SSL. // Call CleanupSSL when finished with SSL. RTC_EXPORT bool InitializeSSL(); // Call to cleanup additional threads, and also the main thread. RTC_EXPORT bool CleanupSSL(); } // namespace rtc #endif // RTC_BASE_SSL_ADAPTER_H_