e1209dcb4c
EnvironmentConfig needs to handle environment variables and '~' in its `data_dir` property. Other components that consume `data_dir` need environment variables and '~' resolved to an absolute path. Add a property called `data_dir_abs_path` that calculates the absolute path from `data_dir`. Since `data_dir` remains unchanged, the EnvironmentConfig can be saved to file without modifying the `data_dir` option in the file. |
||
---|---|---|
.. | ||
cc | ||
deb-package | ||
linux | ||
pyinstaller_hooks | ||
scripts | ||
windows | ||
__init__.py | ||
monkey_island.ico | ||
monkey_island.spec | ||
readme.md | ||
requirements.txt |
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 Island manually, refer to the instructions below.
How to set up the Monkey Island server
On Windows
-
Exclude the folder you are planning to install the Monkey in from your AV software, as it might block or delete files from the installation.
-
Create folder "bin" under monkey\monkey_island
-
Place portable version of Python 3.7.4
- Download and install from: https://www.python.org/ftp/python/3.7.4/
-
Install Island's requirements
python -m pip install -r monkey\monkey_island\requirements.txt
-
Setup mongodb (Use one of the following two options):
- Place portable version of mongodb
- Download from: https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2012plus-4.2.1.zip
- Extract contents of bin folder to \monkey\monkey_island\bin\mongodb.
- Create monkey_island\db folder.
OR
- Use already running instance of mongodb
- Run 'set MONKEY_MONGO_URL="mongodb://:27017/monkeyisland"'. Replace '' with address of mongo server
- Place portable version of mongodb
-
Place portable version of OpenSSL
- Download from: https://indy.fulgan.com/SSL/Archive/openssl-1.0.2p-i386-win32.zip
- Extract contents to monkey_island\bin\openssl
-
Download and install Microsoft Visual C++ redistributable for Visual Studio 2017
- Download and install from: https://go.microsoft.com/fwlink/?LinkId=746572
-
Generate SSL Certificate
- run
./windows/create_certificate.bat
when your current working directory is monkey_island
- run
-
Put Infection Monkey binaries inside monkey_island/cc/binaries (binaries can be found in releases on github or build from source) monkey-linux-64 - monkey binary for linux 64bit monkey-linux-32 - monkey binary for linux 32bit monkey-windows-32.exe - monkey binary for windows 32bit monkey-windows-64.exe - monkey binary for windows 64bit
-
Install npm
- Download and install from: https://www.npmjs.com/get-npm
-
Build Monkey Island frontend
- cd to 'monkey_island\cc\ui'
- run 'npm update'
- run 'npm run dist'
How to run
- When your current working directory is monkey_island, run monkey_island\windows\run_server_py.bat
On Linux
-
Get python 3.7 and pip if your linux distribution doesn't have it built in (following steps are for Ubuntu 16):
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt-get update
sudo apt install python3.7 python3-pip python3.7-dev
python3.7 -m pip install pip
-
Install required packages:
sudo apt-get install libffi-dev upx libssl-dev libc++1 openssl
-
Create the following directories in monkey island folder (execute from ./monkey):
mkdir -p ./monkey_island/bin/mongodb
mkdir -p ./monkey_island/db
mkdir -p ./monkey_island/cc/binaries
-
Install the packages from monkey_island/requirements.txt:
sudo python3.7 -m pip install -r ./monkey_island/requirements.txt
-
Put monkey binaries in /monkey_island/cc/binaries (binaries can be found in releases on github).
monkey-linux-64 - monkey binary for linux 64bit
monkey-linux-32 - monkey binary for linux 32bit
monkey-windows-32.exe - monkey binary for windows 32bit
monkey-windows-64.exe - monkey binary for windows 64bit
Also, if you're going to run monkeys on local machine execute:
chmod 755 ./monkey_island/cc/binaries/monkey-linux-64
chmod 755 ./monkey_island/cc/binaries/monkey-linux-32
-
Setup MongoDB (Use one of the two following options):
- Download MongoDB and extract it to monkey/monkey_island/bin/mongodb:
- Run
./monkey_island/linux/install_mongo.sh ./monkey_island/bin/mongodb
. This will download and extract the relevant mongoDB for your OS.
- Run
OR
- Use already running instance of mongodb
- Run
set MONKEY_MONGO_URL="mongodb://<SERVER ADDR>:27017/monkeyisland"
. Replace '' with address of mongo server
- Run
- Download MongoDB and extract it to monkey/monkey_island/bin/mongodb:
-
Generate SSL Certificate:
cd ./monkey_island
chmod 755 ./linux/create_certificate.sh
./linux/create_certificate.sh
-
Install npm and node by running:
sudo apt-get install curl
curl -sL https://deb.nodesource.com/setup_12.x | sudo -E bash -
sudo apt-get install -y nodejs
-
Build Monkey Island frontend
- cd to 'monkey_island/cc/ui'
npm install sass-loader node-sass webpack --save-dev
npm update
npm run dist
How to run
- When your current working directory is monkey, run
chmod 755 ./monkey_island/linux/run.sh
followed by./monkey_island/linux/run.sh
(located under /linux)