Skip to content

Commit

Permalink
Rewrite mallory_install.sh
Browse files Browse the repository at this point in the history
The old script depended too heavily on it running smoothly - unlikely, when run on a modern Linux distribution.
This script now only installs the dependencies and gives helpful information to the user;
updating the repo should be done manually through git pull.
Overall: easier to debug, safer to run, less junk files generated.
  • Loading branch information
Tokarak committed Jun 3, 2022
1 parent 8e76e10 commit b38f668
Showing 1 changed file with 30 additions and 144 deletions.
174 changes: 30 additions & 144 deletions mallory_install.sh
Original file line number Diff line number Diff line change
@@ -1,147 +1,33 @@
#!/bin/bash
# ----------------------------------------------------------------
# This script updates a basic installation of Ubuntu (10.10 or 11.04)
# to the latest package revs, and installs the packages required
# to run the current (1.0) version of the Mallory tool.
# ----------------------------------------------------------------
# Copyright 2011 - Intrepidus Group
# ----------------------------------------------------------------
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# ----------------------------------------------------------------
echo -e "Latest supported Debian-based releases are Ubuntu 18.04 (Bionic) or Debian 10 (Buster).\nOnly Python 2 is supported.\nThis script assumes the use of apt package manager.\nIt is recommended to install mallory in a virtual machine.\nThis script was tested on ubuntu; there may be a variance in package names between distributions."
echo
echo "The script will now install/update dependencies using apt and pip. (safe to rerun)"
read -p "Press any key to continue, or ctrl+c to exit: " -n 1 -r
echo

set -e
export UPDATE_DIR=${HOME}/.mallory/update
export UPDATE_LOG=${UPDATE_DIR}/update.log

# -----------------------------------------------------------------
# functions
# -----------------------------------------------------------------
function print_header {
echo "+--------------------------------------------------------+"
echo "| MALLORY INSTALL/UPDATE SCRIPT |"
echo "+--------------------------------------------------------+"
}

function phase0 {
# create the update directory if it doesn't exist
mkdir -p ${UPDATE_DIR}
print_header
echo "| Before running this script, please ensure that you've |"
echo "| configured a network interface and that the internet |"
echo "| is reachable by this virtual machine. |"
echo "+--------------------------------------------------------+"
echo "| Once you have done this (or if you already had) simply |"
echo "| rerun this script to continue the update |"
echo "+--------------------------------------------------------+"
echo "phase1" > ${UPDATE_DIR}/.next_phase
exit 0
}

function phase1 {
print_header
echo "beginning Mallory installation"
echo "updating apt package list"
sudo apt-get update |tee ${UPDATE_LOG}
echo ""

echo "upgrading OS to latest versions of installed packages"
sudo apt-get upgrade -y |tee -a ${UPDATE_LOG}

echo "installing Mallory dependencies"
sudo apt-get -y install build-essential libnetfilter-conntrack-dev libnetfilter-conntrack3 |tee -a ${UPDATE_LOG}
if [ ! -f /usr/lib/netfilter_conntrack.so.1 ]; then
sudo ln -s /usr/lib/libnetfilter_conntrack.so /usr/lib/libnetfilter_conntrack.so.1
fi
sudo apt-get -y install python-pip git python-m2crypto python-qt4 pyro-gui python-netfilter python-pyasn1 python-pil python-ipy|tee -a ${UPDATE_LOG}
sudo apt-get -y install python-paramiko python-twisted-web python-qt4-sql libqt4-sql-sqlite sqlite3 |tee -a ${UPDATE_LOG}
sudo pip install pynetfilter_conntrack
echo ""

echo "enter directory you'd like Mallory to be installed to"
read -p "(default: ${HOME}/mallory)" mallorydir

if [ "$mallorydir" == "" ]; then
mallorydir="${HOME}/mallory";
fi
mkdir -p $mallorydir
echo ${mallorydir} > ${UPDATE_DIR}/installdir
echo "retrieving current mallory source from bitbucket"
/usr/bin/git clone https://github.com/intrepidusgroup/mallory ${mallorydir}/current

echo "phase2" > ${UPDATE_DIR}/.next_phase
phase2
}


function phase2 {
print_header
echo "Mallory installation completed"
echo "To use mallory:"
echo "Open a new terminal window, cd to ${mallorydir}/current/src, then run:"
echo " sudo python ./mallory.py"
echo ""
echo "To run the mallory GUI:"
echo "Open a new terminal window cd to ${mallorydir}/current/src and run:"
echo " sudo chown $USER mallory.log"
echo " where $USER is the user you are logged in as. Then run:"
echo " python ./launchgui.py"
echo "Have fun!"
read -n1 -p "press any key to continue..."

echo "update" > ${UPDATE_DIR}/.next_phase
exit 0
}

function update {
echo 'Please cd into ${mallorydir}/current and update manually with "git pull"'
echo "If you want to rerun this script please clean ~/.mallory/update"
exit 0
}


# -----------------------------------------------------------------
# scriptybits
# -----------------------------------------------------------------

if [[ -f ${UPDATE_DIR}/.next_phase ]]; then
case `cat ${UPDATE_DIR}/.next_phase` in
phase0)
phase0
;;

phase1)
phase1
;;

phase2)
phase2
;;

update)
update
;;

phase4)
echo "phase4: profit!"
exit 0
;;

*)
echo "unknown update status, attempting update"
update
;;
esac
else
phase0
fi
set -x
sudo apt-get update

sudo apt-get install build-essential libnetfilter-conntrack-dev git python-pip python-m2crypto python-qt4 pyro-gui python-netfilter python-pyasn1 python-pil python-ipy python-paramiko python-twisted-web python-qt4-sql libqt4-sql-sqlite sqlite3 python --no-install-recommends

sudo -H pip2 install pynetfilter_conntrack
set +x

echo
echo 'Installation complete.'
echo
echo "If you haven't already, install the Mallory repo by running in a directory of your choosing:"
echo
echo " /usr/bin/git clone https://github.com/Tokarak/mallory"
echo
echo 'In the repo, src/mallory.py has the core functionality of mallory. src/launchgui.py can launch the gui WHILE src/mallory.py is already running.'
echo 'It is recommended to run the gui on your virtual machine using ssh with X11 forwarding (ssh -X ...) instead of installing a bulky desktop. To enable X11forwarding on your VM:'
echo " sudo apt install xauth"
echo 'Search "X11Forwarding" online to learn more.'
echo
echo 'Notice: if you get a "cannot open shared object file" error on running the script, please see:'
echo 'https://web.archive.org/web/20131007182424/http://intrepidusgroup.com/insight/2013/07/getting-mallory-to-run-in-modern-versions-of-ubuntu/'
echo "Script end."
echo
exit 0

0 comments on commit b38f668

Please sign in to comment.