- Update building of Rust modules to use modern cargo_vendor
service - Remove unneeded use-offline-build.patch OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-cryptography?expand=0&rev=223
This commit is contained in:
commit
1b46516713
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
## Default LFS
|
||||||
|
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.png filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zst filter=lfs diff=lfs merge=lfs -text
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.osc
|
3
_multibuild
Normal file
3
_multibuild
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<multibuild>
|
||||||
|
<package>test</package>
|
||||||
|
</multibuild>
|
8
_service
Normal file
8
_service
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<services>
|
||||||
|
<service name="download_files" mode="manual"/>
|
||||||
|
<service name="cargo_vendor" mode="manual">
|
||||||
|
<param name="srcdir">cryptography-*</param>
|
||||||
|
<param name="cargotoml">src/rust/Cargo.toml</param>
|
||||||
|
<param name="compression">zst</param>
|
||||||
|
</service>
|
||||||
|
</services>
|
3
cryptography-42.0.8.tar.gz
Normal file
3
cryptography-42.0.8.tar.gz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:8d09d05439ce7baa8e9e95b07ec5b6c886f548deb7e0f69ef25f64b3bce842f2
|
||||||
|
size 671250
|
3
cryptography-43.0.0.tar.gz
Normal file
3
cryptography-43.0.0.tar.gz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:b88075ada2d51aa9f18283532c9f60e72170041bba88d7f37e49cbb10275299e
|
||||||
|
size 686873
|
286
no-pytest_benchmark.patch
Normal file
286
no-pytest_benchmark.patch
Normal file
@ -0,0 +1,286 @@
|
|||||||
|
---
|
||||||
|
pyproject.toml | 31 -------------------------
|
||||||
|
tests/bench/test_aead.py | 40 ++++++++++++++++-----------------
|
||||||
|
tests/bench/test_ec_load.py | 8 +++---
|
||||||
|
tests/bench/test_hashes.py | 4 +--
|
||||||
|
tests/bench/test_hmac.py | 4 +--
|
||||||
|
tests/bench/test_x509.py | 16 ++++++-------
|
||||||
|
7 files changed, 37 insertions(+), 68 deletions(-)
|
||||||
|
|
||||||
|
Index: cryptography-43.0.0/pyproject.toml
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/pyproject.toml
|
||||||
|
+++ cryptography-43.0.0/pyproject.toml
|
||||||
|
@@ -66,8 +66,6 @@ nox = ["nox"]
|
||||||
|
test = [
|
||||||
|
"cryptography_vectors==43.0.0",
|
||||||
|
"pytest >=6.2.0",
|
||||||
|
- "pytest-benchmark",
|
||||||
|
- "pytest-cov",
|
||||||
|
"pytest-xdist",
|
||||||
|
"pretend",
|
||||||
|
"certifi",
|
||||||
|
@@ -117,7 +115,7 @@ exclude = [
|
||||||
|
]
|
||||||
|
|
||||||
|
[tool.pytest.ini_options]
|
||||||
|
-addopts = "-r s --capture=no --strict-markers --benchmark-disable"
|
||||||
|
+addopts = "-r s --capture=no --strict-markers"
|
||||||
|
console_output_style = "progress-even-when-capture-no"
|
||||||
|
markers = [
|
||||||
|
"skip_fips: this test is not executed in FIPS mode",
|
||||||
|
@@ -139,33 +137,6 @@ module = [
|
||||||
|
]
|
||||||
|
ignore_missing_imports = true
|
||||||
|
|
||||||
|
-[tool.coverage.run]
|
||||||
|
-branch = true
|
||||||
|
-relative_files = true
|
||||||
|
-source = [
|
||||||
|
- "cryptography",
|
||||||
|
- "tests/",
|
||||||
|
-]
|
||||||
|
-
|
||||||
|
-[tool.coverage.paths]
|
||||||
|
-source = [
|
||||||
|
- "src/cryptography",
|
||||||
|
- "*.nox/*/lib*/python*/site-packages/cryptography",
|
||||||
|
- "*.nox\\*\\Lib\\site-packages\\cryptography",
|
||||||
|
- "*.nox/pypy/site-packages/cryptography",
|
||||||
|
-]
|
||||||
|
-tests =[
|
||||||
|
- "tests/",
|
||||||
|
- "*tests\\",
|
||||||
|
-]
|
||||||
|
-
|
||||||
|
-[tool.coverage.report]
|
||||||
|
-exclude_lines = [
|
||||||
|
- "@abc.abstractmethod",
|
||||||
|
- "@typing.overload",
|
||||||
|
- "if typing.TYPE_CHECKING",
|
||||||
|
-]
|
||||||
|
-
|
||||||
|
[tool.ruff]
|
||||||
|
line-length = 79
|
||||||
|
|
||||||
|
Index: cryptography-43.0.0/tests/bench/test_aead.py
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/tests/bench/test_aead.py
|
||||||
|
+++ cryptography-43.0.0/tests/bench/test_aead.py
|
||||||
|
@@ -26,84 +26,84 @@ def _aead_supported(cls):
|
||||||
|
not _aead_supported(ChaCha20Poly1305),
|
||||||
|
reason="Requires OpenSSL with ChaCha20Poly1305 support",
|
||||||
|
)
|
||||||
|
-def test_chacha20poly1305_encrypt(benchmark):
|
||||||
|
+def test_chacha20poly1305_encrypt():
|
||||||
|
chacha = ChaCha20Poly1305(b"\x00" * 32)
|
||||||
|
- benchmark(chacha.encrypt, b"\x00" * 12, b"hello world plaintext", b"")
|
||||||
|
+ chacha.encrypt(b"\x00" * 12, b"hello world plaintext", b"")
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(ChaCha20Poly1305),
|
||||||
|
reason="Requires OpenSSL with ChaCha20Poly1305 support",
|
||||||
|
)
|
||||||
|
-def test_chacha20poly1305_decrypt(benchmark):
|
||||||
|
+def test_chacha20poly1305_decrypt():
|
||||||
|
chacha = ChaCha20Poly1305(b"\x00" * 32)
|
||||||
|
ct = chacha.encrypt(b"\x00" * 12, b"hello world plaintext", b"")
|
||||||
|
- benchmark(chacha.decrypt, b"\x00" * 12, ct, b"")
|
||||||
|
+ chacha.decrypt(b"\x00" * 12, ct, b"")
|
||||||
|
|
||||||
|
|
||||||
|
-def test_aesgcm_encrypt(benchmark):
|
||||||
|
+def test_aesgcm_encrypt():
|
||||||
|
aes = AESGCM(b"\x00" * 32)
|
||||||
|
- benchmark(aes.encrypt, b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
+ aes.encrypt(b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
|
||||||
|
|
||||||
|
-def test_aesgcm_decrypt(benchmark):
|
||||||
|
+def test_aesgcm_decrypt():
|
||||||
|
aes = AESGCM(b"\x00" * 32)
|
||||||
|
ct = aes.encrypt(b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
- benchmark(aes.decrypt, b"\x00" * 12, ct, None)
|
||||||
|
+ aes.decrypt(b"\x00" * 12, ct, None)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(AESSIV),
|
||||||
|
reason="Requires OpenSSL with AES-SIV support",
|
||||||
|
)
|
||||||
|
-def test_aessiv_encrypt(benchmark):
|
||||||
|
+def test_aessiv_encrypt():
|
||||||
|
aes = AESSIV(b"\x00" * 32)
|
||||||
|
- benchmark(aes.encrypt, b"hello world plaintext", None)
|
||||||
|
+ aes.encrypt(b"hello world plaintext", None)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(AESSIV),
|
||||||
|
reason="Requires OpenSSL with AES-SIV support",
|
||||||
|
)
|
||||||
|
-def test_aessiv_decrypt(benchmark):
|
||||||
|
+def test_aessiv_decrypt():
|
||||||
|
aes = AESSIV(b"\x00" * 32)
|
||||||
|
ct = aes.encrypt(b"hello world plaintext", None)
|
||||||
|
- benchmark(aes.decrypt, ct, None)
|
||||||
|
+ aes.decrypt(ct, None)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(AESOCB3),
|
||||||
|
reason="Requires OpenSSL with AES-OCB3 support",
|
||||||
|
)
|
||||||
|
-def test_aesocb3_encrypt(benchmark):
|
||||||
|
+def test_aesocb3_encrypt():
|
||||||
|
aes = AESOCB3(b"\x00" * 32)
|
||||||
|
- benchmark(aes.encrypt, b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
+ aes.encrypt(b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(AESOCB3),
|
||||||
|
reason="Requires OpenSSL with AES-OCB3 support",
|
||||||
|
)
|
||||||
|
-def test_aesocb3_decrypt(benchmark):
|
||||||
|
+def test_aesocb3_decrypt():
|
||||||
|
aes = AESOCB3(b"\x00" * 32)
|
||||||
|
ct = aes.encrypt(b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
- benchmark(aes.decrypt, b"\x00" * 12, ct, None)
|
||||||
|
+ aes.decrypt(b"\x00" * 12, ct, None)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(AESCCM),
|
||||||
|
reason="Requires OpenSSL with AES-CCM support",
|
||||||
|
)
|
||||||
|
-def test_aesccm_encrypt(benchmark):
|
||||||
|
+def test_aesccm_encrypt():
|
||||||
|
aes = AESCCM(b"\x00" * 32)
|
||||||
|
- benchmark(aes.encrypt, b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
+ aes.encrypt(b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
not _aead_supported(AESCCM),
|
||||||
|
reason="Requires OpenSSL with AES-CCM support",
|
||||||
|
)
|
||||||
|
-def test_aesccm_decrypt(benchmark):
|
||||||
|
+def test_aesccm_decrypt():
|
||||||
|
aes = AESCCM(b"\x00" * 32)
|
||||||
|
ct = aes.encrypt(b"\x00" * 12, b"hello world plaintext", None)
|
||||||
|
- benchmark(aes.decrypt, b"\x00" * 12, ct, None)
|
||||||
|
+ aes.decrypt(b"\x00" * 12, ct, None)
|
||||||
|
Index: cryptography-43.0.0/tests/bench/test_ec_load.py
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/tests/bench/test_ec_load.py
|
||||||
|
+++ cryptography-43.0.0/tests/bench/test_ec_load.py
|
||||||
|
@@ -5,9 +5,9 @@
|
||||||
|
from ..hazmat.primitives.fixtures_ec import EC_KEY_SECP256R1
|
||||||
|
|
||||||
|
|
||||||
|
-def test_load_ec_public_numbers(benchmark):
|
||||||
|
- benchmark(EC_KEY_SECP256R1.public_numbers.public_key)
|
||||||
|
+def test_load_ec_public_numbers():
|
||||||
|
+ EC_KEY_SECP256R1.public_numbers.public_key()
|
||||||
|
|
||||||
|
|
||||||
|
-def test_load_ec_private_numbers(benchmark):
|
||||||
|
- benchmark(EC_KEY_SECP256R1.private_key)
|
||||||
|
+def test_load_ec_private_numbers():
|
||||||
|
+ EC_KEY_SECP256R1.private_key()
|
||||||
|
Index: cryptography-43.0.0/tests/bench/test_hashes.py
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/tests/bench/test_hashes.py
|
||||||
|
+++ cryptography-43.0.0/tests/bench/test_hashes.py
|
||||||
|
@@ -5,10 +5,10 @@
|
||||||
|
from cryptography.hazmat.primitives import hashes
|
||||||
|
|
||||||
|
|
||||||
|
-def test_sha256(benchmark):
|
||||||
|
+def test_sha256():
|
||||||
|
def bench():
|
||||||
|
h = hashes.Hash(hashes.SHA256())
|
||||||
|
h.update(b"I love hashing. So much. The best.")
|
||||||
|
return h.finalize()
|
||||||
|
|
||||||
|
- benchmark(bench)
|
||||||
|
+ bench()
|
||||||
|
Index: cryptography-43.0.0/tests/bench/test_hmac.py
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/tests/bench/test_hmac.py
|
||||||
|
+++ cryptography-43.0.0/tests/bench/test_hmac.py
|
||||||
|
@@ -5,10 +5,10 @@
|
||||||
|
from cryptography.hazmat.primitives import hashes, hmac
|
||||||
|
|
||||||
|
|
||||||
|
-def test_hmac_sha256(benchmark):
|
||||||
|
+def test_hmac_sha256():
|
||||||
|
def bench():
|
||||||
|
h = hmac.HMAC(b"my extremely secure key", hashes.SHA256())
|
||||||
|
h.update(b"I love hashing. So much. The best.")
|
||||||
|
return h.finalize()
|
||||||
|
|
||||||
|
- benchmark(bench)
|
||||||
|
+ bench()
|
||||||
|
Index: cryptography-43.0.0/tests/bench/test_x509.py
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/tests/bench/test_x509.py
|
||||||
|
+++ cryptography-43.0.0/tests/bench/test_x509.py
|
||||||
|
@@ -13,40 +13,40 @@ from cryptography import x509
|
||||||
|
from ..utils import load_vectors_from_file
|
||||||
|
|
||||||
|
|
||||||
|
-def test_object_identifier_constructor(benchmark):
|
||||||
|
- benchmark(x509.ObjectIdentifier, "1.3.6.1.4.1.11129.2.4.5")
|
||||||
|
+def test_object_identifier_constructor():
|
||||||
|
+ x509.ObjectIdentifier, "1.3.6.1.4.1.11129.2.4.5"
|
||||||
|
|
||||||
|
|
||||||
|
-def test_aki_public_bytes(benchmark):
|
||||||
|
+def test_aki_public_bytes():
|
||||||
|
aki = x509.AuthorityKeyIdentifier(
|
||||||
|
key_identifier=b"\x00" * 16,
|
||||||
|
authority_cert_issuer=None,
|
||||||
|
authority_cert_serial_number=None,
|
||||||
|
)
|
||||||
|
- benchmark(aki.public_bytes)
|
||||||
|
+ aki.public_bytes
|
||||||
|
|
||||||
|
|
||||||
|
-def test_load_der_certificate(benchmark):
|
||||||
|
+def test_load_der_certificate():
|
||||||
|
cert_bytes = load_vectors_from_file(
|
||||||
|
os.path.join("x509", "PKITS_data", "certs", "GoodCACert.crt"),
|
||||||
|
loader=lambda pemfile: pemfile.read(),
|
||||||
|
mode="rb",
|
||||||
|
)
|
||||||
|
|
||||||
|
- benchmark(x509.load_der_x509_certificate, cert_bytes)
|
||||||
|
+ x509.load_der_x509_certificate, cert_bytes
|
||||||
|
|
||||||
|
|
||||||
|
-def test_load_pem_certificate(benchmark):
|
||||||
|
+def test_load_pem_certificate():
|
||||||
|
cert_bytes = load_vectors_from_file(
|
||||||
|
os.path.join("x509", "cryptography.io.pem"),
|
||||||
|
loader=lambda pemfile: pemfile.read(),
|
||||||
|
mode="rb",
|
||||||
|
)
|
||||||
|
|
||||||
|
- benchmark(x509.load_pem_x509_certificate, cert_bytes)
|
||||||
|
+ x509.load_pem_x509_certificate, cert_bytes
|
||||||
|
|
||||||
|
|
||||||
|
-def test_verify_docs_python_org(benchmark, pytestconfig):
|
||||||
|
+def test_verify_docs_python_org(pytestconfig):
|
||||||
|
limbo_root = pytestconfig.getoption("--x509-limbo-root", skip=True)
|
||||||
|
with open(os.path.join(limbo_root, "limbo.json"), "rb") as f:
|
||||||
|
[testcase] = [
|
||||||
|
@@ -78,4 +78,4 @@ def test_verify_docs_python_org(benchmar
|
||||||
|
)
|
||||||
|
verifier.verify(leaf, intermediates)
|
||||||
|
|
||||||
|
- benchmark(bench)
|
||||||
|
+ bench
|
1721
python-cryptography.changes
Normal file
1721
python-cryptography.changes
Normal file
File diff suppressed because it is too large
Load Diff
34
python-cryptography.keyring
Normal file
34
python-cryptography.keyring
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
pub 2048R/29F9ED98 2013-09-01
|
||||||
|
uid Paul Kehrer <paul.l.kehrer@gmail.com>
|
||||||
|
sub 2048R/9714E575 2013-09-01
|
||||||
|
|
||||||
|
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||||
|
Version: GnuPG v2.0.22 (GNU/Linux)
|
||||||
|
|
||||||
|
mQENBFIirTsBCADAeRXlWJkJ9SaKmR6+ox2aXOF3TCyfgtoJpf6WvBxbtoEpD//m
|
||||||
|
5789KO9lPHQrJGR34E36kOkmkHfrLLtmnELCx/UNvLm3VuW31rL3RvTTrxe1Fyft
|
||||||
|
5JQyYF/WSm6Bnj9yu8fVJUhSGe12SvODD7053bY1bSleMX5I6tGeIXJtih8b5u9u
|
||||||
|
1WNv0rxZqGLKaYTzgmtNcyKGK9jLKtkRwPivpjgrjeGQ+OHf/mwFY+HEOQUw+Cj4
|
||||||
|
5FsCo6jvj+n4r9mYu+Ut6zDOx0cWf66QhZvawDyB2TSSulJsudUETDmoJJ5X9PqH
|
||||||
|
F/bHBdzc5I6HYy+CezSvDmjC+3DnIB//nXMPABEBAAG0JVBhdWwgS2VocmVyIDxw
|
||||||
|
YXVsLmwua2VocmVyQGdtYWlsLmNvbT6JATgEEwECACIFAlIirTsCGwMGCwkIBwMC
|
||||||
|
BhUIAgkKCwQWAgMBAh4BAheAAAoJECNa5fEp+e2YnM0H/i8bU3gQ/lMGli97Puui
|
||||||
|
Sm5es3AwE+dC/ubaAB8Hcdm8UH50uOI6JcmLYYcjglnFEQSDzrKg649Dcvjx7hDN
|
||||||
|
XoCx5V6dC8LcTVES5gGrRr/+ZXtsCVZn2TcLUMQ9bq1yb3jAYxOmWQ1rUvu0Kq+Z
|
||||||
|
1j9IERKpt3MZcXBlOxHP6zIhaaerLLRn5+SjCHCAZQYsKh9f6fMoRvbmaLyKrLBn
|
||||||
|
/n9/esn1b0joWEphwOER8UF5fckqDopovGojDXyNEKGGkXTkWtLk69AcaXcBI97X
|
||||||
|
SqYUmzvnHcAPilpKmfdnvcGPrS/wSY/F4T71aeQ+1QoE83CfavNMQ09g4rETSr3e
|
||||||
|
Vlq5AQ0EUiKtOwEIANRWXywm/B46dy2paG/dd1ApwdX3siIfnCKXEsLB1iTA5/HW
|
||||||
|
BZ5+hHRYmI24RyBj9lVhS9UJzpKZE+KLOZRFwMGGp3TxntInflamuI3iC1N7XqCz
|
||||||
|
gLMFJdHPO60LctbvOHTOx1Scb+AycmymF1HuUFbj1jlYUkwRPOiPvHHWkYQlfeUP
|
||||||
|
MPFo/M7Ae5FxKA4PYfJRQl62wsBRNE5k7IwOmstyUUnDZXIxpB+wNvpxQpAvWT8B
|
||||||
|
IyAvtlrkrE53frfyd0KUOR0iSHNcWcUL0L6XvsaOYb4i20bP7YE5XoVzzANbXTa1
|
||||||
|
wVtz2yNoI7/8BLb2NMIacykUxryYtu6E9cmnwkkAEQEAAYkBHwQYAQIACQUCUiKt
|
||||||
|
OwIbDAAKCRAjWuXxKfntmM/yB/91f/17kL4iAS05WgM1xvgmyYJ3FOgP3hyqD5Ur
|
||||||
|
YkkmoFoF+r6bfBlW8AeOawYTvXinKdv9sM6q0EmiO+iqAuRRfaXZWCDqZdEpy+lv
|
||||||
|
Ev3jhVyuf8O+d8VEILsKia0cmzn6F1UMdp3E9TDgXr1/hMCuABvbfWzEkRQrGHc2
|
||||||
|
cWLXXxko3mykZMLkl0MPGjmzEh87RE55hLk5HroXaMtdyz1knfybVnXgOUxMuqc+
|
||||||
|
+wj499FP1jHvTEEknRopxsMe59+CdsoFBR9xs0Ets7K011P4CMKZZAXVwxF551QL
|
||||||
|
xnqe0Tn1t76rxPJKpyvUM+WtakEVPffuQqSkU8dIJgwwXrZo
|
||||||
|
=3pQn
|
||||||
|
-----END PGP PUBLIC KEY BLOCK-----
|
138
python-cryptography.spec
Normal file
138
python-cryptography.spec
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
#
|
||||||
|
# spec file for package python-cryptography
|
||||||
|
#
|
||||||
|
# Copyright (c) 2024 SUSE LLC
|
||||||
|
#
|
||||||
|
# All modifications and additions to the file contributed by third parties
|
||||||
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
|
# upon. The license for this file, and modifications and additions to the
|
||||||
|
# file, is the same license as for the pristine package itself (unless the
|
||||||
|
# license for the pristine package is not an Open Source License, in which
|
||||||
|
# case the license is the MIT License). An "Open Source License" is a
|
||||||
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
%global rustflags '-Clink-arg=-Wl,-z,relro,-z,now'
|
||||||
|
%global flavor @BUILD_FLAVOR@%{nil}
|
||||||
|
%if "%{flavor}" == "test"
|
||||||
|
%define psuffix -test
|
||||||
|
%bcond_without test
|
||||||
|
%else
|
||||||
|
%define psuffix %{nil}
|
||||||
|
%bcond_with test
|
||||||
|
%endif
|
||||||
|
%{?sle15_python_module_pythons}
|
||||||
|
Name: python-cryptography%{psuffix}
|
||||||
|
Version: 43.0.0
|
||||||
|
Release: 0
|
||||||
|
Summary: Python library which exposes cryptographic recipes and primitives
|
||||||
|
License: Apache-2.0 OR BSD-3-Clause
|
||||||
|
Group: Development/Languages/Python
|
||||||
|
URL: https://cryptography.io/en/latest/
|
||||||
|
Source0: https://files.pythonhosted.org/packages/source/c/cryptography/cryptography-%{version}.tar.gz
|
||||||
|
# use `osc service manualrun` to regenerate
|
||||||
|
Source2: vendor.tar.zst
|
||||||
|
Source4: python-cryptography.keyring
|
||||||
|
# PATCH-FEATURE-OPENSUSE no-pytest_benchmark.patch mcepl@suse.com
|
||||||
|
# We don't need no benchmarking and coverage measurement
|
||||||
|
Patch4: no-pytest_benchmark.patch
|
||||||
|
BuildRequires: %{python_module cffi >= 1.12}
|
||||||
|
BuildRequires: %{python_module devel}
|
||||||
|
BuildRequires: %{python_module exceptiongroup}
|
||||||
|
BuildRequires: %{python_module maturin}
|
||||||
|
BuildRequires: %{python_module pip}
|
||||||
|
BuildRequires: %{python_module setuptools-rust >= 1.7.0}
|
||||||
|
BuildRequires: %{python_module setuptools}
|
||||||
|
BuildRequires: %{python_module wheel}
|
||||||
|
BuildRequires: cargo >= 1.56.0
|
||||||
|
BuildRequires: fdupes
|
||||||
|
BuildRequires: libopenssl-devel
|
||||||
|
BuildRequires: pkgconfig
|
||||||
|
BuildRequires: python-rpm-macros
|
||||||
|
BuildRequires: rust >= 1.56.0
|
||||||
|
BuildRequires: zstd
|
||||||
|
BuildRequires: pkgconfig(libffi)
|
||||||
|
# python-base is not enough, we need the _ssl module
|
||||||
|
Requires: python
|
||||||
|
Requires: python-bcrypt
|
||||||
|
%requires_eq python-cffi
|
||||||
|
%if %{with test}
|
||||||
|
BuildRequires: %{python_module bcrypt}
|
||||||
|
BuildRequires: %{python_module certifi}
|
||||||
|
BuildRequires: %{python_module cryptography >= %{version}}
|
||||||
|
BuildRequires: %{python_module cryptography-vectors = %{version}}
|
||||||
|
BuildRequires: %{python_module hypothesis >= 1.11.4}
|
||||||
|
BuildRequires: %{python_module iso8601}
|
||||||
|
BuildRequires: %{python_module pretend}
|
||||||
|
BuildRequires: %{python_module pytest > 6.0}
|
||||||
|
BuildRequires: %{python_module pytest-benchmark}
|
||||||
|
BuildRequires: %{python_module pytest-subtests}
|
||||||
|
BuildRequires: %{python_module pytest-xdist}
|
||||||
|
BuildRequires: %{python_module pytz}
|
||||||
|
%endif
|
||||||
|
%python_subpackages
|
||||||
|
|
||||||
|
%description
|
||||||
|
cryptography is a package designed to expose cryptographic
|
||||||
|
recipes and primitives to Python developers. Our goal is
|
||||||
|
for it to be your "cryptographic standard library". It
|
||||||
|
supports Python 2.7, Python 3.4+, and PyPy-5.3+.
|
||||||
|
|
||||||
|
cryptography includes both high level recipes, and low
|
||||||
|
level interfaces to common cryptographic algorithms such as
|
||||||
|
symmetric ciphers, message digests and key derivation
|
||||||
|
functions.
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%autosetup -a2 -p1 -n cryptography-%{version}
|
||||||
|
|
||||||
|
%build
|
||||||
|
cd src/rust
|
||||||
|
tar xfv %{S:2}
|
||||||
|
rm -v Cargo.lock
|
||||||
|
cargo build
|
||||||
|
cd -
|
||||||
|
|
||||||
|
# https://github.com/pyca/cryptography/issues/9023
|
||||||
|
%global _lto_cflags %{nil}
|
||||||
|
export RUSTFLAGS=%{rustflags}
|
||||||
|
export CFLAGS="%{optflags} -fno-strict-aliasing"
|
||||||
|
%pyproject_wheel
|
||||||
|
|
||||||
|
%install
|
||||||
|
%if !%{with test}
|
||||||
|
export RUSTFLAGS=%{rustflags}
|
||||||
|
# Actually other *.c and *.h are appropriate
|
||||||
|
# see https://github.com/pyca/cryptography/issues/1463
|
||||||
|
find . -name .keep -print -delete
|
||||||
|
|
||||||
|
%pyproject_install
|
||||||
|
%python_expand %fdupes %{buildroot}%{$python_sitearch}
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{with test}
|
||||||
|
%check
|
||||||
|
# won't work for cryptography
|
||||||
|
# fails with OverflowError on 32bit platform
|
||||||
|
%ifarch %ix86 %arm ppc
|
||||||
|
rm -v tests/hazmat/primitives/test_aead.py
|
||||||
|
# imports test_aead so we need to remove also these
|
||||||
|
rm -v tests/wycheproof/test_aes.py
|
||||||
|
rm -v tests/wycheproof/test_chacha20poly1305.py
|
||||||
|
%endif
|
||||||
|
%pytest_arch -n auto --ignore-glob=vendor/*
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if !%{with test}
|
||||||
|
%files %{python_files}
|
||||||
|
%license LICENSE LICENSE.APACHE LICENSE.BSD
|
||||||
|
%doc CONTRIBUTING.rst CHANGELOG.rst README.rst
|
||||||
|
%{python_sitearch}/cryptography
|
||||||
|
%{python_sitearch}/cryptography-%{version}.dist-info
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%changelog
|
14
use-offline-build.patch
Normal file
14
use-offline-build.patch
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
Index: cryptography-43.0.0/pyproject.toml
|
||||||
|
===================================================================
|
||||||
|
--- cryptography-43.0.0.orig/pyproject.toml
|
||||||
|
+++ cryptography-43.0.0/pyproject.toml
|
||||||
|
@@ -84,7 +84,8 @@ python-source = "src"
|
||||||
|
python-packages = ["cryptography"]
|
||||||
|
manifest-path = "src/rust/Cargo.toml"
|
||||||
|
module-name = "cryptography.hazmat.bindings._rust"
|
||||||
|
-locked = true
|
||||||
|
+locked = false
|
||||||
|
+offline = true
|
||||||
|
sdist-generator = "git"
|
||||||
|
features = ["pyo3/abi3-py37"]
|
||||||
|
include = [
|
3
vendor.tar.zst
Normal file
3
vendor.tar.zst
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:1ac7727c4e81168618b012aefd3a0bec71280701a76faae14d4981605a438874
|
||||||
|
size 1949563
|
Loading…
Reference in New Issue
Block a user