%bcond_without lib %define major 3 %define libname %mklibname %{name} %{major} %define libfreebl %mklibname freebl %{major} %define develname %mklibname -d %{name} %define sdevelname %mklibname -d -s %{name} %define cvsver 3_16_5 %define nspr_libname %mklibname nspr 4 %define nspr_version 4.10.0 # this seems fragile, so require the exact version or later (#58754) %define sqlite3_version %(pkg-config --modversion sqlite3 &>/dev/null && pkg-config --modversion sqlite3 2>/dev/null || echo 0) %define nspr_version %(pkg-config --modversion nspr &>/dev/null && pkg-config --modversion nspr 2>/dev/null || echo 0) %define build_empty 0 %{?_with_empty: %{expand: %%global build_empty 1}} %{?_without_empty: %{expand: %%global build_empty 0}} Name: nss Epoch: 2 Version: 3.16.5 Release: 1 Summary: Netscape Security Services Group: System/Libraries License: MPL or GPLv2+ or LGPLv2+ URL: http://www.mozilla.org/projects/security/pki/nss/index.html Source0: ftp://ftp.mozilla.org/pub/mozilla.org/security/nss/releases/NSS_%{cvsver}_RTM/src/nss-%{version}.tar.gz Source1: nss.pc.in Source2: nss-config.in Source3: blank-cert8.db Source4: blank-key3.db Source5: blank-secmod.db Source6: certdata_empty.txt # https://www.verisign.com/support/verisign-intermediate-ca/secure-site-intermediate/index.html # converted from PEM to DER format with openssl command: # openssl x509 -in cert.pem -inform PEM -outform DER -out cert.der # this way we can avoid a buildrequires for openssl Source7: verisign-class-3-secure-server-ca.der # Brasilian government certificate # verified in person with a government official Source8: http://www.icpbrasil.gov.br/certificadoACRaiz.crt Patch0: nss-no-rpath.patch Patch1: nss-fixrandom.patch Patch4: renegotiate-transitional.patch Patch5: nss-3.15.1.prtypes.patch BuildRequires: rootcerts >= 1:20120218.00 BuildRequires: nspr-devel >= 2:4.9.0 BuildRequires: zlib-devel BuildRequires: sqlite3-devel >= 3.7.7.1 BuildRequires: zip %description Network Security Services (NSS) is a set of libraries designed to support cross-platform development of security-enabled client and server applications. Applications built with NSS can support SSL v2 and v3, TLS, PKCS #5, PKCS #7, PKCS #11, PKCS #12, S/MIME, X.509 v3 certificates, and other security standards. For detailed information on standards supported, see http://www.mozilla.org/projects/security/pki/nss/overview.html. %if %without lib Note: This package currently contains the NSS binaries only. The libraries have been not been included due to conflicts with the Mozilla libraries. %endif %package shlibsign Summary: Netscape Security Services - shlibsign Group: System/Libraries Conflicts: %{name} < 2:3.13.1-2 %description shlibsign This package contains the binary shlibsign needed by libfreebl3 and libsoftokn3. %if %with lib %package -n %{libname} Summary: Network Security Services (NSS) Group: System/Libraries %description -n %{libname} This package contains the shared libraries libnss3, libnssckbi, libnssdbm3, libnssutil3, libsmime3, and libssl3. %package -n %{libfreebl} Summary: Network Security Services (NSS) Group: System/Libraries Requires(post): nss-shlibsign Requires(post): rpm-helper Conflicts: %{_lib}nss3 < 2:3.13.1-5 %description -n %{libfreebl} This package contains the shared libraries libfreebl3 and libsoftokn3. %package -n %{develname} Summary: Network Security Services (NSS) - development files Group: Development/C++ Requires: %{libname} >= %{epoch}:%{version}-%{release} Requires: %{libfreebl} >= %{epoch}:%{version}-%{release} Provides: nss-devel = %{epoch}:%{version}-%{release} %rename %{libname}-devel %description -n %{develname} Header files to doing development with Network Security Services. %package -n %{sdevelname} Summary: Network Security Services (NSS) - static libraries Group: Development/C++ Requires: %{libname} >= %{epoch}:%{version}-%{release} Requires: %{develname} >= %{epoch}:%{version}-%{release} Provides: nss-static-devel = %{epoch}:%{version}-%{release} Conflicts: libopenssl-static-devel %rename %{libname}-static-devel %description -n %{sdevelname} Static libraries for doing development with Network Security Services. %endif %prep %setup -q %patch0 -p0 -b .no-rpath %patch1 -p0 %patch4 -p0 -b .transitional %patch5 -p1 find . -type d -perm 0700 -exec chmod 755 {} \; find . -type f -perm 0555 -exec chmod 755 {} \; find . -type f -perm 0444 -exec chmod 644 {} \; find . -name '*.h' -executable -exec chmod -x {} \; find . -name '*.c' -executable -exec chmod -x {} \; %build %setup_compile_flags export BUILD_OPT=1 export OPTIMIZER="%{optflags}" export XCFLAGS="%{optflags}" export ARCHFLAG="$LDFLAGS" export LIBDIR=%{_libdir} export USE_SYSTEM_ZLIB=1 export ZLIB_LIBS="-lz" export PKG_CONFIG_ALLOW_SYSTEM_LIBS=1 export PKG_CONFIG_ALLOW_SYSTEM_CFLAGS=1 export NSPR_INCLUDE_DIR=`%{_bindir}/pkg-config --cflags-only-I nspr | sed 's/-I//'` export NSPR_LIB_DIR=`%{_bindir}/pkg-config --libs-only-L nspr | sed 's/-L//'` export MOZILLA_CLIENT=1 export NS_USE_GCC=1 export NSS_USE_SYSTEM_SQLITE=1 export NSS_ENABLE_ECC=1 %ifarch x86_64 ppc64 ia64 s390x export USE_64=1 %endif %if %{build_empty} # (oe) the "trust no one" scenario, it goes like: # 1. mv /% {_lib}/libnssckbi.so /% {_lib}/libnssckbi.so.BAK # 2. mv /% {_lib}/libnssckbi_empty.so /% {_lib}/libnssckbi.so # 3. restart ff/tb # it has to be done manually for now, but at least we have a way for # users to quickly mitigate future problems, or whatever :-) pushd mozilla/security/nss/lib/ckfw/builtins %{__perl} ./certdata.perl < %{SOURCE6} popd %endif # Parallel is broken as of 3.11.4 :( %make -j1 -C ./nss/coreconf %make -j1 -C ./nss/lib/dbm %make -j1 -C ./nss %if %{build_empty} # tuck away the empty libnssckbi.so library cp -p mozilla/security/nss/lib/ckfw/builtins/Linux*/libnssckbi.so libnssckbi_empty.so %endif # install new Verisign intermediate certificate # http://qa.mandriva.com/show_bug.cgi?id=29612 # use built addbuildin command to avoid having # a buildrequires for nss ADDBUILTIN=`%{_bindir}/find . -type f -name addbuiltin` if [ -z "$ADDBUILTIN" ]; then exit 1 fi ADDBUILTIN="$PWD/$ADDBUILTIN" OLD="$LD_LIBRARY_PATH" libpath=`%{_bindir}/find ./dist/ -name "Linux*" -type d` # to use the built libraries instead of requiring nss # again as buildrequires export LD_LIBRARY_PATH="$PWD/$libpath/lib" pushd nss/lib/ckfw/builtins # (oe) for reference: # *ALL* of the root CA certs are hard coded into the libnssckbi.so library. # So, for Mandriva we can add/remove certs easily in the rootcerts package. Please # checkout and examine the rootcerts package. # Once this has been done and the new rootcerts package has been installed this # package (nss) has to be rebuilt to pickup the changes made. The "recreate # certificates" lines below generates a new certdata.c source containing the root # CA certs for mozilla. # *ALL* of the mozilla based softwares that support SSL has to link against # the NSS library. # recreate certificates %{__perl} ./certdata.perl < /etc/pki/tls/mozilla/certdata.txt %make clean %make -j1 popd export LD_LIBRARY_PATH="$OLD" %install pushd dist/$(uname -s)* %{__mkdir_p} %{buildroot}%{_bindir} %{__cp} -aL bin/* %{buildroot}%{_bindir} %if %with lib %{__mkdir_p} %{buildroot}%{_libdir} %{__mkdir_p} %{buildroot}/%{_lib} %{__mkdir_p} %{buildroot}%{_includedir}/nss %{__cp} -aL ../public/nss/* %{buildroot}%{_includedir}/nss %{__cp} -aL lib/libcrmf.a \ lib/libnss.a \ lib/libnssb.a \ lib/libnssckbi.so \ lib/libnssckfw.a \ lib/libnssutil.a \ lib/libsmime.a \ lib/libssl.a \ %{buildroot}%{_libdir} # Copy the binary libraries we want for file in libsoftokn3.so libfreebl3.so libnss3.so libnssutil3.so \ libssl3.so libsmime3.so libnssckbi.so libnssdbm3.so do %{__install} -m 755 lib/$file %{buildroot}/%{_lib} ln -sf ../../%{_lib}/$file %{buildroot}%{_libdir}/$file done # These ghost files will be generated in the post step # Make sure chk files can be found in both places for file in libsoftokn3.chk libfreebl3.chk do touch %{buildroot}/%{_lib}/$file ln -s ../../%{_lib}/$file %{buildroot}%{_libdir}/$file done %{__mkdir_p} %{buildroot}%{_libdir}/pkgconfig cat %{SOURCE1} | sed -e "s,%%libdir%%,%{_libdir},g" \ -e "s,%%prefix%%,%{_prefix},g" \ -e "s,%%exec_prefix%%,%{_prefix},g" \ -e "s,%%includedir%%,%{_includedir}/nss,g" \ -e "s,%%NSPR_VERSION%%,%{nspr_version},g" \ -e "s,%%NSS_VERSION%%,%{version},g" > \ %{buildroot}%{_libdir}/pkgconfig/nss.pc %endif popd %if %with lib export NSS_VMAJOR=`%{__cat} nss/lib/nss/nss.h | %{__grep} "#define.*NSS_VMAJOR" | %{__awk} '{print $3}'` export NSS_VMINOR=`%{__cat} nss/lib/nss/nss.h | %{__grep} "#define.*NSS_VMINOR" | %{__awk} '{print $3}'` export NSS_VPATCH=`echo %{version} | sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\3/'` %{__mkdir_p} %{buildroot}%{_bindir} cat %{SOURCE2} | sed -e "s,@libdir@,%{_libdir},g" \ -e "s,@prefix@,%{_prefix},g" \ -e "s,@exec_prefix@,%{_prefix},g" \ -e "s,@includedir@,%{_includedir}/nss%{major},g" \ -e "s,@MOD_MAJOR_VERSION@,$NSS_VMAJOR,g" \ -e "s,@MOD_MINOR_VERSION@,$NSS_VMINOR,g" \ -e "s,@MOD_PATCH_VERSION@,$NSS_VPATCH,g" \ > %{buildroot}/%{_bindir}/nss-config %endif pushd nss/cmd/smimetools %{__install} -m 0755 smime %{buildroot}%{_bindir} %{__perl} -pi -e 's|/usr/local/bin|%{_bindir}|g' %{buildroot}%{_bindir}/smime popd # add docs %{__mkdir_p} docs/SSLsample %{__mkdir_p} docs/bltest cp -a nss/cmd/bltest/tests/* docs/bltest/ chmod -R a+r docs %{__mkdir_p} docs/certcgi %{__cp} -a nss/cmd/certcgi/*.html docs/certcgi/ %{__cp} -a nss/cmd/certcgi/HOWTO.txt docs/certcgi/ %{__mkdir_p} docs/modutil %{__cp} -a nss/cmd/modutil/*.html docs/modutil/ %{__mkdir_p} docs/signtool %{__cp} -a nss/cmd/signtool/README docs/signtool/ %{__mkdir_p} docs/signver %{__cp} -a nss/cmd/signver/examples/1/*.pl docs/signver/ %{__cp} -a nss/cmd/signver/examples/1/*.html docs/signver/ %{__mkdir_p} docs/ssltap %{__cp} -a nss/cmd/ssltap/*.html docs/ssltap/ # Install the empty NSS db files %{__mkdir_p} %{buildroot}%{_sysconfdir}/pki/nssdb %{__install} -m 644 %{SOURCE3} %{buildroot}%{_sysconfdir}/pki/nssdb/cert8.db %{__install} -m 644 %{SOURCE4} %{buildroot}%{_sysconfdir}/pki/nssdb/key3.db %{__install} -m 644 %{SOURCE5} %{buildroot}%{_sysconfdir}/pki/nssdb/secmod.db %{_bindir}/find docs -type f | %{_bindir}/xargs -t %{__perl} -pi -e 's/\r$//g' %if %{build_empty} # install the empty libnssckbi.so library (use alternatives?) install -m0755 libnssckbi_empty.so %{buildroot}/%{_lib}/libnssckbi_empty.so %endif %multiarch_binaries %{buildroot}%{_bindir}/nss-config %if %with lib %posttrans -n %{libfreebl} %create_ghostfile /%{_lib}/libsoftokn%{major}.chk root root 644 %create_ghostfile /%{_lib}/libfreebl%{major}.chk root root 644 %{_bindir}/shlibsign -i /%{_lib}/libsoftokn%{major}.so >/dev/null 2>/dev/null %{_bindir}/shlibsign -i /%{_lib}/libfreebl%{major}.so >/dev/null 2>/dev/null %endif %files %doc docs/* %attr(0755,root,root) %{_bindir}/addbuiltin %attr(0755,root,root) %{_bindir}/atob %attr(0755,root,root) %{_bindir}/baddbdir %attr(0755,root,root) %{_bindir}/bltest %attr(0755,root,root) %{_bindir}/btoa %attr(0755,root,root) %{_bindir}/certcgi %attr(0755,root,root) %{_bindir}/certutil %attr(0755,root,root) %{_bindir}/checkcert %attr(0755,root,root) %{_bindir}/chktest %attr(0755,root,root) %{_bindir}/cmsutil %attr(0755,root,root) %{_bindir}/conflict %attr(0755,root,root) %{_bindir}/crlutil %attr(0755,root,root) %{_bindir}/crmftest %attr(0755,root,root) %{_bindir}/dbtest %attr(0755,root,root) %{_bindir}/derdump %attr(0755,root,root) %{_bindir}/dertimetest %attr(0755,root,root) %{_bindir}/digest %attr(0755,root,root) %{_bindir}/encodeinttest %attr(0755,root,root) %{_bindir}/fipstest %attr(0755,root,root) %{_bindir}/httpserv %attr(0755,root,root) %{_bindir}/listsuites %attr(0755,root,root) %{_bindir}/lowhashtest %attr(0755,root,root) %{_bindir}/makepqg %attr(0755,root,root) %{_bindir}/mangle %attr(0755,root,root) %{_bindir}/modutil %attr(0755,root,root) %{_bindir}/multinit %attr(0755,root,root) %{_bindir}/nonspr10 %attr(0755,root,root) %{_bindir}/ocspclnt %attr(0755,root,root) %{_bindir}/ocspresp %attr(0755,root,root) %{_bindir}/oidcalc %attr(0755,root,root) %{_bindir}/p7content %attr(0755,root,root) %{_bindir}/p7env %attr(0755,root,root) %{_bindir}/p7sign %attr(0755,root,root) %{_bindir}/p7verify %attr(0755,root,root) %{_bindir}/pk11gcmtest %attr(0755,root,root) %{_bindir}/pk11mode %attr(0755,root,root) %{_bindir}/pk12util %attr(0755,root,root) %{_bindir}/pk1sign %attr(0755,root,root) %{_bindir}/pkix-errcodes %attr(0755,root,root) %{_bindir}/pp %attr(0755,root,root) %{_bindir}/pwdecrypt %attr(0755,root,root) %{_bindir}/remtest %attr(0755,root,root) %{_bindir}/rsaperf %attr(0755,root,root) %{_bindir}/sdrtest %attr(0755,root,root) %{_bindir}/secmodtest %attr(0755,root,root) %{_bindir}/selfserv %attr(0755,root,root) %{_bindir}/signtool %attr(0755,root,root) %{_bindir}/signver %attr(0755,root,root) %{_bindir}/smime %attr(0755,root,root) %{_bindir}/ssltap %attr(0755,root,root) %{_bindir}/strsclnt %attr(0755,root,root) %{_bindir}/symkeyutil %attr(0755,root,root) %{_bindir}/tstclnt %attr(0755,root,root) %{_bindir}/vfychain %attr(0755,root,root) %{_bindir}/vfyserv %dir %{_sysconfdir}/pki/nssdb %config(noreplace) %{_sysconfdir}/pki/nssdb/cert8.db %config(noreplace) %{_sysconfdir}/pki/nssdb/key3.db %config(noreplace) %{_sysconfdir}/pki/nssdb/secmod.db %files shlibsign %attr(0755,root,root) %{_bindir}/shlibsign %if %with lib %files -n %{libfreebl} /%{_lib}/libfreebl%{major}.so /%{_lib}/libsoftokn%{major}.so %defattr(0644,root,root,0755) %ghost /%{_lib}/libfreebl%{major}.chk %ghost /%{_lib}/libsoftokn%{major}.chk %files -n %{libname} /%{_lib}/libnss%{major}.so /%{_lib}/libnssckbi.so %if %{build_empty} /%{_lib}/libnssckbi_empty.so %endif /%{_lib}/libnssutil%{major}.so /%{_lib}/libnssdbm%{major}.so /%{_lib}/libsmime%{major}.so /%{_lib}/libssl%{major}.so %files -n %{develname} %defattr(0644,root,root,0755) %attr(0755,root,root) %{_bindir}/nss-config %attr(0755,root,root) %{multiarch_bindir}/nss-config %_libdir/*.so %dir %{_includedir}/nss %{_includedir}/nss/base64.h %{_includedir}/nss/blapit.h %{_includedir}/nss/certdb.h %{_includedir}/nss/cert.h %{_includedir}/nss/certt.h %{_includedir}/nss/ciferfam.h %{_includedir}/nss/cmmf.h %{_includedir}/nss/cmmft.h %{_includedir}/nss/cms.h %{_includedir}/nss/cmsreclist.h %{_includedir}/nss/cmst.h %{_includedir}/nss/crmf.h %{_includedir}/nss/crmft.h %{_includedir}/nss/cryptohi.h %{_includedir}/nss/cryptoht.h %{_includedir}/nss/ecl-exp.h %{_includedir}/nss/hasht.h %{_includedir}/nss/jar-ds.h %{_includedir}/nss/jarfile.h %{_includedir}/nss/jar.h %{_includedir}/nss/key.h %{_includedir}/nss/keyhi.h %{_includedir}/nss/keyt.h %{_includedir}/nss/keythi.h %{_includedir}/nss/nssb64.h %{_includedir}/nss/nssb64t.h %{_includedir}/nss/nssbase.h %{_includedir}/nss/nssbaset.h %{_includedir}/nss/nssck.api %{_includedir}/nss/nssckbi.h %{_includedir}/nss/nssckepv.h %{_includedir}/nss/nssckft.h %{_includedir}/nss/nssckfwc.h %{_includedir}/nss/nssckfw.h %{_includedir}/nss/nssckfwt.h %{_includedir}/nss/nssckg.h %{_includedir}/nss/nssckmdt.h %{_includedir}/nss/nssckt.h %{_includedir}/nss/nss.h %{_includedir}/nss/nssilckt.h %{_includedir}/nss/nssilock.h %{_includedir}/nss/nsslocks.h %{_includedir}/nss/nsslowhash.h %{_includedir}/nss/nssrwlk.h %{_includedir}/nss/nssrwlkt.h %{_includedir}/nss/nssutil.h %{_includedir}/nss/ocsp.h %{_includedir}/nss/ocspt.h %{_includedir}/nss/p12.h %{_includedir}/nss/p12plcy.h %{_includedir}/nss/p12t.h %{_includedir}/nss/pk11func.h %{_includedir}/nss/pk11pqg.h %{_includedir}/nss/pk11priv.h %{_includedir}/nss/pk11pub.h %{_includedir}/nss/pk11sdr.h %{_includedir}/nss/pkcs11f.h %{_includedir}/nss/pkcs11.h %{_includedir}/nss/pkcs11n.h %{_includedir}/nss/pkcs11p.h %{_includedir}/nss/pkcs11t.h %{_includedir}/nss/pkcs11u.h %{_includedir}/nss/pkcs12.h %{_includedir}/nss/pkcs12t.h %{_includedir}/nss/pkcs7t.h %{_includedir}/nss/portreg.h %{_includedir}/nss/preenc.h %{_includedir}/nss/secasn1.h %{_includedir}/nss/secasn1t.h %{_includedir}/nss/seccomon.h %{_includedir}/nss/secder.h %{_includedir}/nss/secdert.h %{_includedir}/nss/secdig.h %{_includedir}/nss/secdigt.h %{_includedir}/nss/secerr.h %{_includedir}/nss/sechash.h %{_includedir}/nss/secitem.h %{_includedir}/nss/secmime.h %{_includedir}/nss/secmod.h %{_includedir}/nss/secmodt.h %{_includedir}/nss/secoid.h %{_includedir}/nss/secoidt.h %{_includedir}/nss/secpkcs5.h %{_includedir}/nss/secpkcs7.h %{_includedir}/nss/secport.h %{_includedir}/nss/shsign.h %{_includedir}/nss/smime.h %{_includedir}/nss/sslerr.h %{_includedir}/nss/ssl.h %{_includedir}/nss/sslproto.h %{_includedir}/nss/sslt.h %{_includedir}/nss/utilmodt.h %{_includedir}/nss/utilpars.h %{_includedir}/nss/utilparst.h %{_includedir}/nss/utilrename.h %{_libdir}/pkgconfig/nss.pc %{_libdir}/libsoftokn%{major}.chk %{_libdir}/libfreebl%{major}.chk %files -n %{sdevelname} %defattr(0644,root,root,0755) %{_libdir}/libcrmf.a %{_libdir}/libnss.a %{_libdir}/libnssutil.a %{_libdir}/libnssb.a %{_libdir}/libnssckfw.a %{_libdir}/libsmime.a %{_libdir}/libssl.a %endif