diff options
author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2014-03-10 21:52:13 -0400 |
---|---|---|
committer | Paul Kehrer <paul.l.kehrer@gmail.com> | 2014-03-10 21:52:13 -0400 |
commit | db6fab5a02ec54edb6fe47b4f029a118b4dd26cd (patch) | |
tree | 67e4b46abf48f7ec029c929febef457048aaaeef /cryptography | |
parent | e654ce52985c319b84bdee1ed5325ec420c7da00 (diff) | |
download | cryptography-db6fab5a02ec54edb6fe47b4f029a118b4dd26cd.tar.gz cryptography-db6fab5a02ec54edb6fe47b4f029a118b4dd26cd.tar.bz2 cryptography-db6fab5a02ec54edb6fe47b4f029a118b4dd26cd.zip |
add MGF1 class, docs, tests
Diffstat (limited to 'cryptography')
-rw-r--r-- | cryptography/hazmat/primitives/asymmetric/padding.py | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/cryptography/hazmat/primitives/asymmetric/padding.py b/cryptography/hazmat/primitives/asymmetric/padding.py index 6bafe314..df960b0f 100644 --- a/cryptography/hazmat/primitives/asymmetric/padding.py +++ b/cryptography/hazmat/primitives/asymmetric/padding.py @@ -13,6 +13,8 @@ from __future__ import absolute_import, division, print_function +import six + from cryptography import utils from cryptography.hazmat.primitives import interfaces @@ -20,3 +22,22 @@ from cryptography.hazmat.primitives import interfaces @utils.register_interface(interfaces.AsymmetricPadding) class PKCS1v15(object): name = "EMSA-PKCS1-v1_5" + + +class MGF1(object): + MAX_LENGTH = b"MAX_LENGTH" + + def __init__(self, algorithm, salt_length): + if not isinstance(algorithm, interfaces.HashAlgorithm): + raise TypeError("Expected instance of interfaces.HashAlgorithm.") + + self.algorithm = algorithm + + if (not isinstance(salt_length, six.integer_types) and + salt_length != b"MAX_LENGTH"): + raise TypeError("salt_length must be an integer") + + if salt_length != b"MAX_LENGTH" and salt_length < 0: + raise ValueError("salt_length must be zero or greater") + + self.salt_length = salt_length |