b791ee16e1
Changed proxy schema for the agent |
||
---|---|---|
.. | ||
exploit | ||
model | ||
network | ||
post_breach | ||
pyinstaller_hooks | ||
ransomware | ||
system_info | ||
telemetry | ||
transport | ||
utils | ||
Pipfile | ||
Pipfile.lock | ||
__init__.py | ||
build_linux.sh | ||
build_windows.bat | ||
config.py | ||
control.py | ||
dropper.py | ||
example.conf | ||
main.py | ||
monkey.ico | ||
monkey.py | ||
monkey.spec | ||
monkeyfs.py | ||
pyinstaller_utils.py | ||
readme.md | ||
system_singleton.py | ||
tunnel.py | ||
windows_upgrader.py |
readme.md
Monkey island dev. env. setup guide
To easily setup development environment for Monkey Island and the Monkey look into deployment scripts folder. If you want to setup dev. env. for the Monkey manually, refer to the instructions below.
The monkey is composed of three separate parts.
- The Infection Monkey itself - PyInstaller compressed python archives
- Sambacry binaries - Two linux binaries, 32/64 bit.
Windows
-
Install python 3.7.4 and choose ADD to PATH option when installing.
Download and install from: https://www.python.org/ftp/python/3.7.4/
In case you still need to add python directories to path:
- Run the following command on a cmd console (Replace C:\Python37 with your python directory if it's different)
setx /M PATH "%PATH%;C:\Python37;C:\Python37\Scripts
- Close the console, make sure you execute all commands in a new cmd console from now on.
- Run the following command on a cmd console (Replace C:\Python37 with your python directory if it's different)
-
Install further dependencies
- if not installed, install Microsoft Visual C++ 2017 SP1 Redistributable Package
-
Download the dependent python packages using
pip install -r requirements.txt
-
Download and extract UPX binary to monkey\infection_monkey\bin\upx.exe: https://github.com/upx/upx/releases/download/v3.94/upx394w.zip
-
Build/Download Sambacry
- Build/Download according to sections at the end of this readme.
- Place the binaries under monkey\infection_monkey\bin
-
To build the final exe:
cd monkey\infection_monkey
build_windows.bat
- output is placed under
dist\monkey32.exe
ordist\monkey64.exe
depending on your version of Python
Linux
Tested on Ubuntu 16.04.
0. On older distributions of Ubuntu (16.04) you'll need to download python3.7 via ppa:
- sudo add-apt-repository ppa:deadsnakes/ppa
- sudo apt-get update
- sudo apt install python3.7
-
Install dependencies by running:
sudo apt install python3-pip
python3.7 -m pip install pip
sudo apt-get install python3.7-dev libffi-dev upx libssl-dev libc++1
-
Install the python packages listed in requirements.txt using pip
cd [code location]/infection_monkey
python3.7 -m pipenv lock -r --dev > requirements.txt
python3.7 -m pip install -r requirements.txt
-
Build Sambacry binaries
- Build/Download according to sections at the end of this readme.
- Place the binaries under [code location]/infection_monkey/bin, under the names 'sc_monkey_runner32.so', 'sc_monkey_runner64.so'
-
To build, run in terminal:
cd [code location]/infection_monkey
chmod +x build_linux.sh
pipenv run ./build_linux.sh
output is placed under
dist/monkey32
ordist/monkey64
depending on your version of python
Sambacry
Sambacry requires two standalone binaries to execute remotely.
-
Build sambacry binaries yourself
- Install gcc-multilib if it's not installed
sudo apt-get install gcc-multilib
- Build the binaries
cd [code location]/infection_monkey/exploit/sambacry_monkey_runner
./build.sh
- Install gcc-multilib if it's not installed
-
Download our pre-built sambacry binaries
Troubleshooting
Some of the possible errors that may come up while trying to build the infection monkey:
Linux
When committing your changes for the first time, you may encounter some errors thrown by the pre-commit hooks. This is most likely because some python dependencies are missing from your system.
To resolve this, use pipenv
to create a requirements.txt
for both the infection_monkey/
and monkey_island/
requirements and install it with pip
.
cd [code location]/infection_monkey
python3.7 -m pipenv lock -r --dev > requirements.txt
python3.7 -m pip install -r requirements.txt
and
cd [code location]/monkey_island
python3.7 -m pipenv lock -r --dev > requirements.txt
python3.7 -m pip install -r requirements.txt