Go to file
Mike Salvatore 4b02e3bc63 docs: Add pre-push hooks to manual pre-commit install instructions 2021-04-20 12:13:00 -04:00
.github Add changelog checklist item to pull request template 2021-03-29 12:20:33 -04:00
.swm Swimm: update exercise Add a simple Post Breach action (id: tbxb2cGgUiJQ8Btma0fp). 2021-04-14 11:18:00 +05:30
appimage appimage: add log message when downloading Python3.7 AppImage 2021-04-15 12:20:33 -04:00
deployment_scripts docs: Add pre-push hooks to manual pre-commit install instructions 2021-04-20 12:13:00 -04:00
docker bump duckerfile version 2020-04-01 15:33:27 +03:00
docs docs: Add pre-push hooks to manual pre-commit install instructions 2021-04-20 12:13:00 -04:00
envs Fixed gitignores to exclude some irrelevant files 2021-04-09 14:54:02 +03:00
monkey cc: Move config files and other testing resources to tests/ dir 2021-04-20 11:27:30 -04:00
.flake8 Fix exclude path in flake8 config 2021-04-07 13:40:01 -04:00
.gitignore Fixed gitignores to exclude some irrelevant files 2021-04-09 14:54:02 +03:00
.gitmodules Refactored ScoutSuite into a separate package rather than submodule 2021-03-17 11:49:33 -04:00
.pre-commit-config.yaml Modify pre-commit-config.yaml to make pytest run only pre-push 2021-04-20 18:49:40 +05:30
.travis.yml Change max JS warnings limit to 0 in travis.yml 2021-04-12 18:43:37 +05:30
CHANGELOG.md Update CHANGELOG.md for AppImage v2 2021-04-15 11:32:10 -04:00
CONTRIBUTING.md Update slack links in documentation 2021-01-25 10:35:39 -05:00
LICENSE Add SecureAuth Corporation acknowledgement to LICENSE.md 2021-02-22 17:44:15 +05:30
README.md job posting 2021-03-29 10:10:22 -04:00
codecov.yml Fix codecov.io integration 2021-01-14 09:24:37 -05:00
pyproject.toml Use addopts instead of testpaths to specify path in pytest config 2021-04-19 14:39:39 -04:00

README.md

Infection Monkey

GitHub release (latest by date)

Build Status codecov

GitHub stars GitHub commit activity

Data center Security Testing Tool

Welcome to the Infection Monkey!

The Infection Monkey is an open source security tool for testing a data center's resiliency to perimeter breaches and internal server infection. The Monkey uses various methods to self propagate across a data center and reports success to a centralized Monkey Island server.

The Infection Monkey is comprised of two parts:

  • Monkey - A tool which infects other machines and propagates to them.
  • Monkey Island - A dedicated server to control and visualize the Infection Monkey's progress inside the data center.

To read more about the Monkey, visit infectionmonkey.com.

💥 We're Hiring 💥

We are looking for a strong, full-stack developer with a passion for cybersecurity to join the Infection Monkey development team. Infection Monkey is an open-source, automated, breach and attack simulation platform, consisting of a worm-like agent and C&C server. This is a remote position and is open world-wide. If you're excited about Infection Monkey, we want to see your resume. You can learn more about Infection Monkey on our website.

For more information, or to apply, see the official job post here.

Screenshots

Map

Security report

Zero trust report

ATT&CK report

Main Features

The Infection Monkey uses the following techniques and exploits to propagate to other machines.

  • Multiple propagation techniques:
    • Predefined passwords
    • Common logical exploits
    • Password stealing using Mimikatz
  • Multiple exploit methods:
    • SSH
    • SMB
    • WMI
    • Shellshock
    • Conficker
    • SambaCry
    • Elastic Search (CVE-2015-1427)
    • Weblogic server
    • and more, see our Documentation hub for more information about our RCE exploiters.

Setup

Check out the Setup page in the Wiki or a quick getting started guide.

The Infection Monkey supports a variety of platforms, documented in our documentation hub.

Building the Monkey from source

To deploy development version of monkey you should refer to readme in the deployment scripts folder or follow documentation in documentation hub.

Build status

Branch Status
Develop Build Status
Master Build Status

Tests

Unit Tests

In order to run all of the Unit Tests, run the command python -m pytest in the monkey directory.

To get a coverage report, first make sure the coverage package is installed using pip install coverage. Run the command coverage run -m unittest in the monkey directory and then coverage html. The coverage report can be found in htmlcov.index.

Blackbox tests

In order to run the Blackbox tests, refer to envs/monkey_zoo/blackbox/README.md.

License

Copyright (c) Guardicore Ltd

See the LICENSE file for license rights and limitations (GPLv3).