vcard is now fixed: we use lists for ADR, TEL EMAIL entry cause we can have several
This commit is contained in:
parent
a1858c9517
commit
ce07cfe759
|
@ -174,12 +174,20 @@ class Connection:
|
||||||
if vc.getTag('vCard').getNamespace() == common.xmpp.NS_VCARD:
|
if vc.getTag('vCard').getNamespace() == common.xmpp.NS_VCARD:
|
||||||
card = vc.getChildren()[0]
|
card = vc.getChildren()[0]
|
||||||
for info in card.getChildren():
|
for info in card.getChildren():
|
||||||
if info.getChildren() == []:
|
name = info.getName()
|
||||||
vcard[info.getName()] = info.getData()
|
if name in ['ADR', 'TEL', 'EMAIL']: # we can have several
|
||||||
else:
|
if not vcard.has_key(name):
|
||||||
vcard[info.getName()] = {}
|
vcard[name] = []
|
||||||
|
entry = {}
|
||||||
for c in info.getChildren():
|
for c in info.getChildren():
|
||||||
vcard[info.getName()][c.getName()] = c.getData()
|
entry[c.getName()] = c.getData()
|
||||||
|
vcard[name].append(entry)
|
||||||
|
elif info.getChildren() == []:
|
||||||
|
vcard[name] = info.getData()
|
||||||
|
else:
|
||||||
|
vcard[name] = {}
|
||||||
|
for c in info.getChildren():
|
||||||
|
vcard[name][c.getName()] = c.getData()
|
||||||
if vc.getID() in self.myVCardID:
|
if vc.getID() in self.myVCardID:
|
||||||
self.myVCardID.remove(vc.getID())
|
self.myVCardID.remove(vc.getID())
|
||||||
self.dispatch('MYVCARD', vcard)
|
self.dispatch('MYVCARD', vcard)
|
||||||
|
@ -893,22 +901,20 @@ class Connection:
|
||||||
def send_vcard(self, vcard):
|
def send_vcard(self, vcard):
|
||||||
if not self.connection:
|
if not self.connection:
|
||||||
return
|
return
|
||||||
print vcard
|
|
||||||
iq = common.xmpp.Iq(typ = 'set')
|
iq = common.xmpp.Iq(typ = 'set')
|
||||||
iq2 = iq.setTag(common.xmpp.NS_VCARD + ' vCard')
|
iq2 = iq.setTag(common.xmpp.NS_VCARD + ' vCard')
|
||||||
for i in vcard.keys():
|
for i in vcard:
|
||||||
if i == 'jid':
|
if i == 'jid':
|
||||||
continue
|
continue
|
||||||
if type(vcard[i]) == type({}):
|
if type(vcard[i]) == type({}):
|
||||||
for j in vcard[i].keys():
|
iq3 = iq2.addChild(i)
|
||||||
if type(vcard[i][j]) == type({}):
|
for j in vcard[i]:
|
||||||
iq3 = iq2.addChild(i)
|
iq3.addChild(j).setData(vcard[i][j])
|
||||||
iq3.addChild(j)
|
elif type(vcard[i]) == type([]):
|
||||||
for k in vcard[i][j]:
|
for j in vcard[i]:
|
||||||
iq3.addChild(k).setData(vcard[i][j][k])
|
iq3 = iq2.addChild(i)
|
||||||
else:
|
for k in j:
|
||||||
iq3 = iq2.addChild(i)
|
iq3.addChild(k).setData(j[k])
|
||||||
iq3.addChild(j).setData(vcard[i][j])
|
|
||||||
else:
|
else:
|
||||||
iq2.addChild(i).setData(vcard[i])
|
iq2.addChild(i).setData(vcard[i])
|
||||||
self.connection.send(iq)
|
self.connection.send(iq)
|
||||||
|
|
76
src/vcard.py
76
src/vcard.py
|
@ -135,39 +135,41 @@ class Vcard_window:
|
||||||
|
|
||||||
def set_values(self, vcard):
|
def set_values(self, vcard):
|
||||||
for i in vcard.keys():
|
for i in vcard.keys():
|
||||||
if type(vcard[i]) == type({}):
|
if i == 'PHOTO':
|
||||||
if i == 'PHOTO':
|
img_decoded = None
|
||||||
img_decoded = None
|
if vcard[i].has_key('BINVAL'):
|
||||||
if vcard[i].has_key('BINVAL'):
|
img_encoded = vcard[i]['BINVAL']
|
||||||
img_encoded = vcard[i]['BINVAL']
|
self.avatar_encoded = img_encoded
|
||||||
self.avatar_encoded = img_encoded
|
self.avatar_mime_type = vcard[i]['TYPE']
|
||||||
self.avatar_mime_type = vcard[i]['TYPE']
|
try:
|
||||||
try:
|
img_decoded = base64.decodestring(img_encoded)
|
||||||
img_decoded = base64.decodestring(img_encoded)
|
except:
|
||||||
except:
|
pass
|
||||||
pass
|
elif vcard[i].has_key('EXTVAL'):
|
||||||
elif vcard[i].has_key('EXTVAL'):
|
url = vcard[i]['EXTVAL']
|
||||||
url = vcard[i]['EXTVAL']
|
try:
|
||||||
try:
|
fd = urllib.urlopen(url)
|
||||||
fd = urllib.urlopen(url)
|
img_decoded = fd.read()
|
||||||
img_decoded = fd.read()
|
except:
|
||||||
except:
|
pass
|
||||||
pass
|
if img_decoded:
|
||||||
if img_decoded:
|
pixbufloader = gtk.gdk.PixbufLoader()
|
||||||
pixbufloader = gtk.gdk.PixbufLoader()
|
pixbufloader.write(img_decoded)
|
||||||
pixbufloader.write(img_decoded)
|
pixbufloader.close()
|
||||||
pixbufloader.close()
|
pixbuf = pixbufloader.get_pixbuf()
|
||||||
pixbuf = pixbufloader.get_pixbuf()
|
image = self.xml.get_widget('PHOTO_image')
|
||||||
image = self.xml.get_widget('PHOTO_image')
|
image.set_from_pixbuf(pixbuf)
|
||||||
image.set_from_pixbuf(pixbuf)
|
continue
|
||||||
continue
|
if i == 'ADR' or i == 'TEL' or i == 'EMAIL':
|
||||||
add_on = ''
|
for entry in vcard[i]:
|
||||||
if i == 'ADR' or i == 'TEL' or i == 'EMAIL':
|
|
||||||
add_on = '_HOME'
|
add_on = '_HOME'
|
||||||
if 'WORK' in vcard[i]:
|
if 'WORK' in entry:
|
||||||
add_on = '_WORK'
|
add_on = '_WORK'
|
||||||
|
for j in entry.keys():
|
||||||
|
self.set_value(i + add_on + '_' + j + '_entry', entry[j])
|
||||||
|
if type(vcard[i]) == type({}):
|
||||||
for j in vcard[i].keys():
|
for j in vcard[i].keys():
|
||||||
self.set_value(i + add_on + '_' + j + '_entry', vcard[i][j])
|
self.set_value(i + '_' + j + '_entry', vcard[i][j])
|
||||||
else:
|
else:
|
||||||
if i == 'DESC':
|
if i == 'DESC':
|
||||||
self.xml.get_widget('DESC_textview').get_buffer().set_text(
|
self.xml.get_widget('DESC_textview').get_buffer().set_text(
|
||||||
|
@ -242,6 +244,19 @@ class Vcard_window:
|
||||||
'''Add an information to the vCard dictionary'''
|
'''Add an information to the vCard dictionary'''
|
||||||
entries = entry.split('_')
|
entries = entry.split('_')
|
||||||
loc = vcard
|
loc = vcard
|
||||||
|
if len(entries) == 3: # We need to use lists
|
||||||
|
if not loc.has_key(entries[0]):
|
||||||
|
loc[entries[0]] = []
|
||||||
|
found = False
|
||||||
|
for e in loc[entries[0]]:
|
||||||
|
if entries[1] in e:
|
||||||
|
found = True
|
||||||
|
break
|
||||||
|
if found:
|
||||||
|
e[entries[2]] = txt
|
||||||
|
else:
|
||||||
|
loc[entries[0]].append({entries[1]: '', entries[2]: txt})
|
||||||
|
return vcard
|
||||||
while len(entries) > 1:
|
while len(entries) > 1:
|
||||||
if not loc.has_key(entries[0]):
|
if not loc.has_key(entries[0]):
|
||||||
loc[entries[0]] = {}
|
loc[entries[0]] = {}
|
||||||
|
@ -306,6 +321,7 @@ class Vcard_window:
|
||||||
for e in entries:
|
for e in entries:
|
||||||
self.xml.get_widget(e + '_entry').set_text('')
|
self.xml.get_widget(e + '_entry').set_text('')
|
||||||
self.xml.get_widget('DESC_textview').get_buffer().set_text('')
|
self.xml.get_widget('DESC_textview').get_buffer().set_text('')
|
||||||
|
self.xml.get_widget('PHOTO_image').set_from_pixbuf(None)
|
||||||
gajim.connections[self.account].request_vcard(self.jid)
|
gajim.connections[self.account].request_vcard(self.jid)
|
||||||
else:
|
else:
|
||||||
Error_dialog(_('You are not connected to the server'),
|
Error_dialog(_('You are not connected to the server'),
|
||||||
|
|
Loading…
Reference in New Issue