add property bare_name in zeroconf.contacts[..]
property list. Using it, instead of bad-client
This commit is contained in:
parent
99265c0430
commit
fd7eead5dd
|
@ -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…
Reference in New Issue