detect incoming MUC error presences from the ID. Fixes #5309
This commit is contained in:
		
							parent
							
								
									6c2b658a9a
								
							
						
					
					
						commit
						f18ede1c88
					
				
					 2 changed files with 21 additions and 2 deletions
				
			
		|  | @ -39,6 +39,7 @@ import operator | |||
| 
 | ||||
| import time | ||||
| import locale | ||||
| import hmac | ||||
| 
 | ||||
| try: | ||||
| 	randomsource = random.SystemRandom() | ||||
|  | @ -190,6 +191,7 @@ class Connection(ConnectionHandlers): | |||
| 		self.vcard_supported = False | ||||
| 		self.private_storage_supported = True | ||||
| 		self.streamError = '' | ||||
| 		self.secret_hmac = str(random.random())[2:] | ||||
| 	# END __init__ | ||||
| 
 | ||||
| 	def put_event(self, ev): | ||||
|  | @ -1775,8 +1777,12 @@ class Connection(ConnectionHandlers): | |||
| 				last_log = 0 | ||||
| 			self.last_history_time[room_jid] = last_log | ||||
| 
 | ||||
| 		p = common.xmpp.Presence(to = '%s/%s' % (room_jid, nick), | ||||
| 			show = show, status = self.status) | ||||
| 		p = common.xmpp.Presence(to='%s/%s' % (room_jid, nick), | ||||
| 			show=show, status=self.status) | ||||
| 		h = hmac.new(self.secret_hmac, room_jid).hexdigest()[:6] | ||||
| 		id_ = self.connection.getAnID() | ||||
| 		id_ = 'gajim_muc_' + id_ + '_' + h | ||||
| 		p.setID(id_) | ||||
| 		if gajim.config.get('send_sha_in_gc_presence'): | ||||
| 			p = self.add_sha(p) | ||||
| 		self.add_lang(p) | ||||
|  | @ -1843,6 +1849,10 @@ class Connection(ConnectionHandlers): | |||
| 		xmpp_show = helpers.get_xmpp_show(show) | ||||
| 		p = common.xmpp.Presence(to = '%s/%s' % (jid, nick), typ = ptype, | ||||
| 			show = xmpp_show, status = status) | ||||
| 		h = hmac.new(self.secret_hmac, jid).hexdigest()[:6] | ||||
| 		id_ = self.connection.getAnID() | ||||
| 		id_ = 'gajim_muc_' + id_ + '_' + h | ||||
| 		p.setID(id_) | ||||
| 		if gajim.config.get('send_sha_in_gc_presence') and show != 'offline': | ||||
| 			p = self.add_sha(p, ptype != 'unavailable') | ||||
| 		self.add_lang(p) | ||||
|  |  | |||
|  | @ -34,6 +34,7 @@ import socket | |||
| import sys | ||||
| import operator | ||||
| import hashlib | ||||
| import hmac | ||||
| 
 | ||||
| from time import (altzone, daylight, gmtime, localtime, mktime, strftime, | ||||
| 	time as time_time, timezone, tzname) | ||||
|  | @ -2207,6 +2208,7 @@ class ConnectionHandlers(ConnectionVcard, ConnectionBytestream, ConnectionDisco, | |||
| 			return | ||||
| 		jid_stripped, resource = gajim.get_room_and_nick_from_fjid(who) | ||||
| 		timestamp = None | ||||
| 		id_ = prs.getID() | ||||
| 		is_gc = False # is it a GC presence ? | ||||
| 		sigTag = None | ||||
| 		ns_muc_user_x = None | ||||
|  | @ -2246,6 +2248,13 @@ class ConnectionHandlers(ConnectionVcard, ConnectionBytestream, ConnectionDisco, | |||
| 				if self.connection.getRoster().getItem(agent): # to be sure it's a transport contact | ||||
| 					transport_auto_auth = True | ||||
| 
 | ||||
| 		if not is_gc and id_ and id_.startswith('gajim_muc_') and \ | ||||
| 		ptype == 'error': | ||||
| 			# Error presences may not include sent stanza, so we don't detect it's | ||||
| 			# a muc preence. So detect it by ID | ||||
| 			h = hmac.new(self.secret_hmac, jid_stripped).hexdigest()[:6] | ||||
| 			if id_.split('_')[-1] = h: | ||||
| 				is_gc = True | ||||
| 		status = prs.getStatus() or '' | ||||
| 		show = prs.getShow() | ||||
| 		if not show in gajim.SHOW_LIST: | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue