diff options
Diffstat (limited to 'protocols/jabber/si.c')
| -rw-r--r-- | protocols/jabber/si.c | 52 | 
1 files changed, 32 insertions, 20 deletions
| diff --git a/protocols/jabber/si.c b/protocols/jabber/si.c index 77f7a752..4f989959 100644 --- a/protocols/jabber/si.c +++ b/protocols/jabber/si.c @@ -392,13 +392,43 @@ static xt_status jabber_si_handle_response(struct im_connection *ic, struct xt_n  	GSList *tflist;  	struct jabber_transfer *tf = NULL;  	struct jabber_data *jd = ic->proto_data; +	struct jabber_error *err;  	if (!(tgt_jid = xt_find_attr(node, "from")) || -	    !(ini_jid = xt_find_attr(node, "to"))) { +	    !(ini_jid = xt_find_attr(node, "to")) || +	    !(iq_id   = xt_find_attr(node, "id"))) {  		imcb_log(ic, "Invalid SI response from=%s to=%s", tgt_jid, ini_jid);  		return XT_HANDLED;  	} +	/* Let's see if we can find out what this bytestream should be for... */ + +	for (tflist = jd->filetransfers; tflist; tflist = g_slist_next(tflist)) { +		struct jabber_transfer *tft = tflist->data; +		if ((strcmp(tft->iq_id, iq_id) == 0)) { +			tf = tft; +			break; +		} +	} + +	if (!tf) { +		imcb_log(ic, "WARNING: Received bytestream request from %s that doesn't match an SI request", ini_jid); +		return XT_HANDLED; +	} + +	err = jabber_error_parse(xt_find_node(node->children, "error"), XMLNS_STANZA_ERROR); + +	if (err) { +		if (g_strcmp0(err->code, "forbidden") == 0) { +			imcb_log(ic, "File %s: %s rejected the transfer", tf->ft->file_name, tgt_jid); +		} else { +			imcb_log(ic, "Error: Stream initiation request failed: %s (%s)", err->code, err->text); +		} +		imcb_file_canceled(ic, tf->ft, "Stream initiation request failed"); +		jabber_error_free(err); +		return XT_HANDLED; +	} +  	/* All this means we expect something like this: ( I think )  	 * <iq from=... to=... id=...>  	 *      <si xmlns=si> @@ -408,10 +438,7 @@ static xt_status jabber_si_handle_response(struct im_connection *ic, struct xt_n  	 *                              <field var=stream-method>  	 *                                      <value>  	 */ -	if (!(tgt_jid = xt_find_attr(node, "from")) || -	    !(ini_jid = xt_find_attr(node, "to")) || -	    !(iq_id   = xt_find_attr(node, "id")) || -	    !(c = xt_find_node(node->children, "si")) || +	if (!(c = xt_find_node(node->children, "si")) ||  	    !(cmp = xt_find_attr(c, "xmlns")) ||  	    !(strcmp(cmp, XMLNS_SI) == 0) ||  	    !(d = xt_find_node(c->children, "feature")) || @@ -438,21 +465,6 @@ static xt_status jabber_si_handle_response(struct im_connection *ic, struct xt_n  		return XT_HANDLED;  	} -	/* Let's see if we can find out what this bytestream should be for... */ - -	for (tflist = jd->filetransfers; tflist; tflist = g_slist_next(tflist)) { -		struct jabber_transfer *tft = tflist->data; -		if ((strcmp(tft->iq_id, iq_id) == 0)) { -			tf = tft; -			break; -		} -	} - -	if (!tf) { -		imcb_log(ic, "WARNING: Received bytestream request from %s that doesn't match an SI request", ini_jid); -		return XT_HANDLED; -	} -  	tf->ini_jid = g_strdup(ini_jid);  	tf->tgt_jid = g_strdup(tgt_jid); | 
