Empire/setup/install.sh

109 lines
3.4 KiB
Bash
Executable File

#!/bin/bash
# functions
# Install Powershell on Linux
function install_powershell {
if uname | grep -q "Darwin"; then
brew install openssl
brew install curl --with-openssl
brew tap caskroom/cask
brew cask install powershell
else
if [ ! which powershell > /dev/null ] && [ ! which pwsh > /dev/null ]; then
# TODO: Support multiple powershell releases
# Import the public repository GPG keys
curl https://packages.microsoft.com/keys/microsoft.asc | sudo apt-key add -
# Register the Microsoft Ubuntu repository
curl https://packages.microsoft.com/config/ubuntu/16.04/prod.list | sudo tee /etc/apt/sources.list.d/microsoft.list
# Update the list of products
apt-get update
# Install PowerShell
apt-get install -y powershell
fi
if ls /opt/microsoft/powershell/*/DELETE_ME_TO_DISABLE_CONSOLEHOST_TELEMETRY; then
rm /opt/microsoft/powershell/*/DELETE_ME_TO_DISABLE_CONSOLEHOST_TELEMETRY
fi
fi
mkdir -p /usr/local/share/powershell/Modules
cp -r ../lib/powershell/Invoke-Obfuscation /usr/local/share/powershell/Modules
}
# Ask for the administrator password upfront so sudo is no longer required at Installation.
sudo -v
IFS='/' read -a array <<< pwd
if [[ "$(pwd)" != *setup ]]
then
cd ./setup
fi
# Check for PIP otherwise install it
if ! which pip > /dev/null; then
wget https://bootstrap.pypa.io/get-pip.py
python get-pip.py
fi
if uname | grep -q "Darwin"; then
install_powershell
sudo pip install -r requirements.txt --global-option=build_ext \
--global-option="-L/usr/local/opt/openssl/lib" \
--global-option="-I/usr/local/opt/openssl/include"
# In order to build dependencies these should be exproted.
export LDFLAGS=-L/usr/local/opt/openssl/lib
export CPPFLAGS=-I/usr/local/opt/openssl/include
else
version=$( lsb_release -r | grep -oP "[0-9]+" | head -1 )
if lsb_release -d | grep -q "Fedora"; then
Release=Fedora
sudo dnf install -y make g++ python-devel m2crypto python-m2ext swig python-iptools python3-iptools libxml2-devel default-jdk openssl-devel libssl1.0.0 libssl-dev
sudo pip install -r requirements.txt
elif lsb_release -d | grep -q "Kali"; then
Release=Kali
sudo apt-get install -y make g++ python-dev python-m2crypto swig python-pip libxml2-dev default-jdk libssl1.0.0 libssl-dev
sudo pip install -r requirements.txt
install_powershell
elif lsb_release -d | grep -q "Ubuntu"; then
Release=Ubuntu
sudo apt-get install -y make g++ python-dev python-m2crypto swig python-pip libxml2-dev default-jdk libssl1.0.0 libssl-dev
sudo pip install -r requirements.txt
install_powershell
else
echo "Unknown distro - Debian/Ubuntu Fallback"
sudo apt-get install -y make g++ python-dev python-m2crypto swig python-pip libxml2-dev default-jdk libffi-dev libssl1.0.0 libssl-dev
sudo pip install -r requirements.txt
install_powershell
fi
fi
# Installing xar
tar -xvf ../data/misc/xar-1.5.2.tar.gz
(cd xar-1.5.2 && ./configure)
(cd xar-1.5.2 && make)
(cd xar-1.5.2 && sudo make install)
# Installing bomutils
git clone https://github.com/hogliux/bomutils.git
(cd bomutils && make)
# NIT: This fails on OSX. Leaving it only on Linux instances.
if uname | grep -q "Linux"; then
(cd bomutils && make install)
fi
chmod 755 bomutils/build/bin/mkbom && sudo cp bomutils/build/bin/mkbom /usr/local/bin/.
# set up the database schema
./setup_database.py
# generate a cert
./cert.sh
cd ..
echo -e '\n [*] Setup complete!\n'