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/core/sip/transport.cpp

135 lines
3.2 KiB

/*
* $Id: transport.cpp 1048 2008-07-15 18:48:07Z sayer $
*
* Copyright (C) 2007 Raphael Coeffic
*
* 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. This program is released under
* the GPL with the additional exemption that compiling, linking,
* and/or using OpenSSL is allowed.
*
* 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 "transport.h"
#include "../SipCtrlInterface.h"
#include "../log.h"
#include <assert.h>
#include <netinet/in.h>
#include <string.h> // memset, strerror, ...
trsp_socket::trsp_socket()
: sd(0), ip(), port(0)
{
memset(&addr,0,sizeof(sockaddr_storage));
}
trsp_socket::~trsp_socket()
{
}
const char* trsp_socket::get_ip()
{
return ip.c_str();
}
unsigned short trsp_socket::get_port()
{
return port;
}
void trsp_socket::copy_addr_to(sockaddr_storage* sa)
{
memcpy(sa,&addr,sizeof(sockaddr_storage));
}
/**
* Match with the given address
* @return true if address matches
*/
bool trsp_socket::match_addr(sockaddr_storage* other_addr)
{
if(addr.ss_family != other_addr->ss_family)
return false;
if(addr.ss_family == AF_INET){
if( !memcmp(&((sockaddr_in*)&addr)->sin_addr,
&((sockaddr_in*)other_addr)->sin_addr,
sizeof(in_addr)) )
return true;
}
else if(addr.ss_family == AF_INET6) {
if( !memcmp(&((sockaddr_in6*)&addr)->sin6_addr,
&((sockaddr_in6*)other_addr)->sin6_addr,
sizeof(in6_addr)) )
return true;
}
return false;
}
int trsp_socket::get_sd()
{
return sd;
}
int trsp_socket::send(const sockaddr_storage* sa, const char* msg, const int msg_len)
{
if ((SipCtrlInterface::log_raw_messages >= 0)
&& (SipCtrlInterface::log_raw_messages <= log_level)) {
_LOG(SipCtrlInterface::log_raw_messages,
"send msg\n--++--\n%.*s--++--\n", msg_len, msg);
}
int err;
#ifdef SUPPORT_IPV6
if (sa->ss_family == AF_INET6) {
err = sendto(sd, msg, msg_len, 0, (const struct sockaddr*)sa, sizeof(sockaddr_in6));
}
else {
#endif
err = sendto(sd, msg, msg_len, 0, (const struct sockaddr*)sa, sizeof(sockaddr_in));
#ifdef SUPPORT_IPV6
}
#endif
if (err < 0) {
ERROR("sendto: %s\n",strerror(errno));
return err;
}
else if (err != msg_len) {
ERROR("sendto: sent %i instead of %i bytes\n", err, msg_len);
return -1;
}
return 0;
}
transport::~transport()
{
}
/** EMACS **
* Local variables:
* mode: c++
* c-basic-offset: 4
* End:
*/