File e_nss-CentOS_6.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) 2015-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%{?centos} > 0 && 0%{?centos_version} == 0
%global centos_version %{centos}00
%endif
# Disable non-working configurations
%if 0%{?centos_version} < 900
%undefine enable_module
%global enable_module 0
%endif
%if 0%{?centos_version} >= 1000
%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
Source0: https://roumenpetrov.info/e_nss/e_nss-%{version}.tar.xz
# Default values for additional components
%define openssl_modulesdir %{_libdir}/ossl-modules
%if 0%{?centos_version} >= 900
%define openssl_enginesdir %{_libdir}/engines-3
%endif
%if 0%{?centos_version} >= 800 && 0%{?centos_version} < 900
%define openssl_enginesdir %{_libdir}/engines-1.1
%endif
%if 0%{?centos_version} < 800
%define openssl_enginesdir %{_libdir}/openssl/engines
%endif
%if 0%{?centos_version} >= 800
%define e_nss_docdir %{_docdir}/%{name}
%else
%define e_nss_docdir %{_docdir}/%{name}-%{version}
%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 \
--docdir=%{e_nss_docdir} \
--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
%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