Compare commits
2 Commits
Author | SHA1 | Date |
---|---|---|
Mohamed El Morabity | 0d84761a5f | 10 months ago |
Mohamed El Morabity | 14a8b2ee00 | 3 years ago |
@ -0,0 +1 @@
|
||||
/pycryptodomex-3.20.0.tar.gz
|
@ -0,0 +1,36 @@
|
||||
diff -up ./setup.py.bak ./setup.py
|
||||
--- ./setup.py.bak 2022-06-22 20:21:37.000000000 +0200
|
||||
+++ ./setup.py 2022-06-23 11:09:44.260182023 +0200
|
||||
@@ -369,10 +369,12 @@ ext_modules = [
|
||||
Extension("Crypto.Cipher._raw_des",
|
||||
include_dirs=['src/', 'src/libtom/'],
|
||||
sources=["src/DES.c"],
|
||||
+ extra_link_args=["-ltomcrypt"],
|
||||
py_limited_api=True),
|
||||
Extension("Crypto.Cipher._raw_des3",
|
||||
include_dirs=['src/', 'src/libtom/'],
|
||||
sources=["src/DES3.c"],
|
||||
+ extra_link_args=["-ltomcrypt"],
|
||||
py_limited_api=True),
|
||||
Extension("Crypto.Util._cpuid_c",
|
||||
include_dirs=['src/'],
|
||||
@@ -417,6 +419,7 @@ ext_modules = [
|
||||
Extension("Crypto.Cipher._Salsa20",
|
||||
include_dirs=['src/', 'src/libtom/'],
|
||||
sources=["src/Salsa20.c"],
|
||||
+ extra_link_args=["-ltomcrypt"],
|
||||
py_limited_api=True),
|
||||
Extension("Crypto.Cipher._chacha20",
|
||||
include_dirs=['src/'],
|
||||
diff -up ./src/DES.c.bak ./src/DES.c
|
||||
--- ./src/DES.c.bak 2022-06-22 20:21:37.000000000 +0200
|
||||
+++ ./src/DES.c 2022-06-23 11:10:58.166711358 +0200
|
||||
@@ -39,7 +39,7 @@ FAKE_INIT(raw_des3)
|
||||
|
||||
/* Include the actial DES implementation */
|
||||
#define LTC_NO_PROTOTYPES
|
||||
-#include "libtom/tomcrypt_des.c"
|
||||
+#include <tomcrypt.h>
|
||||
|
||||
struct block_state {
|
||||
symmetric_key sk;
|
@ -0,0 +1,126 @@
|
||||
%global srcname pycryptodomex
|
||||
%global _description %{expand:PyCryptodome is a self-contained Python package of low-level cryptographic
|
||||
primitives. It's a fork of PyCrypto. It brings several enhancements with respect
|
||||
to the last official version of PyCrypto (2.6.1), for instance:
|
||||
|
||||
* Authenticated encryption modes (GCM, CCM, EAX, SIV, OCB)
|
||||
* Accelerated AES on Intel platforms via AES-NI
|
||||
* Elliptic curves cryptography (NIST P-256 curve only)
|
||||
* Better and more compact API (nonce and iv attributes for ciphers, automatic
|
||||
generation of random nonces and IVs, simplified CTR cipher mode, and more)
|
||||
* SHA-3 (including SHAKE XOFs) and BLAKE2 hash algorithms
|
||||
* Salsa20 and ChaCha20 stream ciphers
|
||||
* scrypt and HKDF
|
||||
* Deterministic (EC)DSA
|
||||
* Password-protected PKCS#8 key containers
|
||||
* Shamir's Secret Sharing scheme
|
||||
* Random numbers get sourced directly from the OS (and not from a CSPRNG in
|
||||
userspace)
|
||||
* Cleaner RSA and DSA key generation (largely based on FIPS 186-4)
|
||||
* Major clean ups and simplification of the code base
|
||||
|
||||
PyCryptodome is not a wrapper to a separate C library like OpenSSL. To the
|
||||
largest possible extent, algorithms are implemented in pure Python. Only the
|
||||
pieces that are extremely critical to performance (e.g. block ciphers) are
|
||||
implemented as C extensions.
|
||||
|
||||
Note: all modules are installed under the Cryptodome package to avoid conflicts
|
||||
with the PyCrypto library.}
|
||||
|
||||
Name: python-%{srcname}
|
||||
Version: 3.20.0
|
||||
Release: 1%{?dist}
|
||||
Summary: A self-contained cryptographic library for Python
|
||||
|
||||
# PyCrypto-based code is public domain, further PyCryptodome contributions are
|
||||
# BSD
|
||||
License: BSD-2-Clause AND LicenseRef-Fedora-Public-Domain
|
||||
URL: http://www.pycryptodome.org/
|
||||
Source0: https://github.com/Legrandin/pycryptodome/archive/v%{version}/%{srcname}-%{version}.tar.gz
|
||||
# Use external libtomcrypt library
|
||||
Patch0: %{name}-3.15.0-use_external_libtomcrypt.patch
|
||||
|
||||
BuildRequires: gcc
|
||||
BuildRequires: libtomcrypt-devel
|
||||
BuildRequires: make
|
||||
BuildRequires: python3-devel
|
||||
# Needed for documentation
|
||||
BuildRequires: %{py3_dist sphinx}
|
||||
|
||||
%description
|
||||
%{_description}
|
||||
|
||||
|
||||
%package -n python3-%{srcname}
|
||||
Summary: %{summary}
|
||||
# GMP library is dl-opened
|
||||
Requires: gmp%{?_isa}
|
||||
|
||||
%description -n python3-%{srcname}
|
||||
%{_description}
|
||||
|
||||
|
||||
%package -n python3-%{srcname}-selftest
|
||||
Summary: PyCryptodome test suite module
|
||||
Requires: python3-%{srcname}%{?_isa}
|
||||
|
||||
%description -n python3-%{srcname}-selftest
|
||||
%{_description}
|
||||
|
||||
This package provides the PyCryptodome test suite module (Cryptodome.SelfTest).
|
||||
|
||||
|
||||
%prep
|
||||
%autosetup -n pycryptodome-%{version} -p0
|
||||
|
||||
# Drop bundled libraries
|
||||
rm -r src/libtom/
|
||||
|
||||
# Remove shebang
|
||||
sed '1{\@^#! /usr/bin/env python@d}' lib/Crypto/SelfTest/__main__.py >lib/Crypto/SelfTest/__main__.py.new && \
|
||||
touch -r lib/Crypto/SelfTest/__main__.py lib/Crypto/SelfTest/__main__.py.new && \
|
||||
mv lib/Crypto/SelfTest/__main__.py.new lib/Crypto/SelfTest/__main__.py
|
||||
|
||||
|
||||
%generate_buildrequires
|
||||
%pyproject_buildrequires -r
|
||||
|
||||
|
||||
%build
|
||||
touch .separate_namespace
|
||||
%pyproject_wheel
|
||||
|
||||
# Build documentation
|
||||
%make_build -C Doc/ man SPHINXBUILD=sphinx-build
|
||||
|
||||
|
||||
%install
|
||||
%pyproject_install
|
||||
%pyproject_save_files Cryptodome
|
||||
|
||||
|
||||
# Install man pages
|
||||
install -Dpm 0644 Doc/_build/man/pycryptodome.1 $RPM_BUILD_ROOT%{_mandir}/man1/pycryptodome.1
|
||||
|
||||
|
||||
%check
|
||||
PYTHONPATH=$RPM_BUILD_ROOT%{python3_sitearch}/ %{__python3} %{py_setup} test
|
||||
|
||||
|
||||
%files -n python3-%{srcname} -f %{pyproject_files}
|
||||
%doc AUTHORS.rst Changelog.rst README.rst
|
||||
%license LICENSE.rst
|
||||
%exclude %{python3_sitearch}/Cryptodome/SelfTest/
|
||||
%{_mandir}/man1/pycryptodome.1*
|
||||
|
||||
|
||||
%files -n python3-%{srcname}-selftest
|
||||
%{python3_sitearch}/Cryptodome/SelfTest/
|
||||
|
||||
|
||||
%changelog
|
||||
* Sun Feb 25 2024 Mohamed El Morabity <melmorabity@fedoraproject.org> - 3.20.0-1
|
||||
- Update to 3.20.0
|
||||
|
||||
* Wed Feb 02 2022 Mohamed El Morabity <melmorabity@fedoraproject.org> - 3.14.0-1
|
||||
- Initial EPEL9 release
|
Loading…
Reference in new issue