Merge commit 'upstream/0.3.4'
[anytun.git] / src / anyrtpproxy / rtpSession.h
1 /*
2  *  anytun
3  *
4  *  The secure anycast tunneling protocol (satp) defines a protocol used
5  *  for communication between any combination of unicast and anycast
6  *  tunnel endpoints.  It has less protocol overhead than IPSec in Tunnel
7  *  mode and allows tunneling of every ETHER TYPE protocol (e.g.
8  *  ethernet, ip, arp ...). satp directly includes cryptography and
9  *  message authentication based on the methodes used by SRTP.  It is
10  *  intended to deliver a generic, scaleable and secure solution for
11  *  tunneling and relaying of packets of any protocol.
12  *
13  *
14  *  Copyright (C) 2007-2009 Othmar Gsenger, Erwin Nindl,
15  *                          Christian Pointner <satp@wirdorange.org>
16  *
17  *  This file is part of Anytun.
18  *
19  *  Anytun is free software: you can redistribute it and/or modify
20  *  it under the terms of the GNU General Public License as published by
21  *  the Free Software Foundation, either version 3 of the License, or
22  *  any later version.
23  *
24  *  Anytun is distributed in the hope that it will be useful,
25  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
26  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
27  *  GNU General Public License for more details.
28  *
29  *  You should have received a copy of the GNU General Public License
30  *  along with anytun.  If not, see <http://www.gnu.org/licenses/>.
31  */
32
33 #ifndef _RTPSESSION_H_
34 #define _RTPSESSION_H_
35
36 #include <boost/asio.hpp>
37
38 #include "../threadUtils.hpp"
39
40 #include <boost/archive/text_oarchive.hpp>
41 #include <boost/archive/text_iarchive.hpp>
42
43 class RtpSession
44 {
45 public:
46   typedef boost::asio::ip::udp proto;
47
48   RtpSession(const std::string& call_id);
49
50   bool isDead();
51   bool isDead(bool d);
52
53   bool isComplete();
54   bool isComplete(bool c);
55
56   proto::endpoint getLocalEnd1();
57   RtpSession& setLocalEnd1(proto::endpoint e);
58   proto::endpoint getLocalEnd2();
59   RtpSession& setLocalEnd2(proto::endpoint e);
60
61   proto::endpoint getRemoteEnd1();
62   RtpSession& setRemoteEnd1(proto::endpoint e);
63   proto::endpoint getRemoteEnd2();
64   RtpSession& setRemoteEnd2(proto::endpoint e);
65
66   RtpSession& setSeen1();
67   bool getSeen1();
68
69   RtpSession& setSeen2();
70   bool getSeen2();
71
72 private:
73   RtpSession(const RtpSession& src);
74
75   void reinit();
76
77   //TODO: check if this is ok
78   friend class boost::serialization::access;
79   template<class Archive>
80   void serialize(Archive& ar, const unsigned int version) {
81     Lock lock(mutex_);
82
83     // address of local_end1 and local_end2 are always equal
84     std::string local_addr(local_end1_.address().to_string());
85     uint16_t local_port1 = local_end1_.port();
86     uint16_t local_port2 = local_end2_.port();
87
88     std::string remote_addr1(remote_end1_.address().to_string());
89     uint16_t remote_port1 = remote_end1_.port();
90     std::string remote_addr2(remote_end2_.address().to_string());
91     uint16_t remote_port2 = remote_end2_.port();
92
93     ar& dead_;
94     ar& complete_;
95     ar& local_addr;
96     ar& local_port1;
97     ar& local_port2;
98     ar& remote_addr1;
99     ar& remote_port1;
100     ar& remote_addr2;
101     ar& remote_port2;
102     ar& seen1_;
103     ar& seen2_;
104
105     proto::endpoint local_end1(boost::asio::ip::address::from_string(local_addr), local_port1);
106     local_end1_ = local_end1;
107     proto::endpoint local_end2(boost::asio::ip::address::from_string(local_addr), local_port2);
108     local_end2_ = local_end2;
109
110     proto::endpoint remote_end1(boost::asio::ip::address::from_string(remote_addr1), remote_port1);
111     remote_end1_ = remote_end1;
112     proto::endpoint remote_end2(boost::asio::ip::address::from_string(remote_addr2), remote_port2);
113     remote_end2_ = remote_end2;
114
115     if(complete_ && !dead_) {
116       reinit();
117     }
118
119     in_sync_ = true;
120   }
121
122   bool in_sync_;
123   ::Mutex mutex_;
124
125   const std::string& call_id_;
126   bool dead_;
127   bool complete_;
128   proto::endpoint local_end1_, local_end2_;
129   proto::endpoint remote_end1_, remote_end2_;
130   bool seen1_,seen2_; //has at least 1 packet been recieved?
131 };
132
133
134 #endif