summaryrefslogtreecommitdiff
path: root/poezio
diff options
context:
space:
mode:
authorEmmanuel Gil Peyrot <linkmauve@linkmauve.fr>2018-01-25 16:00:33 +0100
committerEmmanuel Gil Peyrot <linkmauve@linkmauve.fr>2018-01-25 16:00:33 +0100
commit25898e9ee7fc4562b73443de8a7359e6ffe674cb (patch)
tree5263b1a781effd445c2473c3ea9a365e4df5c8bf /poezio
parent4c2eee6a133785ac651b4818977661d0ac6008dd (diff)
downloadpoezio-25898e9ee7fc4562b73443de8a7359e6ffe674cb.tar.gz
poezio-25898e9ee7fc4562b73443de8a7359e6ffe674cb.tar.bz2
poezio-25898e9ee7fc4562b73443de8a7359e6ffe674cb.tar.xz
poezio-25898e9ee7fc4562b73443de8a7359e6ffe674cb.zip
Check that avatar sha1 is consistent with the hash.
Diffstat (limited to 'poezio')
-rw-r--r--poezio/core/handlers.py13
1 files changed, 9 insertions, 4 deletions
diff --git a/poezio/core/handlers.py b/poezio/core/handlers.py
index 59ab9f37..626f2093 100644
--- a/poezio/core/handlers.py
+++ b/poezio/core/handlers.py
@@ -13,7 +13,7 @@ import ssl
import sys
import time
from datetime import datetime
-from hashlib import sha256, sha512
+from hashlib import sha1, sha256, sha512
from os import path, makedirs
import pyasn1.codec.der.decoder
@@ -415,8 +415,10 @@ class HandlerCore:
result = yield from self.core.xmpp[
'xep_0084'].retrieve_avatar(
jid, avatar_hash, timeout=60)
- contact.avatar = result['pubsub']['items']['item'][
- 'avatar_data']['value']
+ avatar = result['pubsub']['items']['item']['avatar_data']['value']
+ if sha1(avatar).hexdigest().lower() != avatar_hash.lower():
+ raise Exception('Avatar sha1 doesn’t match 0084 hash.')
+ contact.avatar = avatar
except Exception:
log.debug(
'Failed retrieving 0084 data from %s:',
@@ -460,7 +462,10 @@ class HandlerCore:
result = yield from self.core.xmpp['xep_0054'].get_vcard(
jid, cached=True, timeout=60)
avatar = result['vcard_temp']['PHOTO']
- contact.avatar = avatar['BINVAL']
+ binval = avatar['BINVAL']
+ if sha1(binval).hexdigest().lower() != avatar_hash.lower():
+ raise Exception('Avatar sha1 doesn’t match 0153 hash.')
+ contact.avatar = binval
except Exception:
log.debug('Failed retrieving vCard from %s:', jid, exc_info=True)
return