aboutsummaryrefslogtreecommitdiffstats
path: root/cryptography
diff options
context:
space:
mode:
authorPaul Kehrer <paul.l.kehrer@gmail.com>2014-03-10 21:52:13 -0400
committerPaul Kehrer <paul.l.kehrer@gmail.com>2014-03-10 21:52:13 -0400
commitdb6fab5a02ec54edb6fe47b4f029a118b4dd26cd (patch)
tree67e4b46abf48f7ec029c929febef457048aaaeef /cryptography
parente654ce52985c319b84bdee1ed5325ec420c7da00 (diff)
downloadcryptography-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.py21
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