#!/bin/bash ulimit -s unlimited shopt -s extglob # Copyright 2000 BSDi, Inc. Concord, CA, USA # Copyright 2001, 2002, 2003 Slackware Linux, Inc. Concord, CA, USA # All rights reserved. # # Redistribution and use of this script, with or without modification, is # permitted provided that the following conditions are met: # # 1. Redistributions of this script must retain the above copyright # notice, this list of conditions and the following disclaimer. # # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS 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 AUTHOR 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. # Modified by Stuart Winter for Slackware ARM. # Heavily based on the original Slackware build script. # 02-May-2004 # Record toolchain & other info for the build log: slackbuildinfo # Paths to skeleton port's source & real Slackware source tree: slackset_var_cwds # Temporary build locations: export TMPBUILD=$TMP/build-$PKGNAM export PKG=$TMP/package-$PKGNAM mkpkgdirs # Delete and re-create temporary directories # Extract source: tar xvvf $CWD/$PKGNAM-$VERSION.tar.!(*sign|*asc|*sig) cd $PKGNAM-*/ || exit 1 slackhousekeeping # Apply patches: # # Restore support for tcpwrappers: zcat $CWD/openssh.tcp_wrappers.diff.gz | patch -p1 --verbose || exit 1 # Choose correct options depending on whether PAM is installed: if [ -L /lib${LIBDIRSUFFIX}/libpam.so.? ]; then PAM_OPTIONS="--with-pam --with-kerberos5" unset SHADOW_OPTIONS # Enable PAM in sshd_config: zcat $CWD/sshd_config-pam.diff.gz | patch -p1 --verbose || exit 1 else unset PAM_OPTIONS SHADOW_OPTIONS="--without-pam" fi autoreconf -vif # Configure package: LDFLAGS="-Wl,-z,relro -Wl,--as-needed -Wl,-z,now" \ CFLAGS="$SLKCFLAGS -Wall" \ ./configure \ --prefix=/usr \ --mandir=/usr/man \ --sysconfdir=/etc/ssh \ $PAM_OPTIONS \ $SHADOW_OPTIONS \ --with-md5-passwords \ --with-libedit \ --with-tcp-wrappers \ --with-default-path=/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin \ --with-privsep-path=/var/empty \ --with-privsep-user=sshd \ --with-pid-dir=/var/run \ --build=${SLK_ARCH_BUILD} \ --host=${SLK_ARCH_HOST} || failconfig # --build=${SLK_ARCH_BUILD} || failconfig # Build: make $NUMJOBS || make || failmake # Install the package: make install-nokeys DESTDIR=$PKG # Install directory used with PrivilegeSeparation option: mkdir -pm755 $PKG/var/empty # Install defaults file mkdir -p $PKG/etc/default install -vpm644 $CWD/sshd.default $PKG/etc/default/sshd.new # Install docs: mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION cp -a CREDITS ChangeLog INSTALL LICENCE OVERVIEW README README.privsep \ README.smartcard RFC.nroff TODO WARNING.RNG \ $PKG/usr/doc/openssh-$VERSION changelogliposuction ChangeLog $PKGNAM $VERSION # Fix man page locations: # I have no idea why this is happening. If anybody knows then let me know. # I must confess that I haven't looked for the cause because I have more # pressing things to do at the moment. ( cd $PKG/usr/man mv cat1 man1 mv cat5 man5 mv cat8 man8 ) # Install also 'ssh-copy-id' and its manpage from contrib: ( cd contrib install -m755 ssh-copy-id $PKG/usr/bin install -m644 ssh-copy-id.1 $PKG/usr/man/man1 ) # Enter the package's root: cd $PKG # Set up the config script installation: mv etc/ssh/ssh_config etc/ssh/ssh_config.new mv etc/ssh/sshd_config etc/ssh/sshd_config.new # Add the init script: mkdir -p etc/rc.d install -vpm755 $CWD/rc.sshd etc/rc.d/rc.sshd.new if [ ! -z "$PAM_OPTIONS" ]; then # Add the pam stuff: mkdir -p etc/pam.d install -vpm644 $CWD/sshd.pam etc/pam.d/sshd.new fi # Patch the init script. To generate a DSA SSH key gen takes about 5 minutes # on a RiscPC and new users may think the bootup has hung. #sed -i 's?/usr/bin/ssh-keygen?echo "SSH key generation: This will take a few minutes on older hardware" ; /usr/bin/ssh-keygen?g' etc/rc.d/rc.sshd.new # Set generic Slackware packaging policies: slackgzpages -i # compress man & info pages and delete usr/info/dir slackslack # set all files to root.root, chmod -R og-w, slackchown, slack644docs slackdesc # install slack-desc and doinst.sh slackmp # run makepkg -l y -c n # Perform any final checks on the package: cd $PKG slackhlinks # search for any hard links