You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
216 lines
7.7 KiB
216 lines
7.7 KiB
## |
|
## pks.spec -- OpenPKG RPM Package Specification |
|
## Copyright (c) 2000-2022 OpenPKG Project <http://openpkg.org/> |
|
## |
|
## Permission to use, copy, modify, and distribute this software for |
|
## any purpose with or without fee is hereby granted, provided that |
|
## the above copyright notice and this permission notice appear in all |
|
## copies. |
|
## |
|
## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED |
|
## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
|
## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. |
|
## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR |
|
## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF |
|
## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
|
## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
|
## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT |
|
## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
|
## SUCH DAMAGE. |
|
## |
|
|
|
# package information |
|
Name: pks |
|
Summary: OpenPGP Key Server |
|
URL: http://pks.sourceforge.net/ |
|
Vendor: Marc Horowitz et al. |
|
Packager: OpenPKG Project |
|
Distribution: OpenPKG Community |
|
Class: PLUS |
|
Group: PGP |
|
License: GPL |
|
Version: 0.9.6 |
|
Release: 20080101 |
|
|
|
# package options |
|
%option with_fsl yes |
|
|
|
# list of sources |
|
Source0: http://download.sourceforge.net/pks/pks-%{version}.tar.gz |
|
Source1: fsl.pks |
|
Source2: rc.pks |
|
Source3: pksd.conf |
|
Source4: pks-mail.c |
|
Source5: pks.html |
|
Source6: pks-apache.conf |
|
Patch0: pks.patch |
|
|
|
# build information |
|
BuildPreReq: OpenPKG, openpkg >= 20160101 |
|
PreReq: OpenPKG, openpkg >= 20160101, MTA |
|
%if "%{with_fsl}" == "yes" |
|
BuildPreReq: fsl |
|
PreReq: fsl |
|
%endif |
|
|
|
%description |
|
PKS is an OpenPGP (RFC 2440) compliant Public Key server, originally |
|
developed by Marc Horowitz for http://pgp.mit.edu/. |
|
|
|
%track |
|
prog pks = { |
|
version = %{version} |
|
url = http://sourceforge.net/projects/pks/files/ |
|
regex = pks-(__VER__)\.tar\.gz |
|
} |
|
|
|
%prep |
|
%setup -q |
|
%patch -p0 |
|
|
|
%build |
|
# configure and build programs |
|
echo "ac_cv_path_SENDMAIL=%{l_prefix}/sbin/sendmail" >config.cache |
|
CC="%{l_cc}" \ |
|
CFLAGS="%{l_cflags -O}" \ |
|
CPPFLAGS="%{l_cppflags}" \ |
|
LDFLAGS="%{l_fsl_ldflags}" \ |
|
LIBS="%{l_fsl_ldflags} %{l_fsl_libs}" \ |
|
./configure \ |
|
--cache-file=./config.cache \ |
|
--prefix=%{l_prefix} \ |
|
--sysconfdir=%{l_prefix}/etc/pks \ |
|
--localstatedir=%{l_prefix}/var/pks \ |
|
--datadir=%{l_prefix}/share/pks |
|
%{l_make} %{l_mflags} |
|
|
|
# build suid wrapper for pks-mail |
|
%{l_cc} %{l_cflags} %{l_ldflags} '-DL_PREFIX="%{l_prefix}"' \ |
|
-o pks-mail %{SOURCE pks-mail.c} |
|
|
|
%install |
|
|
|
# install programs |
|
%{l_make} %{l_mflags} install DESTDIR=$RPM_BUILD_ROOT |
|
|
|
# strip installation files and adjust paths |
|
rm -rf $RPM_BUILD_ROOT%{l_prefix}/include/db2 |
|
rm -rf $RPM_BUILD_ROOT%{l_prefix}/lib/db2 |
|
rm -f $RPM_BUILD_ROOT%{l_prefix}/bin/db_* |
|
rm -f $RPM_BUILD_ROOT%{l_prefix}/var/pks/index.html |
|
mv $RPM_BUILD_ROOT%{l_prefix}/bin/pks-queue-run.sh \ |
|
$RPM_BUILD_ROOT%{l_prefix}/bin/pks-queue-run |
|
mv $RPM_BUILD_ROOT%{l_prefix}/var/pks/incoming \ |
|
$RPM_BUILD_ROOT%{l_prefix}/var/pks/queue |
|
strip $RPM_BUILD_ROOT%{l_prefix}/bin/* >/dev/null 2>&1 || true |
|
|
|
# install HTML top-level page |
|
%{l_shtool} mkdir -f -p -m 755 \ |
|
$RPM_BUILD_ROOT%{l_prefix}/pub/pks |
|
%{l_shtool} install -c -m 644 \ |
|
%{SOURCE pks.html} $RPM_BUILD_ROOT%{l_prefix}/pub/pks/index.html |
|
|
|
# install suid wrapper for pks-mail |
|
%{l_shtool} mkdir -f -p -m 755 \ |
|
$RPM_BUILD_ROOT%{l_prefix}/libexec/pks |
|
mv $RPM_BUILD_ROOT%{l_prefix}/bin/pks-mail.sh \ |
|
$RPM_BUILD_ROOT%{l_prefix}/libexec/pks/pks-mail |
|
%{l_shtool} install -c -s -m 755 \ |
|
pks-mail $RPM_BUILD_ROOT%{l_prefix}/bin/ |
|
|
|
# install run-command script |
|
%{l_shtool} mkdir -f -p -m 755 \ |
|
$RPM_BUILD_ROOT%{l_prefix}/etc/rc.d |
|
%{l_shtool} install -c -m 755 %{l_value -s -a} \ |
|
%{SOURCE rc.pks} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/ |
|
|
|
# override default configuration |
|
%{l_shtool} install -c -m 644 %{l_value -s -a} \ |
|
%{SOURCE pksd.conf} $RPM_BUILD_ROOT%{l_prefix}/etc/pks/ |
|
%{l_shtool} install -c -m 644 %{l_value -s -a} \ |
|
%{SOURCE pks-apache.conf} $RPM_BUILD_ROOT%{l_prefix}/etc/pks/ |
|
|
|
# install OSSP fsl configuration |
|
%{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/etc/fsl |
|
%{l_shtool} install -c -m 644 %{l_value -s -a} \ |
|
%{SOURCE fsl.pks} \ |
|
$RPM_BUILD_ROOT%{l_prefix}/etc/fsl/ |
|
|
|
# determine installation files |
|
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \ |
|
%{l_files_std} \ |
|
'%config %{l_prefix}/etc/fsl/fsl.pks' \ |
|
'%config %{l_prefix}/etc/pks/pksd.conf' \ |
|
'%attr(4755,%{l_rusr},%{l_mgrp}) %{l_prefix}/bin/pks-mail' \ |
|
'%dir %attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/pks' \ |
|
'%dir %attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/pks/db' \ |
|
'%dir %attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/pks/queue' |
|
|
|
%files -f files |
|
|
|
%clean |
|
|
|
%pre |
|
# before upgrade, save status and stop service |
|
[ $1 -eq 2 ] || exit 0 |
|
eval `%{l_rc} pks status 2>/dev/null | tee %{l_tmpfile}` |
|
%{l_rc} pks stop 2>/dev/null |
|
exit 0 |
|
|
|
%post |
|
if [ $1 -eq 1 ]; then |
|
# create initial database |
|
su - %{l_rusr} -c "$RPM_INSTALL_PREFIX/bin/pksclient \ |
|
$RPM_INSTALL_PREFIX/var/pks/db create" >/dev/null 2>&1 |
|
for key in $RPM_INSTALL_PREFIX/etc/openpkg/*.pgp; do \ |
|
su - %{l_rusr} -c "$RPM_INSTALL_PREFIX/bin/pksclient \ |
|
$RPM_INSTALL_PREFIX/var/pks/db add $key" >/dev/null 2>&1 |
|
done |
|
|
|
# activate in MTA configuration |
|
aliases_file=`$RPM_INSTALL_PREFIX/bin/openpkg rc --query MTA_aliases_file` |
|
aliases_update=`$RPM_INSTALL_PREFIX/bin/openpkg rc --query MTA_aliases_update` |
|
if [ ".$aliases_file" != . ]; then |
|
( echo "pks: pks-request" |
|
echo "pks-request: \"|$RPM_INSTALL_PREFIX/bin/pks-mail $RPM_INSTALL_PREFIX/etc/pks/pksd.conf\"" |
|
echo "pks-daemon: MAILER-DAEMON" |
|
echo "pks-admin: postmaster" |
|
echo "pgp-public-keys: pks-request" |
|
echo "pgp: pks-request" |
|
) | %{l_rpmtool} config -a -i "$RPM_INSTALL_PREFIX:pks" $aliases_file |
|
fi |
|
if [ ".$aliases_update" != . ]; then |
|
eval $aliases_update |
|
fi |
|
elif [ $1 -eq 2 ]; then |
|
# after upgrade, restore status |
|
eval `cat %{l_tmpfile}`; rm -f %{l_tmpfile} |
|
[ ".$pks_active" = .yes ] && %{l_rc} pks start |
|
fi |
|
exit 0 |
|
|
|
%preun |
|
# before erase, stop service |
|
[ $1 -eq 0 ] || exit 0 |
|
%{l_rc} pks stop 2>/dev/null |
|
|
|
# deactivate in MTA configuration |
|
aliases_file=`$RPM_INSTALL_PREFIX/bin/openpkg rc --query MTA_aliases_file` |
|
aliases_update=`$RPM_INSTALL_PREFIX/bin/openpkg rc --query MTA_aliases_update` |
|
if [ ".$aliases_file" != . ]; then |
|
%{l_rpmtool} config -r -i "$RPM_INSTALL_PREFIX:pks" $aliases_file |
|
fi |
|
if [ ".$aliases_update" != . ]; then |
|
eval $aliases_update |
|
fi |
|
|
|
# remove generated files |
|
rm -f $RPM_INSTALL_PREFIX/var/pks/pksd.ctl >/dev/null 2>&1 || true |
|
rm -f $RPM_INSTALL_PREFIX/var/pks/pks.log* >/dev/null 2>&1 || true |
|
rm -f $RPM_INSTALL_PREFIX/var/pks/pks-queue-run.pid >/dev/null 2>&1 || true |
|
rm -f $RPM_INSTALL_PREFIX/var/pks/queue/* >/dev/null 2>&1 || true |
|
rm -f $RPM_INSTALL_PREFIX/var/pks/db/* >/dev/null 2>&1 || true |
|
exit 0 |
|
|
|
|