clean up Makefile
[anytun.git] / src / rtpSessionTable.cpp
blobb751a5047e9f3202fe42241a5df2cf2e61ea26c8
1 /*
2 * anytun
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.
14 * Copyright (C) 2007-2008 Othmar Gsenger, Erwin Nindl,
15 * Christian Pointner <satp@wirdorange.org>
17 * This file is part of Anytun.
19 * Anytun is free software: you can redistribute it and/or modify
20 * it under the terms of the GNU General Public License version 3 as
21 * published by the Free Software Foundation.
23 * Anytun is distributed in the hope that it will be useful,
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
26 * GNU General Public License for more details.
28 * You should have received a copy of the GNU General Public License
29 * along with anytun. If not, see <http://www.gnu.org/licenses/>.
31 #include "threadUtils.hpp"
32 #include "datatypes.h"
34 #include "rtpSessionTable.h"
36 RtpSessionTable* RtpSessionTable::inst = NULL;
37 Mutex RtpSessionTable::instMutex;
38 RtpSessionTable& gRtpSessionTable = RtpSessionTable::instance();
41 RtpSessionTable& RtpSessionTable::instance()
43 Lock lock(instMutex);
44 static instanceCleaner c;
45 if(!inst)
46 inst = new RtpSessionTable();
48 return *inst;
51 RtpSessionTable::RtpSessionTable()
55 RtpSessionTable::~RtpSessionTable()
59 void RtpSessionTable::delSession(const std::string & call_id)
61 Lock lock(mutex_);
63 RtpSessionMap::iterator it = map_.find(call_id);
64 if(it!=map_.end())
65 delete it->second;
67 map_.erase(it);
70 RtpSession& RtpSessionTable::getOrNewSession(const std::string & call_id, bool& is_new)
72 Lock lock(mutex_);
73 return getOrNewSessionUnlocked(call_id, is_new);
76 RtpSession& RtpSessionTable::getOrNewSessionUnlocked(const std::string & call_id, bool& is_new)
78 is_new = false;
79 RtpSessionMap::iterator it = map_.find(call_id);
80 if(it!=map_.end())
81 return *(it->second);
83 is_new = true;
84 std::pair<RtpSessionMap::iterator, bool> ret = map_.insert(RtpSessionMap::value_type(call_id, NULL));
85 ret.first->second = new RtpSession(ret.first->first);
86 return *(ret.first->second);
89 RtpSession& RtpSessionTable::getSession(const std::string & call_id)
91 RtpSessionMap::iterator it = map_.find(call_id);
92 if(it!=map_.end())
93 return *(it->second);
95 throw std::runtime_error("session not found");
98 RtpSessionMap::iterator RtpSessionTable::getBeginUnlocked()
100 return map_.begin();
103 RtpSessionMap::iterator RtpSessionTable::getEndUnlocked()
105 return map_.end();
108 void RtpSessionTable::clear()
110 Lock lock(mutex_);
111 map_.clear();
114 bool RtpSessionTable::empty()
116 Lock lock(mutex_);
117 return map_.empty();
120 Mutex& RtpSessionTable::getMutex()
122 return mutex_;