You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
sems/apps/sbc/SDPFilter.cpp

99 lines
3.3 KiB

/*
* Copyright (C) 2010 Stefan Sayer
*
* This file is part of SEMS, a free SIP media server.
*
* SEMS 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 2 of the License, or
* (at your option) any later version.
*
* For a license to use the SEMS software under conditions
* other than those described here, or to purchase support for this
* software, please contact iptel.org by e-mail at the following addresses:
* info@iptel.org
*
* SEMS 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 this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include "SDPFilter.h"
#include <algorithm>
#include "log.h"
#include "AmUtils.h"
#include "RTPParameters.h"
int filterSDP(AmSdp& sdp, FilterType sdpfilter, const std::set<string>& sdpfilter_list) {
if (sdpfilter == Transparent)
return 0;
for (std::vector<SdpMedia>::iterator m_it =
sdp.media.begin(); m_it != sdp.media.end(); m_it++) {
SdpMedia& media = *m_it;
std::vector<SdpPayload> new_pl;
for (std::vector<SdpPayload>::iterator p_it =
media.payloads.begin(); p_it != media.payloads.end(); p_it++) {
string c = p_it->encoding_name;
std::transform(c.begin(), c.end(), c.begin(), ::tolower);
bool is_filtered = (sdpfilter == Whitelist) ^
(sdpfilter_list.find(c) != sdpfilter_list.end());
// DBG("%s (%s) is_filtered: %s\n", p_it->encoding_name.c_str(), c.c_str(),
// is_filtered?"true":"false");
if (!is_filtered)
new_pl.push_back(*p_it);
}
// todo: what if no payload supported any more?
media.payloads = new_pl;
}
return 0;
}
void fix_missing_encodings(SdpMedia& m) {
for (std::vector<SdpPayload>::iterator p_it=
m.payloads.begin(); p_it!=m.payloads.end(); p_it++) {
SdpPayload& p = *p_it;
if (!p.encoding_name.empty())
continue;
if (p.payload_type > (IANA_RTP_PAYLOADS_SIZE-1) || p.payload_type < 0)
continue; // todo: throw out this payload
if (IANA_RTP_PAYLOADS[p.payload_type].payload_name[0]=='\0')
continue; // todo: throw out this payload
p.encoding_name = IANA_RTP_PAYLOADS[p.payload_type].payload_name;
p.clock_rate = IANA_RTP_PAYLOADS[p.payload_type].clock_rate;
if (IANA_RTP_PAYLOADS[p.payload_type].channels > 1)
p.encoding_param = IANA_RTP_PAYLOADS[p.payload_type].channels;
DBG("named SDP payload type %d with %s/%d%s\n",
p.payload_type, IANA_RTP_PAYLOADS[p.payload_type].payload_name,
IANA_RTP_PAYLOADS[p.payload_type].clock_rate,
IANA_RTP_PAYLOADS[p.payload_type].channels > 1 ?
("/"+int2str(IANA_RTP_PAYLOADS[p.payload_type].channels)).c_str() : "");
}
}
int normalizeSDP(AmSdp& sdp) {
for (std::vector<SdpMedia>::iterator m_it=
sdp.media.begin(); m_it != sdp.media.end(); m_it++) {
if (m_it->type != MT_AUDIO && m_it->type != MT_VIDEO)
continue;
// fill missing encoding names (a= lines)
fix_missing_encodings(*m_it);
}
return 0;
}