File e_nss-Fedora_31.spec of Package e_nss
#
# spec file for e_nss package
#
# This is free software; see Copyright file in the source
# distribution for precise wording.
#
# Copyright (c) 2019-2025 Roumen Petrov
#
# Do we build provider module? (1=yes 0=no)
%global enable_module 1
# Do we want to enable engine module? (1=yes 0=no)
%global enable_engine 1
# Do we want to enable DSA publickey algorithms? (1=yes 0=no)
%global enable_dsa 1
# Do we want to enable tests with DSA certificates (1=yes 0=no)
%global enable_dsa_test 1
%if 0%{?rhel} > 0 && 0%{?rhel_version} == 0
%global rhel_version %{rhel}00
%endif
# Disable non-working configurations
%if 0%{?fedora} >= 99
# Development builds - Rawhide ...
%endif
%if 0%{?rhel_version} < 900 && 0%{?rhel_version} > 0
%undefine enable_module
%global enable_module 0
%endif
%if 0%{?fedora} < 36 && 0%{?fedora} > 0
%undefine enable_module
%global enable_module 0
%endif
%if 0%{?rhel_version} >= 1000
%undefine enable_engine
%global enable_engine 0
%endif
%if 0%{?fedora} >= 41
%undefine enable_engine
%global enable_engine 0
%endif
%if !%{?enable_dsa}
%undefine enable_dsa_test
%global enable_dsa_test 0
%endif
# norootforbuild
Url: https://roumenpetrov.info/e_nss/
Name: e_nss
Summary: OpenSSL loadable modules for Mozilla's NSS(Network Security Services)
Version: 5.1
Release: 1
License: MIT
Group: Productivity/Security
Requires: openssl nspr nss
BuildRequires: openssl-devel nspr-devel nss-devel
BuildRequires: openssl nss-tools
BuildRoot: %{_tmppath}/%{name}-%{version}-build
%if 0%{?rhel_version} > 0 && 0%{?rhel_version} < 600
Source0: https://roumenpetrov.info/e_nss/e_nss-%{version}.tar.gz
%else
Source0: https://roumenpetrov.info/e_nss/e_nss-%{version}.tar.xz
%endif
# Default values for additional components
%define openssl_modulesdir %{_libdir}/ossl-modules
%if 0%{?rhel_version} >= 900
%define openssl_enginesdir %{_libdir}/engines-3
%endif
%if 0%{?rhel_version} >= 800 && 0%{?rhel_version} < 900
%define openssl_enginesdir %{_libdir}/engines-1.1
%endif
%if 0%{?rhel_version} < 800 && 0%{?rhel_version} > 0
%define openssl_enginesdir %{_libdir}/openssl/engines
%endif
%if 0%{?fedora} > 0
# keep one and the same even not correct
%define openssl_enginesdir %{_libdir}/openssl/engines
%endif
%if 0%{?rhel_version} > 0
%define e_nss_docdir %{_docdir}/%{name}-%{version}
%else
%define e_nss_docdir %{_docdir}/%{name}
%endif
# autoconf before 2.60 does not support --docdir
%define use_docdir 1
%if 0%{?rhel_version} > 0 && 0%{?rhel_version} < 600
%undefine use_docdir
%define use_docdir 0
%endif
%description
Cryptographic module, either engine or provider, that use key and/or
certificates stored in Mozilla NSS(Network Security Services)
database to perform cryptographic operations.
Module support RSA, EC, and DSA(optionally) keys.
%changelog
# Not managed, please see source repository for changes.
%prep
%setup -q
%build
CPPFLAGS="$CPPFLAGS -I/usr/include/nspr4 -I/usr/include/nss3"
export CPPFLAGS
%configure \
%if %{use_docdir}
--docdir=%{e_nss_docdir} \
%endif
--with-modulesdir=%{openssl_modulesdir} \
--with-enginesdir=%{openssl_enginesdir} \
%if %{?enable_engine}
--enable-engine \
%else
--disable-engine \
%endif
%if %{?enable_dsa}
--enable-dsa \
%else
--disable-dsa \
%endif
%if %{?enable_dsa_test}
--enable-dsa-tests \
%else
--disable-dsa-tests \
%endif
--enable-tests
make
%check
make check
%install
rm -rf $RPM_BUILD_ROOT
make install DESTDIR=$RPM_BUILD_ROOT/
%if %{?enable_module}
rm $RPM_BUILD_ROOT/%{openssl_modulesdir}/nss_prov.la
%endif
%if %{?enable_engine}
rm $RPM_BUILD_ROOT/%{openssl_enginesdir}/*e_nss.la
%endif
%if !%{use_docdir}
%if 0%{?rhel_version} > 0
mv $RPM_BUILD_ROOT/%{_docdir}/%{name} $RPM_BUILD_ROOT/%{_docdir}/%{name}-%{version}
%endif
%endif
%clean
rm -rf $RPM_BUILD_ROOT
%pre
%post
%files
%defattr(-,root,root)
%doc AUTHORS Copyright INSTALL README.adoc
%doc NOTES-provider.adoc
%if %{?enable_module}
%dir %{openssl_modulesdir}
%attr(0755,root,root) %{openssl_modulesdir}/nss_prov.so
%endif
%if %{?enable_engine}
%dir %{openssl_enginesdir}
%attr(0755,root,root) %{openssl_enginesdir}/*e_nss.so
%endif