// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef REMOTING_PROTOCOL_CONTENT_DESCRIPTION_H_ #define REMOTING_PROTOCOL_CONTENT_DESCRIPTION_H_ #include #include "base/memory/scoped_ptr.h" #include "base/memory/ref_counted.h" #include "remoting/protocol/session_config.h" #include "third_party/libjingle/source/talk/p2p/base/sessiondescription.h" namespace buzz { class XmlElement; } // namespace buzz namespace remoting { namespace protocol { // ContentDescription used for chromoting sessions. It contains the information // from the content description stanza in the session intialization handshake. // // This class also provides a type abstraction so that the Chromotocol Session // interface does not need to depend on libjingle. class ContentDescription : public cricket::ContentDescription { public: static const char kChromotingContentName[]; ContentDescription(scoped_ptr config, scoped_ptr authenticator_message); virtual ~ContentDescription(); virtual ContentDescription* Copy() const OVERRIDE; const CandidateSessionConfig* config() const { return candidate_config_.get(); } const buzz::XmlElement* authenticator_message() const { return authenticator_message_.get(); } buzz::XmlElement* ToXml() const; static scoped_ptr ParseXml( const buzz::XmlElement* element); private: scoped_ptr candidate_config_; scoped_ptr authenticator_message_; static bool ParseChannelConfigs(const buzz::XmlElement* const element, const char tag_name[], bool codec_required, bool optional, std::list* const configs); }; } // namespace protocol } // namespace remoting #endif // REMOTING_PROTOCOL_CONTENT_DESCRIPTION_H_