aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2010-03-15 01:25:47 +0000
committerWilmer van der Gaast <wilmer@gaast.net>2010-03-15 01:25:47 +0000
commit315dd4c1566dcd4caa9c4ca0eceeceb995a01443 (patch)
treee9b1d54c4c539bc4b86153f3bedf7bf5149b4a9b
parent7e2b5934976f6d833397f72bd11fbc63616a56f2 (diff)
Oops.. Today's Jabber fix could get stuck in a somewhat infinite loop if a
Jabber server returns an empty <iq type="result"/> response to the session establishment request (which is valid and actually done by the example, but my test Jabberd shows different behaviour). Fixed.
-rw-r--r--protocols/jabber/io.c12
-rw-r--r--protocols/jabber/iq.c8
2 files changed, 3 insertions, 17 deletions
diff --git a/protocols/jabber/io.c b/protocols/jabber/io.c
index 4a790f27..a14ad21c 100644
--- a/protocols/jabber/io.c
+++ b/protocols/jabber/io.c
@@ -379,18 +379,8 @@ static xt_status jabber_pkt_features( struct xt_node *node, gpointer data )
if( ( c = xt_find_node( node->children, "session" ) ) )
jd->flags |= JFLAG_WANT_SESSION;
- /* This flag is already set if we authenticated via SASL, so now
- we can resume the session in the new stream, if we don't have
- to bind/initialize the session. */
- if( jd->flags & JFLAG_AUTHENTICATED && ( jd->flags & ( JFLAG_WANT_BIND | JFLAG_WANT_SESSION ) ) == 0 )
- {
- if( !jabber_get_roster( ic ) )
- return XT_ABORT;
- }
- else if( jd->flags & JFLAG_AUTHENTICATED )
- {
+ if( jd->flags & JFLAG_AUTHENTICATED )
return jabber_pkt_bind_sess( ic, NULL, NULL );
- }
return XT_HANDLED;
}
diff --git a/protocols/jabber/iq.c b/protocols/jabber/iq.c
index 21e52da6..1b76a761 100644
--- a/protocols/jabber/iq.c
+++ b/protocols/jabber/iq.c
@@ -306,23 +306,19 @@ xt_status jabber_pkt_bind_sess( struct im_connection *ic, struct xt_node *node,
if( c && c->text_len && ( s = strchr( c->text, '/' ) ) &&
strcmp( s + 1, set_getstr( &ic->acc->set, "resource" ) ) != 0 )
imcb_log( ic, "Server changed session resource string to `%s'", s + 1 );
-
- jd->flags &= ~JFLAG_WANT_BIND;
- }
- else if( node && ( c = xt_find_node( node->children, "session" ) ) )
- {
- jd->flags &= ~JFLAG_WANT_SESSION;
}
if( jd->flags & JFLAG_WANT_BIND )
{
reply = xt_new_node( "bind", NULL, xt_new_node( "resource", set_getstr( &ic->acc->set, "resource" ), NULL ) );
xt_add_attr( reply, "xmlns", XMLNS_BIND );
+ jd->flags &= ~JFLAG_WANT_BIND;
}
else if( jd->flags & JFLAG_WANT_SESSION )
{
reply = xt_new_node( "session", NULL, NULL );
xt_add_attr( reply, "xmlns", XMLNS_SESSION );
+ jd->flags &= ~JFLAG_WANT_SESSION;
}
if( reply != NULL )