Merge "Make 'signing csr' accept Unicode CA Private key"

This commit is contained in:
Jenkins 2016-06-22 07:25:16 +00:00 committed by Gerrit Code Review
commit 160c61c398
3 changed files with 45 additions and 10 deletions

View File

@ -151,6 +151,22 @@ def _generate_certificate(issuer_name, subject_name, extensions, ca_key=None,
return keypairs return keypairs
def _load_pem_private_key(ca_key, ca_key_password=None):
if not isinstance(ca_key, rsa.RSAPrivateKey):
if isinstance(ca_key, six.text_type):
ca_key = six.b(str(ca_key))
if isinstance(ca_key_password, six.text_type):
ca_key_password = six.b(str(ca_key_password))
ca_key = serialization.load_pem_private_key(
ca_key,
password=ca_key_password,
backend=default_backend()
)
return ca_key
def sign(csr, issuer_name, ca_key, ca_key_password=None, def sign(csr, issuer_name, ca_key, ca_key_password=None,
skip_validation=False): skip_validation=False):
"""Sign a given csr """Sign a given csr
@ -163,10 +179,7 @@ def sign(csr, issuer_name, ca_key, ca_key_password=None,
:returns: generated certificate :returns: generated certificate
""" """
if not isinstance(ca_key, rsa.RSAPrivateKey): ca_key = _load_pem_private_key(ca_key, ca_key_password)
ca_key = serialization.load_pem_private_key(ca_key,
password=ca_key_password,
backend=default_backend())
if not isinstance(issuer_name, six.text_type): if not isinstance(issuer_name, six.text_type):
issuer_name = six.text_type(issuer_name.decode('utf-8')) issuer_name = six.text_type(issuer_name.decode('utf-8'))
@ -213,9 +226,8 @@ def sign(csr, issuer_name, ca_key, ca_key_password=None,
def decrypt_key(encrypted_key, password): def decrypt_key(encrypted_key, password):
private_key = serialization.load_pem_private_key( private_key = _load_pem_private_key(encrypted_key, password)
encrypted_key, password=password, backend=default_backend()
)
decrypted_pem = private_key.private_bytes( decrypted_pem = private_key.private_bytes(
encoding=serialization.Encoding.PEM, encoding=serialization.Encoding.PEM,
format=serialization.PrivateFormat.PKCS8, format=serialization.PrivateFormat.PKCS8,

View File

@ -25,7 +25,7 @@ class TestX509Operations(base.BaseTestCase):
@mock.patch.object(serialization, 'NoEncryption') @mock.patch.object(serialization, 'NoEncryption')
@mock.patch.object(operations, 'default_backend') @mock.patch.object(operations, 'default_backend')
@mock.patch.object(serialization, 'load_pem_private_key') @mock.patch.object(operations, '_load_pem_private_key')
def test_decrypt_key(self, mock_load_pem_private_key, def test_decrypt_key(self, mock_load_pem_private_key,
mock_default_backend, mock_no_encryption_class): mock_default_backend, mock_no_encryption_class):
mock_private_key = mock.MagicMock() mock_private_key = mock.MagicMock()
@ -36,8 +36,7 @@ class TestX509Operations(base.BaseTestCase):
mock.sentinel.passphrase) mock.sentinel.passphrase)
mock_load_pem_private_key.assert_called_once_with( mock_load_pem_private_key.assert_called_once_with(
mock.sentinel.key, password=mock.sentinel.passphrase, mock.sentinel.key, mock.sentinel.passphrase)
backend=mock_default_backend.return_value)
mock_private_key.private_bytes.assert_called_once_with( mock_private_key.private_bytes.assert_called_once_with(
encoding=serialization.Encoding.PEM, encoding=serialization.Encoding.PEM,
format=serialization.PrivateFormat.PKCS8, format=serialization.PrivateFormat.PKCS8,

View File

@ -72,6 +72,13 @@ class TestX509(base.BaseTestCase):
serialization.PublicFormat.SubjectPublicKeyInfo serialization.PublicFormat.SubjectPublicKeyInfo
) )
def _private_bytes(self, private_key):
return private_key.private_bytes(
encoding=serialization.Encoding.PEM,
format=serialization.PrivateFormat.PKCS8,
encryption_algorithm=serialization.NoEncryption()
)
def _generate_private_key(self): def _generate_private_key(self):
return rsa.generate_private_key( return rsa.generate_private_key(
public_exponent=65537, public_exponent=65537,
@ -183,6 +190,23 @@ class TestX509(base.BaseTestCase):
self.assertInClientExtensions(cert) self.assertInClientExtensions(cert)
def test_load_pem_private_key_with_bytes_private_key(self):
private_key = self._generate_private_key()
private_key = self._private_bytes(private_key)
self.assertIsInstance(private_key, six.binary_type)
private_key = operations._load_pem_private_key(private_key)
self.assertIsInstance(private_key, rsa.RSAPrivateKey)
def test_load_pem_private_key_with_unicode_private_key(self):
private_key = self._generate_private_key()
private_key = self._private_bytes(private_key)
private_key = six.text_type(private_key.decode('utf-8'))
self.assertIsInstance(private_key, six.text_type)
private_key = operations._load_pem_private_key(private_key)
self.assertIsInstance(private_key, rsa.RSAPrivateKey)
@mock.patch('cryptography.x509.load_pem_x509_csr') @mock.patch('cryptography.x509.load_pem_x509_csr')
@mock.patch('six.b') @mock.patch('six.b')
def test_sign_with_unicode_csr(self, mock_six, mock_load_pem): def test_sign_with_unicode_csr(self, mock_six, mock_load_pem):