Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2017 The WebRTC project authors. All Rights Reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 11 | #ifndef PC_DTLS_SRTP_TRANSPORT_H_ |
| 12 | #define PC_DTLS_SRTP_TRANSPORT_H_ |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 13 | |
Harald Alvestrand | 5761e7b | 2021-01-29 14:45:08 | [diff] [blame^] | 14 | #include <string> |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 15 | #include <vector> |
| 16 | |
Yves Gerey | 3e70781 | 2018-11-28 15:47:49 | [diff] [blame] | 17 | #include "absl/types/optional.h" |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 18 | #include "api/crypto_params.h" |
| 19 | #include "api/rtc_error.h" |
| 20 | #include "p2p/base/dtls_transport_internal.h" |
| 21 | #include "p2p/base/packet_transport_internal.h" |
| 22 | #include "pc/srtp_transport.h" |
Joachim Bauch | 5b32f23 | 2018-03-07 19:02:26 | [diff] [blame] | 23 | #include "rtc_base/buffer.h" |
Yves Gerey | 3e70781 | 2018-11-28 15:47:49 | [diff] [blame] | 24 | #include "rtc_base/third_party/sigslot/sigslot.h" |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 25 | |
| 26 | namespace webrtc { |
| 27 | |
Zhi Huang | 365381f | 2018-04-13 23:44:34 | [diff] [blame] | 28 | // The subclass of SrtpTransport is used for DTLS-SRTP. When the DTLS handshake |
| 29 | // is finished, it extracts the keying materials from DtlsTransport and |
| 30 | // configures the SrtpSessions in the base class. |
| 31 | class DtlsSrtpTransport : public SrtpTransport { |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 32 | public: |
Zhi Huang | 365381f | 2018-04-13 23:44:34 | [diff] [blame] | 33 | explicit DtlsSrtpTransport(bool rtcp_mux_enabled); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 34 | |
| 35 | // Set P2P layer RTP/RTCP DtlsTransports. When using RTCP-muxing, |
| 36 | // |rtcp_dtls_transport| is null. |
| 37 | void SetDtlsTransports(cricket::DtlsTransportInternal* rtp_dtls_transport, |
| 38 | cricket::DtlsTransportInternal* rtcp_dtls_transport); |
| 39 | |
| 40 | void SetRtcpMuxEnabled(bool enable) override; |
| 41 | |
| 42 | // Set the header extension ids that should be encrypted. |
Zhi Huang | cd3fc5d | 2017-11-29 18:41:57 | [diff] [blame] | 43 | void UpdateSendEncryptedHeaderExtensionIds( |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 44 | const std::vector<int>& send_extension_ids); |
| 45 | |
Zhi Huang | cd3fc5d | 2017-11-29 18:41:57 | [diff] [blame] | 46 | void UpdateRecvEncryptedHeaderExtensionIds( |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 47 | const std::vector<int>& recv_extension_ids); |
| 48 | |
Jonas Olsson | 635474e | 2018-10-18 13:58:17 | [diff] [blame] | 49 | sigslot::signal<DtlsSrtpTransport*, bool> SignalDtlsSrtpSetupFailure; |
| 50 | sigslot::signal<> SignalDtlsStateChange; |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 51 | |
Zhi Huang | e830e68 | 2018-03-30 17:48:35 | [diff] [blame] | 52 | RTCError SetSrtpSendKey(const cricket::CryptoParams& params) override { |
| 53 | return RTCError(RTCErrorType::UNSUPPORTED_OPERATION, |
| 54 | "Set SRTP keys for DTLS-SRTP is not supported."); |
| 55 | } |
| 56 | RTCError SetSrtpReceiveKey(const cricket::CryptoParams& params) override { |
| 57 | return RTCError(RTCErrorType::UNSUPPORTED_OPERATION, |
| 58 | "Set SRTP keys for DTLS-SRTP is not supported."); |
| 59 | } |
| 60 | |
Zhi Huang | b57e169 | 2018-06-12 18:41:11 | [diff] [blame] | 61 | // If |active_reset_srtp_params_| is set to be true, the SRTP parameters will |
| 62 | // be reset whenever the DtlsTransports are reset. |
| 63 | void SetActiveResetSrtpParams(bool active_reset_srtp_params) { |
| 64 | active_reset_srtp_params_ = active_reset_srtp_params; |
| 65 | } |
| 66 | |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 67 | private: |
| 68 | bool IsDtlsActive(); |
| 69 | bool IsDtlsConnected(); |
| 70 | bool IsDtlsWritable(); |
| 71 | bool DtlsHandshakeCompleted(); |
| 72 | void MaybeSetupDtlsSrtp(); |
| 73 | void SetupRtpDtlsSrtp(); |
| 74 | void SetupRtcpDtlsSrtp(); |
| 75 | bool ExtractParams(cricket::DtlsTransportInternal* dtls_transport, |
| 76 | int* selected_crypto_suite, |
Joachim Bauch | 5b32f23 | 2018-03-07 19:02:26 | [diff] [blame] | 77 | rtc::ZeroOnFreeBuffer<unsigned char>* send_key, |
| 78 | rtc::ZeroOnFreeBuffer<unsigned char>* recv_key); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 79 | void SetDtlsTransport(cricket::DtlsTransportInternal* new_dtls_transport, |
| 80 | cricket::DtlsTransportInternal** old_dtls_transport); |
| 81 | void SetRtpDtlsTransport(cricket::DtlsTransportInternal* rtp_dtls_transport); |
| 82 | void SetRtcpDtlsTransport( |
| 83 | cricket::DtlsTransportInternal* rtcp_dtls_transport); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 84 | |
| 85 | void OnDtlsState(cricket::DtlsTransportInternal* dtls_transport, |
| 86 | cricket::DtlsTransportState state); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 87 | |
Zhi Huang | 365381f | 2018-04-13 23:44:34 | [diff] [blame] | 88 | // Override the SrtpTransport::OnWritableState. |
| 89 | void OnWritableState(rtc::PacketTransportInternal* packet_transport) override; |
| 90 | |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 91 | // Owned by the TransportController. |
| 92 | cricket::DtlsTransportInternal* rtp_dtls_transport_ = nullptr; |
| 93 | cricket::DtlsTransportInternal* rtcp_dtls_transport_ = nullptr; |
| 94 | |
| 95 | // The encrypted header extension IDs. |
Danil Chapovalov | 66cadcc | 2018-06-19 14:47:43 | [diff] [blame] | 96 | absl::optional<std::vector<int>> send_extension_ids_; |
| 97 | absl::optional<std::vector<int>> recv_extension_ids_; |
Zhi Huang | b57e169 | 2018-06-12 18:41:11 | [diff] [blame] | 98 | |
| 99 | bool active_reset_srtp_params_ = false; |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 100 | }; |
| 101 | |
| 102 | } // namespace webrtc |
| 103 | |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 104 | #endif // PC_DTLS_SRTP_TRANSPORT_H_ |