aboutsummaryrefslogtreecommitdiffstats
path: root/res
diff options
context:
space:
mode:
authorphsultan <phsultan@f38db490-d61c-443f-a65b-d21fe96a405b>2007-10-07 15:54:48 +0000
committerphsultan <phsultan@f38db490-d61c-443f-a65b-d21fe96a405b>2007-10-07 15:54:48 +0000
commit62a54f210c61afd9e6b30eef33b6874cc27f95be (patch)
treef6ba479ca6c36fd5d6799af7182be3ef2e91a106 /res
parentec6ee0ca092eb47eaee10543aa0606e8e46af7cc (diff)
Merged revisions 84890 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r84890 | phsultan | 2007-10-07 17:52:44 +0200 (Sun, 07 Oct 2007) | 5 lines Prevent Asterisk from crashing when receiving a presence packet without resource from a buddy that is known to have a resource list. Revert a change I previously made, where Asterisk could point to a freed memory location. ........ git-svn-id: http://svn.digium.com/svn/asterisk/trunk@84891 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'res')
-rw-r--r--res/res_jabber.c13
1 files changed, 4 insertions, 9 deletions
diff --git a/res/res_jabber.c b/res/res_jabber.c
index 5743898c6..83114a5e5 100644
--- a/res/res_jabber.c
+++ b/res/res_jabber.c
@@ -1284,7 +1284,7 @@ static void aji_handle_presence(struct aji_client *client, ikspak *pak)
tmp = buddy->resources;
descrip = ast_strdup(iks_find_cdata(pak->x,"status"));
- while (tmp) {
+ while (tmp && pak->from->resource) {
if (!strcasecmp(tmp->resource, pak->from->resource)) {
tmp->status = status;
if (tmp->description) ast_free(tmp->description);
@@ -1357,7 +1357,7 @@ static void aji_handle_presence(struct aji_client *client, ikspak *pak)
}
/* resource not found in our list, create it */
- if (!found && status != 6) {
+ if (!found && status != 6 && pak->from->resource) {
found = ast_calloc(1, sizeof(*found));
if (!found) {
@@ -1391,12 +1391,6 @@ static void aji_handle_presence(struct aji_client *client, ikspak *pak)
buddy->resources = found;
}
- /* if 'from' attribute does not contain 'resource' string
- point to the top of our resource list */
- if (!found && !pak->from->resource && buddy->resources) {
- found = buddy->resources;
- }
-
ASTOBJ_UNLOCK(buddy);
ASTOBJ_UNREF(buddy, aji_buddy_destroy);
@@ -1409,7 +1403,8 @@ static void aji_handle_presence(struct aji_client *client, ikspak *pak)
ver = iks_find_attrib(iks_find(pak->x, "caps:c"), "ver");
}
- if(status !=6 && !found->cap) {
+ /* retrieve capabilites of the new resource */
+ if(status !=6 && found && !found->cap) {
found->cap = aji_find_version(node, ver, pak);
if(gtalk_yuck(pak->x)) /* gtalk should do discover */
found->cap->jingle = 1;