# HG changeset patch # User Mychaela Falconia # Date 1663733504 28800 # Node ID 915f0f397fb6f7d2c5ef04633ffa1d4dac7cd8c4 # Parent a9944b66dcc5e17028f8edc2bcaf07fec35fb1a9 sip-in: beginning of outgoing BYE support diff -r a9944b66dcc5 -r 915f0f397fb6 libsip/out_msg.c --- a/libsip/out_msg.c Tue Sep 20 19:35:34 2022 -0800 +++ b/libsip/out_msg.c Tue Sep 20 20:11:44 2022 -0800 @@ -22,6 +22,21 @@ return(0); } +start_request_out_msg_urilen(msg, method, uri, uri_len) + struct sip_msg_out *msg; + char *method, *uri; + unsigned uri_len; +{ + unsigned len; + + len = strlen(method) + uri_len + (2 + 7 + 2); + if (len + 2 > MAX_SIP_TX_PACKET) + return(-1); + sprintf(msg->buf, "%s %.*s SIP/2.0\r\n", method, uri_len, uri); + msg->msg_len = len; + return(0); +} + start_response_out_msg(msg, status) struct sip_msg_out *msg; char *status; diff -r a9944b66dcc5 -r 915f0f397fb6 sip-in/Makefile --- a/sip-in/Makefile Tue Sep 20 19:35:34 2022 -0800 +++ b/sip-in/Makefile Tue Sep 20 20:11:44 2022 -0800 @@ -1,9 +1,9 @@ CC= gcc CFLAGS= -O2 PROG= themwi-sip-in -OBJS= bye_in.o call_list.o call_setup.o cancel.o disconnect.o invite.o main.o\ - mgw_ops.o mgw_sock.o mncc_handle.o mncc_sock.o readconf.o retrans.o \ - sip_ack.o sip_log.o sip_uas.o sip_udp.o +OBJS= bye_in.o bye_out.o call_list.o call_setup.o cancel.o disconnect.o \ + invite.o main.o mgw_ops.o mgw_sock.o mncc_handle.o mncc_sock.o \ + readconf.o retrans.o sip_ack.o sip_log.o sip_uas.o sip_udp.o LIBS= ../libnumdb/libnumdb.a ../libsip/libsip.a ../libutil/libutil.a INSTBIN=/usr/local/bin diff -r a9944b66dcc5 -r 915f0f397fb6 sip-in/bye_out.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sip-in/bye_out.c Tue Sep 20 20:11:44 2022 -0800 @@ -0,0 +1,74 @@ +/* + * In this module we implement our UAC functionality of sending BYE. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "../libsip/parse.h" +#include "../libsip/out_msg.h" +#include "call.h" + +extern struct in_addr sip_bind_ip; +extern unsigned sip_bind_port; + +fill_bye_out_msg(msg, call) + struct sip_msg_out *msg; + struct call *call; +{ + char strbuf[80]; + int rc; + + rc = start_request_out_msg_urilen(msg, "BYE", call->from_uri, + call->from_uri_len); + if (rc < 0) + return rc; + sprintf(strbuf, "SIP/2.0/UDP %s:%u", + inet_ntoa(sip_bind_ip), sip_bind_port); + rc = out_msg_add_header(msg, "Via", strbuf); + if (rc < 0) + return rc; + rc = out_msg_add_header(msg, "From", call->invite_to); + if (rc < 0) + return rc; + rc = out_msg_add_header(msg, "To", call->invite_from); + if (rc < 0) + return rc; + rc = out_msg_add_header(msg, "Call-ID", call->sip_call_id); + if (rc < 0) + return rc; + rc = out_msg_add_header(msg, "CSeq", "1 BYE"); + if (rc < 0) + return rc; + rc = out_msg_add_header(msg, "Max-Forwards", "70"); + if (rc < 0) + return rc; + out_msg_finish(msg); + return 0; +} + +void +initiate_bye(call) + struct call *call; +{ + struct sip_msg_out msg; + int rc; + + rc = fill_bye_out_msg(&msg, call); + if (rc < 0) { + syslog(LOG_ERR, "outgoing BYE request msg length exceeded"); + call->sip_state = SIP_STATE_MSG_SIZE_ERR; + /* TODO: transition from TEARDOWN to DEAD_SIP */ + return; + } + sip_tx_packet(&msg, &call->udp_sin); + call->sip_state = SIP_STATE_BYE_SENT; + call->sip_tx_count = 1; +} diff -r a9944b66dcc5 -r 915f0f397fb6 sip-in/call_list.c --- a/sip-in/call_list.c Tue Sep 20 19:35:34 2022 -0800 +++ b/sip-in/call_list.c Tue Sep 20 20:11:44 2022 -0800 @@ -63,6 +63,7 @@ switch (call->sip_state) { case SIP_STATE_INVITE_200: case SIP_STATE_INVITE_ERR: + case SIP_STATE_BYE_SENT: *retrans = 1; break; } diff -r a9944b66dcc5 -r 915f0f397fb6 sip-in/retrans.c --- a/sip-in/retrans.c Tue Sep 20 19:35:34 2022 -0800 +++ b/sip-in/retrans.c Tue Sep 20 20:11:44 2022 -0800 @@ -33,12 +33,11 @@ sip_tx_packet(&msg, &call->udp_sin); call->sip_tx_count++; } else { - /* TODO: send BYE */ - call->sip_state = SIP_STATE_ENDED; call->overall_state = OVERALL_STATE_TEARDOWN; disconnect_mncc(call, GSM48_CAUSE_LOC_PRN_S_LU, GSM48_CC_CAUSE_INTERWORKING); disconnect_tmgw(call); + initiate_bye(call); } break; case SIP_STATE_INVITE_ERR: @@ -51,6 +50,14 @@ } else call->sip_state = SIP_STATE_ENDED; break; + case SIP_STATE_BYE_SENT: + if (call->sip_tx_count < cfg_retrans_count) { + fill_bye_out_msg(&msg, call); + sip_tx_packet(&msg, &call->udp_sin); + call->sip_tx_count++; + } else + call->sip_state = SIP_STATE_ENDED; + break; } } }