handles file transfer cancel properly

This commit is contained in:
Jefry Lagrange 2012-03-21 15:54:46 -04:00
parent c412a6a55f
commit c5ebac3f77
3 changed files with 30 additions and 1 deletions

View File

@ -1400,6 +1400,16 @@ class JingleDisconnectedReceivedEvent(nec.NetworkIncomingEvent):
self.sid = self.jingle_session.sid self.sid = self.jingle_session.sid
return True return True
class JingleTransferCancelledEvent(nec.NetworkIncomingEvent):
name = 'jingleFT-cancelled-received'
base_network_events = []
def generate(self):
self.fjid = self.jingle_session.peerjid
self.jid, self.resource = gajim.get_room_and_nick_from_fjid(self.fjid)
self.sid = self.jingle_session.sid
return True
class JingleErrorReceivedEvent(nec.NetworkIncomingEvent): class JingleErrorReceivedEvent(nec.NetworkIncomingEvent):
name = 'jingle-error-received' name = 'jingle-error-received'
base_network_events = [] base_network_events = []

View File

@ -585,7 +585,7 @@ class JingleSession(object):
else: else:
# TODO # TODO
text = reason text = reason
gajim.nec.push_incoming_event(JingleDisconnectedReceivedEvent(None, gajim.nec.push_incoming_event(JingleTransferCancelledEvent(None,
conn=self.connection, jingle_session=self, media=None, conn=self.connection, jingle_session=self, media=None,
reason=text)) reason=text))

View File

@ -1150,6 +1150,24 @@ class Interface:
'resource. Please type a new one'), resource=proposed_resource, 'resource. Please type a new one'), resource=proposed_resource,
ok_handler=on_ok) ok_handler=on_ok)
def handle_event_jingleft_cancel(self, obj):
ft = self.instances['file_transfers']
file_props = None
# get the file_props of our session
for sid in obj.conn.files_props:
fp = obj.conn.files_props[sid]
if fp['session-sid'] == obj.sid:
file_props = fp
break
ft.set_status(file_props['type'], file_props['sid'], 'stop')
file_props['error'] = -4 # is it the right error code?
ft.show_stopped(obj.jid, file_props, 'Peer cancelled ' +
'the transfer')
obj.conn.delete_jingle_session(obj.sid)
def handle_event_jingle_incoming(self, obj): def handle_event_jingle_incoming(self, obj):
# ('JINGLE_INCOMING', account, peer jid, sid, tuple-of-contents==(type, # ('JINGLE_INCOMING', account, peer jid, sid, tuple-of-contents==(type,
# data...)) # data...))
@ -1486,6 +1504,7 @@ class Interface:
self.handle_event_jingle_disconnected], self.handle_event_jingle_disconnected],
'jingle-error-received': [self.handle_event_jingle_error], 'jingle-error-received': [self.handle_event_jingle_error],
'jingle-request-received': [self.handle_event_jingle_incoming], 'jingle-request-received': [self.handle_event_jingle_incoming],
'jingleFT-cancelled-received': [self.handle_event_jingleft_cancel],
'last-result-received': [self.handle_event_last_status_time], 'last-result-received': [self.handle_event_last_status_time],
'message-error': [self.handle_event_msgerror], 'message-error': [self.handle_event_msgerror],
'message-not-sent': [self.handle_event_msgnotsent], 'message-not-sent': [self.handle_event_msgnotsent],