/* * anytun * * The secure anycast tunneling protocol (satp) defines a protocol used * for communication between any combination of unicast and anycast * tunnel endpoints. It has less protocol overhead than IPSec in Tunnel * mode and allows tunneling of every ETHER TYPE protocol (e.g. * ethernet, ip, arp ...). satp directly includes cryptography and * message authentication based on the methodes used by SRTP. It is * intended to deliver a generic, scaleable and secure solution for * tunneling and relaying of packets of any protocol. * * * Copyright (C) 2007-2008 Othmar Gsenger, Erwin Nindl, * Christian Pointner * * This file is part of Anytun. * * Anytun is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * Anytun is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with anytun. If not, see . */ #ifndef _RTPSESSION_H_ #define _RTPSESSION_H_ #include #include "../threadUtils.hpp" #include #include class RtpSession { public: typedef boost::asio::ip::udp proto; RtpSession(const std::string& call_id); bool isDead(); bool isDead(bool d); bool isComplete(); bool isComplete(bool c); proto::endpoint getLocalEnd1(); RtpSession& setLocalEnd1(proto::endpoint e); proto::endpoint getLocalEnd2(); RtpSession& setLocalEnd2(proto::endpoint e); proto::endpoint getRemoteEnd1(); RtpSession& setRemoteEnd1(proto::endpoint e); proto::endpoint getRemoteEnd2(); RtpSession& setRemoteEnd2(proto::endpoint e); RtpSession& setSeen1(); bool getSeen1(); RtpSession& setSeen2(); bool getSeen2(); private: RtpSession(const RtpSession & src); void reinit(); //TODO: check if this is ok friend class boost::serialization::access; template void serialize(Archive & ar, const unsigned int version) { Lock lock(mutex_); // address of local_end1 and local_end2 are always equal std::string local_addr(local_end1_.address().to_string()); u_int16_t local_port1 = local_end1_.port(); u_int16_t local_port2 = local_end2_.port(); std::string remote_addr1(remote_end1_.address().to_string()); u_int16_t remote_port1 = remote_end1_.port(); std::string remote_addr2(remote_end2_.address().to_string()); u_int16_t remote_port2 = remote_end2_.port(); ar & dead_; ar & complete_; ar & local_addr; ar & local_port1; ar & local_port2; ar & remote_addr1; ar & remote_port1; ar & remote_addr2; ar & remote_port2; ar & seen1_; ar & seen2_; proto::endpoint local_end1(boost::asio::ip::address::from_string(local_addr), local_port1); local_end1_ = local_end1; proto::endpoint local_end2(boost::asio::ip::address::from_string(local_addr), local_port2); local_end2_ = local_end2; proto::endpoint remote_end1(boost::asio::ip::address::from_string(remote_addr1), remote_port1); remote_end1_ = remote_end1; proto::endpoint remote_end2(boost::asio::ip::address::from_string(remote_addr2), remote_port2); remote_end2_ = remote_end2; if(complete_ && !dead_) reinit(); in_sync_ = true; } bool in_sync_; ::Mutex mutex_; const std::string& call_id_; bool dead_; bool complete_; proto::endpoint local_end1_, local_end2_; proto::endpoint remote_end1_, remote_end2_; bool seen1_,seen2_; //has at least 1 packet been recieved? }; #endif