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 | c24a218 | 2022-02-23 13:44:59 | [diff] [blame] | 14 | #include <functional> |
Harald Alvestrand | 5761e7b | 2021-01-29 14:45:08 | [diff] [blame] | 15 | #include <string> |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 16 | #include <vector> |
| 17 | |
Yves Gerey | 3e70781 | 2018-11-28 15:47:49 | [diff] [blame] | 18 | #include "absl/types/optional.h" |
Harald Alvestrand | 0d01841 | 2021-11-04 13:52:31 | [diff] [blame] | 19 | #include "api/crypto_params.h" |
Mirko Bonadei | 9f6808b | 2021-05-21 18:46:09 | [diff] [blame] | 20 | #include "api/dtls_transport_interface.h" |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 21 | #include "api/rtc_error.h" |
| 22 | #include "p2p/base/dtls_transport_internal.h" |
| 23 | #include "p2p/base/packet_transport_internal.h" |
| 24 | #include "pc/srtp_transport.h" |
Joachim Bauch | 5b32f23 | 2018-03-07 19:02:26 | [diff] [blame] | 25 | #include "rtc_base/buffer.h" |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 26 | |
| 27 | namespace webrtc { |
| 28 | |
Zhi Huang | 365381f | 2018-04-13 23:44:34 | [diff] [blame] | 29 | // The subclass of SrtpTransport is used for DTLS-SRTP. When the DTLS handshake |
| 30 | // is finished, it extracts the keying materials from DtlsTransport and |
| 31 | // configures the SrtpSessions in the base class. |
| 32 | class DtlsSrtpTransport : public SrtpTransport { |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 33 | public: |
Jonas Oreland | e62c2f2 | 2022-03-29 09:04:48 | [diff] [blame] | 34 | DtlsSrtpTransport(bool rtcp_mux_enabled, const FieldTrialsView& field_trials); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 35 | |
| 36 | // Set P2P layer RTP/RTCP DtlsTransports. When using RTCP-muxing, |
Artem Titov | 880fa81 | 2021-07-30 20:30:23 | [diff] [blame] | 37 | // `rtcp_dtls_transport` is null. |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 38 | void SetDtlsTransports(cricket::DtlsTransportInternal* rtp_dtls_transport, |
| 39 | cricket::DtlsTransportInternal* rtcp_dtls_transport); |
| 40 | |
| 41 | void SetRtcpMuxEnabled(bool enable) override; |
| 42 | |
| 43 | // Set the header extension ids that should be encrypted. |
Zhi Huang | cd3fc5d | 2017-11-29 18:41:57 | [diff] [blame] | 44 | void UpdateSendEncryptedHeaderExtensionIds( |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 45 | const std::vector<int>& send_extension_ids); |
| 46 | |
Zhi Huang | cd3fc5d | 2017-11-29 18:41:57 | [diff] [blame] | 47 | void UpdateRecvEncryptedHeaderExtensionIds( |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 48 | const std::vector<int>& recv_extension_ids); |
| 49 | |
Lahiru Ginnaliya Gamathige | c32f00e | 2021-02-17 08:43:21 | [diff] [blame] | 50 | void SetOnDtlsStateChange(std::function<void(void)> callback); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 51 | |
Artem Titov | 880fa81 | 2021-07-30 20:30:23 | [diff] [blame] | 52 | // If `active_reset_srtp_params_` is set to be true, the SRTP parameters will |
Zhi Huang | b57e169 | 2018-06-12 18:41:11 | [diff] [blame] | 53 | // be reset whenever the DtlsTransports are reset. |
| 54 | void SetActiveResetSrtpParams(bool active_reset_srtp_params) { |
| 55 | active_reset_srtp_params_ = active_reset_srtp_params; |
| 56 | } |
| 57 | |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 58 | private: |
| 59 | bool IsDtlsActive(); |
| 60 | bool IsDtlsConnected(); |
| 61 | bool IsDtlsWritable(); |
| 62 | bool DtlsHandshakeCompleted(); |
| 63 | void MaybeSetupDtlsSrtp(); |
| 64 | void SetupRtpDtlsSrtp(); |
| 65 | void SetupRtcpDtlsSrtp(); |
| 66 | bool ExtractParams(cricket::DtlsTransportInternal* dtls_transport, |
| 67 | int* selected_crypto_suite, |
Joachim Bauch | 5b32f23 | 2018-03-07 19:02:26 | [diff] [blame] | 68 | rtc::ZeroOnFreeBuffer<unsigned char>* send_key, |
| 69 | rtc::ZeroOnFreeBuffer<unsigned char>* recv_key); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 70 | void SetDtlsTransport(cricket::DtlsTransportInternal* new_dtls_transport, |
| 71 | cricket::DtlsTransportInternal** old_dtls_transport); |
| 72 | void SetRtpDtlsTransport(cricket::DtlsTransportInternal* rtp_dtls_transport); |
| 73 | void SetRtcpDtlsTransport( |
| 74 | cricket::DtlsTransportInternal* rtcp_dtls_transport); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 75 | |
| 76 | void OnDtlsState(cricket::DtlsTransportInternal* dtls_transport, |
Mirko Bonadei | 9f6808b | 2021-05-21 18:46:09 | [diff] [blame] | 77 | DtlsTransportState state); |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 78 | |
Zhi Huang | 365381f | 2018-04-13 23:44:34 | [diff] [blame] | 79 | // Override the SrtpTransport::OnWritableState. |
| 80 | void OnWritableState(rtc::PacketTransportInternal* packet_transport) override; |
| 81 | |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 82 | // Owned by the TransportController. |
| 83 | cricket::DtlsTransportInternal* rtp_dtls_transport_ = nullptr; |
| 84 | cricket::DtlsTransportInternal* rtcp_dtls_transport_ = nullptr; |
| 85 | |
| 86 | // The encrypted header extension IDs. |
Danil Chapovalov | 66cadcc | 2018-06-19 14:47:43 | [diff] [blame] | 87 | absl::optional<std::vector<int>> send_extension_ids_; |
| 88 | absl::optional<std::vector<int>> recv_extension_ids_; |
Zhi Huang | b57e169 | 2018-06-12 18:41:11 | [diff] [blame] | 89 | |
| 90 | bool active_reset_srtp_params_ = false; |
Lahiru Ginnaliya Gamathige | c32f00e | 2021-02-17 08:43:21 | [diff] [blame] | 91 | std::function<void(void)> on_dtls_state_change_; |
Zhi Huang | f2d7beb | 2017-11-20 22:35:11 | [diff] [blame] | 92 | }; |
| 93 | |
| 94 | } // namespace webrtc |
| 95 | |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 96 | #endif // PC_DTLS_SRTP_TRANSPORT_H_ |