add property bare_name in zeroconf.contacts[..]
property list. Using it, instead of bad-client
This commit is contained in:
		
							parent
							
								
									99265c0430
								
							
						
					
					
						commit
						fd7eead5dd
					
				
					 3 changed files with 48 additions and 47 deletions
				
			
		|  | @ -164,8 +164,7 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf): | ||||||
| 			diffs = self.roster.getDiffs() | 			diffs = self.roster.getDiffs() | ||||||
| 			for key in diffs: | 			for key in diffs: | ||||||
| 				self.roster.setItem(key) | 				self.roster.setItem(key) | ||||||
| 				display_key = self.zeroconf.check_jid(key) | 				self.dispatch('NOTIFY', (key, self.roster.getStatus(key), self.roster.getMessage(key), 'local', 0, None, 0)) | ||||||
| 				self.dispatch('NOTIFY', (display_key, self.roster.getStatus(key), self.roster.getMessage(key), 'local', 0, None, 0)) |  | ||||||
| 		return self.call_resolve_timeout | 		return self.call_resolve_timeout | ||||||
| 
 | 
 | ||||||
| 	# callbacks called from zeroconf	 | 	# callbacks called from zeroconf	 | ||||||
|  |  | ||||||
|  | @ -21,8 +21,8 @@ class Roster: | ||||||
| 		self.zeroconf = zeroconf 	  	 # our zeroconf instance | 		self.zeroconf = zeroconf 	  	 # our zeroconf instance | ||||||
| 
 | 
 | ||||||
| 	def update_roster(self): | 	def update_roster(self): | ||||||
| 		for (jid, dom, interf, proto, host, addr, port, txt) in self.zeroconf.get_contacts().values(): | 		for val in self.zeroconf.contacts.values(): | ||||||
| 			self.setItem(jid) | 			self.setItem(val[zeroconf.C_NAME]) | ||||||
| 
 | 
 | ||||||
| 	def getRoster(self): | 	def getRoster(self): | ||||||
| 		#print 'roster_zeroconf.py: getRoster' | 		#print 'roster_zeroconf.py: getRoster' | ||||||
|  | @ -47,7 +47,7 @@ class Roster: | ||||||
| 		 | 		 | ||||||
| 	def setItem(self, jid, name = '', groups = ''): | 	def setItem(self, jid, name = '', groups = ''): | ||||||
| 		#print 'roster_zeroconf.py: setItem %s' % jid | 		#print 'roster_zeroconf.py: setItem %s' % jid | ||||||
| 		(service_jid, domain, interface, protocol, host, address, port, txt)  \ | 		(service_jid, domain, interface, protocol, host, address, port, bare_jid, txt)  \ | ||||||
| 			= self.zeroconf.get_contact(jid) | 			= self.zeroconf.get_contact(jid) | ||||||
| 
 | 
 | ||||||
| 		self._data[jid]={} | 		self._data[jid]={} | ||||||
|  | @ -63,19 +63,25 @@ class Roster: | ||||||
| 			status = txt_dict['status'] | 			status = txt_dict['status'] | ||||||
| 		else: | 		else: | ||||||
| 			status = '' | 			status = '' | ||||||
| 		if txt_dict.has_key('1st') and txt_dict.has_key('last'): | 		nm = '' | ||||||
| 			self._data[jid]['name']=txt_dict['1st']+' '+txt_dict['last'] | 		if txt_dict.has_key('1st'): | ||||||
|  | 			nm = txt_dict['1st'] | ||||||
|  | 		if txt_dict.has_key('last'): | ||||||
|  | 			if nm != '': | ||||||
|  | 				nm = +' ' | ||||||
|  | 			nm += txt_dict['last'] | ||||||
|  | 		if nm: | ||||||
|  | 			self._data[jid]['name'] = nm | ||||||
| 		else: | 		else: | ||||||
| 			self._data[jid]['name']=jid | 			self._data[jid]['name'] = jid | ||||||
| 		if status == 'avail': status = 'online' | 		if status == 'avail':  | ||||||
|  | 			status = 'online' | ||||||
| 		self._data[jid]['txt_dict'] = txt_dict | 		self._data[jid]['txt_dict'] = txt_dict | ||||||
| 		if not self._data[jid]['txt_dict'].has_key('msg'): | 		if not self._data[jid]['txt_dict'].has_key('msg'): | ||||||
| 			self._data[jid]['txt_dict']['msg'] = '' | 			self._data[jid]['txt_dict']['msg'] = '' | ||||||
| 		self._data[jid]['status'] = status | 		self._data[jid]['status'] = status | ||||||
| 		self._data[jid]['show'] = status | 		self._data[jid]['show'] = status | ||||||
| 
 | 
 | ||||||
| 		# print self._data[jid] |  | ||||||
| 
 |  | ||||||
| 	def delItem(self, jid): | 	def delItem(self, jid): | ||||||
| 		#print 'roster_zeroconf.py: delItem %s' % jid | 		#print 'roster_zeroconf.py: delItem %s' % jid | ||||||
| 		if self._data.has_key(jid): | 		if self._data.has_key(jid): | ||||||
|  |  | ||||||
|  | @ -21,13 +21,17 @@ from common import xmpp | ||||||
| try: | try: | ||||||
| 	import avahi, gobject, dbus | 	import avahi, gobject, dbus | ||||||
| except ImportError: | except ImportError: | ||||||
| 	print "Error: python-avahi and python-dbus need to be installed. No zeroconf support." | 	gajim.log.debug("Error: python-avahi and python-dbus need to be installed. No zeroconf support.") | ||||||
| 
 | 
 | ||||||
| try: | try: | ||||||
| 	import dbus.glib | 	import dbus.glib | ||||||
| except ImportError, e: | except ImportError, e: | ||||||
| 	pass | 	pass | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | C_NAME, C_DOMAIN, C_INTERFACE, C_PROTOCOL, C_HOST, \ | ||||||
|  | C_ADDRESS, C_PORT, C_BARE_NAME, C_TXT = range(9) | ||||||
|  | 
 | ||||||
| class Zeroconf: | class Zeroconf: | ||||||
| 	def __init__(self, new_serviceCB, remove_serviceCB, name, host, port): | 	def __init__(self, new_serviceCB, remove_serviceCB, name, host, port): | ||||||
| 		self.domain = None   # specific domain to browse | 		self.domain = None   # specific domain to browse | ||||||
|  | @ -66,8 +70,11 @@ class Zeroconf: | ||||||
| 	def remove_service_callback(self, interface, protocol, name, stype, domain, flags): | 	def remove_service_callback(self, interface, protocol, name, stype, domain, flags): | ||||||
| 		# print "Service '%s' in domain '%s' on %i.%i disappeared." % (name, domain, interface, protocol) | 		# print "Service '%s' in domain '%s' on %i.%i disappeared." % (name, domain, interface, protocol) | ||||||
| 		if name != self.name: | 		if name != self.name: | ||||||
| 			del self.contacts[name] | 			for key in self.contacts.keys(): | ||||||
| 			self.remove_serviceCB(name) | 				if self.contacts[key][C_BARE_NAME] == name: | ||||||
|  | 					del self.contacts[key] | ||||||
|  | 					self.remove_serviceCB(key) | ||||||
|  | 					return | ||||||
| 
 | 
 | ||||||
| 	def new_service_type(self, interface, protocol, stype, domain, flags): | 	def new_service_type(self, interface, protocol, stype, domain, flags): | ||||||
| 		# Are we already browsing this domain for this type?  | 		# Are we already browsing this domain for this type?  | ||||||
|  | @ -88,23 +95,6 @@ class Zeroconf: | ||||||
| 		if domain != "local": | 		if domain != "local": | ||||||
| 			self.browse_domain(interface, protocol, domain) | 			self.browse_domain(interface, protocol, domain) | ||||||
| 
 | 
 | ||||||
| 	def check_jid(self, jid): |  | ||||||
| 		# TODO: at least miranda uses bad service names(only host name), so change them - probabaly not so nice... need to find a better solution |  | ||||||
| 		# this is necessary so they don't get displayed as a transport |  | ||||||
| 		# [dkirov] maybe turn it into host+'@'+host, instead ? |  | ||||||
| 		# [sb] that would mean we can't do recreate below |  | ||||||
| 		if jid.find('@') == -1: |  | ||||||
| 			return 'bad-client@' + jid |  | ||||||
| 		else: |  | ||||||
| 			return jid |  | ||||||
| 		 |  | ||||||
| 	def recreate_bad_jid(self,jid): |  | ||||||
| 		at = jid.find('@') |  | ||||||
| 		if  jid[:at] == 'bad-client': |  | ||||||
| 			return jid[at+1:] |  | ||||||
| 		else: |  | ||||||
| 			return jid |  | ||||||
| 		 |  | ||||||
| 	def txt_array_to_dict(self,txt_array): | 	def txt_array_to_dict(self,txt_array): | ||||||
| 		items = {} | 		items = {} | ||||||
| 
 | 
 | ||||||
|  | @ -117,16 +107,23 @@ class Zeroconf: | ||||||
| 	 | 	 | ||||||
| 	def service_resolved_callback(self, interface, protocol, name, stype, domain, host, aprotocol, address, port, txt, flags):	 | 	def service_resolved_callback(self, interface, protocol, name, stype, domain, host, aprotocol, address, port, txt, flags):	 | ||||||
| 		print "Service data for service '%s' in domain '%s' on %i.%i:" % (name, domain, interface, protocol) | 		print "Service data for service '%s' in domain '%s' on %i.%i:" % (name, domain, interface, protocol) | ||||||
| 		print "\tHost %s (%s), port %i, TXT data: %s" % (host, address, port, str(avahi.txt_array_to_string_array(txt))) | 		print "\tHost %s (%s), port %i, TXT data: %s" % (host, address, port, avahi.txt_array_to_string_array(txt)) | ||||||
| 		self.contacts[name] = (name, domain, interface, protocol, host, address, port, txt) | 		bare_name = name | ||||||
|  | 		if name.find('@') == -1: | ||||||
|  | 			name = name + '@' + name | ||||||
|  | 		 | ||||||
|  | 		self.contacts[name] = (name, domain, interface, protocol, host, address, port,  | ||||||
|  | 					bare_name, txt) | ||||||
| 		self.new_serviceCB(name) | 		self.new_serviceCB(name) | ||||||
| 
 | 
 | ||||||
| 	# different handler when resolving all contacts | 	# different handler when resolving all contacts | ||||||
| 	def service_resolved_all_callback(self, interface, protocol, name, stype, domain, host, aprotocol, address, port, txt, flags): | 	def service_resolved_all_callback(self, interface, protocol, name, stype, domain, host, aprotocol, address, port, txt, flags): | ||||||
| 		#print "Service data for service '%s' in domain '%s' on %i.%i:" % (name, domain, interface, protocol) | 		#print "Service data for service '%s' in domain '%s' on %i.%i:" % (name, domain, interface, protocol) | ||||||
| 		#print "\tHost %s (%s), port %i, TXT data: %s" % (host, address, port, str(avahi.txt_array_to_string_array(txt))) | 		#print "\tHost %s (%s), port %i, TXT data: %s" % (host, address, port, str(avahi.txt_array_to_string_array(txt))) | ||||||
| 		 | 		bare_name = name | ||||||
| 		self.contacts[name] = (name, domain, interface, protocol, host, address, port, txt) | 		if name.find('@') == -1: | ||||||
|  | 			name = name + '@' + name | ||||||
|  | 		self.contacts[name] = (name, domain, interface, protocol, host, address, port, bare_name, txt) | ||||||
| 
 | 
 | ||||||
| 	def service_added_callback(self): | 	def service_added_callback(self): | ||||||
| 		# print 'Service successfully added' | 		# print 'Service successfully added' | ||||||
|  | @ -255,6 +252,9 @@ class Zeroconf: | ||||||
| 
 | 
 | ||||||
| 		return True | 		return True | ||||||
| 
 | 
 | ||||||
|  | 	def check_jid(self, jid): | ||||||
|  | 		return jid | ||||||
|  | 
 | ||||||
| 	def disconnect(self): | 	def disconnect(self): | ||||||
| 		if self.connected: | 		if self.connected: | ||||||
| 			self.connected = False | 			self.connected = False | ||||||
|  | @ -263,17 +263,15 @@ class Zeroconf: | ||||||
| 	# refresh txt data of all contacts manually (no callback available) | 	# refresh txt data of all contacts manually (no callback available) | ||||||
| 	def resolve_all(self): | 	def resolve_all(self): | ||||||
| 		for val in self.contacts.values(): | 		for val in self.contacts.values(): | ||||||
| 			#val:(name, domain, interface, protocol, host, address, port, txt) | 			self.server.ResolveService(int(val[C_INTERFACE]), int(val[C_PROTOCOL]), val[C_BARE_NAME], \ | ||||||
| 			self.server.ResolveService(int(val[2]), int(val[3]), val[0], \ | 				self.stype, val[C_DOMAIN], avahi.PROTO_UNSPEC, dbus.UInt32(0),\ | ||||||
| 				self.stype, val[1], avahi.PROTO_UNSPEC, dbus.UInt32(0),\ |  | ||||||
| 				reply_handler=self.service_resolved_all_callback, error_handler=self.print_error_callback) | 				reply_handler=self.service_resolved_all_callback, error_handler=self.print_error_callback) | ||||||
| 
 | 
 | ||||||
| 	def get_contacts(self): | 	def get_contacts(self): | ||||||
| 		return self.contacts | 		return self.contacts | ||||||
| 
 | 
 | ||||||
| 	def get_contact(self, jid): | 	def get_contact(self, jid): | ||||||
| 		if self.contacts.has_key(jid): | 		return self.contacts[jid] | ||||||
| 			return self.contacts[jid] |  | ||||||
| 		 | 		 | ||||||
| 	def update_txt(self, txt): | 	def update_txt(self, txt): | ||||||
| 		# update only given keys | 		# update only given keys | ||||||
|  | @ -301,14 +299,12 @@ class Zeroconf: | ||||||
| 
 | 
 | ||||||
| 	def send_message(self, jid, msg, type = 'chat'): | 	def send_message(self, jid, msg, type = 'chat'): | ||||||
| 		print 'zeroconf.py: send_message:'+ msg | 		print 'zeroconf.py: send_message:'+ msg | ||||||
| 		jid = self.recreate_bad_jid(jid) |  | ||||||
| 		 | 		 | ||||||
| 		sock = socket.socket ( socket.AF_INET, socket.SOCK_STREAM ) | 		sock = socket.socket ( socket.AF_INET, socket.SOCK_STREAM ) | ||||||
|  		#sock.setblocking(False) | 		#sock.setblocking(False) | ||||||
|  | 		sock.connect ( ( self.contacts[jid][C_ADDRESS], self.contacts[jid][C_PORT] ) ) | ||||||
| 		 | 		 | ||||||
| 		sock.connect ( ( self.contacts[jid][4], self.contacts[jid][6] ) ) | 		#print (self.txt_array_to_dict(self.contacts[jid][C_TXT]))['port.p2pj'] | ||||||
| 		 |  | ||||||
| 		print (self.txt_array_to_dict(self.contacts[jid][7]))['port.p2pj'] |  | ||||||
| 
 | 
 | ||||||
| 		#was for adium which uses the txt record | 		#was for adium which uses the txt record | ||||||
| 		#sock.connect ( ( self.contacts[jid][5], int((self.txt_array_to_dict(self.contacts[jid][7]))['port.p2pj']) ) ) | 		#sock.connect ( ( self.contacts[jid][5], int((self.txt_array_to_dict(self.contacts[jid][7]))['port.p2pj']) ) ) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue