1 ###############################################################################
2 # IPFire.org - An Open Source Firewall Solution #
3 # Copyright (C) - IPFire Development Team <info@ipfire.org> #
4 ###############################################################################
10 maintainer = Michael Tremer <michael.tremer@ipfire.org>
11 groups = System/Libraries
12 url = http://www.openssl.org/
14 summary = A general purpose cryptography library with TLS implementation.
17 The OpenSSL toolkit provides support for secure communications between
18 machines. OpenSSL includes a certificate management tool and shared
19 libraries which provide various cryptographic algorithms and protocols.
22 source_dl = http://openssl.org/source/
34 export RPM_OPT_FLAGS = %{CFLAGS}
37 find crypto/ -name Makefile -exec \
38 sed 's/^ASFLAGS=/&-Wa,--noexecstack /' -i {} \;
40 # Modify the various perl scripts to reference perl in the right location.
41 perl util/perlpath.pl /usr/bin
43 # Generate a table with the compile settings for my perusal.
45 make TABLE PERL=/usr/bin/perl
48 # Set default ssl_arch.
49 ssl_arch = linux-%{DISTRO_ARCH}
51 if "%{DISTRO_ARCH}" == "i686"
53 ssl_arch = linux-elf no-asm 386
56 if "%{DISTRO_ARCH}" == "armv5tel"
57 ssl_arch = linux-generic32
60 if "%{DISTRO_ARCH}" == "armv7hl"
61 ssl_arch = linux-generic32
67 --openssldir=/etc/pki/tls \
68 --enginesdir=%{libdir}/openssl/engines \
79 no-ec no-ec2m no-ecdh no-ecdsa \
89 # Generate hashes for the included certs.
94 # Revert ca-dir patch. Otherwise the tests will fail.
95 patch -Np1 -R < %{DIR_PATCHES}/openssl-1.0.0-beta4-ca-dir.patch
101 make install build-shared INSTALL_PREFIX=%{BUILDROOT}
103 # Install manpages do right place
104 mkdir -pv %{BUILDROOT}/usr/share
105 mv -v %{BUILDROOT}/etc/pki/tls/man %{BUILDROOT}/usr/share/
107 mkdir -pv %{BUILDROOT}%{libdir}/openssl
108 mv -v %{BUILDROOT}%{libdir}/engines %{BUILDROOT}%{libdir}/openssl
110 mkdir -pv %{BUILDROOT}/etc/pki/CA/private
111 chmod -v 700 -R %{BUILDROOT}/etc/pki/CA
113 mkdir -pv %{BUILDROOT}/etc/pki/tls
114 install -m 0644 %{DIR_SOURCE}/openssl.cnf %{BUILDROOT}/etc/pki/tls
115 cp -v -r certs %{BUILDROOT}/etc/pki/tls
117 # Rename man pages so that they don't conflict with other system man pages.
118 pushd %{BUILDROOT}%{mandir}
119 for manpage in man*/*; do
120 if [ -L ${manpage} ]; then
121 TARGET=`ls -l ${manpage} | awk '{ print $NF }'`
122 ln -snf ${TARGET}ssl ${manpage}ssl
125 mv ${manpage} ${manpage}ssl
138 requires += ca-certificates
140 files += %{libdir}/openssl
143 package %{name}-devel
147 package %{name}-debuginfo