##
## lsh.spec -- OpenPKG RPM Specification
## Copyright (c) 2000-2004 The OpenPKG Project
## Copyright (c) 2000-2004 Ralf S. Engelschall
## Copyright (c) 2000-2004 Cable & Wireless
##
## 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: lsh
Summary: GNU Secure Shell (SSH) Implementation
URL: http://www.lysator.liu.se/~nisse/lsh/
Vendor: Niels Möller
Packager: The OpenPKG Project
Distribution: OpenPKG
Class: EVAL
Group: Network
License: GPL
Version: 2.0
Release: 20041209
# list of sources
Source0: ftp://ftp.lysator.liu.se/pub/security/lsh/lsh-%{version}.tar.gz
Source1: rc.lsh
Source2: fsl.lsh
Source3: lsh.cfg
# build information
Prefix: %{l_prefix}
BuildRoot: %{l_buildroot}
BuildPreReq: OpenPKG, openpkg >= 20040130, make, gcc, m4
PreReq: OpenPKG, openpkg >= 20040130
BuildPreReq: gmp, liboop, zlib, readline
PreReq: gmp, liboop, zlib, readline
AutoReq: no
AutoReqProv: no
%description
LSH is GNU's free implementation of the SSH version 2 protocol,
currently being standardised by the IETF SECSH working group.
%track
prog lsh = {
version = %{version}
url = ftp://ftp.lysator.liu.se/pub/security/lsh/
regex = lsh-(__VER__)\.tar\.gz
}
%prep
%setup -q
%build
# configure program
%{l_shtool} subst \
-e 's;/var/run;%{l_prefix}/var/lsh;g' \
-e 's;/var/spool/lsh;%{l_prefix}/var/lsh;g' \
-e 's;/var/spool/lsh;%{l_prefix}/var/lsh;g' \
src/daemon.c src/environ.h src/lsh-make-seed.c src/unix_random.c
CC="%{l_cc}" \
CFLAGS="%{l_cflags -O}" \
CPPFLAGS="%{l_cppflags}" \
LDFLAGS="%{l_ldflags}" \
./configure \
--prefix=%{l_prefix} \
--sysconfdir=%{l_prefix}/etc/lsh \
--enable-tcp-forward \
--enable-x11-forward \
--enable-agent-forward \
--enable-utmp \
--enable-srp \
--disable-gss \
--disable-kerberos \
--disable-pam \
--disable-ipv6 \
--disable-dependency-tracking
# build program
%{l_make} %{l_mflags -O}
%install
rm -rf $RPM_BUILD_ROOT
# install program
%{l_make} %{l_mflags} install AM_MAKEFLAGS="DESTDIR=$RPM_BUILD_ROOT"
# strip down installation
strip $RPM_BUILD_ROOT%{l_prefix}/bin/* >/dev/null 2>&1 || true
rm -f $RPM_BUILD_ROOT%{l_prefix}/bin/nettle*
rm -rf $RPM_BUILD_ROOT%{l_prefix}/include
rm -rf $RPM_BUILD_ROOT%{l_prefix}/lib
rm -f $RPM_BUILD_ROOT%{l_prefix}/info/dir
rm -f $RPM_BUILD_ROOT%{l_prefix}/info/nettle.info
# resolve conflicts with other packages
mv $RPM_BUILD_ROOT%{l_prefix}/sbin/sftp-server \
$RPM_BUILD_ROOT%{l_prefix}/sbin/lsh-sftp-server
mv $RPM_BUILD_ROOT%{l_prefix}/man/man8/sftp-server.8 \
$RPM_BUILD_ROOT%{l_prefix}/man/man8/lsh-sftp-server.8
# install server configuration
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/etc/lsh
%{l_shtool} install -c -m 644 %{l_value -s -a} \
%{SOURCE lsh.cfg} $RPM_BUILD_ROOT%{l_prefix}/etc/lsh/
# 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.lsh} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
# 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.lsh} $RPM_BUILD_ROOT%{l_prefix}/etc/fsl/
# create data directory
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/var/lsh
# determine installation files
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
%{l_files_std} \
'%config %{l_prefix}/etc/lsh/*'
%files -f files
%clean
rm -rf $RPM_BUILD_ROOT
%post
# generate server key
if [ ! -f "$RPM_INSTALL_PREFIX/etc/lsh/lsh.key" -o \
! -s "$RPM_INSTALL_PREFIX/etc/lsh/lsh.key" ]; then
echo "Generating LSH RSA host key:"
$RPM_INSTALL_PREFIX/bin/lsh-make-seed --server --sloppy --quiet || true
$RPM_INSTALL_PREFIX/bin/lsh-keygen --server | \
$RPM_INSTALL_PREFIX/bin/lsh-writekey --server \
-o $RPM_INSTALL_PREFIX/etc/lsh/lsh.key
fi
# after upgrade, restart service
[ $1 -eq 2 ] || exit 0
eval `%{l_rc} lsh status 2>/dev/null`
[ ".$lsh_active" = .yes ] && %{l_rc} lsh restart
exit 0
%preun
# before erase, stop service and remove log files
[ $1 -eq 0 ] || exit 0
%{l_rc} lsh stop 2>/dev/null
rm -f $RPM_INSTALL_PREFIX/var/lsh/*
exit 0