[svn-commits] pabelanger: branch pabelanger/issue18183 r292863 - /team/pabelanger/issue1818...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Sat Oct 23 16:07:49 CDT 2010
Author: pabelanger
Date: Sat Oct 23 16:07:43 2010
New Revision: 292863
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=292863
Log:
Fix issue in update_registry. More formatting changes.
Modified:
team/pabelanger/issue18183/channels/chan_iax2.c
Modified: team/pabelanger/issue18183/channels/chan_iax2.c
URL: http://svnview.digium.com/svn/asterisk/team/pabelanger/issue18183/channels/chan_iax2.c?view=diff&rev=292863&r1=292862&r2=292863
==============================================================================
--- team/pabelanger/issue18183/channels/chan_iax2.c (original)
+++ team/pabelanger/issue18183/channels/chan_iax2.c Sat Oct 23 16:07:43 2010
@@ -2876,8 +2876,9 @@
iaxs[x] = new_iax(sin, host);
update_max_nontrunk();
if (iaxs[x]) {
- if (iaxdebug)
+ if (iaxdebug) {
ast_debug(1, "Creating new call structure %d\n", x);
+ }
iaxs[x]->callno_entry = callno_entry;
iaxs[x]->sockfd = sockfd;
iaxs[x]->addr.sin_port = sin->sin_port;
@@ -2905,8 +2906,9 @@
replace_callno(callno_entry);
return 0;
}
- if (!return_locked)
+ if (!return_locked) {
ast_mutex_unlock(&iaxsl[x]);
+ }
res = x;
}
return res;
@@ -7890,16 +7892,21 @@
ast_clear_flag(&iaxs[callno]->state, IAX_STATE_AUTHENTICATED);
/* iaxs[callno]->peer[0] = '\0'; not necc. any more-- stringfield is pre-inited to null string */
- if (ies->username)
+ if (ies->username) {
ast_copy_string(peer, ies->username, sizeof(peer));
- if (ies->password)
+ }
+ if (ies->password) {
ast_copy_string(secret, ies->password, sizeof(secret));
- if (ies->md5_result)
+ }
+ if (ies->md5_result) {
ast_copy_string(md5secret, ies->md5_result, sizeof(md5secret));
- if (ies->rsa_result)
+ }
+ if (ies->rsa_result) {
ast_copy_string(rsasecret, ies->rsa_result, sizeof(rsasecret));
- if (ies->refresh)
+ }
+ if (ies->refresh) {
expire = ies->refresh;
+ }
if (ast_strlen_zero(peer)) {
ast_log(LOG_NOTICE, "Empty registration from %s\n", ast_inet_ntoa(sin->sin_addr));
@@ -7930,21 +7937,24 @@
res = 0;
}
}
- if (authdebug && !p)
+ if (authdebug && !p) {
ast_log(LOG_NOTICE, "No registration for peer '%s' (from %s)\n", peer, ast_inet_ntoa(sin->sin_addr));
+ }
goto return_unref;
}
if (!ast_test_flag64(p, IAX_DYNAMIC)) {
- if (authdebug)
+ if (authdebug) {
ast_log(LOG_NOTICE, "Peer '%s' is not dynamic (from %s)\n", peer, ast_inet_ntoa(sin->sin_addr));
+ }
goto return_unref;
}
ast_sockaddr_from_sin(&addr, sin);
if (!ast_apply_ha(p->ha, &addr)) {
- if (authdebug)
+ if (authdebug) {
ast_log(LOG_NOTICE, "Host %s denied access to register peer '%s'\n", ast_inet_ntoa(sin->sin_addr), p->name);
+ }
goto return_unref;
}
ast_string_field_set(iaxs[callno], secret, p->secret);
@@ -7953,27 +7963,30 @@
if (!ast_strlen_zero(rsasecret) && (p->authmethods & IAX_AUTH_RSA) && !ast_strlen_zero(iaxs[callno]->challenge)) {
if (!ast_strlen_zero(p->inkeys)) {
char tmpkeys[256];
- char *stringp=NULL;
+ char *stringp = NULL;
ast_copy_string(tmpkeys, p->inkeys, sizeof(tmpkeys));
- stringp=tmpkeys;
+ stringp = tmpkeys;
keyn = strsep(&stringp, ":");
- while(keyn) {
+ while (keyn) {
key = ast_key_get(keyn, AST_KEY_PUBLIC);
if (key && !ast_check_signature(key, iaxs[callno]->challenge, rsasecret)) {
ast_set_flag(&iaxs[callno]->state, IAX_STATE_AUTHENTICATED);
break;
- } else if (!key)
+ } else if (!key) {
ast_log(LOG_WARNING, "requested inkey '%s' does not exist\n", keyn);
+ }
keyn = strsep(&stringp, ":");
}
if (!keyn) {
- if (authdebug)
+ if (authdebug) {
ast_log(LOG_NOTICE, "Host %s failed RSA authentication with inkeys '%s'\n", peer, p->inkeys);
+ }
goto return_unref;
}
} else {
- if (authdebug)
+ if (authdebug) {
ast_log(LOG_NOTICE, "Host '%s' trying to do RSA authentication, but we have no inkeys\n", peer);
+ }
goto return_unref;
}
} else if (!ast_strlen_zero(md5secret) && (p->authmethods & IAX_AUTH_MD5) && !ast_strlen_zero(iaxs[callno]->challenge)) {
@@ -7983,31 +7996,36 @@
tmppw = ast_strdupa(p->secret);
stringp = tmppw;
- while((tmppw = strsep(&stringp, ";"))) {
+ while ((tmppw = strsep(&stringp, ";"))) {
MD5Init(&md5);
MD5Update(&md5, (unsigned char *)iaxs[callno]->challenge, strlen(iaxs[callno]->challenge));
MD5Update(&md5, (unsigned char *)tmppw, strlen(tmppw));
MD5Final(digest, &md5);
- for (x=0;x<16;x++)
+ for (x = 0; x < 16; x++) {
sprintf(requeststr + (x << 1), "%2.2x", digest[x]); /* safe */
- if (!strcasecmp(requeststr, md5secret))
+ }
+ if (!strcasecmp(requeststr, md5secret)) {
break;
+ }
}
if (tmppw) {
ast_set_flag(&iaxs[callno]->state, IAX_STATE_AUTHENTICATED);
} else {
- if (authdebug)
+ if (authdebug) {
ast_log(LOG_NOTICE, "Host %s failed MD5 authentication for '%s' (%s != %s)\n", ast_inet_ntoa(sin->sin_addr), p->name, requeststr, md5secret);
+ }
goto return_unref;
}
} else if (!ast_strlen_zero(secret) && (p->authmethods & IAX_AUTH_PLAINTEXT)) {
/* They've provided a plain text password and we support that */
if (strcmp(secret, p->secret)) {
- if (authdebug)
+ if (authdebug) {
ast_log(LOG_NOTICE, "Host %s did not provide proper plaintext password for '%s'\n", ast_inet_ntoa(sin->sin_addr), p->name);
+ }
goto return_unref;
- } else
+ } else {
ast_set_flag(&iaxs[callno]->state, IAX_STATE_AUTHENTICATED);
+ }
} else if (!ast_strlen_zero(iaxs[callno]->challenge) && ast_strlen_zero(md5secret) && ast_strlen_zero(rsasecret)) {
/* if challenge has been sent, but no challenge response if given, reject. */
goto return_unref;
@@ -8496,7 +8514,6 @@
return iax2_append_register(hostname, username, secret, porta);
}
-
static void register_peer_exten(struct iax2_peer *peer, int onoff)
{
char multi[256];
@@ -8504,13 +8521,14 @@
if (!ast_strlen_zero(regcontext)) {
ast_copy_string(multi, S_OR(peer->regexten, peer->name), sizeof(multi));
stringp = multi;
- while((ext = strsep(&stringp, "&"))) {
+ while ((ext = strsep(&stringp, "&"))) {
if (onoff) {
- if (!ast_exists_extension(NULL, regcontext, ext, 1, NULL))
- ast_add_extension(regcontext, 1, ext, 1, NULL, NULL,
- "Noop", ast_strdup(peer->name), ast_free_ptr, "IAX2");
- } else
+ if (!ast_exists_extension(NULL, regcontext, ext, 1, NULL)) {
+ ast_add_extension(regcontext, 1, ext, 1, NULL, NULL, "Noop", ast_strdup(peer->name), ast_free_ptr, "IAX2");
+ }
+ } else {
ast_context_remove_extension(regcontext, ext, 1, NULL);
+ }
}
}
}
@@ -8657,8 +8675,10 @@
return -1;
}
ast_mutex_lock(&iaxsl[callno]);
- if (!iaxs[callno])
+
+ if (!iaxs[callno]) {
goto return_unref;
+ }
if (ast_test_flag64((&globalflags), IAX_RTUPDATE) && (ast_test_flag64(p, IAX_TEMPONLY|IAX_RTCACHEFRIENDS))) {
if (sin->sin_addr.s_addr) {
@@ -8679,7 +8699,7 @@
peercnt_modify(0, 0, &p->addr);
/* Stash the IP address from which they registered */
- memcpy(&p->addr, sin, sizeof(p->addr));
+ ast_sockaddr_from_sin(&p->addr, sin);
snprintf(data, sizeof(data), "%s:%d:%d", ast_inet_ntoa(sin->sin_addr), ntohs(sin->sin_port), p->expiry);
if (!ast_test_flag64(p, IAX_TEMPONLY) && sin->sin_addr.s_addr) {
@@ -8723,23 +8743,23 @@
}
}
/* treat an unspecified refresh interval as the minimum */
- if (!refresh)
+ if (!refresh) {
refresh = min_reg_expire;
+ }
if (refresh > max_reg_expire) {
- ast_log(LOG_NOTICE, "Restricting registration for peer '%s' to %d seconds (requested %d)\n",
- p->name, max_reg_expire, refresh);
+ ast_log(LOG_NOTICE, "Restricting registration for peer '%s' to %d seconds (requested %d)\n", p->name, max_reg_expire, refresh);
p->expiry = max_reg_expire;
} else if (refresh < min_reg_expire) {
- ast_log(LOG_NOTICE, "Restricting registration for peer '%s' to %d seconds (requested %d)\n",
- p->name, min_reg_expire, refresh);
+ ast_log(LOG_NOTICE, "Restricting registration for peer '%s' to %d seconds (requested %d)\n", p->name, min_reg_expire, refresh);
p->expiry = min_reg_expire;
} else {
p->expiry = refresh;
}
if (p->expiry && sin->sin_addr.s_addr) {
p->expire = iax2_sched_add(sched, (p->expiry + 10) * 1000, expire_registry, peer_ref(p));
- if (p->expire == -1)
+ if (p->expire == -1) {
peer_unref(p);
+ }
}
iax_ie_append_str(&ied, IAX_IE_USERNAME, p->name);
iax_ie_append_int(&ied, IAX_IE_DATETIME, iax2_datetime(p->zonetag));
@@ -8757,8 +8777,9 @@
context = mailbox = ast_strdupa(p->mailbox);
strsep(&context, "@");
- if (ast_strlen_zero(context))
+ if (ast_strlen_zero(context)) {
context = "default";
+ }
event = ast_event_get_cached(AST_EVENT_MWI,
AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_STR, mailbox,
@@ -8788,8 +8809,9 @@
}
}
version = iax_check_version(devtype);
- if (version)
+ if (version) {
iax_ie_append_short(&ied, IAX_IE_FIRMWAREVER, version);
+ }
res = 0;
@@ -11168,11 +11190,12 @@
}
if ((ast_strlen_zero(iaxs[fr->callno]->secret) && ast_strlen_zero(iaxs[fr->callno]->inkeys)) ||
ast_test_flag(&iaxs[fr->callno]->state, IAX_STATE_AUTHENTICATED)) {
-
- if (f.subclass.integer == IAX_COMMAND_REGREL)
+ if (f.subclass.integer == IAX_COMMAND_REGREL) {
memset(&sin, 0, sizeof(sin));
- if (update_registry(&sin, fr->callno, ies.devicetype, fd, ies.refresh))
+ }
+ if (update_registry(&sin, fr->callno, ies.devicetype, fd, ies.refresh)) {
ast_log(LOG_WARNING, "Registry error\n");
+ }
if (!iaxs[fr->callno]) {
break;
}
@@ -11893,7 +11916,9 @@
return 0;
}
- ast_sockaddr_to_sin(&peer->addr, &peer_addr);
+ if (!ast_sockaddr_to_sin(&peer->addr, &peer_addr)) {
+ return -1;
+ }
/* The peer could change the callno inside iax2_destroy, since we do deadlock avoidance */
if ((callno = peer->callno) > 0) {
@@ -11902,11 +11927,13 @@
iax2_destroy(callno);
ast_mutex_unlock(&iaxsl[callno]);
}
- if (heldcall)
+ if (heldcall) {
ast_mutex_unlock(&iaxsl[heldcall]);
+ }
callno = peer->callno = find_callno(0, 0, &peer_addr, NEW_FORCE, peer->sockfd, 0);
- if (heldcall)
+ if (heldcall) {
ast_mutex_lock(&iaxsl[heldcall]);
+ }
if (peer->callno < 1) {
ast_log(LOG_WARNING, "Unable to allocate call for poking peer '%s'\n", peer->name);
return -1;
@@ -11925,13 +11952,15 @@
/* Queue up a new task to handle no reply */
/* If the host is already unreachable then use the unreachable interval instead */
- if (peer->lastms < 0)
+ if (peer->lastms < 0) {
peer->pokeexpire = iax2_sched_add(sched, peer->pokefreqnotok, iax2_poke_noanswer, peer_ref(peer));
- else
+ } else {
peer->pokeexpire = iax2_sched_add(sched, DEFAULT_MAXMS * 2, iax2_poke_noanswer, peer_ref(peer));
-
- if (peer->pokeexpire == -1)
+ }
+
+ if (peer->pokeexpire == -1) {
peer_unref(peer);
+ }
/* And send the poke */
ast_mutex_lock(&iaxsl[callno]);
@@ -12284,7 +12313,7 @@
ast_copy_flags64(peer, &globalflags, IAX_USEJITTERBUF | IAX_FORCEJITTERBUF | IAX_SENDCONNECTEDLINE | IAX_RECVCONNECTEDLINE | IAX_FORCE_ENCRYPT);
peer->encmethods = iax2_encryption;
peer->adsi = adsi;
- ast_string_field_set(peer,secret,"");
+ ast_string_field_set(peer, secret, "");
if (!found) {
ast_string_field_set(peer, name, name);
/* TODO: Why do we need to set this? */
More information about the svn-commits
mailing list