2020-08-05 19:00:52 +02:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2021-01-08 04:26:32 +01:00
|
|
|
case $(./config.guess) in
|
|
|
|
*-darwin*)
|
2021-01-12 09:22:47 +01:00
|
|
|
brew install automake
|
2021-01-08 04:26:32 +01:00
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2020-08-05 19:00:52 +02:00
|
|
|
TARGETS=$@
|
|
|
|
|
|
|
|
PACKAGES=""
|
|
|
|
INSTALL_FIDO_PPA="no"
|
|
|
|
|
|
|
|
#echo "Setting up for '$TARGETS'"
|
|
|
|
|
|
|
|
set -ex
|
|
|
|
|
|
|
|
lsb_release -a
|
|
|
|
|
2021-02-17 08:41:30 +01:00
|
|
|
if [ "${TARGETS}" = "kitchensink" ]; then
|
|
|
|
TARGETS="kerberos5 libedit pam sk selinux"
|
|
|
|
fi
|
|
|
|
|
2020-08-05 19:00:52 +02:00
|
|
|
for TARGET in $TARGETS; do
|
|
|
|
case $TARGET in
|
2021-02-17 08:41:30 +01:00
|
|
|
default|without-openssl|without-zlib)
|
2020-08-05 19:00:52 +02:00
|
|
|
# nothing to do
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
kerberos5)
|
2020-08-05 19:00:52 +02:00
|
|
|
PACKAGES="$PACKAGES heimdal-dev"
|
|
|
|
#PACKAGES="$PACKAGES libkrb5-dev"
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
libedit)
|
2020-08-05 19:00:52 +02:00
|
|
|
PACKAGES="$PACKAGES libedit-dev"
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
*pam)
|
2020-08-05 19:00:52 +02:00
|
|
|
PACKAGES="$PACKAGES libpam0g-dev"
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
sk)
|
2020-08-05 19:00:52 +02:00
|
|
|
INSTALL_FIDO_PPA="yes"
|
|
|
|
PACKAGES="$PACKAGES libfido2-dev libu2f-host-dev"
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
selinux)
|
2020-08-05 19:00:52 +02:00
|
|
|
PACKAGES="$PACKAGES libselinux1-dev selinux-policy-dev"
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
hardenedmalloc)
|
2021-01-08 14:36:05 +01:00
|
|
|
INSTALL_HARDENED_MALLOC=yes
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
openssl-head)
|
2021-01-28 04:31:01 +01:00
|
|
|
INSTALL_OPENSSL_HEAD=yes
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
libressl-head)
|
2021-01-28 04:31:01 +01:00
|
|
|
INSTALL_LIBRESSL_HEAD=yes
|
|
|
|
;;
|
2021-02-19 00:16:56 +01:00
|
|
|
valgrind)
|
|
|
|
PACKAGES="$PACKAGES valgrind"
|
|
|
|
;;
|
2021-01-08 14:36:05 +01:00
|
|
|
*) echo "Invalid option '${TARGET}'"
|
2020-08-05 19:00:52 +02:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ "yes" == "$INSTALL_FIDO_PPA" ]; then
|
|
|
|
sudo apt update -qq
|
|
|
|
sudo apt install software-properties-common
|
|
|
|
sudo apt-add-repository ppa:yubico/stable
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "x" != "x$PACKAGES" ]; then
|
|
|
|
sudo apt update -qq
|
|
|
|
sudo apt install -qy $PACKAGES
|
|
|
|
fi
|
2021-01-08 14:36:05 +01:00
|
|
|
|
|
|
|
if [ "${INSTALL_HARDENED_MALLOC}" = "yes" ]; then
|
|
|
|
(cd ${HOME} &&
|
|
|
|
git clone https://github.com/GrapheneOS/hardened_malloc.git &&
|
|
|
|
cd ${HOME}/hardened_malloc &&
|
2021-01-28 10:55:16 +01:00
|
|
|
make -j2 && sudo cp libhardened_malloc.so /usr/lib/)
|
2021-01-08 14:36:05 +01:00
|
|
|
fi
|
2021-01-28 04:31:01 +01:00
|
|
|
|
|
|
|
if [ "${INSTALL_OPENSSL_HEAD}" = "yes" ];then
|
|
|
|
(cd ${HOME} &&
|
|
|
|
git clone https://github.com/openssl/openssl.git &&
|
|
|
|
cd ${HOME}/openssl &&
|
|
|
|
./config no-threads no-engine no-fips no-shared --prefix=/opt/openssl/head &&
|
2021-01-28 10:55:16 +01:00
|
|
|
make -j2 && sudo make install_sw)
|
2021-01-28 04:31:01 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "${INSTALL_LIBRESSL_HEAD}" = "yes" ];then
|
|
|
|
(mkdir -p ${HOME}/libressl && cd ${HOME}/libressl &&
|
|
|
|
git clone https://github.com/libressl-portable/portable.git &&
|
|
|
|
cd ${HOME}/libressl/portable && sh update.sh && sh autogen.sh &&
|
|
|
|
./configure --prefix=/opt/libressl/head &&
|
2021-01-28 10:55:16 +01:00
|
|
|
make -j2 && sudo make install_sw)
|
2021-01-28 04:31:01 +01:00
|
|
|
fi
|