-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This PR supports a bad old algorithm to support a scapy use case, but does not expose support for effective key bits or any key length other than 128-bit. CBC support only -- no other modes.
- Loading branch information
1 parent
6643f54
commit 429d349
Showing
4 changed files
with
59 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
# This file is dual licensed under the terms of the Apache License, Version | ||
# 2.0, and the BSD License. See the LICENSE file in the root of this repository | ||
# for complete details. | ||
|
||
""" | ||
Test using the NIST Test Vectors | ||
""" | ||
|
||
|
||
import binascii | ||
import os | ||
|
||
import pytest | ||
|
||
from cryptography.hazmat.decrepit.ciphers.algorithms import RC2 | ||
from cryptography.hazmat.primitives.ciphers import modes | ||
|
||
from ....utils import load_nist_vectors | ||
from ..utils import generate_encrypt_test | ||
|
||
|
||
@pytest.mark.supported( | ||
only_if=lambda backend: backend.cipher_supported( | ||
RC2(b"\x00" * 16), modes.CBC(b"\x00" * 8) | ||
), | ||
skip_message="Does not support RC2 CBC", | ||
) | ||
class TestRC2ModeCBC: | ||
test_kat = generate_encrypt_test( | ||
load_nist_vectors, | ||
os.path.join("ciphers", "RC2"), | ||
[ | ||
"rc2-cbc.txt", | ||
], | ||
lambda key, **kwargs: RC2(binascii.unhexlify(key)), | ||
lambda iv, **kwargs: modes.CBC(binascii.unhexlify(iv)), | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters