blob: 588e02f139de0d34a0791735fe005bd90232af88 [file] [log] [blame]
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001/*
kjellanderb24317b2016-02-10 07:54:43 -08002 * Copyright 2011 The WebRTC project authors. All Rights Reserved.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003 *
kjellanderb24317b2016-02-10 07:54:43 -08004 * 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.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00009 */
10
11// This file contain functions for parsing and serializing SDP messages.
12// Related RFC/draft including:
13// * RFC 4566 - SDP
14// * RFC 5245 - ICE
15// * RFC 3388 - Grouping of Media Lines in SDP
16// * RFC 4568 - SDP Security Descriptions for Media Streams
17// * draft-lennox-mmusic-sdp-source-selection-02 -
18// Mechanisms for Media Source Selection in SDP
19
Steve Anton10542f22019-01-11 09:11:00 -080020#ifndef PC_WEBRTC_SDP_H_
21#define PC_WEBRTC_SDP_H_
henrike@webrtc.org28e20752013-07-10 00:45:36 +000022
23#include <string>
24
Johannes Kron72d69152020-02-10 14:05:55 +010025#include "media/base/codec.h"
Mirko Bonadei977b46a2018-10-24 16:22:04 +020026#include "rtc_base/system/rtc_export.h"
27
Honghai Zhang7fb69db2016-03-14 11:59:18 -070028namespace cricket {
29class Candidate;
30} // namespace cricket
tommi6f59a4f2016-03-11 14:05:09 -080031
Johannes Kron72d69152020-02-10 14:05:55 +010032namespace rtc {
33class StringBuilder;
34} // namespace rtc
35
Honghai Zhang7fb69db2016-03-14 11:59:18 -070036namespace webrtc {
henrike@webrtc.org28e20752013-07-10 00:45:36 +000037class IceCandidateInterface;
38class JsepIceCandidate;
39class JsepSessionDescription;
40struct SdpParseError;
41
42// Serializes the passed in JsepSessionDescription.
43// Serialize SessionDescription including candidates if
44// JsepSessionDescription has candidates.
45// jdesc - The JsepSessionDescription object to be serialized.
deadbeef9d3584c2016-02-16 17:54:10 -080046// unified_plan_sdp - If set to true, include "a=msid" lines where appropriate.
henrike@webrtc.org28e20752013-07-10 00:45:36 +000047// return - SDP string serialized from the arguments.
Steve Antone831b8c2018-02-01 12:22:16 -080048std::string SdpSerialize(const JsepSessionDescription& jdesc);
henrike@webrtc.org28e20752013-07-10 00:45:36 +000049
50// Serializes the passed in IceCandidateInterface to a SDP string.
51// candidate - The candidate to be serialized.
52std::string SdpSerializeCandidate(const IceCandidateInterface& candidate);
53
Honghai Zhang7fb69db2016-03-14 11:59:18 -070054// Serializes a cricket Candidate.
55// candidate - The candidate to be serialized.
Mirko Bonadei977b46a2018-10-24 16:22:04 +020056RTC_EXPORT std::string SdpSerializeCandidate(
57 const cricket::Candidate& candidate);
Honghai Zhang7fb69db2016-03-14 11:59:18 -070058
henrike@webrtc.org28e20752013-07-10 00:45:36 +000059// Deserializes the passed in SDP string to a JsepSessionDescription.
60// message - SDP string to be Deserialized.
61// jdesc - The JsepSessionDescription deserialized from the SDP string.
62// error - The detail error information when parsing fails.
63// return - true on success, false on failure.
64bool SdpDeserialize(const std::string& message,
65 JsepSessionDescription* jdesc,
66 SdpParseError* error);
67
68// Deserializes the passed in SDP string to one JsepIceCandidate.
69// The first line must be a=candidate line and only the first line will be
70// parsed.
71// message - The SDP string to be Deserialized.
72// candidates - The JsepIceCandidate from the SDP string.
73// error - The detail error information when parsing fails.
74// return - true on success, false on failure.
Mirko Bonadei66e76792019-04-02 11:33:59 +020075RTC_EXPORT bool SdpDeserializeCandidate(const std::string& message,
76 JsepIceCandidate* candidate,
77 SdpParseError* error);
Honghai Zhang7fb69db2016-03-14 11:59:18 -070078
79// Deserializes the passed in SDP string to a cricket Candidate.
80// The first line must be a=candidate line and only the first line will be
81// parsed.
82// transport_name - The transport name (MID) of the candidate.
83// message - The SDP string to be deserialized.
84// candidate - The cricket Candidate from the SDP string.
85// error - The detail error information when parsing fails.
86// return - true on success, false on failure.
Mirko Bonadei977b46a2018-10-24 16:22:04 +020087RTC_EXPORT bool SdpDeserializeCandidate(const std::string& transport_name,
88 const std::string& message,
89 cricket::Candidate* candidate,
90 SdpParseError* error);
Honghai Zhang7fb69db2016-03-14 11:59:18 -070091
Guido Urdanetada374732019-01-25 10:36:43 +010092// Parses |message| according to the grammar defined in RFC 5245, Section 15.1
93// and, if successful, stores the result in |candidate| and returns true.
94// If unsuccessful, returns false and stores error information in |error| if
95// |error| is not null.
96// If |is_raw| is false, |message| is expected to be prefixed with "a=".
97// If |is_raw| is true, no prefix is expected in |messaage|.
98RTC_EXPORT bool ParseCandidate(const std::string& message,
99 cricket::Candidate* candidate,
100 SdpParseError* error,
101 bool is_raw);
102
Johannes Kron72d69152020-02-10 14:05:55 +0100103// Generates an FMTP line based on |parameters|. Please note that some
104// parameters are not considered to be part of the FMTP line, see the function
105// IsFmtpParam(). Returns true if the set of FMTP parameters is nonempty, false
106// otherwise.
107bool WriteFmtpParameters(const cricket::CodecParameterMap& parameters,
108 rtc::StringBuilder* os);
109
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000110} // namespace webrtc
111
Steve Anton10542f22019-01-11 09:11:00 -0800112#endif // PC_WEBRTC_SDP_H_