#!/bin/sh # $Id$ # Copyright 2005-2012 Eric Hameleers, Eindhoven, NL # All rights reserved. # # 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. # ----------------------------------------------------------------------------- # # Slackware SlackBuild script # =========================== # By: Eric Hameleers # For: truecrypt # Descr: On-the-fly disk encryption # URL: http://truecrypt.org # Needs: # Changelog: # 4.0-1: 02/Nov/2005 by Eric Hameleers # * Initial build. # 4.2-1: 18/apr/2006 by Eric Hameleers # * This release makes the Linux build independent of MS Windows. # (so far, crypted containers could only be created in Windows). # 4.2a-1: 03/oct/2006 by Eric Hameleers # * Bugfix update. Reworked the SlackBuild too. # 4.2a-2: 14/jan/2007 by Eric Hameleers # * Fix compilation under kernels 2.6.18 and 2.6.19. # 4.3-1: 15/apr/2007 by Eric Hameleers # * Update. # 4.3a-1: 26/may/2007 by Eric Hameleers # * Update. This fixes a security issue with seteuid. # 4.3a-2: 26/may/2007 by Eric Hameleers # * Device-mapper is part of a Slackware 12 install, so don't # list it as a dependency. # 4.3a-3: 13/oct/2007 by Eric Hameleers # * Add patch to support kernel >= 2.6.23 # 5.1a-1: 04/Jul/2008 by Eric Hameleers # * New release requires wxWindows for the GUI, no longer is # kernel version dependant (by using fuse). # 6.0a-1: 10/Jul/2008 by Eric Hameleers # * New release # 6.2a-1: 06/sep/2009 by Eric Hameleers # * New release # 6.3-1: 27/oct/2009 by Eric Hameleers # * New release. Since we do not ship nautilus, use xdg-open. # 6.3-2: 27/oct/2009 by Eric Hameleers # * Updated the "open container directory" patch to get rid of # a (harmless) error message. # 6.3a-1: 04/apr/2010 by Eric Hameleers # * New release. # 6.3a-2: 31/may/2010 by Eric Hameleers # * Rebuilt for Slackware 13.1. # 7.0-1: 21/jul/2010 by Eric Hameleers # * Update to 7.0. # 7.0a-1: 15/may/2011 by Eric Hameleers # * Update to 7.0a. # 7.1-1: 19/sep/2011 by Eric Hameleers # * Update to 7.1. # 7.1a-1: 09/feb/2012 by Eric Hameleers # * Update to 7.1a. # 7.1a-2: 31/mar/2012 by Eric Hameleers # * I had forgotten to update the two patches for umount and diropen. # # Run 'sh truecrypt.SlackBuild' to build a Slackware package. # The package (.tgz) plus descriptive .txt file are created in /tmp . # Install using 'installpkg'. # # ----------------------------------------------------------------------------- # Set initial variables: PRGNAM=truecrypt VERSION=${VERSION:-7.1a} BUILD=${BUILD:-2} TAG=${TAG:-alien} WX=${WX:-2.8.12} # for the GUI # Where do we look for sources? SRCDIR=$(cd $(dirname $0); pwd) # Place to build (TMP) package (PKG) and output (OUTPUT) the program: TMP=${TMP:-/tmp/build} PKG=$TMP/package-$PRGNAM OUTPUT=${OUTPUT:-/tmp} # If you want automatic download to work, supply a URL for 'SRCURL' below: SOURCE[0]="$SRCDIR/${PRGNAM}-${VERSION}-source.tar.gz" SRCURL[0]="" SOURCE[1]="$SRCDIR/wxGTK-${WX}.tar.bz2" SRCURL[1]="http://downloads.sourceforge.net/wxwindows/wxGTK-${WX}.tar.bz2" SOURCE[2]="$SRCDIR/pks-11-v2-20.tar.bz2" SRCURL[2]="" # Use the src_checkout() function if no downloadable tarball exists. # This function checks out sources from SVN/CVS and creates a tarball of them. src_checkout() { # Param #1 : index in the SOURCE[] array. # Param #2 : full path to where SOURCE[$1] tarball should be created. # Determine the tarball extension: PEXT=$(echo "${2}" | sed -r -e 's/.*[^.].(tar.xz|tar.gz|tar.bz2|tgz).*/\1/') case "$PEXT" in "tar.xz") TARCOMP="J" ;; "tar.gz") TARCOMP="z" ;; "tgz") TARCOMP="z" ;; "tar.bz2") TARCOMP="j" ;; *) echo "Archive can only have extension 'tar.xz', '.tar.gz' '.tar.bz2' or '.tgz'" ; exit 1 ;; esac case ${1} in 2) # pks-11 mkdir pks-11-v2-20 \ && cd pks-11-v2-20 \ && wget ftp://mirror.switch.ch/mirror/pkcs/pkcs-11/v2-20/*.h \ && chown -R root:root . \ && cd .. \ && tar -${TARCOMP}cf ${2} pks-11-v2-20 rm -rf pks-11-v2-20 ;; *) # Do nothing ;; esac } ## ## --- with a little luck, you won't have to edit below this point --- ## ## # Automatically determine the architecture we're building on: if [ -z "$ARCH" ]; then case "$( uname -m )" in i?86) export ARCH=i486 ;; arm*) export ARCH=arm ;; # Unless $ARCH is already set, use uname -m for all other archs: *) export ARCH=$( uname -m ) ;; esac fi case "$ARCH" in i486) SLKCFLAGS="-O2 -march=i486 -mtune=i686" SLKLDFLAGS=""; LIBDIRSUFFIX="" ;; x86_64) SLKCFLAGS="-O2 -fPIC" SLKLDFLAGS="-L/usr/lib64"; LIBDIRSUFFIX="64" ;; *) SLKCFLAGS="-O2" SLKLDFLAGS=""; LIBDIRSUFFIX="" ;; esac # Exit the script on errors: set -e trap 'echo "$0 FAILED at line ${LINENO}" | tee $OUTPUT/error-${PRGNAM}.log' ERR # Catch unitialized variables: set -u P1=${1:-1} # Save old umask and set to 0022: _UMASK_=$(umask) umask 0022 # Create working directories: mkdir -p $OUTPUT # place for the package to be saved mkdir -p $TMP/tmp-$PRGNAM # location to build the source mkdir -p $PKG # place for the package to be built rm -rf $PKG/* # always erase old package's contents rm -rf $TMP/tmp-$PRGNAM/* # remove the remnants of previous build # Source file availability: for (( i = 0; i < ${#SOURCE[*]}; i++ )) ; do if ! [ -f ${SOURCE[$i]} ]; then echo "Source '$(basename ${SOURCE[$i]})' not available yet..." # Check if the $SRCDIR is writable at all - if not, download to $OUTPUT [ -w "$SRCDIR" ] || SOURCE[$i]="$OUTPUT/$(basename ${SOURCE[$i]})" if ! [ "x${SRCURL[$i]}" == "x" ]; then echo "Will download file to $(dirname $SOURCE[$i])" if ! $(wget -nv -T 20 -O "${SOURCE[$i]}" "${SRCURL[$i]}"); then echo "Downloading '$(basename ${SOURCE[$i]})' failed.. aborting the build." mv -f "${SOURCE[$i]}" "${SOURCE[$i]}".FAIL exit 1 fi else # Try if we have a SVN/CVS download routine for ${SOURCE[$i]} echo "Will checkout sources to $(dirname $SOURCE[$i])" src_checkout $i "${SOURCE[$i]}" 2>&1 > $OUTPUT/checkout-$(basename ${SOURCE[$i]}).log fi if [ ! -f "${SOURCE[$i]}" -o ! -s "${SOURCE[$i]}" ]; then echo "File '$(basename ${SOURCE[$i]})' not available.. aborting the build." exit 1 fi fi done if [ "$P1" == "--download" ]; then echo "Download complete." exit 0 fi # --- PACKAGE BUILDING --- echo "++" echo "|| $PRGNAM-$VERSION" echo "++" cd $TMP/tmp-$PRGNAM echo "Extracting the source archive(s) for $PRGNAM..." for (( i = 0; i < ${#SOURCE[*]}; i++ )) ; do tar -xvf ${SOURCE[$i]} done chown -R root:root . chmod -R u+w,go+r-w,a+X-s . cd ${PRGNAM}-${VERSION}-source # Add required rsa header files: cp -a ../pks-11-v2-20/*.h Crypto/ # Fix loopmounted volume dismount failure: cat $SRCDIR/${PRGNAM}-${VERSION}_umount.patch | patch -p1 --verbose \ 2>&1 | tee $OUTPUT/patch-${PRGNAM}.log # Use xdg-open instead of nautilus to open a mounted TC container: cat $SRCDIR/${PRGNAM}-${VERSION}_diropen.patch | patch -p1 --verbose \ 2>&1 | tee -a $OUTPUT/patch-${PRGNAM}.log echo Building ... export LDFLAGS="$SLKLDFLAGS" export CXXFLAGS="$SLKCFLAGS" export CFLAGS="$SLKCFLAGS" # First build a static wxGTK, then build truecrypt: make WX_ROOT=$(cd ../wxGTK-$WX; pwd) VERBOSE=1 wxbuild 2>&1 | tee $OUTPUT/make-${PRGNAM}.log make WXSTATIC=1 VERBOSE=1 2>&1 | tee -a $OUTPUT/make-${PRGNAM}.log # Install the binary: mkdir -p $PKG/usr/bin cp Main/truecrypt $PKG/usr/bin # Add a desktop entry: mkdir -p $PKG/usr/share/{applications,pixmaps} cp $SRCDIR/truecrypt.png $PKG/usr/share/pixmaps/ cat <<-EOT > $PKG/usr/share/applications/truecrypt.desktop [Desktop Entry] Name=Truecrypt GenericName=Disk encryption software Comment=Disk encryption software Exec=truecrypt Icon=/usr/share/pixmaps/truecrypt.png Terminal=0 Type=Application Encoding=UTF-8 Categories=System;Application; EOT # Add this to the doinst.sh: ! [ -d $PKG/install ] && mkdir -p $PKG/install cat <> $PKG/install/doinst.sh # Update the desktop database: if [ -x usr/bin/update-desktop-database ]; then chroot . /usr/bin/update-desktop-database usr/share/applications > /dev/null 2>&1 fi EOT # Add documentation: mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION cp -a Readme.txt License.txt Release/Setup\ Files/*.pdf $PKG/usr/doc/$PRGNAM-$VERSION || true cat $SRCDIR/$(basename $0) > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild chown -R root:root $PKG/usr/doc/$PRGNAM-$VERSION find $PKG/usr/doc -type f -exec chmod 644 {} \; # Add a package description: mkdir -p $PKG/install cat $SRCDIR/slack-desc > $PKG/install/slack-desc # Build the package: cd $PKG makepkg --linkadd y --chown n $OUTPUT/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}${TAG}.tgz 2>&1 | tee $OUTPUT/makepkg-${PRGNAM}.log cd $OUTPUT md5sum ${PRGNAM}-${VERSION}-${ARCH}-${BUILD}${TAG}.tgz > ${PRGNAM}-${VERSION}-${ARCH}-${BUILD}${TAG}.tgz.md5 cd - cat $PKG/install/slack-desc | grep "^${PRGNAM}" > $OUTPUT/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}${TAG}.txt # Restore the original umask: umask ${_UMASK_}