diff options
author | Wilmer van der Gaast <wilmer@gaast.net> | 2006-09-21 20:44:34 +0200 |
---|---|---|
committer | Wilmer van der Gaast <wilmer@gaast.net> | 2006-09-21 20:44:34 +0200 |
commit | 5bcf70a662244dc77af09d2fffbe913ec6f19393 (patch) | |
tree | 856ecf3b4bf92450f6b99e77ca9ebfaa852b8c68 /protocols/jabber/io.c | |
parent | 4a0614e65b45364d4d1f631aeaae047a92c752c5 (diff) |
Now also sending <presence type="unavailable"/> tag on disconnect, as
recommended by rfc3921/5.1.5.
Diffstat (limited to 'protocols/jabber/io.c')
-rw-r--r-- | protocols/jabber/io.c | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/protocols/jabber/io.c b/protocols/jabber/io.c index 8c0b239e..b11ef17d 100644 --- a/protocols/jabber/io.c +++ b/protocols/jabber/io.c @@ -234,15 +234,23 @@ gboolean jabber_start_stream( struct gaim_connection *gc ) return st; } -gboolean jabber_end_stream( struct gaim_connection *gc ) +void jabber_end_stream( struct gaim_connection *gc ) { struct jabber_data *jd = gc->proto_data; - char eos[] = "</stream:stream>"; /* Let's only do this if the queue is currently empty, otherwise it'd take too long anyway. */ - if( jd->tx_len > 0 ) - return TRUE; - else - return jabber_write( gc, eos, strlen( eos ) ); + if( jd->tx_len == 0 ) + { + char eos[] = "</stream:stream>"; + struct xt_node *node; + int st; + + node = jabber_make_packet( "presence", "unavailable", NULL, NULL ); + st = jabber_write_packet( gc, node ); + xt_free_node( node ); + + if( st ) + jabber_write( gc, eos, strlen( eos ) ); + } } |