aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Gaynor <alex.gaynor@gmail.com>2016-04-02 13:03:05 -0400
committerPaul Kehrer <paul.l.kehrer@gmail.com>2016-04-02 13:03:05 -0400
commit70153dd363e0cc12ef201ca4c1b2cef04dea6b5d (patch)
treeadcb5f341b1f52ea54b2fed3c2dd353106482278
parent15ab4fc371bc9f94868f430eec9d55bca05e147a (diff)
downloadcryptography-70153dd363e0cc12ef201ca4c1b2cef04dea6b5d.tar.gz
cryptography-70153dd363e0cc12ef201ca4c1b2cef04dea6b5d.tar.bz2
cryptography-70153dd363e0cc12ef201ca4c1b2cef04dea6b5d.zip
Handle two more error conditions correctly
* Handle two more error conditions correctly * fixed test case
-rw-r--r--src/cryptography/hazmat/primitives/serialization.py6
-rw-r--r--tests/hazmat/primitives/test_serialization.py11
2 files changed, 17 insertions, 0 deletions
diff --git a/src/cryptography/hazmat/primitives/serialization.py b/src/cryptography/hazmat/primitives/serialization.py
index 5c166c89..d848e5d4 100644
--- a/src/cryptography/hazmat/primitives/serialization.py
+++ b/src/cryptography/hazmat/primitives/serialization.py
@@ -127,7 +127,13 @@ def _read_next_string(data):
While the RFC calls these strings, in Python they are bytes objects.
"""
+ if len(data) < 4:
+ raise ValueError("Key is not in the proper format")
+
str_len, = struct.unpack('>I', data[:4])
+ if len(data) < str_len + 4:
+ raise ValueError("Key is not in the proper format")
+
return data[4:4 + str_len], data[4 + str_len:]
diff --git a/tests/hazmat/primitives/test_serialization.py b/tests/hazmat/primitives/test_serialization.py
index f82e7354..1ba8a3b6 100644
--- a/tests/hazmat/primitives/test_serialization.py
+++ b/tests/hazmat/primitives/test_serialization.py
@@ -854,6 +854,17 @@ class TestRSASSHSerialization(object):
with pytest.raises(ValueError):
load_ssh_public_key(ssh_key, backend)
+ def test_load_ssh_public_key_truncated_int(self, backend):
+ ssh_key = b'ssh-rsa AAAAB3NzaC1yc2EAAAA='
+
+ with pytest.raises(ValueError):
+ load_ssh_public_key(ssh_key, backend)
+
+ ssh_key = b'ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAAACKr+IHXo'
+
+ with pytest.raises(ValueError):
+ load_ssh_public_key(ssh_key, backend)
+
def test_load_ssh_public_key_rsa_comment_with_spaces(self, backend):
ssh_key = (
b"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDDu/XRP1kyK6Cgt36gts9XAk"