monkey/deployment_scripts
Mike Salvatore 1be6de0bd8 Deploy: Set mode=0755 when creating /opt/infection-monkey/bin/ 2022-04-10 14:50:09 -04:00
..
dump_attack_mitigations Deployment: Add requirements.txt for attack mitigations dump script 2021-09-30 18:03:28 +02:00
README.md Removed quotes in deployment_scripts README for first argument of deploy_linux.sh. Related #1108. 2021-06-14 12:54:25 -04:00
config Deploy: Remove 32-bit binaries from Linux deployment script 2022-02-24 13:23:58 -05:00
config.ps1 Deploy: Remove 32-bit agents from Windows deployment script 2022-02-25 14:45:57 -05:00
deploy_linux.sh Deploy: Use `npm ci` instead of install/update in Linux deployment 2022-02-24 13:23:58 -05:00
deploy_windows.ps1 Deploy: Remove 32-bit agents from Windows deployment script 2022-02-25 14:45:57 -05:00
install-infection-monkey-service.sh Deploy: Set mode=0755 when creating /opt/infection-monkey/bin/ 2022-04-10 14:50:09 -04:00

README.md

Deployment guide for a development environemnt

This guide is for you if you wish to develop for Infection Monkey. If you only want to use it, please download the relevant version from our website.

Prerequisites

Before running the script you must have git installed. If you don't have git installed, please follow this guide.

Deploy on Windows

Run the following command in powershell:

Invoke-WebRequest https://raw.githubusercontent.com/guardicore/monkey/develop/deployment_scripts/deploy_windows.ps1 -OutFile deploy_windows.ps1

This will download our deploy script. It's a good idea to read it quickly before executing it!

After downloading that script, execute it in powershell.

The first argument is an empty directory (script can create one). The second argument is which branch you want to clone - by default, the script will check out the develop branch. Some example usages:

  • .\deploy_windows.ps1 (Sets up monkey in current directory under .\infection_monkey)
  • .\deploy_windows.ps1 -monkey_home "C:\test" (Sets up monkey in C:\test)
  • .\deploy_windows.ps1 -branch "master" (Sets up master branch instead of develop in current dir)

You may also pass in an optional agents=$false parameter to disable downloading the latest agent binaries.

Troubleshooting

  • If you run into Execution Policy warnings, you can disable them by prefixing the following snippet: powershell -ExecutionPolicy ByPass -Command "[original command here]"
  • Don't forget to add python to PATH or do so while installing it via this script.

Deploy on Linux

Linux deployment script is meant for Ubuntu 16 and Ubuntu 18 machines.

Your user must have root permissions; however, don't run the script as root!

wget https://raw.githubusercontent.com/guardicore/monkey/develop/deployment_scripts/deploy_linux.sh
chmod u+x ./deploy_linux.sh

This will download our deploy script. It's a good idea to read it quickly before executing it!

Then execute the resulting script with your shell.

After downloading that script, execute it in a shell. The first argument should be an absolute path of an empty directory (the script will create one if doesn't exist, default is ./infection_monkey). The second parameter is the branch you want to clone (develop by default). Some example usages:

  • ./deploy_linux.sh (deploys under ./infection_monkey)
  • ./deploy_linux.sh /home/test/monkey (deploys under /home/test/monkey)
  • ./deploy_linux.sh "" "master" (deploys master branch in script directory)
  • ./deploy_linux.sh /home/user/new "master" (if directory "new" is not found creates it and clones master branch into it)

You may also pass in an optional third false parameter to disable downloading the latest agent binaries.

Run on Linux

After the deploy_linux.sh script completes, you can start the monkey island.

Note: You'll need to run the commands below in a new shell in order to ensure your PATH environment variable is up to date.

cd infection_monkey/monkey/monkey_island
pipenv run python ../monkey_island.py

Pre-commit hooks

Both the Linux and Windows deployment scrips will install and configure pre-commit. Pre-commit is a multi-language package manager for pre-commit hooks. It will run a set of checks when you attempt to commit. If your commit does not pass all checks, it will be reformatted and/or you'll be given a list of errors and warnings that need to be fixed before you can commit.

Our CI system runs the same checks when pull requests are submitted. This system may report that the build has failed if the pre-commit hooks have not been run or all issues have not been resolved.

Manually installing pre-commit

To install and configure pre-commit manually, run pip install --user pre-commit. Next, go to the top level directory of this repository and run pre-commit install -t pre-commit -t pre-push Now, pre-commit will automatically run whenever you git commit.

Swimm

Infection Monkey has development tutorials that use swimm.io to help teach new developers how to perform common code tasks in the Infection Monkey codebase and accelerate the ramp-up process. The tutorials include adding new configuration values, new system info collectors and more.

In order to pass the pre-commit checks, you'll have to install Swimm successfully. Both the Linux and Windows deployment scrips will install Swimm, but you'll have to sign up here to complete the process.