Переглянути джерело

fix TypeError in errorhandler, fixes #1903

Thomas Waldmann 9 роки тому
батько
коміт
989b2286ff
1 змінених файлів з 4 додано та 2 видалено
  1. 4 2
      borg/key.py

+ 4 - 2
borg/key.py

@@ -143,11 +143,13 @@ class AESKeyBase(KeyBase):
     def decrypt(self, id, data):
     def decrypt(self, id, data):
         if not (data[0] == self.TYPE or
         if not (data[0] == self.TYPE or
             data[0] == PassphraseKey.TYPE and isinstance(self, RepoKey)):
             data[0] == PassphraseKey.TYPE and isinstance(self, RepoKey)):
-            raise IntegrityError('Chunk %s: Invalid encryption envelope' % bin_to_hex(id))
+            id_str = bin_to_hex(id) if id is not None else '(unknown)'
+            raise IntegrityError('Chunk %s: Invalid encryption envelope' % id_str)
         hmac_given = memoryview(data)[1:33]
         hmac_given = memoryview(data)[1:33]
         hmac_computed = memoryview(HMAC(self.enc_hmac_key, memoryview(data)[33:], sha256).digest())
         hmac_computed = memoryview(HMAC(self.enc_hmac_key, memoryview(data)[33:], sha256).digest())
         if not compare_digest(hmac_computed, hmac_given):
         if not compare_digest(hmac_computed, hmac_given):
-            raise IntegrityError('Chunk %s: Encryption envelope checksum mismatch' % bin_to_hex(id))
+            id_str = bin_to_hex(id) if id is not None else '(unknown)'
+            raise IntegrityError('Chunk %s: Encryption envelope checksum mismatch' % id_str)
         self.dec_cipher.reset(iv=PREFIX + data[33:41])
         self.dec_cipher.reset(iv=PREFIX + data[33:41])
         data = self.compressor.decompress(self.dec_cipher.decrypt(data[41:]))
         data = self.compressor.decompress(self.dec_cipher.decrypt(data[41:]))
         if id:
         if id: