1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright 2018 The WebRTC project authors. All Rights Reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker #ifndef API_DTLS_TRANSPORT_INTERFACE_H_ 12*d9f75844SAndroid Build Coastguard Worker #define API_DTLS_TRANSPORT_INTERFACE_H_ 13*d9f75844SAndroid Build Coastguard Worker 14*d9f75844SAndroid Build Coastguard Worker #include <memory> 15*d9f75844SAndroid Build Coastguard Worker #include <utility> 16*d9f75844SAndroid Build Coastguard Worker 17*d9f75844SAndroid Build Coastguard Worker #include "absl/types/optional.h" 18*d9f75844SAndroid Build Coastguard Worker #include "api/ice_transport_interface.h" 19*d9f75844SAndroid Build Coastguard Worker #include "api/rtc_error.h" 20*d9f75844SAndroid Build Coastguard Worker #include "api/scoped_refptr.h" 21*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/ref_count.h" 22*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/ssl_certificate.h" 23*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/system/rtc_export.h" 24*d9f75844SAndroid Build Coastguard Worker 25*d9f75844SAndroid Build Coastguard Worker namespace webrtc { 26*d9f75844SAndroid Build Coastguard Worker 27*d9f75844SAndroid Build Coastguard Worker // States of a DTLS transport, corresponding to the JS API specification. 28*d9f75844SAndroid Build Coastguard Worker // http://w3c.github.io/webrtc-pc/#dom-rtcdtlstransportstate 29*d9f75844SAndroid Build Coastguard Worker enum class DtlsTransportState { 30*d9f75844SAndroid Build Coastguard Worker kNew, // Has not started negotiating yet. 31*d9f75844SAndroid Build Coastguard Worker kConnecting, // In the process of negotiating a secure connection. 32*d9f75844SAndroid Build Coastguard Worker kConnected, // Completed negotiation and verified fingerprints. 33*d9f75844SAndroid Build Coastguard Worker kClosed, // Intentionally closed. 34*d9f75844SAndroid Build Coastguard Worker kFailed, // Failure due to an error or failing to verify a remote 35*d9f75844SAndroid Build Coastguard Worker // fingerprint. 36*d9f75844SAndroid Build Coastguard Worker kNumValues 37*d9f75844SAndroid Build Coastguard Worker }; 38*d9f75844SAndroid Build Coastguard Worker 39*d9f75844SAndroid Build Coastguard Worker enum class DtlsTransportTlsRole { 40*d9f75844SAndroid Build Coastguard Worker kServer, // Other end sends CLIENT_HELLO 41*d9f75844SAndroid Build Coastguard Worker kClient // This end sends CLIENT_HELLO 42*d9f75844SAndroid Build Coastguard Worker }; 43*d9f75844SAndroid Build Coastguard Worker 44*d9f75844SAndroid Build Coastguard Worker // This object gives snapshot information about the changeable state of a 45*d9f75844SAndroid Build Coastguard Worker // DTLSTransport. 46*d9f75844SAndroid Build Coastguard Worker class RTC_EXPORT DtlsTransportInformation { 47*d9f75844SAndroid Build Coastguard Worker public: 48*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation(); 49*d9f75844SAndroid Build Coastguard Worker explicit DtlsTransportInformation(DtlsTransportState state); 50*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation( 51*d9f75844SAndroid Build Coastguard Worker DtlsTransportState state, 52*d9f75844SAndroid Build Coastguard Worker absl::optional<DtlsTransportTlsRole> role, 53*d9f75844SAndroid Build Coastguard Worker absl::optional<int> tls_version, 54*d9f75844SAndroid Build Coastguard Worker absl::optional<int> ssl_cipher_suite, 55*d9f75844SAndroid Build Coastguard Worker absl::optional<int> srtp_cipher_suite, 56*d9f75844SAndroid Build Coastguard Worker std::unique_ptr<rtc::SSLCertChain> remote_ssl_certificates); 57*d9f75844SAndroid Build Coastguard Worker ABSL_DEPRECATED("Use version with role parameter") 58*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation( 59*d9f75844SAndroid Build Coastguard Worker DtlsTransportState state, 60*d9f75844SAndroid Build Coastguard Worker absl::optional<int> tls_version, 61*d9f75844SAndroid Build Coastguard Worker absl::optional<int> ssl_cipher_suite, 62*d9f75844SAndroid Build Coastguard Worker absl::optional<int> srtp_cipher_suite, 63*d9f75844SAndroid Build Coastguard Worker std::unique_ptr<rtc::SSLCertChain> remote_ssl_certificates); 64*d9f75844SAndroid Build Coastguard Worker 65*d9f75844SAndroid Build Coastguard Worker // Copy and assign 66*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation(const DtlsTransportInformation& c); 67*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation& operator=(const DtlsTransportInformation& c); 68*d9f75844SAndroid Build Coastguard Worker // Move 69*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation(DtlsTransportInformation&& other) = default; 70*d9f75844SAndroid Build Coastguard Worker DtlsTransportInformation& operator=(DtlsTransportInformation&& other) = 71*d9f75844SAndroid Build Coastguard Worker default; 72*d9f75844SAndroid Build Coastguard Worker state()73*d9f75844SAndroid Build Coastguard Worker DtlsTransportState state() const { return state_; } role()74*d9f75844SAndroid Build Coastguard Worker absl::optional<DtlsTransportTlsRole> role() const { return role_; } tls_version()75*d9f75844SAndroid Build Coastguard Worker absl::optional<int> tls_version() const { return tls_version_; } ssl_cipher_suite()76*d9f75844SAndroid Build Coastguard Worker absl::optional<int> ssl_cipher_suite() const { return ssl_cipher_suite_; } srtp_cipher_suite()77*d9f75844SAndroid Build Coastguard Worker absl::optional<int> srtp_cipher_suite() const { return srtp_cipher_suite_; } 78*d9f75844SAndroid Build Coastguard Worker // The accessor returns a temporary pointer, it does not release ownership. remote_ssl_certificates()79*d9f75844SAndroid Build Coastguard Worker const rtc::SSLCertChain* remote_ssl_certificates() const { 80*d9f75844SAndroid Build Coastguard Worker return remote_ssl_certificates_.get(); 81*d9f75844SAndroid Build Coastguard Worker } 82*d9f75844SAndroid Build Coastguard Worker 83*d9f75844SAndroid Build Coastguard Worker private: 84*d9f75844SAndroid Build Coastguard Worker DtlsTransportState state_; 85*d9f75844SAndroid Build Coastguard Worker absl::optional<DtlsTransportTlsRole> role_; 86*d9f75844SAndroid Build Coastguard Worker absl::optional<int> tls_version_; 87*d9f75844SAndroid Build Coastguard Worker absl::optional<int> ssl_cipher_suite_; 88*d9f75844SAndroid Build Coastguard Worker absl::optional<int> srtp_cipher_suite_; 89*d9f75844SAndroid Build Coastguard Worker std::unique_ptr<rtc::SSLCertChain> remote_ssl_certificates_; 90*d9f75844SAndroid Build Coastguard Worker }; 91*d9f75844SAndroid Build Coastguard Worker 92*d9f75844SAndroid Build Coastguard Worker class DtlsTransportObserverInterface { 93*d9f75844SAndroid Build Coastguard Worker public: 94*d9f75844SAndroid Build Coastguard Worker // This callback carries information about the state of the transport. 95*d9f75844SAndroid Build Coastguard Worker // The argument is a pass-by-value snapshot of the state. 96*d9f75844SAndroid Build Coastguard Worker virtual void OnStateChange(DtlsTransportInformation info) = 0; 97*d9f75844SAndroid Build Coastguard Worker // This callback is called when an error occurs, causing the transport 98*d9f75844SAndroid Build Coastguard Worker // to go to the kFailed state. 99*d9f75844SAndroid Build Coastguard Worker virtual void OnError(RTCError error) = 0; 100*d9f75844SAndroid Build Coastguard Worker 101*d9f75844SAndroid Build Coastguard Worker protected: 102*d9f75844SAndroid Build Coastguard Worker virtual ~DtlsTransportObserverInterface() = default; 103*d9f75844SAndroid Build Coastguard Worker }; 104*d9f75844SAndroid Build Coastguard Worker 105*d9f75844SAndroid Build Coastguard Worker // A DTLS transport, as represented to the outside world. 106*d9f75844SAndroid Build Coastguard Worker // This object is created on the network thread, and can only be 107*d9f75844SAndroid Build Coastguard Worker // accessed on that thread, except for functions explicitly marked otherwise. 108*d9f75844SAndroid Build Coastguard Worker // References can be held by other threads, and destruction can therefore 109*d9f75844SAndroid Build Coastguard Worker // be initiated by other threads. 110*d9f75844SAndroid Build Coastguard Worker class DtlsTransportInterface : public rtc::RefCountInterface { 111*d9f75844SAndroid Build Coastguard Worker public: 112*d9f75844SAndroid Build Coastguard Worker // Returns a pointer to the ICE transport that is owned by the DTLS transport. 113*d9f75844SAndroid Build Coastguard Worker virtual rtc::scoped_refptr<IceTransportInterface> ice_transport() = 0; 114*d9f75844SAndroid Build Coastguard Worker // Returns information on the state of the DtlsTransport. 115*d9f75844SAndroid Build Coastguard Worker // This function can be called from other threads. 116*d9f75844SAndroid Build Coastguard Worker virtual DtlsTransportInformation Information() = 0; 117*d9f75844SAndroid Build Coastguard Worker // Observer management. 118*d9f75844SAndroid Build Coastguard Worker virtual void RegisterObserver(DtlsTransportObserverInterface* observer) = 0; 119*d9f75844SAndroid Build Coastguard Worker virtual void UnregisterObserver() = 0; 120*d9f75844SAndroid Build Coastguard Worker }; 121*d9f75844SAndroid Build Coastguard Worker 122*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc 123*d9f75844SAndroid Build Coastguard Worker 124*d9f75844SAndroid Build Coastguard Worker #endif // API_DTLS_TRANSPORT_INTERFACE_H_ 125