/* * Copyright 2019 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. */ #include "pc/media_protocol_names.h" #include #include #include namespace cricket { // The official registry of RTP parameters is at // http://www.iana.org/assignments/rtp-parameters/rtp-parameters.xml // The UDP/DTLS and TCP/DTLS prefixes are not registered there. // There are multiple variants of the RTP protocol stack, including // UDP/TLS/RTP/SAVPF (WebRTC default), RTP/AVP, RTP/AVPF, RTP/SAVPF, // TCP/DTLS/RTP/SAVPF and so on. We accept anything that has RTP/ // embedded in it somewhere as being an RTP protocol. const char kMediaProtocolRtpPrefix[] = "RTP/"; // Protocol names generated by WebRTC const char kMediaProtocolSctp[] = "SCTP"; const char kMediaProtocolUdpDtlsSctp[] = "UDP/DTLS/SCTP"; const char kMediaProtocolDtlsSctp[] = "DTLS/SCTP"; const char kMediaProtocolTcpDtlsSctp[] = "TCP/DTLS/SCTP"; // RFC5124 const char kMediaProtocolDtlsSavpf[] = "UDP/TLS/RTP/SAVPF"; const char kMediaProtocolSavpf[] = "RTP/SAVPF"; const char kMediaProtocolAvpf[] = "RTP/AVPF"; namespace { // Protocol names that we tolerate, but do not generate. // We always generate offers with "UDP/TLS/RTP/SAVPF" when using DTLS-SRTP, // but we tolerate "RTP/SAVPF" and "RTP/SAVP" and the "UDP/TLS" and "TCP/TLS" // prefixes in offers we receive, for compatibility. // RFC4585 const char kMediaProtocolSavp[] = "RTP/SAVP"; const char kMediaProtocolAvp[] = "RTP/AVP"; const char kMediaProtocolTcpTlsSavpf[] = "TCP/TLS/RTP/SAVPF"; const char kMediaProtocolUdpTlsSavpf[] = "UDP/TLS/RTP/SAVPF"; const char kMediaProtocolTcpTlsSavp[] = "TCP/TLS/RTP/SAVP"; const char kMediaProtocolUdpTlsSavp[] = "UDP/TLS/RTP/SAVP"; } // namespace bool IsDtlsSctp(absl::string_view protocol) { return protocol == kMediaProtocolDtlsSctp || protocol == kMediaProtocolUdpDtlsSctp || protocol == kMediaProtocolTcpDtlsSctp; } bool IsPlainSctp(absl::string_view protocol) { return protocol == kMediaProtocolSctp; } bool IsSctpProtocol(absl::string_view protocol) { return IsPlainSctp(protocol) || IsDtlsSctp(protocol); } bool IsRtpProtocol(absl::string_view protocol) { if (protocol.empty()) { return true; } size_t pos = protocol.find(cricket::kMediaProtocolRtpPrefix); if (pos == std::string::npos) { return false; } // RTP must be at the beginning of a string or not preceded by alpha if (pos == 0 || !isalpha(static_cast(protocol[pos - 1]))) { return true; } return false; } // Note that the below functions support some protocol strings purely for // legacy compatibility, as required by JSEP in Section 5.1.2, Profile Names // and Interoperability. bool IsDtlsRtp(absl::string_view protocol) { // Most-likely values first. return protocol == kMediaProtocolDtlsSavpf || protocol == kMediaProtocolTcpTlsSavpf || protocol == kMediaProtocolUdpTlsSavpf || protocol == kMediaProtocolUdpTlsSavp || protocol == kMediaProtocolTcpTlsSavp; } bool IsPlainRtp(absl::string_view protocol) { // Most-likely values first. return protocol == kMediaProtocolSavpf || protocol == kMediaProtocolAvpf || protocol == kMediaProtocolSavp || protocol == kMediaProtocolAvp; } } // namespace cricket