[svn-commits] bbryant: branch bbryant/sip-tcptls r74161 - in /team/bbryant/sip-tcptls: chan...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Mon Jul 9 15:52:47 CDT 2007
Author: bbryant
Date: Mon Jul 9 15:52:47 2007
New Revision: 74161
URL: http://svn.digium.com/view/asterisk?view=rev&rev=74161
Log:
* Added support for connection to an SSL server
* Updated configuration files for a register
* Closed all tcp connections when module unloaded
Modified:
team/bbryant/sip-tcptls/channels/chan_sip.c
team/bbryant/sip-tcptls/configs/sip.conf.sample
team/bbryant/sip-tcptls/include/asterisk/server.h
team/bbryant/sip-tcptls/main/server.c
Modified: team/bbryant/sip-tcptls/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/bbryant/sip-tcptls/channels/chan_sip.c?view=diff&rev=74161&r1=74160&r2=74161
==============================================================================
--- team/bbryant/sip-tcptls/channels/chan_sip.c (original)
+++ team/bbryant/sip-tcptls/channels/chan_sip.c Mon Jul 9 15:52:47 2007
@@ -1241,7 +1241,16 @@
char lastmsg[256]; /*!< Last Message sent/received */
};
+struct sip_threadinfo {
+ int stop;
+ pthread_t threadid;
+ AST_LIST_ENTRY(sip_threadinfo) list;
+};
+
/* --- Linked lists of various objects --------*/
+
+/*! \brief The thread list of TCP threads */
+static AST_LIST_HEAD_STATIC(threadl, sip_threadinfo);
/*! \brief The user list: Users and friends */
static struct ast_user_list {
@@ -1750,6 +1759,15 @@
int cl;
char buf[1024];
struct sip_request req = { 0, }, reqcpy = { 0, };
+ struct sip_threadinfo *me;
+
+ me = ast_calloc(1, sizeof(*me));
+
+ if (!me)
+ goto cleanup2;
+
+ me->threadid = pthread_self();
+ AST_LIST_INSERT_TAIL(&threadl, me, list);
req.socket.lock = ast_calloc(1, sizeof(*req.socket.lock));
@@ -1765,6 +1783,8 @@
while (req.len < 4 || strncmp((char *)&req.data + req.len - 4, "\r\n\r\n", 4)) {
if (!fgets(buf, sizeof(buf), ser->f))
goto cleanup;
+
+ if (me->stop) goto cleanup;
strncat(req.data, buf, sizeof(req.data) - req.len);
req.len = strlen(req.data);
@@ -1776,6 +1796,8 @@
while (cl > 0) {
if (!fread(buf, (cl < sizeof(buf)) ? cl : sizeof(buf), 1, ser->f))
goto cleanup;
+
+ if (me->stop) goto cleanup;
cl -= strlen(buf);
strncat(req.data, buf, sizeof(req.data) - req.len);
@@ -1799,6 +1821,9 @@
}
cleanup:
+ AST_LIST_REMOVE(&threadl, me, list);
+ ast_free(me);
+cleanup2:
fclose(ser->f);
ast_free(ser);
ast_free(req.socket.lock);
@@ -18824,7 +18849,15 @@
static int unload_module(void)
{
struct sip_pvt *p, *pl;
+ struct sip_threadinfo *th;
+ while(!AST_LIST_EMPTY(&threadl)) {
+ AST_LIST_TRAVERSE(&threadl, th, list) {
+ th->stop = 1;
+ pthread_kill(th->threadid, SIGURG);
+ }
+ }
+
/* First, take us out of the channel type list */
ast_channel_unregister(&sip_tech);
Modified: team/bbryant/sip-tcptls/configs/sip.conf.sample
URL: http://svn.digium.com/view/asterisk/team/bbryant/sip-tcptls/configs/sip.conf.sample?view=diff&rev=74161&r1=74160&r2=74161
==============================================================================
--- team/bbryant/sip-tcptls/configs/sip.conf.sample (original)
+++ team/bbryant/sip-tcptls/configs/sip.conf.sample Mon Jul 9 15:52:47 2007
@@ -262,7 +262,9 @@
;----------------------------------------- OUTBOUND SIP REGISTRATIONS ------------------------
; Asterisk can register as a SIP user agent to a SIP proxy (provider)
; Format for the register statement is:
-; register => user[:secret[:authuser]]@host[:port][/extension]
+; register => [transport://]user[:secret[:authuser]]@host[:port][/extension]
+;
+;
;
; If no extension is given, the 's' extension is used. The extension needs to
; be defined in extensions.conf to be able to accept calls from this SIP proxy
Modified: team/bbryant/sip-tcptls/include/asterisk/server.h
URL: http://svn.digium.com/view/asterisk/team/bbryant/sip-tcptls/include/asterisk/server.h?view=diff&rev=74161&r1=74160&r2=74161
==============================================================================
--- team/bbryant/sip-tcptls/include/asterisk/server.h (original)
+++ team/bbryant/sip-tcptls/include/asterisk/server.h Mon Jul 9 15:52:47 2007
@@ -106,6 +106,7 @@
FILE *f; /* fopen/funopen result */
int fd; /* the socket returned by accept() */
SSL *ssl; /* ssl state */
+ int (*ssl_setup)(SSL *);
struct sockaddr_in requestor;
struct server_args *parent;
};
Modified: team/bbryant/sip-tcptls/main/server.c
URL: http://svn.digium.com/view/asterisk/team/bbryant/sip-tcptls/main/server.c?view=diff&rev=74161&r1=74160&r2=74161
==============================================================================
--- team/bbryant/sip-tcptls/main/server.c (original)
+++ team/bbryant/sip-tcptls/main/server.c Mon Jul 9 15:52:47 2007
@@ -109,6 +109,8 @@
ser->fd = fd;
ser->parent = desc;
memcpy(&ser->requestor, &sin, sizeof(ser->requestor));
+
+ ser->ssl_setup = SSL_accept;
if (ast_pthread_create_detached_background(&launched, NULL, ast_make_file_from_fd, ser)) {
ast_log(LOG_WARNING, "Unable to launch helper thread: %s\n", strerror(errno));
@@ -199,6 +201,7 @@
ser->parent->worker_fn = NULL;
memcpy(&ser->requestor, &desc->sin, sizeof(ser->requestor));
+ ser->ssl_setup = SSL_connect;
ast_make_file_from_fd(ser);
return ser;
@@ -297,7 +300,7 @@
#ifdef DO_SSL
else if ( (ser->ssl = SSL_new(ser->parent->tls_cfg->ssl_ctx)) ) {
SSL_set_fd(ser->ssl, ser->fd);
- if ((ret = SSL_accept(ser->ssl)) <= 0) {
+ if ((ret = ser->ssl_setup(ser->ssl)) <= 0) {
if(option_verbose > 1)
ast_verbose(VERBOSE_PREFIX_2 "Problem setting up ssl connection: %s\n", ERR_error_string(ERR_get_error(), err));
} else {
More information about the svn-commits
mailing list