| /* | 
 |  *  Copyright 2011 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. | 
 |  */ | 
 |  | 
 | // This file contain functions for parsing and serializing SDP messages. | 
 | // Related RFC/draft including: | 
 | // * RFC 4566 - SDP | 
 | // * RFC 5245 - ICE | 
 | // * RFC 3388 - Grouping of Media Lines in SDP | 
 | // * RFC 4568 - SDP Security Descriptions for Media Streams | 
 | // * draft-lennox-mmusic-sdp-source-selection-02 - | 
 | //   Mechanisms for Media Source Selection in SDP | 
 |  | 
 | #ifndef PC_WEBRTC_SDP_H_ | 
 | #define PC_WEBRTC_SDP_H_ | 
 |  | 
 | #include <string> | 
 |  | 
 | #include "absl/strings/string_view.h" | 
 | #include "api/candidate.h" | 
 | #include "api/jsep.h" | 
 | #include "api/jsep_ice_candidate.h" | 
 | #include "api/jsep_session_description.h" | 
 | #include "media/base/codec.h" | 
 | #include "rtc_base/strings/string_builder.h" | 
 | #include "rtc_base/system/rtc_export.h" | 
 |  | 
 | namespace cricket { | 
 | class Candidate; | 
 | }  // namespace cricket | 
 |  | 
 | namespace rtc { | 
 | class StringBuilder; | 
 | }  // namespace rtc | 
 |  | 
 | namespace webrtc { | 
 | class IceCandidateInterface; | 
 | class JsepIceCandidate; | 
 | class JsepSessionDescription; | 
 | struct SdpParseError; | 
 |  | 
 | // Serializes the passed in JsepSessionDescription. | 
 | // Serialize SessionDescription including candidates if | 
 | // JsepSessionDescription has candidates. | 
 | // jdesc - The JsepSessionDescription object to be serialized. | 
 | // unified_plan_sdp - If set to true, include "a=msid" lines where appropriate. | 
 | // return - SDP string serialized from the arguments. | 
 | std::string SdpSerialize(const JsepSessionDescription& jdesc); | 
 |  | 
 | // Serializes the passed in IceCandidateInterface to a SDP string. | 
 | // candidate - The candidate to be serialized. | 
 | std::string SdpSerializeCandidate(const IceCandidateInterface& candidate); | 
 |  | 
 | // Serializes a cricket Candidate. | 
 | // candidate - The candidate to be serialized. | 
 | RTC_EXPORT std::string SdpSerializeCandidate( | 
 |     const cricket::Candidate& candidate); | 
 |  | 
 | // Deserializes the passed in SDP string to a JsepSessionDescription. | 
 | // message - SDP string to be Deserialized. | 
 | // jdesc - The JsepSessionDescription deserialized from the SDP string. | 
 | // error - The detail error information when parsing fails. | 
 | // return - true on success, false on failure. | 
 | bool SdpDeserialize(absl::string_view message, | 
 |                     JsepSessionDescription* jdesc, | 
 |                     SdpParseError* error); | 
 |  | 
 | // Deserializes the passed in SDP string to one JsepIceCandidate. | 
 | // The first line must be a=candidate line and only the first line will be | 
 | // parsed. | 
 | // message - The SDP string to be Deserialized. | 
 | // candidates - The JsepIceCandidate from the SDP string. | 
 | // error - The detail error information when parsing fails. | 
 | // return - true on success, false on failure. | 
 | RTC_EXPORT bool SdpDeserializeCandidate(absl::string_view message, | 
 |                                         JsepIceCandidate* candidate, | 
 |                                         SdpParseError* error); | 
 |  | 
 | // Deserializes the passed in SDP string to a cricket Candidate. | 
 | // The first line must be a=candidate line and only the first line will be | 
 | // parsed. | 
 | // transport_name - The transport name (MID) of the candidate. | 
 | // message - The SDP string to be deserialized. | 
 | // candidate - The cricket Candidate from the SDP string. | 
 | // error - The detail error information when parsing fails. | 
 | // return - true on success, false on failure. | 
 | RTC_EXPORT bool SdpDeserializeCandidate(absl::string_view transport_name, | 
 |                                         absl::string_view message, | 
 |                                         cricket::Candidate* candidate, | 
 |                                         SdpParseError* error); | 
 |  | 
 | // Parses `message` according to the grammar defined in RFC 5245, Section 15.1 | 
 | // and, if successful, stores the result in `candidate` and returns true. | 
 | // If unsuccessful, returns false and stores error information in `error` if | 
 | // `error` is not null. | 
 | // If `is_raw` is false, `message` is expected to be prefixed with "a=". | 
 | // If `is_raw` is true, no prefix is expected in `messaage`. | 
 | RTC_EXPORT bool ParseCandidate(absl::string_view message, | 
 |                                cricket::Candidate* candidate, | 
 |                                SdpParseError* error, | 
 |                                bool is_raw); | 
 |  | 
 | // Generates an FMTP line based on `parameters`. Please note that some | 
 | // parameters are not considered to be part of the FMTP line, see the function | 
 | // IsFmtpParam(). Returns true if the set of FMTP parameters is nonempty, false | 
 | // otherwise. | 
 | bool WriteFmtpParameters(const cricket::CodecParameterMap& parameters, | 
 |                          rtc::StringBuilder* os); | 
 |  | 
 | }  // namespace webrtc | 
 |  | 
 | #endif  // PC_WEBRTC_SDP_H_ |