
This reverts commit 7f1ffcccce563a086da037334aec2d4faa723edb. Reason for revert: Speculative revert Original change's description: > Add SSLConfig object to IceServer. > > This is being added to allow greater configurability to TLS connections. > tlsAlpnProtocols, tlsEllipticCurves and tlsCertPolicy will be removed from IceServer in a > follow-up CL. > > Bug: webrtc:9662 > Change-Id: I33cb804b02c26c662ed2a28c76f9a9dc2df40f36 > Reviewed-on: https://webrtc-review.googlesource.com/96020 > Commit-Queue: Diogo Real <diogor@google.com> > Reviewed-by: Qingsi Wang <qingsi@webrtc.org> > Reviewed-by: Benjamin Wright <benwright@webrtc.org> > Reviewed-by: Steve Anton <steveanton@webrtc.org> > Reviewed-by: Sami Kalliomäki <sakal@webrtc.org> > Reviewed-by: Kári Helgason <kthelgason@webrtc.org> > Cr-Commit-Position: refs/heads/master@{#24559} TBR=steveanton@webrtc.org,sakal@webrtc.org,kthelgason@webrtc.org,juberti@webrtc.org,emadomara@webrtc.org,qingsi@webrtc.org,benwright@webrtc.org,diogor@google.com Change-Id: Iae9fc68b77f743876bda36fc2a04f6d791aae8e2 No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: webrtc:9662 Reviewed-on: https://webrtc-review.googlesource.com/98000 Reviewed-by: Ying Wang <yinwa@webrtc.org> Commit-Queue: Ying Wang <yinwa@webrtc.org> Cr-Commit-Position: refs/heads/master@{#24563}
94 lines
3.0 KiB
C++
94 lines
3.0 KiB
C++
/*
|
|
* Copyright 2011 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 P2P_BASE_PACKETSOCKETFACTORY_H_
|
|
#define P2P_BASE_PACKETSOCKETFACTORY_H_
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "rtc_base/constructormagic.h"
|
|
#include "rtc_base/proxyinfo.h"
|
|
#include "rtc_base/sslcertificate.h"
|
|
|
|
namespace rtc {
|
|
|
|
// This structure contains options required to create TCP packet sockets.
|
|
struct PacketSocketTcpOptions {
|
|
PacketSocketTcpOptions();
|
|
~PacketSocketTcpOptions();
|
|
|
|
int opts = 0;
|
|
std::vector<std::string> tls_alpn_protocols;
|
|
std::vector<std::string> tls_elliptic_curves;
|
|
// An optional custom SSL certificate verifier that an API user can provide to
|
|
// inject their own certificate verification logic.
|
|
SSLCertificateVerifier* tls_cert_verifier = nullptr;
|
|
};
|
|
|
|
class AsyncPacketSocket;
|
|
class AsyncResolverInterface;
|
|
|
|
class PacketSocketFactory {
|
|
public:
|
|
enum Options {
|
|
OPT_STUN = 0x04,
|
|
|
|
// The TLS options below are mutually exclusive.
|
|
OPT_TLS = 0x02, // Real and secure TLS.
|
|
OPT_TLS_FAKE = 0x01, // Fake TLS with a dummy SSL handshake.
|
|
OPT_TLS_INSECURE = 0x08, // Insecure TLS without certificate validation.
|
|
|
|
// Deprecated, use OPT_TLS_FAKE.
|
|
OPT_SSLTCP = OPT_TLS_FAKE,
|
|
};
|
|
|
|
PacketSocketFactory() {}
|
|
virtual ~PacketSocketFactory() = default;
|
|
|
|
virtual AsyncPacketSocket* CreateUdpSocket(const SocketAddress& address,
|
|
uint16_t min_port,
|
|
uint16_t max_port) = 0;
|
|
virtual AsyncPacketSocket* CreateServerTcpSocket(
|
|
const SocketAddress& local_address,
|
|
uint16_t min_port,
|
|
uint16_t max_port,
|
|
int opts) = 0;
|
|
|
|
// TODO(deadbeef): |proxy_info| and |user_agent| should be set
|
|
// per-factory and not when socket is created.
|
|
virtual AsyncPacketSocket* CreateClientTcpSocket(
|
|
const SocketAddress& local_address,
|
|
const SocketAddress& remote_address,
|
|
const ProxyInfo& proxy_info,
|
|
const std::string& user_agent,
|
|
int opts) = 0;
|
|
|
|
// TODO(deadbeef): |proxy_info|, |user_agent| and |tcp_options| should
|
|
// be set per-factory and not when socket is created.
|
|
// TODO(deadbeef): Implement this method in all subclasses (namely those in
|
|
// Chromium), make pure virtual, and remove the old CreateClientTcpSocket.
|
|
virtual AsyncPacketSocket* CreateClientTcpSocket(
|
|
const SocketAddress& local_address,
|
|
const SocketAddress& remote_address,
|
|
const ProxyInfo& proxy_info,
|
|
const std::string& user_agent,
|
|
const PacketSocketTcpOptions& tcp_options);
|
|
|
|
virtual AsyncResolverInterface* CreateAsyncResolver() = 0;
|
|
|
|
private:
|
|
RTC_DISALLOW_COPY_AND_ASSIGN(PacketSocketFactory);
|
|
};
|
|
|
|
} // namespace rtc
|
|
|
|
#endif // P2P_BASE_PACKETSOCKETFACTORY_H_
|