| /* |
| * 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 <ctype.h> |
| #include <stddef.h> |
| |
| #include <string> |
| |
| 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<unsigned char>(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 |