| /* |
| * Copyright 2004 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. |
| */ |
| |
| #ifndef WEBRTC_P2P_BASE_SESSIONDESCRIPTION_H_ |
| #define WEBRTC_P2P_BASE_SESSIONDESCRIPTION_H_ |
| |
| #include <string> |
| #include <vector> |
| |
| #include "webrtc/p2p/base/transportinfo.h" |
| #include "webrtc/base/constructormagic.h" |
| |
| namespace cricket { |
| |
| // Describes a session content. Individual content types inherit from |
| // this class. Analagous to a <jingle><content><description> or |
| // <session><description>. |
| class ContentDescription { |
| public: |
| virtual ~ContentDescription() {} |
| virtual ContentDescription* Copy() const = 0; |
| }; |
| |
| // Analagous to a <jingle><content> or <session><description>. |
| // name = name of <content name="..."> |
| // type = xmlns of <content> |
| struct ContentInfo { |
| ContentInfo() : description(NULL) {} |
| ContentInfo(const std::string& name, |
| const std::string& type, |
| ContentDescription* description) : |
| name(name), type(type), rejected(false), description(description) {} |
| ContentInfo(const std::string& name, |
| const std::string& type, |
| bool rejected, |
| ContentDescription* description) : |
| name(name), type(type), rejected(rejected), description(description) {} |
| std::string name; |
| std::string type; |
| bool rejected; |
| ContentDescription* description; |
| }; |
| |
| typedef std::vector<std::string> ContentNames; |
| |
| // This class provides a mechanism to aggregate different media contents into a |
| // group. This group can also be shared with the peers in a pre-defined format. |
| // GroupInfo should be populated only with the |content_name| of the |
| // MediaDescription. |
| class ContentGroup { |
| public: |
| explicit ContentGroup(const std::string& semantics) : |
| semantics_(semantics) {} |
| |
| const std::string& semantics() const { return semantics_; } |
| const ContentNames& content_names() const { return content_names_; } |
| |
| const std::string* FirstContentName() const; |
| bool HasContentName(const std::string& content_name) const; |
| void AddContentName(const std::string& content_name); |
| bool RemoveContentName(const std::string& content_name); |
| |
| private: |
| std::string semantics_; |
| ContentNames content_names_; |
| }; |
| |
| typedef std::vector<ContentInfo> ContentInfos; |
| typedef std::vector<ContentGroup> ContentGroups; |
| |
| const ContentInfo* FindContentInfoByName( |
| const ContentInfos& contents, const std::string& name); |
| const ContentInfo* FindContentInfoByType( |
| const ContentInfos& contents, const std::string& type); |
| |
| // Describes a collection of contents, each with its own name and |
| // type. Analogous to a <jingle> or <session> stanza. Assumes that |
| // contents are unique be name, but doesn't enforce that. |
| class SessionDescription { |
| public: |
| SessionDescription() {} |
| explicit SessionDescription(const ContentInfos& contents) : |
| contents_(contents) {} |
| SessionDescription(const ContentInfos& contents, |
| const ContentGroups& groups) : |
| contents_(contents), |
| content_groups_(groups) {} |
| SessionDescription(const ContentInfos& contents, |
| const TransportInfos& transports, |
| const ContentGroups& groups) : |
| contents_(contents), |
| transport_infos_(transports), |
| content_groups_(groups) {} |
| ~SessionDescription() { |
| for (ContentInfos::iterator content = contents_.begin(); |
| content != contents_.end(); ++content) { |
| delete content->description; |
| } |
| } |
| |
| SessionDescription* Copy() const; |
| |
| // Content accessors. |
| const ContentInfos& contents() const { return contents_; } |
| ContentInfos& contents() { return contents_; } |
| const ContentInfo* GetContentByName(const std::string& name) const; |
| ContentInfo* GetContentByName(const std::string& name); |
| const ContentDescription* GetContentDescriptionByName( |
| const std::string& name) const; |
| ContentDescription* GetContentDescriptionByName(const std::string& name); |
| const ContentInfo* FirstContentByType(const std::string& type) const; |
| const ContentInfo* FirstContent() const; |
| |
| // Content mutators. |
| // Adds a content to this description. Takes ownership of ContentDescription*. |
| void AddContent(const std::string& name, |
| const std::string& type, |
| ContentDescription* description); |
| void AddContent(const std::string& name, |
| const std::string& type, |
| bool rejected, |
| ContentDescription* description); |
| bool RemoveContentByName(const std::string& name); |
| |
| // Transport accessors. |
| const TransportInfos& transport_infos() const { return transport_infos_; } |
| TransportInfos& transport_infos() { return transport_infos_; } |
| const TransportInfo* GetTransportInfoByName( |
| const std::string& name) const; |
| TransportInfo* GetTransportInfoByName(const std::string& name); |
| const TransportDescription* GetTransportDescriptionByName( |
| const std::string& name) const { |
| const TransportInfo* tinfo = GetTransportInfoByName(name); |
| return tinfo ? &tinfo->description : NULL; |
| } |
| |
| // Transport mutators. |
| void set_transport_infos(const TransportInfos& transport_infos) { |
| transport_infos_ = transport_infos; |
| } |
| // Adds a TransportInfo to this description. |
| // Returns false if a TransportInfo with the same name already exists. |
| bool AddTransportInfo(const TransportInfo& transport_info); |
| bool RemoveTransportInfoByName(const std::string& name); |
| |
| // Group accessors. |
| const ContentGroups& groups() const { return content_groups_; } |
| const ContentGroup* GetGroupByName(const std::string& name) const; |
| bool HasGroup(const std::string& name) const; |
| |
| // Group mutators. |
| void AddGroup(const ContentGroup& group) { content_groups_.push_back(group); } |
| // Remove the first group with the same semantics specified by |name|. |
| void RemoveGroupByName(const std::string& name); |
| |
| // Global attributes. |
| void set_msid_supported(bool supported) { msid_supported_ = supported; } |
| bool msid_supported() const { return msid_supported_; } |
| |
| private: |
| ContentInfos contents_; |
| TransportInfos transport_infos_; |
| ContentGroups content_groups_; |
| bool msid_supported_ = true; |
| }; |
| |
| // Indicates whether a ContentDescription was an offer or an answer, as |
| // described in http://www.ietf.org/rfc/rfc3264.txt. CA_UPDATE |
| // indicates a jingle update message which contains a subset of a full |
| // session description |
| enum ContentAction { |
| CA_OFFER, CA_PRANSWER, CA_ANSWER, CA_UPDATE |
| }; |
| |
| // Indicates whether a ContentDescription was sent by the local client |
| // or received from the remote client. |
| enum ContentSource { |
| CS_LOCAL, CS_REMOTE |
| }; |
| |
| } // namespace cricket |
| |
| #endif // WEBRTC_P2P_BASE_SESSIONDESCRIPTION_H_ |